CXXR (C++ R) API
|
Monitor function application for unary functions. More...
#include <UnaryFunction.hpp>
Public Member Functions | |
UnaryNAPropagator (const Functor &f) | |
Constructor. | |
result_type | operator() (const argument_type &in) const |
Monitored invocation of f . | |
void | warnings () |
Raise warnings after processing a vector. |
Monitor function application for unary functions.
VectorOps::UnaryFunction takes as a template parameter a FunctorWrapper class template. The apply() method of UnaryFunction creates an object from this template, and delegates to it the task of calling the unary function; the FunctorWrapper object can then monitor any special conditions that occur, and take appropriate action either immediately (for example by raising an error and/or modifying the result value) or when processing of the input vector is complete (typically by providing one or more warnings).
This template is the default value of the FunctorWrapper template parameter, and its effect is to ensure that if the argument to the unary function is NA, then the result is set to NA (without actually calling the unary function). If different behaviour is required, another class can be created using this class as a model.
argument_type | Element type of the input vector of the UnaryFunction. |
result_type | Element type of the result of the UnaryFunction. |
Functor | Function or function object type, representing a unary function. ElementTraits<argument_type>::Data::Type must be convertible to the type of the argument of this function. The result of the function must be assignable to result_type . |
|
inline |
Constructor.
f | Pointer to an object of type Functor defining the unary function whose operation this FunctorWrapper is to monitor. |
|
inline |
Monitored invocation of f .
The apply() method of an object instantiating the VectorOps::UnaryFunction template will call this function to generate a value for an element of the output vector from the value of the corresponding element of the input vector, using the functor f .
in | Element of the input vector to which f is to be applied. |
|
inline |
Raise warnings after processing a vector.
The apply() method of an object instantiating the VectorOps::UnaryFunction template will call this function once all the elements of the input vector have been processed. Typically this function will do nothing if no abnormalities have occurred during the lifetime of this FunctorWrapper object , otherwise it will raise one or more warnings. (Note that the lifetime of a FunctorWrapper object corresponds to the processing of an input vector by the apply() method of UnaryFunction.)
The default behaviour, implemented here, is to do nothing.