8 #include "ioda/io/ObsIoGenerateList.h"
11 #include "ioda/io/ObsIoGenerateUtils.h"
14 #include "oops/util/missingValues.h"
33 const boost::optional<oops::Variables> & obsSimVarsVal =
36 oops::Log::trace() <<
"Constructing ObsIoGenerateList: List method" << std::endl;
66 const std::vector<float> & obsErrors,
67 const std::vector<std::string> & simVarNames) {
68 ASSERT(obsErrors.size() == simVarNames.size());
71 std::vector<float> latVals =
params.lats;
72 std::vector<float> lonVals =
params.lons;
73 std::vector<std::string> dtStrings =
params.datetimes;
81 os <<
"ObsIoGenerateList: " << std::endl;
Describe the dimensions of a ioda::Attribute or ioda::Variable.
Definitions for setting up backends with file and memory I/O.
oops::RequiredParameter< std::vector< float > > lats
latitude values
Groups are a new implementation of ObsSpaces.
Options controlling the ObsIoGenerateList class.
EmbeddedObsGenerateListParameters list
options shared by this class and the legacy implementation (LegacyObsGenerateParameters)
oops::Parameter< std::vector< float > > obsErrors
obs error estimates
static ObsGroup generate(Group &emptyGroup, const NewDimensionScales_t &fundamentalDims, std::shared_ptr< const detail::DataLayoutPolicy > layout=nullptr)
Create an empty ObsGroup and populate it with the fundamental dimensions.
void print(std::ostream &os) const override
print routine for oops::Printable base class
void genDistList(const EmbeddedObsGenerateListParameters ¶ms, const std::vector< float > &obsErrors, const std::vector< std::string > &simVarNames)
generate observation locations using the list method
ObsIoGenerateList(const Parameters_ &ioParams, const ObsSpaceParameters &obsSpaceParams)
Dimensions_t max_var_size_
maximum variable size (ie, first dimension size)
Dimensions_t nlocs_
number of locations from source (file or generator)
VarNameObjectList var_list_
list of regular variables from source (file or generator)
std::vector< std::string > obs_grouping_vars_
names of variables to be used to group observations into records
VarNameObjectList dim_var_list_
list of dimension scale variables from source (file or generator)
Dimensions_t numLocs() const
return number of locations from the source
VarDimMap dims_attached_to_vars_
map containing variables with their attached dimension scales
ObsGroup obs_group_
ObsGroup object representing io source/destination.
oops::Parameter< ObsGroupingParameters > obsGrouping
options controlling obs record grouping
ObsTopLevelParameters top_level_
sub groups of parameters
oops::RequiredParameter< oops::Variables > simVars
simulated variables
Has_Variables vars
Use this to access variables.
virtual Variable open(const std::string &name) const
Open a Variable by name.
virtual Dimensions getDimensions() const
BackendNames
Backend names.
IODA_DL Group constructBackend(BackendNames name, BackendCreationParameters ¶ms)
This is a simple factory style function that will instantiate a different backend based on a given na...
@ ObsStore
ObsStore in-memory.
static DistributionMaker< AtlasDistribution > maker(DIST_NAME)
std::vector< std::shared_ptr< NewDimensionScale_Base > > NewDimensionScales_t
void storeGenData(const std::vector< float > &latVals, const std::vector< float > &lonVals, const std::vector< std::string > &dtStrings, const std::vector< std::string > &obsVarNames, const std::vector< float > &obsErrors, ObsGroup &obsGroup)
store generated data into an ObsGroup
void collectVarDimInfo(const ObsGroup &obsGroup, VarNameObjectList &varObjectList, VarNameObjectList &dimVarObjectList, VarDimMap &dimsAttachedToVars, Dimensions_t &maxVarSize0)
collect variable and dimension information from a ioda ObsGroup
std::vector< Dimensions_t > dimsCur
The dimensions of the data.
Used to specify backend creation-time properties.