IODA
ioda::ObsIoGenerateRandom Class Reference

Implementation of ObsIo generating observations at random locations. More...

#include <ObsIoGenerateRandom.h>

Inheritance diagram for ioda::ObsIoGenerateRandom:
Collaboration diagram for ioda::ObsIoGenerateRandom:

Public Types

typedef ObsGenerateRandomParameters Parameters_
 Type used by ObsIoFactory. More...
 

Public Member Functions

 ObsIoGenerateRandom (const Parameters_ &ioParams, const ObsSpaceParameters &obsSpaceParams)
 
 ~ObsIoGenerateRandom ()
 
bool applyTimingWindow () const override
 return true if only observations within the timing window should be retained, false otherwise. More...
 
- Public Member Functions inherited from ioda::ObsIo
 ObsIo ()
 
virtual ~ObsIo ()
 
Dimensions_t maxVarSize () const
 return number of maximum variable size (along first dimension) More...
 
Dimensions_t numLocs () const
 return number of locations from the source More...
 
Dimensions_t numVars () const
 return number of regular variables from the source More...
 
Dimensions_t numDimVars () const
 return number of dimension scale variables from the source More...
 
const VarNameObjectListvarList () const
 return list of regular variable names More...
 
const VarNameObjectListdimVarList () const
 return list of dimension scale variable names More...
 
VarDimMap varDimMap () const
 return map of variables to attached dimension scales More...
 
bool isVarDimByNlocs (const std::string &varName) const
 return true if variable's first dimension is nlocs More...
 
Has_Variablesvars ()
 access to the variables container in the associated ObsGroup More...
 
Has_Attributesatts ()
 access to the attributes container in the associated ObsGroup More...
 
void updateVarDimInfo ()
 update the variable and dimension information More...
 
const std::vector< std::string > & obsGroupingVars () const
 return the names of variables to be used to group observations into records More...
 
virtual bool eachProcessGeneratesSeparateObs () const
 return true if each process generates a separate series of observations (e.g. read from different files). More...
 

Static Public Member Functions

static const std::string classname ()
 classname method for object counter More...
 

Private Member Functions

void genDistRandom (const EmbeddedObsGenerateRandomParameters &params, const util::DateTime &winStart, const util::DateTime &winEnd, const eckit::mpi::Comm &comm, const std::vector< float > &obsErrors, const std::vector< std::string > &simVarNames)
 generate observation locations using the random method More...
 
void print (std::ostream &os) const override
 print routine for oops::Printable base class More...
 

Additional Inherited Members

- Protected Attributes inherited from ioda::ObsIo
ObsGroup obs_group_
 ObsGroup object representing io source/destination. More...
 
Dimensions_t max_var_size_
 maximum variable size (ie, first dimension size) More...
 
Dimensions_t nlocs_
 number of locations from source (file or generator) More...
 
VarNameObjectList var_list_
 list of regular variables from source (file or generator) More...
 
VarNameObjectList dim_var_list_
 list of dimension scale variables from source (file or generator) More...
 
VarDimMap dims_attached_to_vars_
 map containing variables with their attached dimension scales More...
 
std::vector< std::string > obs_grouping_vars_
 names of variables to be used to group observations into records More...
 

Detailed Description

Implementation of ObsIo generating observations at random locations.

Author
Stephen Herbener (JCSDA)

Definition at line 29 of file ObsIoGenerateRandom.h.

Member Typedef Documentation

◆ Parameters_

Constructor & Destructor Documentation

◆ ObsIoGenerateRandom()

ioda::ObsIoGenerateRandom::ObsIoGenerateRandom ( const Parameters_ ioParams,
const ObsSpaceParameters obsSpaceParams 
)
explicit

Definition at line 23 of file ObsIoGenerateRandom.cc.

Here is the call graph for this function:

◆ ~ObsIoGenerateRandom()

ioda::ObsIoGenerateRandom::~ObsIoGenerateRandom ( )

Definition at line 61 of file ObsIoGenerateRandom.cc.

Member Function Documentation

◆ applyTimingWindow()

bool ioda::ObsIoGenerateRandom::applyTimingWindow ( ) const
inlineoverridevirtual

return true if only observations within the timing window should be retained, false otherwise.

Reimplemented from ioda::ObsIo.

Definition at line 45 of file ObsIoGenerateRandom.h.

◆ classname()

static const std::string ioda::ObsIoGenerateRandom::classname ( )
inlinestatic

classname method for object counter

This method is supplied for the ObjectCounter base class. It defines a name to identify an object of this class for reporting by OOPS.

Definition at line 36 of file ObsIoGenerateRandom.h.

◆ genDistRandom()

void ioda::ObsIoGenerateRandom::genDistRandom ( const EmbeddedObsGenerateRandomParameters params,
const util::DateTime &  winStart,
const util::DateTime &  winEnd,
const eckit::mpi::Comm &  comm,
const std::vector< float > &  obsErrors,
const std::vector< std::string > &  simVarNames 
)
private

generate observation locations using the random method

This method will generate a set of latitudes and longitudes of which can be used for testing without reading in an obs file. Two latitude values, two longitude values, the number of locations (nobs keyword) and an optional random seed are specified in the configuration given by the conf parameter. Random locations between the two latitudes and two longitudes are generated and stored in the obs container as meta data. Random time stamps that fall inside the given timing window (which is specified in the configuration file) are also generated and stored in the obs container as meta data. These data are intended for use with the MakeObs functionality.

Parameters
paramsParameters structure specific to the generate random method
winStartDateTime object marking DA window start
winEndDateTime object marking DA window end
commMPI communicator group
obsErrorslist of error estimates for each assimilated variable
simVarNameslist of names of variables to be assimilated

Grab the parameter values

Definition at line 67 of file ObsIoGenerateRandom.cc.

Here is the call graph for this function:
Here is the caller graph for this function:

◆ print()

void ioda::ObsIoGenerateRandom::print ( std::ostream &  os) const
overrideprivatevirtual

print routine for oops::Printable base class

Parameters
ostreamoutput stream

Implements ioda::ObsIo.

Definition at line 155 of file ObsIoGenerateRandom.cc.


The documentation for this class was generated from the following files: