14 #include "gsl/gsl-lite.hpp"
31 digits_.assign(digit_sizes.size(), 0);
44 for (std::size_t i = 0; i <
ndigits_; ++i) {
77 end_(gsl::narrow<int>(start + npoints) - 1),
78 index_(0), npoints_(npoints) {
83 const std::vector<Dimensions_t>& dim_sizes)
89 dim_selects_(dim_selects),
90 dim_sizes_(dim_sizes),
130 std::size_t lin_index = 0;
136 const std::vector<std::size_t>& curCount =
counter_->count();
150 .
add(
" Next linear index: ", lin_index)
157 bool finished =
false;
Functions for ObsStore Selection.
The ioda exception class.
Exception & add(const std::string &key, const T value)
Add a key-value pair to the error message.
bool finished() const
returns true when inc attempts to go past final state of counter
const std::vector< std::size_t > & count() const
return current counter value
std::vector< std::size_t > digits_
counter digits
bool counter_end_
true when finished counting
std::size_t icount_
index to counter digit
SelectionModes mode_
mode of selection
void reset(const SelectionModes mode, const std::vector< std::size_t > &digit_sizes_)
allocate n digits for counter and set count to zero
std::size_t ndigits_
number of digits in counter
void inc()
increment counter
std::vector< std::size_t > digit_sizes_
size (range) for each digit place
std::size_t npoints() const
returns number of points in selection
int end_
end of selection for ALL mode
std::size_t npoints_
total number of points in selection
std::unique_ptr< SelectCounter > counter_
counter for generating linear memory indices
bool end_lin_indx() const
returns true when at the end of the linear memory indices
SelectionModes mode() const
returns selection mode
void init_lin_indx()
initializes iterator for walking through linear memory indices
std::vector< std::size_t > dim_select_sizes_
number of dimension selections per dimension
SelectionModes mode_
mode of selection (which impacts how linear memory is accessed)
std::vector< Dimensions_t > dim_sizes_
sizes of data dimensions (length is rank of dimensions)
int index_
index value for ALL mode
std::size_t max_index_
maximum allowed index value
std::size_t next_lin_indx()
returns next linear memory index
std::vector< SelectSpecs > dim_selects_
selection indices for each dimension
@ ObsStore
ObsStore in-memory.
SelectionModes
ObsStore selection modes.