nidas v1.2.3
|
A linear converter useful for REBS net radiometers, which have two sets of linear coefficients, one set to be applied during the day when Rnet > 0 and one when Rnet < 0: i.e. More...
#include <RebsLinear.h>
Public Member Functions | |
RebsLinear () | |
RebsLinear * | clone () const |
virtual std::string | toString () const override |
Generate a string description of this VariableConverter. | |
float | convert (dsm_time_t t, float volts) |
Apply linear conversion. | |
void | setCoefficients (const std::vector< float > &vals) |
void | setCoefficients (const float *fp, unsigned int n) |
const std::vector< float > & | getCoefficients () const |
const float * | getCoefficients (unsigned int &n) const |
double | convert (dsm_time_t t, double val) |
void | reset () |
Reset the converter to invalid or default settings, such as after an error occurs parsing a CalFile. | |
void | parseFields (CalFile *cf) |
Parse the fields in the current CalFile record for the particular settings and coefficients needed by this converter. | |
void | fromString (const std::string &) |
void | fromDOMElement (const xercesc::DOMElement *) |
virtual void | readCalFile (dsm_time_t) throw () |
Before a VariableConverter can be used for a conversion, the converter's CalFile, if it exists, needs to be advanced to the right record for the current sample time. | |
void | setCalFileHandler (CalFileHandler *) |
Set the instance of CalFileHandler which will be called and given first option to handle new CalFile records. | |
void | setUnits (const std::string &val) |
virtual const std::string & | getUnits () const |
void | setVariable (const Variable *val) |
const Variable * | getVariable () const |
const DSMSensor * | getDSMSensor () const |
const DSMConfig * | getDSMConfig () const |
void | addParameter (Parameter *val) |
Add a parameter to this VariableConverter. | |
const std::list< const Parameter * > & | getParameters () const |
Get list of parameters. | |
const Parameter * | getParameter (const std::string &name) const |
Fetch a parameter by name. | |
void | setCalFile (CalFile *) |
CalFile * | getCalFile () |
const CalFile * | getCalFile () const |
virtual xercesc::DOMElement * | toDOMParent (xercesc::DOMElement *parent, bool complete) const |
Create a DOMElement and append it to the parent. | |
virtual xercesc::DOMElement * | toDOMElement (xercesc::DOMElement *node, bool complete) const |
Add my content into a DOMElement. | |
Static Public Member Functions | |
static double | eval (double x, float *p, unsigned int np) |
This is static and defined inline below so the implementation can be shared with at least the one class in dynld which uses it: ParoSci_202BG_Calibration. | |
static VariableConverter * | createVariableConverter (XDOMElement &child) |
static VariableConverter * | createFromString (const std::string &) |
static const XMLCh * | getNamespaceURI () |
Protected Member Functions | |
void | abortCalFile (const std::string &what) |
Protected Attributes | |
CalFile * | _calFile |
CalFileHandler * | _handler |
Private Types | |
enum | coef { INTCP_NEG , SLOPE_NEG , INTCP_POS , SLOPE_POS , NUM_COEFS } |
Order of coefficients. More... | |
Private Attributes | |
std::vector< float > | _coefs |
std::string | _units |
std::map< std::string, Parameter * > | _parameters |
Map of parameters by name. | |
std::list< const Parameter * > | _constParameters |
List of const pointers to Parameters for providing via getParameters(). | |
const Variable * | _variable |
Static Private Attributes | |
static XMLCh * | namespaceURI = 0 |
A linear converter useful for REBS net radiometers, which have two sets of linear coefficients, one set to be applied during the day when Rnet > 0 and one when Rnet < 0: i.e.
a linear conversion with an if-test (wow! highly complicated code). Coefficients are read from a calibration file in this order intercept_neg slope_neg intercept_pos slope_pos
RebsLinear::RebsLinear | ( | ) |
Referenced by clone().
Add a parameter to this VariableConverter.
VariableConverter will then own the pointer and will delete it in its destructor. If a Parameter exists with the same name, it will be replaced with the new Parameter.
References nidas::core::VariableConverter::_constParameters, nidas::core::VariableConverter::_parameters, and nidas::core::getSample().
Referenced by nidas::core::VariableConverter::fromDOMElement(), nidas::core::VariableConverter::operator=(), and nidas::core::VariableConverter::VariableConverter().
|
virtual |
Reimplemented from nidas::core::Polynomial.
References RebsLinear().
|
virtualinherited |
float RebsLinear::convert | ( | dsm_time_t | t, |
float | volts ) |
Apply linear conversion.
References nidas::core::floatNAN, nidas::core::Polynomial::getCoefficients(), nidas::core::getSample(), INTCP_NEG, INTCP_POS, nidas::core::VariableConverter::readCalFile(), SLOPE_NEG, and SLOPE_POS.
|
staticinherited |
nidas::util::InvalidParameterException |
References nidas::core::getSample().
|
staticinherited |
References nidas::core::DOMObjectFactory::createObject(), and nidas::core::getSample().
Referenced by nidas::core::Variable::fromDOMElement().
This is static and defined inline below so the implementation can be shared with at least the one class in dynld which uses it: ParoSci_202BG_Calibration.
References nidas::core::getSample().
Referenced by nidas::dynld::ParoSci_202BG_Calibration::computePressure(), nidas::dynld::ParoSci_202BG_Calibration::computeTemperature(), and nidas::core::Polynomial::convert().
nidas::util::InvalidParameterException |
Implements nidas::core::DOMable.
References nidas::core::VariableConverter::fromDOMElement(), nidas::core::getSample(), and nidas::core::Polynomial::setCoefficients().
nidas::util::InvalidParameterException |
Reimplemented from nidas::core::VariableConverter.
References nidas::core::getSample(), nidas::core::Polynomial::setCoefficients(), and nidas::core::VariableConverter::setUnits().
|
inlineinherited |
References nidas::core::VariableConverter::_calFile.
Referenced by nidas::core::SampleTag::fromDOMElement(), and toString().
References nidas::core::VariableConverter::_calFile.
References nidas::core::Polynomial::_coefs.
Referenced by convert(), nidas::dynld::raf::SyncRecordSource::createHeader(), and toString().
References nidas::core::Polynomial::_coefs.
References nidas::core::VariableConverter::getDSMSensor(), and nidas::core::getSample().
References nidas::core::DOMable::namespaceURI.
Referenced by nidas::dynld::UDPSampleOutput::getProjectDOM(), nidas::core::Dataset::toDOMElement(), nidas::core::ProjectConfig::toDOMElement(), nidas::core::Dataset::toDOMParent(), nidas::core::Datasets::toDOMParent(), nidas::core::ProjectConfig::toDOMParent(), nidas::core::ProjectConfigs::toDOMParent(), nidas::core::DSMConfig::toDOMParent(), nidas::core::DSMSensor::toDOMParent(), nidas::core::Project::toDOMParent(), nidas::core::SampleTag::toDOMParent(), nidas::core::Site::toDOMParent(), nidas::core::ServerSocket::toDOMParent(), nidas::core::Variable::toDOMParent(), nidas::core::Datasets::writeXML(), and nidas::core::ProjectConfigs::writeXML().
Fetch a parameter by name.
Returns a NULL pointer if no such parameter exists.
References nidas::core::VariableConverter::_parameters.
Referenced by nidas::dynld::isff::CS_Krypton::fromDOMElement().
|
inlineinherited |
Get list of parameters.
References nidas::core::VariableConverter::_constParameters.
|
inlinevirtualinherited |
References nidas::core::VariableConverter::_units.
Referenced by nidas::core::Linear::toString(), nidas::core::Polynomial::toString(), and toString().
References nidas::core::VariableConverter::_variable.
Referenced by nidas::core::VariableConverter::getDSMSensor().
Parse the fields in the current CalFile record for the particular settings and coefficients needed by this converter.
Implements nidas::core::VariableConverter.
References nidas::core::VariableConverter::_calFile, DLOG, nidas::util::UTime::format(), nidas::core::CalFile::getCurrentFileName(), nidas::core::getSample(), nidas::core::Polynomial::setCoefficients(), and WLOG.
|
virtualinherited |
Before a VariableConverter can be used for a conversion, the converter's CalFile, if it exists, needs to be advanced to the right record for the current sample time.
As records are read, this method calls parseFields() so the VariableConverter subclass can extract the particular information it needs from the CalFile fields, typically coefficients.
For sensors which need to extend the kind of conversions which can be specified by a CalFile, there is a callback function available. See setCalFileHandler().
References DLOG, nidas::util::UTime::format(), and nidas::core::getSample().
Referenced by nidas::core::Linear::convert(), nidas::core::Polynomial::convert(), nidas::dynld::isff::CS_Krypton::convert(), convert(), nidas::dynld::isff::NCAR_TRH::convertVariable(), and nidas::dynld::raf::SyncRecordSource::preLoadCalibrations().
|
virtualinherited |
Reset the converter to invalid or default settings, such as after an error occurs parsing a CalFile.
Implements nidas::core::VariableConverter.
References nidas::core::getSample(), and nidas::core::Polynomial::setCoefficients().
References nidas::core::VariableConverter::_calFile, and nidas::core::getSample().
Referenced by nidas::core::VariableConverter::fromDOMElement().
|
inherited |
Set the instance of CalFileHandler which will be called and given first option to handle new CalFile records.
Pass null to disable the callbacks.
References nidas::core::VariableConverter::_handler, and nidas::core::getSample().
References nidas::core::Polynomial::_coefs, fp, and nidas::core::getSample().
References nidas::core::Polynomial::setCoefficients().
Referenced by nidas::core::Polynomial::fromDOMElement(), nidas::core::Polynomial::fromString(), nidas::core::Polynomial::parseFields(), nidas::core::Polynomial::Polynomial(), nidas::core::Polynomial::reset(), and nidas::core::Polynomial::setCoefficients().
References nidas::core::VariableConverter::_variable, and nidas::core::getSample().
|
virtualinherited |
Add my content into a DOMElement.
xercesc::DOMException |
Reimplemented in nidas::core::DSMConfig, nidas::core::DSMSensor, nidas::core::Project, nidas::core::SampleTag, nidas::core::Site, nidas::core::ServerSocket, and nidas::core::Variable.
Referenced by nidas::core::ServerSocket::toDOMParent().
|
virtualinherited |
Create a DOMElement and append it to the parent.
xercesc::DOMException |
Reimplemented in nidas::core::DSMConfig, nidas::core::DSMSensor, nidas::core::Project, nidas::core::SampleTag, nidas::core::Site, nidas::core::ServerSocket, and nidas::core::Variable.
|
overridevirtual |
Generate a string description of this VariableConverter.
May be used in meta-data, for example Netcdf comment.
Reimplemented from nidas::core::Polynomial.
References nidas::core::VariableConverter::getCalFile(), nidas::core::Polynomial::getCoefficients(), nidas::core::CalFile::getFile(), nidas::core::CalFile::getPath(), nidas::core::getSample(), nidas::core::VariableConverter::getUnits(), and NUM_COEFS.
|
protectedinherited |
Referenced by nidas::core::VariableConverter::abortCalFile(), nidas::core::VariableConverter::getCalFile(), nidas::core::VariableConverter::getCalFile(), nidas::core::VariableConverter::operator=(), nidas::core::Polynomial::parseFields(), nidas::core::VariableConverter::setCalFile(), nidas::core::VariableConverter::VariableConverter(), and nidas::core::VariableConverter::~VariableConverter().
|
privateinherited |
List of const pointers to Parameters for providing via getParameters().
Referenced by nidas::core::VariableConverter::addParameter(), nidas::core::VariableConverter::getParameters(), and nidas::core::VariableConverter::~VariableConverter().
|
protectedinherited |
|
privateinherited |
Map of parameters by name.
Referenced by nidas::core::VariableConverter::addParameter(), and nidas::core::VariableConverter::getParameter().
|
privateinherited |
|
staticprivateinherited |
Referenced by nidas::core::DOMable::getNamespaceURI().