OpendTect-6_4
6.4
|
Math formula: (expression, inputs, units, calculation, storage). More...
Classes | |
class | InpDef |
Public Member Functions | |
Formula (bool inputsareseries=true, const char *txt=0) | |
Formula (bool inputsareseries, const SpecVarSet &, const char *txt=0) | |
Formula (const Formula &) | |
~Formula () | |
Formula & | operator= (const Formula &) |
void | setText (const char *) |
bool | isOK () const |
bool | isBad () const |
const char * | errMsg () const |
const char * | text () const |
int | nrInputs () const |
const char * | variableName (int iinp) const |
bool | isConst (int iinp) const |
bool | isSpec (int iinp) const |
int | specIdx (int) const |
const TypeSet< int > & | getShifts (int iinp) const |
Interval< int > | shiftRange (int iinp) const |
bool | isRecursive () const |
int | maxRecShift () const |
void | setInputDef (int, const char *) |
void | setInputUnit (int, const UnitOfMeasure *) |
void | setOutputUnit (const UnitOfMeasure *uom) |
TypeSet< double > & | recStartVals () |
void | clearInputDefs () |
const UnitOfMeasure * | outputUnit () const |
const char * | inputDef (int iinp) const |
const UnitOfMeasure * | inputUnit (int iinp) const |
double | getConstVal (int) const |
if isConst returns toDouble(inputDef(i)), else Udf More... | |
int | nrValues2Provide () const |
void | startNewSeries () const |
float | getValue (const float *, bool internal_units=true) const |
double | getValue (const double *, bool internal_units=true) const |
void | fillPar (IOPar &) const |
void | usePar (const IOPar &) |
const Expression * | expression () const |
const SpecVarSet & | specVars () const |
bool | inputsAreSeries () const |
int | nrConsts () const |
const char * | userDispText () const |
int | nrExternalInputs () const |
Static Public Member Functions | |
static const char * | sKeyExpression () |
static const char * | sKeyRecStartVals () |
static const char * | sKeyFileType () |
Protected Member Functions | |
int | varNameIdx (const char *varnm) const |
void | addShift (int, int, int &, TypeSet< TypeSet< int > > &) |
Protected Attributes | |
BufferString | text_ |
TypeSet< InpDef > | inps_ |
const UnitOfMeasure * | outputunit_ |
TypeSet< double > | recstartvals_ |
const SpecVarSet * | specvars_ |
const bool | inputsareseries_ |
Expression * | expr_ |
TypeSet< int > | inpidxs_ |
TypeSet< int > | recshifts_ |
TypeSet< int > | validxs_ |
TypeSet< double > | prevvals_ |
BufferString | errmsg_ |
Math formula: (expression, inputs, units, calculation, storage).
Before construction gather your 'special variables'. Users can insert them and they are not 'regular input'. See SpecVars and SpecVarSet.
At construction or when calling setText(), the input text is parsed. Then, the variable definitions are known. You can use setInputUnit(idx) before calculation, this unit is the unit that the user wants the variable value to be converted to before inserting it into the mathexpression.
When you know what is required, you can provide numbers for the different inputs and get a result using getValue(). The input values you provide must be in internal units.
If your formula is to work on a series of input vectors, then two things become possible: 1) Recursive values. This is when the user uses out[i] ot this[i]. 2) Input shifts. For example: ampl[-1] or den[3]. For (1), you can specify start values. The maximum shift is the size of the TypeSet. These recursive variables will not show up in the inputs. For (2), you need to have extra values in the input value array (i.e. you need to loop over the getShifts(iinp).
Before using getValue(), you want to use setInputDef(idx) and maybe set the input unit conversions. This makes it possible to store/retrieve in IOPar, but this is aso required if there are constants in the expression.
The setOutputUnit() can be used to keep track of what the result means, or to get the result in that unit from getValue().
Lastly, the SpecVarSet you provide usually lives forever, but should at least stay alive during the lifetime of the formula (it is not copied).
Math::Formula::Formula | ( | bool | inputsareseries = true , |
const char * | txt = 0 |
||
) |
Math::Formula::Formula | ( | bool | inputsareseries, |
const SpecVarSet & | , | ||
const char * | txt = 0 |
||
) |
Math::Formula::Formula | ( | const Formula & | ) |
Math::Formula::~Formula | ( | ) |
void Math::Formula::clearInputDefs | ( | ) |
|
inline |
|
inline |
void Math::Formula::fillPar | ( | IOPar & | ) | const |
double Math::Formula::getConstVal | ( | int | ) | const |
if isConst returns toDouble(inputDef(i)), else Udf
|
inline |
float Math::Formula::getValue | ( | const float * | , |
bool | internal_units = true |
||
) | const |
double Math::Formula::getValue | ( | const double * | , |
bool | internal_units = true |
||
) | const |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
int Math::Formula::nrConsts | ( | ) | const |
int Math::Formula::nrExternalInputs | ( | ) | const |
|
inline |
int Math::Formula::nrValues2Provide | ( | ) | const |
|
inline |
|
inline |
void Math::Formula::setInputDef | ( | int | , |
const char * | |||
) |
void Math::Formula::setInputUnit | ( | int | , |
const UnitOfMeasure * | |||
) |
|
inline |
void Math::Formula::setText | ( | const char * | ) |
|
inline |
|
inlinestatic |
|
inlinestatic |
|
inlinestatic |
int Math::Formula::specIdx | ( | int | ) | const |
|
inline |
void Math::Formula::startNewSeries | ( | ) | const |
|
inline |
void Math::Formula::usePar | ( | const IOPar & | ) |
const char* Math::Formula::userDispText | ( | ) | const |
|
inline |
|
protected |
|
mutableprotected |
|
protected |
|
protected |
|
protected |
|
protected |
|
mutableprotected |
|
protected |
|
protected |
|
protected |
|
protected |
|
protected |
Generated at for the OpendTect seismic interpretation project. Copyright (C): dGB Beheer B. V. 2019