mxlib
c++ tools for analyzing astronomical data and other tasks by Jared R. Males. [git repo]
|
Class to manage fitting the Exponetially Modified Gaussian Distribution to data via the levmarInterface.
In addition to the requirements on fitterT specified by levmarInterface this class also requires this definition in fitterT
where the number 3 is replaced by the number of parameters that fitterT expects to fit.
fitterT | a type meeting the above requirements. |
Definition at line 65 of file fitExpModGaussian.hpp.
#include <math/fit/fitExpModGaussian.hpp>
Public Member Functions | |
void | setGuess (realT G0, realT mu, realT sigma, realT lambda) |
Set the initial guess. | |
void | setGuess (realT mu, realT sigma, realT lambda) |
Set the initial guess. | |
Public Member Functions inherited from mx::math::fit::levmarInterface< fitterT > | |
levmarInterface () | |
Default constructor. | |
levmarInterface (realT *i_p, realT *i_x, int i_m, int i_n, void *i_adata) | |
Setup constructor. | |
~levmarInterface () | |
Destructor. | |
void | nParams (int i_m) |
Set number of parameters, but don't allocate. | |
int | nParams () |
Get the current number of parameters. | |
void | allocate_params () |
Allocate parameters array based on previous call to nParams. | |
void | allocate_params (int i_m) |
Set number of parameters and allocate. | |
void | point_params (realT *i_p) |
Point the parameter pointer at an externally allocated array. | |
void | point_params (realT *i_p, int i_m) |
Point the parameter pointer at an externally allocated array. | |
void | set_params (realT *i_p) |
Copy parameters to the parameter array. | |
realT * | get_params () |
Get current pointer array address. | |
void | set_itmax (int i_itmax) |
Set the maximum number of iterations. | |
int | get_itmax () |
Get the maximum number of iterations. | |
void | allocate_work () |
Allocate the work and covar matrices. | |
void | set_opts (int n, realT val) |
Set one of the minimization options to val. | |
void | set_opts_default (int n=-1) |
Set one or all of the minimization options to the default. | |
realT | get_opts (int n) |
Get the current value of an option. | |
int | fit () |
Perform the fit. | |
realT | get_initial_norm () |
Returns the L2-norm before minimization occurs. | |
realT | get_final_norm () |
Returns the L2-norm at the end of the minimization. | |
int | get_iterations () |
Get the number of iterations taken during the minimization. | |
int | get_reason_code () |
Get a code specifying the reason minimization terminated. | |
std::string | get_reason_string () |
Get the descriptive string describing the reason minimization terminated. | |
int | get_fevals () |
Get the number of function evaluations during the minimization. | |
int | get_jevals () |
Get the number of jacobian evaluations during the minimization. | |
int | get_nlinsys () |
Get the number of linear system solutions during the minimization. | |
double | get_deltaT () |
Get the elapsed time of the fit. | |
template<typename iosT , char comment = '#'> | |
iosT & | dumpParameters (iosT &ios) |
Output current parameters to a stream. | |
template<char comment = '#'> | |
std::ostream & | dumpParameters () |
Dump the parameter vector to stdout. | |
template<typename iosT , char comment = '#'> | |
iosT & | dumpReport (iosT &ios, bool dumpParams=true) |
Output current parameters to a stream. | |
template<char comment = '#'> | |
std::ostream & | dumpReport (bool dumpParams=true) |
Dump a status report to stdout. | |
Additional Inherited Members | |
Public Attributes inherited from mx::math::fit::levmarInterface< fitterT > | |
realT * | x |
I: measurement vector. NULL implies a zero vector. | |
int | n |
I: measurement vector dimension. | |
realT | opts [LM_OPTS_SZ] |
Options passed to the minimization routines. See set_opts for details. | |
realT | info [LM_INFO_SZ] |
Information regarding the minimization. | |
double | deltaT |
Elapsed time of the fitting procedure. | |
realT * | work |
Working memory passed to the levmar routines. | |
int | work_sz |
The current size of the work array. | |
realT * | covar |
Covariance matrix corresponding to LS solution; mxm. | |
int | covar_sz |
The current size of the covar array. | |
bool | getCovar |
Controls whether the covar array is allocated. | |
void * | adata |
Pointer to possibly additional data, passed uninterpreted to func & jacf. | |
Protected Attributes inherited from mx::math::fit::levmarInterface< fitterT > | |
realT * | p |
Parameter array. On input is the initial estimates. On output has the estimated solution. | |
realT * | init_p |
Parameter array on input, saved for comparison. | |
int | m |
Parameter vector dimension (i.e. number of unknowns) | |
bool | own_p |
Flag indicating whether the p array is owned by this object (for de-allocation). | |
int | itmax |
Maximum number of iterations, default is 100. | |
|
inline |
Set the initial guess.
[in] | G0 | the location parameter |
[in] | mu | the shape parameter |
[in] | sigma | the scale parameter |
[in] | lambda | the denominator or 1/peak-scale |
Definition at line 91 of file fitExpModGaussian.hpp.
References mx::math::fit::levmarInterface< fitterT >::p.
|
inline |
Set the initial guess.
[in] | mu | the location parameter |
[in] | sigma | the shape parameter |
[in] | lambda | the scale parameter |
Definition at line 106 of file fitExpModGaussian.hpp.
References mx::math::fit::levmarInterface< fitterT >::p.