// -*- mode: C++; c-indent-level: 4; c-basic-offset: 4; indent-tabs-mode: nil; -*-
//
// Vector.cpp: Rcpp R/C++ interface class library -- Vector unit tests
//
// Copyright (C) 2012 - 2018 Dirk Eddelbuettel and Romain Francois
//
// This file is part of Rcpp.
//
// Rcpp is free software: you can redistribute it and/or modify it
// under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 2 of the License, or
// (at your option) any later version.
//
// Rcpp is distributed in the hope that it will be useful, but
// WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Rcpp. If not, see .
#include
#include
#include
using namespace Rcpp ;
inline double square( double x){ return x*x; }
// [[Rcpp::export]]
RawVector raw_(){
RawVector x(10) ;
for( int i=0; i<10; i++) x[i] = (Rbyte)i ;
return x ;
}
// [[Rcpp::export]]
RawVector raw_REALSXP( RawVector x ){
for( int i=0; i vec(4) ;
for( size_t i = 0; i<4; i++) vec[i] = i;
IntegerVector y( vec.begin(), vec.end() ) ;
return y;
}
// [[Rcpp::export]]
IntegerVector integer_names_set(){
IntegerVector y(2) ;
std::vector names(2) ;
names[0] = "foo" ;
names[1] = "bar" ;
y.names() = names ;
return y ;
}
// [[Rcpp::export]]
CharacterVector integer_names_get( IntegerVector y ){
return y.names() ;
}
// [[Rcpp::export]]
int integer_names_indexing( IntegerVector y ){
return y["foo"] ;
}
// [[Rcpp::export]]
IntegerVector integer_push_back( IntegerVector y ){
y.push_back( 5 ) ;
return y ;
}
// [[Rcpp::export]]
IntegerVector integer_push_front( IntegerVector y ){
y.push_front( 5 ) ;
return y ;
}
// [[Rcpp::export]]
IntegerVector integer_insert( IntegerVector y){
y.insert( 0, 5 ) ;
y.insert( 2, 7 ) ;
return y ;
}
// [[Rcpp::export]]
IntegerVector integer_erase( IntegerVector y ){
y.erase(2) ;
return y ;
}
// [[Rcpp::export]]
List integer_erase_range( IntegerVector x, IntegerVector y ){
x.erase(x.begin()+5, x.end()-1 );
y.erase(y.begin()+5, y.end()-1 );
return List::create( x, y ) ;
}
// [[Rcpp::export]]
List integer_erase_range_2( IntegerVector x, IntegerVector y ){
IntegerVector::iterator it = x.begin()+1 ;
while( it != x.end() ){
it = x.erase(it) ;
}
it = y.begin() + 1 ;
while( it != y.end() ){
it = y.erase(it) ;
}
return List::create( x, y ) ;
}
// [[Rcpp::export]]
List List_erase_range_2( List x, List y ){
List::iterator it = x.begin()+1 ;
while( it != x.end() ){
it = x.erase(it) ;
}
it = y.begin() + 1 ;
while( it != y.end() ){
it = y.erase(it) ;
}
return List::create( x, y ) ;
}
// [[Rcpp::export]]
IntegerVector integer_erase2( IntegerVector y ){
y.erase(1,2) ;
return y ;
}
// [[Rcpp::export]]
IntegerVector integer_fill( IntegerVector y ){
y.fill(10) ;
return y ;
}
// [[Rcpp::export]]
IntegerVector integer_zero(){
return IntegerVector(0);
}
// [[Rcpp::export]]
IntegerVector integer_create_zero(){
return IntegerVector::create();
}
// [[Rcpp::export]]
List integer_create_(){
List output(2);
output[0] = IntegerVector::create( 10, 20 ) ;
output[1] = IntegerVector::create(
_["foo"] = 20,
_["bar"] = 30 ) ;
return output ;
}
// [[Rcpp::export]]
IntegerVector integer_clone_( IntegerVector vec ){
IntegerVector dolly = clone( vec ) ;
for( size_t i=0; i<10; i++){
dolly[i] = 10 - i ;
}
return dolly ;
}
// [[Rcpp::export]]
NumericVector numeric_(){
NumericVector x(10) ;
for( int i=0; i<10; i++) x[i] = i ;
return x ;
}
// [[Rcpp::export]]
NumericVector numeric_REALSXP( SEXP vec){
NumericVector x(vec) ;
for( int i=0; i v(10) ;
for( int i=0; i<10; i++) v[i] = i ;
return IntegerVector::import( v.begin(), v.end() ) ;
}
// [[Rcpp::export]]
NumericVector numeric_importtransform(){
std::vector v(10) ;
for( int i=0; i<10; i++) v[i] = i ;
return NumericVector::import_transform( v.begin(), v.end(), square ) ;
}
// [[Rcpp::export]]
List list_ctor(){
List x(10) ;
for( int i=0; i<10; i++) x[i] = Rf_ScalarInteger( i * 2) ;
return x ;
}
// [[Rcpp::export]]
List list_template_(){
List x(4) ;
x[0] = "foo" ;
x[1] = 10 ;
x[2] = 10.2 ;
x[3] = false;
return x ;
}
// [[Rcpp::export]]
List list_VECSXP_( SEXP vec){
List x(vec) ;
return x ;
}
// [[Rcpp::export]]
List list_matrix_indexing_1( List m ){
List out(4) ;
for( size_t i=0 ; i<4; i++){
out[i] = m(i,i) ;
}
return out ;
}
// [[Rcpp::export]]
List list_matrix_indexing_2( GenericVector m ){
for(size_t i=0 ; i<4; i++){
m(i,i) = "foo" ;
}
return m ;
}
// [[Rcpp::export]]
List list_Dimension_constructor_1(){
return List( Dimension( 5 ) ) ;
}
// [[Rcpp::export]]
List list_Dimension_constructor_2(){
return List( Dimension( 5, 5 ) );
}
// [[Rcpp::export]]
List list_Dimension_constructor_3(){
return List( Dimension( 2, 3, 4) ) ;
}
// [[Rcpp::export]]
List list_iterator_( List input, Function fun){
List output( input.size() ) ;
std::transform( input.begin(), input.end(), output.begin(), fun ) ;
output.names() = input.names() ;
return output ;
}
// [[Rcpp::export]]
int list_name_indexing( List df ){
IntegerVector df_x = df["x"] ;
int res = std::accumulate( df_x.begin(), df_x.end(), 0 ) ;
return res ;
}
// [[Rcpp::export]]
List list_push_back(List list){
list.push_back( 10 ) ;
list.push_back( "bar", "foo" ) ;
return list ;
}
// [[Rcpp::export]]
List list_push_front( List list ){
list.push_front( 10 ) ;
list.push_front( "bar", "foo" ) ;
return list ;
}
// [[Rcpp::export]]
List list_erase( List list ){
list.erase( list.begin() ) ;
return list ;
}
// [[Rcpp::export]]
List list_erase_range( List list ){
list.erase( 0, 2 ) ;
return list ;
}
// [[Rcpp::export]]
List list_implicit_push_back(){
List list ;
list["foo"] = 10 ;
list["bar" ] = "foobar" ;
return list ;
}
// [[Rcpp::export]]
List list_create_(){
List output(2);
output[0] = List::create( 10, "foo" ) ;
output[1] = List::create(
_["foo"] = 10,
_["bar"] = true ) ;
return output ;
}
// [[Rcpp::export]]
List list_stdcomplex(){
std::vector< std::complex > v_double(10) ;
std::vector< std::complex > v_float(10) ;
return List::create( _["float"] = v_float, _["double"] = v_double ) ;
}
// [[Rcpp::export]]
CharacterVector character_ctor(){
CharacterVector x(10) ;
for( int i=0; i<10; i++) x[i] = "foo" ;
return x ;
}
// [[Rcpp::export]]
std::string character_STRSXP_( SEXP vec ){
CharacterVector x(vec) ;
std::string st = "" ;
for( int i=0; i vec(4) ;
vec[0] = "foo";
vec[1] = "bar";
vec[2] = "bling";
vec[3] = "boom" ;
CharacterVector y ;
y.assign( vec.begin(), vec.end() ) ;
return y;
}
// [[Rcpp::export]]
CharacterVector character_range_ctor1(){
const char* x[] = { "foo", "bar", "bling", "boom" } ;
CharacterVector y( x, x+4 ) ;
return y;
}
// [[Rcpp::export]]
CharacterVector character_range_ctor2(){
std::vector vec(4) ;
vec[0] = "foo";
vec[1] = "bar";
vec[2] = "bling";
vec[3] = "boom" ;
CharacterVector y( vec.begin(), vec.end() ) ;
return y;
}
// [[Rcpp::export]]
CharacterVector character_dimension_ctor1(){
return CharacterVector( Dimension( 5 ) ) ;
}
// [[Rcpp::export]]
CharacterVector character_dimension_ctor2(){
return CharacterVector( Dimension( 5, 5 ) ) ;
}
// [[Rcpp::export]]
CharacterVector character_dimension_ctor3(){
return CharacterVector( Dimension( 2, 3, 4) ) ;
}
// [[Rcpp::export]]
std::string character_iterator1( CharacterVector letters ){
std::string res ;
CharacterVector::iterator first = letters.begin() ;
CharacterVector::iterator last = letters.end() ;
while( first != last ){
res += *first ;
++first ;
}
return res ;
}
// [[Rcpp::export]]
std::string character_const_iterator1( const CharacterVector letters ){
std::string res ;
CharacterVector::const_iterator first = letters.begin() ;
CharacterVector::const_iterator last = letters.end() ;
while( first != last ){
res += *first ;
++first ;
}
return res ;
}
// [[Rcpp::export]]
std::string character_iterator2( CharacterVector letters ){
std::string res(std::accumulate(letters.begin(), letters.end(), std::string()));
return res ;
}
// [[Rcpp::export]]
std::string character_const_iterator2( const CharacterVector letters ){
std::string res(std::accumulate(letters.begin(), letters.end(), std::string()));
return res ;
}
// [[Rcpp::export]]
CharacterVector character_reverse( CharacterVector y ){
std::reverse( y.begin(), y.end() ) ;
return y ;
}
// [[Rcpp::export]]
std::string character_names_indexing( CharacterVector y ){
std::string foo( y["foo"] ) ;
return foo ;
}
// [[Rcpp::export]]
List character_listOf( List ll ){
CharacterVector cv1 = ll["foo"];
CharacterVector cv2 = ll["bar"];
std::string rv1 = std::string(cv1[0]) + cv1[1] + cv1[2];
std::string rv2 = std::string(cv2[0]) + cv2[1] + cv2[2];
return List::create(_["foo"] = rv1, _["bar"] = rv2);
}
// [[Rcpp::export]]
int character_find_(CharacterVector y){
CharacterVector::iterator it = std::find( y.begin(), y.end(), "foo" ) ;
return std::distance( y.begin(), it );
}
// [[Rcpp::export]]
List character_create_(){
List output(2);
output[0] = CharacterVector::create( "foo", "bar" ) ;
output[1] = CharacterVector::create(
_["foo"] = "bar",
_["bar"] = "foo"
) ;
return output ;
}
// [[Rcpp::export]]
List complex_binary_sugar(ComplexVector xx, ComplexVector yy){
return List::create(
_["+"] = xx + yy,
_["-"] = xx - yy,
_["*"] = xx * yy,
_["/"] = xx / yy
) ;
}
// [[Rcpp::export]]
List List_extract( List input ){
bool a = input[0] ;
int b = input[1] ;
return List::create(a, b) ;
}
// [[Rcpp::export]]
CharacterVector factors( CharacterVector s){
return s;
}
// [[Rcpp::export]]
IntegerVector IntegerVector_int_init(){
IntegerVector x(2,4) ;
return x ;
}
// [[Rcpp::export]]
bool containsElementNamed( List l, CharacterVector n){
return l.containsElementNamed(n[0]);
}
// [[Rcpp::export]]
List CharacterVectorEqualityOperator( CharacterVector x, CharacterVector y){
int n = x.size() ;
LogicalVector eq(n), neq(n);
for( int i=0; i x) {
return x.size();
}
// [[Rcpp::export]]
int stdVectorDoubleConst(const std::vector x) {
return x.size();
}
// [[Rcpp::export]]
int stdVectorDoubleRef(std::vector & x) {
return x.size();
}
// [[Rcpp::export]]
int stdVectorDoubleConstRef(const std::vector & x) {
return x.size();
}
// [[Rcpp::export]]
int stdVectorInt(std::vector x) {
return x.size();
}
// [[Rcpp::export]]
int stdVectorIntConst(const std::vector x) {
return x.size();
}
// [[Rcpp::export]]
int stdVectorIntRef(std::vector & x) {
return x.size();
}
// [[Rcpp::export]]
int stdVectorIntConstRef(const std::vector & x) {
return x.size();
}
// [[Rcpp::export]]
std::string character_vector_const_proxy(const CharacterVector& str){
char* cstr = (char*) str[0] ;
std::string res ;
res += cstr ;
return cstr ;
}
// [[Rcpp::export]]
CharacterVector CharacterVector_test_const_proxy(const CharacterVector x){
CharacterVector out( x.size() ) ;
for( int i=0; i x){
return x.size() ;
}
// [[Rcpp::export]]
int noprotect_matrix( Matrix x){
return x.nrow() ;
}
// [[Rcpp::export]]
int vec_access_with_bounds_checking(const IntegerVector x, int index) {
return x.at(index);
}
// [[Rcpp::export]]
String vec_print_numeric(NumericVector v) {
std::ostringstream buf;
buf << v;
return buf.str();
}
// [[Rcpp::export]]
String vec_print_character(CharacterVector v) {
std::ostringstream buf;
buf << v;
return buf.str();
}
// [[Rcpp::export]]
String vec_print_integer(IntegerVector v) {
std::ostringstream buf;
buf << v;
return buf.str();
}
// [[Rcpp::export]]
IntegerVector vec_subset(IntegerVector x, IntegerVector y) {
return x[y - 1];
}
// [[Rcpp::export]]
int CharacterVectorNoProtect(Vector s){
s[0] = "";
return s.size();
}
// [[Rcpp::export]]
CharacterVector CharacterVectorNoProtect_crosspolicy(Vector s){
CharacterVector s2(1) ;
s2[0] = s[0];
return s;
}
// [[Rcpp::export]]
List ListNoProtect_crosspolicy(Vector data){
List data2(1) ;
data2[0] = data[0];
return data2;
}
// [[Rcpp::export]]
bool CharacterVector_test_equality(CharacterVector x, CharacterVector y) {
if (x.length() != y.length()) {
return false;
}
return std::equal(x.begin(), x.end(), y.begin());
}
// [[Rcpp::export]]
bool CharacterVector_test_equality_crosspolicy(CharacterVector x, Vector y) {
if (x.length() != y.length()) {
return false;
}
return std::equal(x.begin(), x.end(), y.begin());
}
// [[Rcpp::export]]
double NumericVector_test_out_of_bounds_read(NumericVector v, R_xlen_t i) {
return v[i];
}
// [[Rcpp::export]]
SEXP CharacterVector_test_out_of_bounds_read(CharacterVector v, R_xlen_t i) {
return v[i];
}