File: RangeIndexer.h

package info (click to toggle)
rcpp 1.0.10-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 11,432 kB
  • sloc: ansic: 44,024; cpp: 40,602; sh: 53; makefile: 2
file content (104 lines) | stat: -rw-r--r-- 3,341 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
// -*- mode: C++; c-indent-level: 4; c-basic-offset: 4; tab-width: 8 -*-
//
// RangeIndexer.h: Rcpp R/C++ interface class library --
//
// Copyright (C) 2010 - 2011 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 <http://www.gnu.org/licenses/>.

#ifndef Rcpp__vector__RangeIndexer_h
#define Rcpp__vector__RangeIndexer_h

#define UNROLL_LOOP(OP)                              \
    typedef typename ::Rcpp::traits::Extractor<RTYPE,NA,T>::type EXT ; \
    const EXT& input( x.get_ref() ) ;                   \
    int __trip_count = (size_) >> 2;                 \
    int i=0 ;                                        \
    for ( ; __trip_count > 0 ; --__trip_count) {     \
        start[i] OP input[i] ; i++ ;                 \
        start[i] OP input[i] ; i++ ;                 \
        start[i] OP input[i] ; i++ ;                 \
        start[i] OP input[i] ; i++ ;                 \
    }                                                \
    switch (size_ - i){                              \
      case 3:                                        \
          start[i] OP input[i] ; i++ ;               \
      case 2:                                        \
          start[i] OP input[i] ; i++ ;               \
      case 1:                                        \
          start[i] OP input[i] ; i++ ;               \
      case 0:                                        \
      default:                                       \
          return *this ;                             \
    }


namespace Rcpp{
namespace internal{

template <int RTYPE, bool NA, typename VECTOR>
class RangeIndexer : public VectorBase<RTYPE, NA, RangeIndexer<RTYPE,NA,VECTOR> >  {
public:
	typedef typename VECTOR::Proxy Proxy ;
	typedef typename VECTOR::iterator iterator ;

	RangeIndexer( VECTOR& vec_, const Rcpp::Range& range_) :
		start(vec_.begin() + range_.get_start() ), size_( range_.size() ) {}

	template <bool NA_, typename T>
	RangeIndexer& operator=( const Rcpp::VectorBase<RTYPE,NA_,T>& x){
	    UNROLL_LOOP(=)
	}

	template <bool NA_, typename T>
	RangeIndexer& operator+=( const Rcpp::VectorBase<RTYPE,NA_,T>& x){
		 UNROLL_LOOP(+=)
	}

	template <bool NA_, typename T>
	RangeIndexer& operator*=( const Rcpp::VectorBase<RTYPE,NA_,T>& x){
		UNROLL_LOOP(*=)
	}

	template <bool NA_, typename T>
	RangeIndexer& operator-=( const Rcpp::VectorBase<RTYPE,NA_,T>& x){
		UNROLL_LOOP(-=)
	}

	template <bool NA_, typename T>
	RangeIndexer& operator/=( const Rcpp::VectorBase<RTYPE,NA_,T>& x){
		UNROLL_LOOP(/=)
	}

	inline Proxy operator[]( R_xlen_t i ) const {
	    return start[i] ;
	}

	inline R_xlen_t size() const {
		return size_ ;
	}

private:
	iterator start ;
	R_xlen_t size_ ;
} ;

}
}

#undef UNROLL_LOOP

#endif