| Top |  |  |  |  | 
| gdouble | gwy_nlfit_preset_get_value () | 
| const gchar * | gwy_nlfit_preset_get_formula () | 
| gint | gwy_nlfit_preset_get_nparams () | 
| const gchar * | gwy_nlfit_preset_get_param_name () | 
| GwySIUnit * | gwy_nlfit_preset_get_param_units () | 
| gint | gwy_nlfit_preset_get_param_power_x () | 
| gint | gwy_nlfit_preset_get_param_power_y () | 
| void | gwy_nlfit_preset_guess () | 
| GwyNLFitter * | gwy_nlfit_preset_create_fitter () | 
| GwyNLFitter * | gwy_nlfit_preset_fit () | 
| GwyInventory * | gwy_nlfit_presets () | 
fitting functions, with guessing, weighting, etc. to ease fitting of common functions. Most of those currently implemented are related to one-dimensional statistical characteristics of randomly rough surfaces, however, several general-purpose fitting functions are also available.
The presets are identified by name and can be obtained from the
corresponding GwyInventory, see gwy_nlfit_presets().  All their properties
can be queried with methods such as gwy_nlfit_preset_get_nparams() or
gwy_nlfit_preset_get_formula().  A generic method to derive units of
fitting parameters from units of fitted data is also available:
gwy_nlfit_preset_get_param_units().
The defined functions include:
| "Gaussian" | 
| "Gaussian (PSDF)" | 
| "Gaussian (ACF)" | 
| "Gaussian (HHCF)" | 
| "Gaussian (RPSDF)" | 
| "Exponential" | 
| "Exponential (PSDF)" | 
| "Exponential (ACF)" | 
| "Exponential (HHCF)" | 
| "Exponential (RPSDF)" | 
| "Polynomial (order 0)" | 
| "Polynomial (order 1)" | 
| "Polynomial (order 2)" | 
| "Polynomial (order 3)" | 
| "Square wave" | 
| "Power" | 
| "Lorentzian" | 
| "Sinc" | 
| "Parabolic step" | 
| "Two Gaussians (PSDF)" | 
| "Smooth bent step" | 
| "Smooth slanted step" | 
| "K-correlated (PSDF)" | 
| "Boltzmann bent step" | 
The result of the fitting is stored in a normal GwyNLFitter, therefore the typical use is:
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | GwyNLFitPreset *preset; GwyNLFitter *fitter; gdouble *params, *errors; preset = gwy_inventory_get_item(gwy_nlfit_presets(), "Gaussian"); params = g_new(gdouble, gwy_nlfit_preset_get_nparams(preset)); errors = g_new(gdouble, gwy_nlfit_preset_get_nparams(preset)); /* Use a priori parameter value information, or: */ gwy_nlfit_preset_guess(preset, ndata, xdata, ydata, params, &ok); fitter = gwy_nlfit_preset_fit(preset, NULL, ndata, xdata, ydata, params, params, errors, NULL); /* Examine fitting status, parameters and errors... */ g_free(params); g_free(errors); gwy_math_nlfit_free(fitter); | 
gdouble gwy_nlfit_preset_get_value (GwyNLFitPreset *preset,gdouble x,const gdouble *params,gboolean *fres);
Calculates preset function value in a single point with given parameters.
const gchar *
gwy_nlfit_preset_get_formula (GwyNLFitPreset *preset);
Gets function formula of preset
 (with Pango markup).
gint
gwy_nlfit_preset_get_nparams (GwyNLFitPreset *preset);
Return the number of parameters of preset
.
const gchar * gwy_nlfit_preset_get_param_name (GwyNLFitPreset *preset,gint i);
Gets the name of a fitting parameter of a fitter preset.
The name may contain Pango markup.
GwySIUnit * gwy_nlfit_preset_get_param_units (GwyNLFitPreset *preset,gint i,GwySIUnit *siunit_x,GwySIUnit *siunit_y);
Derives the SI unit of a fitting parameter from the units of abscissa and ordinate.
gint gwy_nlfit_preset_get_param_power_x (GwyNLFitPreset *preset,gint i);
Gets the power of abscissa units in a fitting parameter.
Usually it is easier to let gwy_nlfit_preset_get_param_units() derive the parameter units.
gint gwy_nlfit_preset_get_param_power_y (GwyNLFitPreset *preset,gint i);
Gets the power of ordinate units in a fitting parameter.
Usually it is easier to let gwy_nlfit_preset_get_param_units() derive the parameter units.
void gwy_nlfit_preset_guess (GwyNLFitPreset *preset,gint n_dat,const gdouble *x,const gdouble *y,gdouble *params,gboolean *fres);
Performs initial parameter estimate for a NL fitter.
The initial estimate method depends on the function used. There is no absolute guarantee of quality, however if the data points approximately match the fitted function the fit will typically converge from the returned estimate.
The parameters are filled also on failure, though just with some neutral values that should not give raise to NaNs and infinities.
| preset | A NL fitter function preset. | |
| n_dat | The number of data points (number of items in  | |
| x | Abscissa points. | |
| y | Ordinate points. | |
| params | The array to fill with estimated parameter values.  It has to be
at least  | |
| fres | Set to  | 
GwyNLFitter *
gwy_nlfit_preset_create_fitter (GwyNLFitPreset *preset);
Creates a non-linear least-squares fitter for a preset function.
The created fitter will be of the function data type, as created with
gwy_math_nlfit_new().
If you do not need to modify the fitter settings you can use
gwy_nlfit_preset_fit() directly with NULL fitter.
GwyNLFitter * gwy_nlfit_preset_fit (GwyNLFitPreset *preset,GwyNLFitter *fitter,gint n_dat,const gdouble *x,const gdouble *y,gdouble *params,gdouble *err,const gboolean *fixed_param);
Performs a nonlinear fit with a preset.
See gwy_math_nlfit_fit_full() for details.
| preset | A NL fitter function preset. | |
| fitter | A Marquardt-Levenberg nonlinear fitter already initialized for
 | |
| n_dat | The number of data points (number of items in  | |
| x | Abscissa points. | |
| y | Ordinate points. | |
| params | Initial parameter estimate (the number of parameters depends on
the fitted preset and it can be obtained with
 | |
| err | Array to store parameter errros to, may be  | |
| fixed_param | Which parameters should be treated as fixed (set
corresponding element to  | 
GwyInventory *
gwy_nlfit_presets (void);
Gets inventory with all the NLFit presets.