Rcpp Version 1.0.14
Loading...
Searching...
No Matches
cummax.h
Go to the documentation of this file.
1
// -*- mode: C++; c-indent-level: 4; c-basic-offset: 4; tab-width: 8 -*-
2
//
3
// cumsum.h: Rcpp R/C++ interface class library -- cumsum
4
//
5
// Copyright (C) 2010 - 2011 Dirk Eddelbuettel and Romain Francois
6
//
7
// This file is part of Rcpp.
8
//
9
// Rcpp is free software: you can redistribute it and/or modify it
10
// under the terms of the GNU General Public License as published by
11
// the Free Software Foundation, either version 2 of the License, or
12
// (at your option) any later version.
13
//
14
// Rcpp is distributed in the hope that it will be useful, but
15
// WITHOUT ANY WARRANTY; without even the implied warranty of
16
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17
// GNU General Public License for more details.
18
//
19
// You should have received a copy of the GNU General Public License
20
// along with Rcpp. If not, see <http://www.gnu.org/licenses/>.
21
22
#ifndef Rcpp__sugar__cummax_h
23
#define Rcpp__sugar__cummax_h
24
25
namespace
Rcpp
{
26
namespace
sugar{
27
28
template
<
int
RTYPE,
bool
NA,
typename
T>
29
class
Cummax
:
public
Lazy
< Rcpp::Vector<RTYPE>, Cummax<RTYPE, NA, T> > {
30
public
:
31
typedef
typename
Rcpp::VectorBase<RTYPE, NA, T>
VEC_TYPE
;
32
typedef
typename
Rcpp::traits::storage_type<RTYPE>::type
STORAGE
;
33
typedef
Rcpp::Vector<RTYPE>
VECTOR
;
34
35
Cummax
(
const
VEC_TYPE
&
object_
) :
object
(
object_
) {}
36
37
VECTOR
get
()
const
{
38
R_xlen_t
n =
object
.
size
();
39
VECTOR
result
(n, Rcpp::traits::get_na<RTYPE>());
40
STORAGE
current =
object
[0];
41
42
if
(Rcpp::traits::is_na<RTYPE>(current))
return
result
;
43
result
[0] = current;
44
for
(
R_xlen_t
i = 1; i < n; i++) {
45
current =
object
[i];
46
if
(Rcpp::traits::is_na<RTYPE>(current))
return
result
;
47
result
[i] =
result
[i-1] > current ?
result
[i-1] : current;
48
}
49
return
result
;
50
}
51
private
:
52
const
VEC_TYPE
&
object
;
53
};
54
55
}
// sugar
56
57
58
template
<
bool
NA,
typename
T>
59
inline
sugar::Cummax<INTSXP, NA, T>
cummax
(
const
VectorBase<INTSXP, NA, T>
& t) {
60
return
sugar::Cummax<INTSXP, NA, T>
(t);
61
}
62
63
template
<
bool
NA,
typename
T>
64
inline
sugar::Cummax<REALSXP, NA, T>
cummax
(
const
VectorBase<REALSXP, NA, T>
& t) {
65
return
sugar::Cummax<REALSXP, NA, T>
(t);
66
}
67
68
69
}
// Rcpp
70
#endif
// Rcpp__sugar__cummax_h
71
Rcpp::VectorBase
Definition
VectorBase.h:29
Rcpp::Vector
Definition
Vector.h:35
Rcpp::Vector::size
R_xlen_t size() const
Definition
Vector.h:275
Rcpp::object
Definition
Module.h:65
Rcpp::result
Definition
Module.h:56
Rcpp::sugar::Cummax
Definition
cummax.h:29
Rcpp::sugar::Cummax::VEC_TYPE
Rcpp::VectorBase< RTYPE, NA, T > VEC_TYPE
Definition
cummax.h:31
Rcpp::sugar::Cummax::Cummax
Cummax(const VEC_TYPE &object_)
Definition
cummax.h:35
Rcpp::sugar::Cummax::VECTOR
Rcpp::Vector< RTYPE > VECTOR
Definition
cummax.h:33
Rcpp::sugar::Cummax::object
const VEC_TYPE & object
Definition
cummax.h:52
Rcpp::sugar::Cummax::STORAGE
Rcpp::traits::storage_type< RTYPE >::type STORAGE
Definition
cummax.h:32
Rcpp::sugar::Cummax::get
VECTOR get() const
Definition
cummax.h:37
Rcpp::sugar::Lazy
Definition
Lazy.h:29
Rcpp
Rcpp API.
Definition
algo.h:28
Rcpp::cummax
sugar::Cummax< INTSXP, NA, T > cummax(const VectorBase< INTSXP, NA, T > &t)
Definition
cummax.h:59
Rcpp::as
T as(SEXP x)
Definition
as.h:151
Rcpp::traits::storage_type::type
SEXP type
Definition
storage_type.h:36
inst
include
Rcpp
sugar
functions
cummax.h
Generated on Sun Jan 12 2025 11:21:43 for Rcpp Version 1.0.14 by
1.9.8