14 #include "oops/util/Logger.h"
21 #include "eckit/exception/Exceptions.h"
26 : obsdb_(obsdb), keyOvec_(0)
33 : obsdb_(other.obsdb_), keyOvec_(0) {
108 const int keyOvecOther = other.
keyOvec_;
157 double zmin, zmax, zavg;
159 std::ios_base::fmtflags f(os.flags());
161 << std::scientific << std::setprecision(4)
162 <<
" Min=" << std::setw(12) << zmin
163 <<
", Max=" << std::setw(12) << zmax
164 <<
", Average=" << std::setw(12) << zavg;
172 unsigned int nobs(iobs);
Data in observation space.
const ObsVecQG & vect() const
const std::string & obsname() const
observation type
void getdb(const std::string &, int &) const
read data or metadata
const oops::Variables & obsvariables() const
return variables simulated by ObsOperators
void putdb(const std::string &, const int &) const
save data or metadata
int nobs() const
return number of observations (unique locations)
ObsVecQG class to handle vectors in observation space for QG model.
ObsVecQG & operator/=(const ObsVecQG &)
const ObsSpaceQG & obsdb_
void print(std::ostream &) const
void zero()
set all values to zero
void read(const std::string &)
ObsVecQG & operator-=(const ObsVecQG &)
unsigned int nobs() const
double dot_product_with(const ObsVecQG &) const
void axpy(const double &, const ObsVecQG &)
ObsVecQG & operator+=(const ObsVecQG &)
void ones()
set all values to one
ObsVecQG & operator=(const ObsVecQG &)
size_t packEigenSize(const ObsVecQG &) const
void mask(const ObsDataQG< int > &)
void setToMissing(int i)
set i-th value to missing value
Eigen::VectorXd packEigen(const ObsVecQG &) const
ObsVecQG(const ObsSpaceQG &, const std::string &name="")
ObsVecQG & operator*=(const double &)
void save(const std::string &) const
The namespace for the qg model.
void qg_obsvec_settomissing_ith_f90(const F90ovec &, const int &)
void qg_obsvec_dotprod_f90(const F90ovec &, const F90ovec &, double &)
void qg_obsvec_get_withmask_f90(const F90ovec &, const F90ovec &mask_key, double *data, const int &nobs)
fill data (size nobs) with all non-masked out (non-missing) values
void qg_obsvec_mask_with_missing_f90(const F90ovec &obsvector_key, const F90ovec &mask_key)
void qg_obsvec_ones_f90(const F90ovec &)
void qg_obsvec_nobs_withmask_f90(const F90ovec &, const F90ovec &mask_key, int &)
void qg_obsvec_mul_f90(const F90ovec &, const F90ovec &)
void qg_obsvec_zero_f90(const F90ovec &)
void qg_obsvec_setup_f90(F90ovec &, const int &, const int &)
void qg_obsvec_stats_f90(const F90ovec &, double &, double &, double &)
void qg_obsvec_mul_scal_f90(const F90ovec &, const double &)
void qg_obsvec_invert_f90(const F90ovec &)
void qg_obsvec_size_f90(const F90ovec &, int &)
void qg_obsvec_mask_f90(const F90ovec &obsvector_key, const F90ovec &mask_key)
void qg_obsvec_sub_f90(const F90ovec &, const F90ovec &)
void qg_obsvec_div_f90(const F90ovec &, const F90ovec &)
void qg_obsvec_add_f90(const F90ovec &, const F90ovec &)
void qg_obsvec_delete_f90(F90ovec &)
void qg_obsvec_copy_f90(const F90ovec &, const F90ovec &)
void qg_obsvec_axpy_f90(const F90ovec &, const double &, const F90ovec &)
void qg_obsvec_clone_f90(F90ovec &, const F90ovec &)
void qg_obsvec_nobs_f90(const F90ovec &, int &)
void qg_obsvec_random_f90(const ObsSpaceQG &, const F90ovec &)