IODA
ObsIoFileRead.cc
Go to the documentation of this file.
1 /*
2  * (C) Copyright 2017-2019 UCAR
3  *
4  * This software is licensed under the terms of the Apache Licence Version 2.0
5  * which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.
6  */
7 
8 #include "eckit/config/YAMLConfiguration.h"
9 
10 #include "ioda/core/FileFormat.h"
11 #include "ioda/Engines/Factory.h"
12 #include "ioda/Engines/HH.h" // for genUniqueName()
13 #include "ioda/Engines/ODC.h"
14 #include "ioda/io/ObsIoFileRead.h"
15 
16 namespace ioda {
17 
18 //--------------------------------------------------------------------------------
19 static ObsIoMaker<ObsIoFileRead> maker("FileRead");
20 
21 //------------------------------ public functions --------------------------------
22 //--------------------------------------------------------------------------------
24  const ObsSpaceParameters & obsSpaceParams) : ObsIo() {
25  std::string fileName = ioParams.fileName;
26 
27  oops::Log::trace() << "Constructing ObsIoFileRead: Opening file for read: "
28  << fileName << std::endl;
29 
30  const bool odb = (determineFileFormat(fileName, ioParams.format) == FileFormat::ODB);
31 
32  if (ioParams.readFromSeparateFiles) {
33  // We are initializing from a prior run and therefore reading in the
34  // separate ioda files produced from that prior run.
35  fileName = uniquifyFileName(fileName, obsSpaceParams.getMpiRank(),
36  obsSpaceParams.getMpiTimeRank());
37  read_separate_files_ = true;
38  }
39 
40  if (odb)
41  createObsGroupFromOdbFile(fileName, ioParams);
42  else
44 
45  // Collect variable and dimension infomation for downstream use
48 
49  // record number of locations
51 
52  // record variables by which observations should be grouped into records
53  obs_grouping_vars_ = ioParams.obsGrouping.value().obsGroupVars;
54 }
55 
57 
59  return read_separate_files_;
60 }
61 
62 //------------------------------ private functions ----------------------------------
63 //-----------------------------------------------------------------------------------
64 void ObsIoFileRead::print(std::ostream & os) const {
65  os << "ObsIoFileRead: " << std::endl;
66 }
67 
68 void ObsIoFileRead::createObsGroupFromHdf5File(const std::string & fileName) {
69  // Prepare to create a backend backed by an existing read-only hdf5 file
72  backendParams.fileName = fileName;
75 
76  // Create the backend and attach it to an ObsGroup
77  Group backend = constructBackend(backendName, backendParams);
78  obs_group_ = ObsGroup(backend);
79 }
80 
81 void ObsIoFileRead::createObsGroupFromOdbFile(const std::string & fileName,
82  const Parameters_ & ioParams) {
83  if (ioParams.mappingFile.value().empty())
84  throw ioda::Exception("The 'obsdatain.mapping file' option "
85  "must be set for obs files in the ODB format.", ioda_Here());
86  if (ioParams.queryFile.value().empty())
87  throw ioda::Exception("The 'obsdatain.query file' option "
88  "must be set for obs files in the ODB format.", ioda_Here());
89 
90  // Create an in-memory backend
96  backendParams.allocBytes = 1024*1024*50;
97  backendParams.flush = false;
98  Group backend = constructBackend(backendName, backendParams);
99 
100  // And load the ODB file into it
102  odcparams.filename = fileName;
103  odcparams.mappingFile = ioParams.mappingFile;
104  odcparams.queryFile = ioParams.queryFile;
105 
106  obs_group_ = Engines::ODC::openFile(odcparams, backend);
107 }
108 
109 } // namespace ioda
Definitions for setting up backends with file and memory I/O.
HDF5 engine.
ODB / ODC engine.
The ioda exception class.
Definition: Exception.h:54
Groups are a new implementation of ObsSpaces.
Definition: Group.h:159
oops::Parameter< FileFormat > format
oops::Parameter< std::string > queryFile
oops::Parameter< std::string > mappingFile
oops::Parameter< bool > readFromSeparateFiles
oops::RequiredParameter< std::string > fileName
input obs file name
An ObsGroup is a specialization of a ioda::Group. It provides convenience functions and guarantees th...
Definition: ObsGroup.h:32
ObsIoFileRead(const Parameters_ &ioParams, const ObsSpaceParameters &obsSpaceParams)
bool eachProcessGeneratesSeparateObs() const override
return true if each process generates a separate series of observations (e.g. read from different fil...
void createObsGroupFromOdbFile(const std::string &fileName, const Parameters_ &ioParams)
Read the contents of an ODB file into obs_group_.
void createObsGroupFromHdf5File(const std::string &fileName)
Read the contents of an HDF5 file into obs_group_.
void print(std::ostream &os) const override
print routine for oops::Printable base class
Dimensions_t max_var_size_
maximum variable size (ie, first dimension size)
Definition: ObsIo.h:97
Dimensions_t nlocs_
number of locations from source (file or generator)
Definition: ObsIo.h:100
VarNameObjectList var_list_
list of regular variables from source (file or generator)
Definition: ObsIo.h:103
std::vector< std::string > obs_grouping_vars_
names of variables to be used to group observations into records
Definition: ObsIo.h:112
VarNameObjectList dim_var_list_
list of dimension scale variables from source (file or generator)
Definition: ObsIo.h:106
VarDimMap dims_attached_to_vars_
map containing variables with their attached dimension scales
Definition: ObsIo.h:109
ObsGroup obs_group_
ObsGroup object representing io source/destination.
Definition: ObsIo.h:94
oops::Parameter< ObsGroupingParameters > obsGrouping
options controlling obs record grouping
int getMpiTimeRank() const
get the MPI rank number
std::size_t getMpiRank() const
get the MPI rank number
Has_Variables vars
Use this to access variables.
Definition: Group.h:123
virtual Variable open(const std::string &name) const
Open a Variable by name.
virtual Dimensions getDimensions() const
Definition: Variable.cpp:160
IODA_DL std::string genUniqueName()
Convenience function to generate a random file name.
Definition: HH.cpp:50
IODA_DL ObsGroup openFile(const ODC_Parameters &params, Group emptyStorageGroup=ioda::Engines::ObsStore::createRootGroup())
Import an ODB file.
Definition: ODC.cpp:56
BackendNames
Backend names.
Definition: Factory.h:28
IODA_DL Group constructBackend(BackendNames name, BackendCreationParameters &params)
This is a simple factory style function that will instantiate a different backend based on a given na...
Definition: Factory.cpp:124
@ Open
Open an existing file.
@ Hdf5File
HDF5 file access.
@ ObsStore
ObsStore in-memory.
@ Truncate_If_Exists
If the file already exists, overwrite it.
@ Read_Only
Open the file in read-only mode.
static DistributionMaker< AtlasDistribution > maker(DIST_NAME)
@ ODB
ODB file format.
std::string uniquifyFileName(const std::string &fileName, const std::size_t rankNum, const int timeRankNum)
uniquify the output file name
Definition: IodaUtils.cc:343
void collectVarDimInfo(const ObsGroup &obsGroup, VarNameObjectList &varObjectList, VarNameObjectList &dimVarObjectList, VarDimMap &dimsAttachedToVars, Dimensions_t &maxVarSize0)
collect variable and dimension information from a ioda ObsGroup
Definition: IodaUtils.cc:125
FileFormat determineFileFormat(const std::string &filePath, FileFormat hint)
Determine the format of an observation file.
Definition: FileFormat.cc:13
#define ioda_Here()
std::vector< Dimensions_t > dimsCur
The dimensions of the data.
Definition: Dimensions.h:23
Used to specify backend creation-time properties.
Definition: Factory.h:59
Encapsulate the parameters to make calling simpler.
Definition: ODC.h:32
std::string filename
The name of the database "file" to open.
Definition: ODC.h:34