Isis 3 Programmer Reference
|
Time based linear equation class. More...
#include <Basis1VariableFunction.h>
Public Member Functions | |
Basis1VariableFunction (const QString &name, int numCoefs) | |
Creates a Basis Function with a single variable. | |
virtual | ~Basis1VariableFunction () |
Destroys the Basis1VariableFunction object. | |
virtual double | DerivativeVar (const double value)=0 |
This will take the Derivative with respect to the variable and evaluate at given value. | |
virtual double | DerivativeCoef (const double value, const int coefIndex)=0 |
Evaluate the derivative defined by the given coefficients with respect to the coefficient at the given index, at the current value. | |
void | SetCoefficients (const std::vector< double > &coefs) |
Set the coefficients for the equation. | |
double | Evaluate (const std::vector< double > &vars) |
Compute the equation using the input variables. | |
double | Evaluate (const double &var) |
Compute the equation using the input variable. | |
virtual void | Expand (const std::vector< double > &vars) |
This is the function you should replace depending on your needs. | |
int | Coefficients () const |
Returns the number of coefficients for the equation. | |
int | Variables () const |
Returns the number of variables in the equation. | |
QString | Name () const |
Returns the name of the equation. | |
double | Term (int c) const |
Returns the cth term. | |
double | Coefficient (int i) const |
Returns the ith coefficient. | |
Protected Attributes | |
QString | p_name |
The name of the equation. Call it by using Name() | |
int | p_numVars |
The number of variables in the equation. Call it by using Variables() | |
int | p_numCoefs |
The number of coefficients in the equation. | |
std::vector< double > | p_coefs |
A vector of the coefficients in the equation. | |
std::vector< double > | p_terms |
A vector of the terms in the equation. | |
Time based linear equation class.
This is a class for generating a general one-variable equation for the Isis least squares fitting algorithm (IsisLSQ). It allows the programmer to set up equations in the form of:
\[ x = C1*T1 + C2*T2 + ... + CN*TN; \]
where C1-CN are coefficients and T1-TN are terms with a single variable. For example,
\[ x = C1 + C2*t + C3*t**2 \]
2005-03-16 Leah Dahmer - modified file to support Doxygen documentation.
2008-01-08 Tracie Sucharski - Derived from BasisFunction class for a single variable function. Added Derivative methods as pure virtuals. This class was developed as a convenience to simplify the Derivative methods and any other methods that might need to be developed in the future.
2017-08-30 Summer Stapleton - Updated documentation. References #4807.
Definition at line 50 of file Basis1VariableFunction.h.
Isis::Basis1VariableFunction::Basis1VariableFunction | ( | const QString & | name, |
int | numCoefs ) |
Creates a Basis Function with a single variable.
name | Name of the Basis1VariableFunction. For example, "affine". |
numCoefs | Number of coefficients in the equation. For example: \[ x = C1 + C2 * x + C3 * x**2 \] has three coefficients: C1, C2 & C3. |
Definition at line 25 of file Basis1VariableFunction.cpp.
|
inlinevirtual |
Destroys the Basis1VariableFunction object.
Definition at line 54 of file Basis1VariableFunction.h.
|
inlineinherited |
Returns the ith coefficient.
i | The index for the desired coefficient. |
Definition at line 107 of file BasisFunction.h.
References Isis::BasisFunction::p_coefs.
Referenced by Isis::PolynomialUnivariate::DerivativeVar(), Isis::SurfaceModel::MinMax(), and Isis::OverlapNormalization::Solve().
|
inlineinherited |
Returns the number of coefficients for the equation.
Definition at line 64 of file BasisFunction.h.
References Isis::BasisFunction::p_numCoefs.
Referenced by Isis::PolynomialUnivariate::DerivativeCoef(), Isis::PolynomialUnivariate::DerivativeVar(), Isis::OverlapNormalization::Solve(), Isis::LeastSquares::SolveQRD(), and Isis::LeastSquares::SolveSVD().
|
pure virtual |
Evaluate the derivative defined by the given coefficients with respect to the coefficient at the given index, at the current value.
[in] | value | (const double) value at which to evaluate derivative |
[in] | coefIndex | (const int) The index of the coefficient to differentiate with respect to |
Implemented in Isis::PolynomialUnivariate.
|
pure virtual |
This will take the Derivative with respect to the variable and evaluate at given value.
[in] | value | (const double) value at which to evaluate derivative |
Implemented in Isis::PolynomialUnivariate.
|
inherited |
Compute the equation using the input variable.
var | A single double value to use for the equation. |
Definition at line 101 of file BasisFunction.cpp.
References Isis::BasisFunction::Evaluate().
|
inherited |
Compute the equation using the input variables.
vars | A vector of double values to use for the equation. After setting the coefficients, this can be invoked many times to compute output values given input values. |
Definition at line 64 of file BasisFunction.cpp.
References Isis::BasisFunction::Expand(), Isis::BasisFunction::p_coefs, Isis::BasisFunction::p_numCoefs, Isis::BasisFunction::p_numVars, Isis::BasisFunction::p_terms, Isis::IException::Programmer, and Isis::toString().
Referenced by Isis::BasisFunction::Evaluate(), Isis::LeastSquares::Evaluate(), Isis::LeastSquares::SolveQRD(), and Isis::LeastSquares::SolveSVD().
|
virtualinherited |
This is the function you should replace depending on your needs.
It will expand the variables into the terms of the equation. For example,
\[ x = C1 + C2*y + C3*z + C4*y*z \]
must be expanded into the p_terms vector as (1.0, y, z, y*z). Note that the term expansion is not limited, you can use cos, sin, sqrt, abs, etc. This virtual method is automatically invoked by the Evaluate method. We provide a default expansion of p_terms = vars, just a linear combination of the variables.
vars | A vector of double values to use for the expansion. |
Reimplemented in Isis::NthOrderPolynomial, Isis::PolynomialBivariate, and Isis::PolynomialUnivariate.
Definition at line 123 of file BasisFunction.cpp.
References Isis::BasisFunction::p_terms.
Referenced by Isis::BasisFunction::Evaluate(), Isis::LeastSquares::FillSparseA(), Isis::LeastSquares::SolveQRD(), and Isis::LeastSquares::SolveSVD().
|
inlineinherited |
Returns the name of the equation.
Definition at line 80 of file BasisFunction.h.
References Isis::BasisFunction::p_name.
Referenced by Isis::LeastSquares::AddKnown().
|
inherited |
Set the coefficients for the equation.
coefs | A vector of coefficients for the equation. |
Definition at line 42 of file BasisFunction.cpp.
References Isis::BasisFunction::p_coefs, Isis::BasisFunction::p_numCoefs, Isis::IException::Programmer, and Isis::toString().
Referenced by Isis::SpiceRotation::DCJdt(), Isis::PolynomialUnivariate::PolynomialUnivariate(), Isis::LeastSquares::SolveQRD(), Isis::LeastSquares::SolveSparse(), and Isis::LeastSquares::SolveSVD().
|
inlineinherited |
Returns the cth term.
This is only valid after a Evalute/Expand has been invoked. It represents the expansion of the variables into the ith term. For example,
\[ x = C1 + C2*x + C3*y + C4*x*y \]
would return x*y for the 3rd term (zero-based)
c | The index for the desired coefficient. |
Definition at line 97 of file BasisFunction.h.
References Isis::BasisFunction::p_terms.
Referenced by Isis::LeastSquares::FillSparseA(), Isis::LeastSquares::SolveQRD(), and Isis::LeastSquares::SolveSVD().
|
inlineinherited |
Returns the number of variables in the equation.
Definition at line 72 of file BasisFunction.h.
References Isis::BasisFunction::p_numVars.
Referenced by Isis::LeastSquares::AddKnown(), and Isis::NthOrderPolynomial::Expand().
|
protectedinherited |
A vector of the coefficients in the equation.
Call it by using Coefficient()
Definition at line 123 of file BasisFunction.h.
Referenced by Isis::BasisFunction::Coefficient(), Isis::BasisFunction::Evaluate(), and Isis::BasisFunction::SetCoefficients().
|
protectedinherited |
The name of the equation. Call it by using Name()
Definition at line 113 of file BasisFunction.h.
Referenced by Isis::BasisFunction::BasisFunction(), and Isis::BasisFunction::Name().
|
protectedinherited |
The number of coefficients in the equation.
Call it by using Coefficients()
Definition at line 119 of file BasisFunction.h.
Referenced by Isis::BasisFunction::BasisFunction(), Isis::BasisFunction::Coefficients(), Isis::BasisFunction::Evaluate(), and Isis::BasisFunction::SetCoefficients().
|
protectedinherited |
The number of variables in the equation. Call it by using Variables()
Definition at line 115 of file BasisFunction.h.
Referenced by Isis::BasisFunction::BasisFunction(), Isis::BasisFunction::Evaluate(), and Isis::BasisFunction::Variables().
|
protectedinherited |
A vector of the terms in the equation.
Call it by using Term()
Definition at line 127 of file BasisFunction.h.
Referenced by Isis::BasisFunction::Evaluate(), Isis::BasisFunction::Expand(), Isis::NthOrderPolynomial::Expand(), Isis::PolynomialBivariate::Expand(), Isis::PolynomialUnivariate::Expand(), and Isis::BasisFunction::Term().