8 #ifndef UFO_FILTERS_OBSDERIVATIVECHECK_H_
9 #define UFO_FILTERS_OBSDERIVATIVECHECK_H_
16 #include "oops/util/ObjectCounter.h"
25 template <
typename DATATYPE>
class ObsDataVector;
35 private util::ObjectCounter<ObsDerivativeCheck> {
37 static const std::string
classname() {
return "ufo::ObsDerivativeCheck";}
45 void print(std::ostream &)
const override;
47 std::vector<std::vector<bool>> &)
const override;
Base class for UFO QC filters.
Derivative check: check if the derivative of one variable with respect to another.
ObsDerivativeCheck(ioda::ObsSpace &, const eckit::Configuration &, std::shared_ptr< ioda::ObsDataVector< int > >, std::shared_ptr< ioda::ObsDataVector< float > >)
static const std::string classname()
void print(std::ostream &) const override
int qcFlag() const override
void applyFilter(const std::vector< bool > &, const Variables &, std::vector< std::vector< bool >> &) const override