This page was created by the IDL library routine 
mk_html_help2.
Last modified: Wed Feb 19 18:16:43 2025.
FUNCTION EXPONENTIAL USAGE: y = exponential(x,par=p)
(See general/tools/fitting/exponential.pro)
 NAME:
       FIT
 PURPOSE:
       Non-linear least squares fit to a user defined function.
       This procedure is an improved version of CURVEFIT that allows fitting
       to a subset of the function parameters.
       The function may be any non-linear function.
       If available, partial derivatives can be calculated by
       the user function, else this routine will estimate partial derivatives
       with a forward difference approximation.
 CATEGORY:
       E2 - Curve and Surface Fitting.
 CALLING SEQUENCE:
       FIT,X, Y, PARAMETERS=par, NAMES=string, $
             FUNCTION_NAME=string, ITMAX=ITMAX, ITER=ITER, TOL=TOL, $
             /NODERIVATIVE
 INPUTS:
       X:  A row vector of independent variables.  The FIT routine does
     not manipulate or use X, it simply passes X
     to the user-written function.
       Y:  A row vector containing the dependent variable.
 KEYWORD INPUTS:
       FUNCTION_NAME:  The name of the function to fit.
          If omitted, "FUNC" is used. The procedure must be written as
          described under RESTRICTIONS, below.
       PARAMETERS:  A structure containing the starting parameter values
          for the function.  Final values are also passed back through
          this variable.  The fitting function must accept this keyword.
          If omitted, this structure is obtained from the user defined
          function.
       NAMES: The parameters to be fit.  Several options exist:
          A string with parameter names delimited by spaces.
          A string array specifying which parameters to fit.
          An integer array corresponding to elements within the PARAMETERS structure.
          If undefined, then FIT will attemp to fit to all double precision
          elements of the PARAMETERS structure.
       WEIGHT:   A row vector of weights, the same length as Y.
          For no weighting,
            w(i) = 1.0.
          For instrumental weighting,
            w(i) = 1.0/y(i), etc.
          if not set then w is set to all one's  (equal weighting)
       DY:  A row vector of errors in Y.  If set, then WEIGHTS are set to:
               W = 1/DY^2 and previous values of the WEIGHTS are replaced.
       ERROR_FACTOR: set this keyword to have DY set to ERROR_FACTOR * Y.
       ITMAX:  Maximum number of iterations. Default = 20.
       TOL:    The convergence tolerance. The routine returns when the
               relative decrease in chi-squared is less than TOL in an
               interation. Default = 1.e-5.
       NODERIVATIVE:  (optional)
            If set to 1 then the partial derivatives will be estimated in CURVEFIT using
               forward differences.
            If set to 0 then the user function is forced to provide
               partial derivatives.
            If not provided then partial derivatives will be determined
               from the user function only if it has the proper keyword
               arguments.
       VERBOSE: Verbose level (0: prints only errors, 1: prints results, 2: prints each iteration)
              (see "DPRINT" for more info)
       MAXPRINT: Maximum number of parameters to display while iterating
               (Default is 8)
       SILENT:  Equivalent to VERBOSE=0
 KEYWORD OUTPUTS:
       ITER:   The actual number of iterations which were performed.
       CHI2:   The value of chi-squared on exit.
       FULLNAMES:  A string array containing the parameter names.
       P_VALUES:  A vector with same dimensions as FULLNAMES, that
           contains the final values for each parameter.  These values
           will be the same as the values returned in PARAMETERS.
       P_SIGMA:  A vector containing the estimated uncertainties in P_VALUES.
       FITVALUES:  The fitted function values:
 OUTPUT
       Returns a vector of calculated values.
 COMMON BLOCKS:
       NONE.
 RESTRICTIONS:
       The function to be fit must be defined and called FUNC,
       unless the FUNCTION_NAME keyword is supplied.  This function,
       must accept values of X (the independent variable), the keyword
       PARAMETERS, and return F (the function's value at X).
       if the NODERIV keyword is not set. then the function must also accept
       the keywords: P_NAMES and PDER (a 2d array of partial derivatives).
       For an example, see "GAUSS2".
   The calling sequence is:
       CASE 1:    (NODERIV is set)
          F = FUNC(X,PAR=par)               ; if NODERIV is set  or:
             where:
          X = Variable passed into function.  It is the job of the user-written
             function to interpret this variable. FIT does NOT use X.
          PAR = structure containing function parameters, input.
          F = Vector of NPOINT values of function, y(i) = funct(x), output.
       CASE 2:     (NODERIV is not set)
          F = FUNC(X,PAR=par,NAMES=names,PDER=pder)
             where:
          NAMES = string array of parameters to be fit.
          PDER = Array, (NPOINT, NTERMS), of partial derivatives of FUNC.
             PDER(I,J) = Derivative of function at ith point with
             respect to jth parameter.  Optional output parameter.
             PDER should not be calculated if P_NAMES is not
             supplied in call. If the /NODERIVATIVE keyword is set in the
             call to FIT then the user routine will never need to
             calculate PDER.
 PROCEDURE:
       Adapted from "CURVEFIT", least squares fit to a non-linear
       function, pages 237-239, Bevington, Data Reduction and Error
       Analysis for the Physical Sciences.
       "This method is the Gradient-expansion algorithm which
       combines the best features of the gradient search with
       the method of linearizing the fitting function."
       Iterations are performed until the chi square changes by
       only TOL or until ITMAX iterations have been performed.
       The initial guess of the parameter values should be
       as close to the actual values as possible or the solution
       may not converge.
EXAMPLE:  Fit to a gaussian plus a quadratic background:
  Here is the user-written procedure to return F(x) and the partials, given x:
See the function "GAUSSIAN" for an example function to fit to.
x=findgen(10)-4.5                          ; Initialize independent variables.
y=[1.7,1.9,2.1,2.7,4.6,5.5,4.4,1.7,0.5,0.3]; Initialize dependent variables.
plot,x,y,psym=4                            ; Plot data.
xv = findgen(100)/10.-5.                   ; get better resolution abscissa.
oplot,xv,gaussian(xv,par=p)                ; Plot initial guess.
help,p,/structure                          ; Display initial guess.
fit,x,y,func='gaussian',par=p,fit=f        ; Fit to all parameters.
oplot,x,f,psym=1                           ; Use '+' to plot fitted values.
oplot,xv,gaussian(xv,par=p)                ; Plot fitted function.
help,p,/structure                          ; Display new parameter values.
names =tag_names(p)                        ; Obtain parameter names.
p.a2 = 0                                   ; set quadratic term to 0.
names = names([0,1,2,3,4])                 ; Choose a subset of parameters.
print,names                                ; Display subset of names
fit,x,y,func='gaussian',par=p,names=names  ; Fit to subset.
   Please Note:  Typically the initial guess for parameters must be reasonably
   good, otherwise the routine will not converge.  In this example the data
   was selected so that the default parameters would converge.
The following functions can be used with FIT:
   "gaussian", "polycurve", "power_law", "exponential", "gauss2", "igauss"
KNOWN BUGS:
   Do NOT trust the P_SIGMA Values (uncertainty in the parameters) if the
   the value of flambda gets large. I believe
   That some error (relating to flambda) was carried over from CURVEFIT. -Davin
MODIFICATION HISTORY:
       Function adapted from CURVEFIT Written, DMS, RSI, September, 1982
       and last modified by Mark Rivers, U. of Chicago, Febuary 12, 1995.
       Davin Larson, U of California, November 1995, MAJOR MODIFICATIONS:
           - Changed FUNCTION_NAME to a function (instead of procedure) that
             accepts a structure to hold the parameters.  This makes the usage
             much more user friendly, and allows a subset of parameters to
             be fit.
           - Allowed vectors and recursively searched structures to be fit as well.
           
 $LastChangedBy: davin-mac $
 $LastChangedDate: 2022-06-29 16:35:37 -0700 (Wed, 29 Jun 2022) $
 $LastChangedRevision: 30892 $
 $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/tools/fitting/fit.pro $
           
           
(See general/tools/fitting/fit.pro)
Crib sheet to show how to use fit routine.
(See general/tools/fitting/fit_crib.pro)
FUNCTION:  GAUSS
PURPOSE:
  Evaluates a gaussian function with background.
  This function may be used with the "fit" curve fitting procedure.
KEYWORDS:
  PARAMETERS: structure with the format:
** Structure <275ac0>, 6 tags, length=48, refs=1:
   H               DOUBLE           1.0000000      ; hieght
   W               DOUBLE           1.0000000      ; width
   X0              DOUBLE           0.0000000      ; center
   A0              DOUBLE           0.0000000
   A1              DOUBLE           0.0000000
   A2              DOUBLE           0.0000000
     If this parameter is not a structure then it will be created.
USAGE:
  p={h:2.,w:1.5,x0:5.0,a0:0.,a1:0.,a2:0.}
  x = findgen(100)/10.
  y = gaussian(x,par=p)
  plot,x,y
RETURNS:
  p.a2*x^2 + p.a1*x + p.a0 + p.h * exp( - ((x-p.x0)/2/p.w)^2 )
(See general/tools/fitting/gauss.pro)
FUNCTION:  GAUSS
PURPOSE:
  Evaluates a gaussian function with background.
  This function may be used with the "fit" curve fitting procedure.
KEYWORDS:
  PARAMETERS: structure with the format:
** Structure <275ac0>, 6 tags, length=48, refs=1:
   a               DOUBLE           1.0000000      ; area
   s               DOUBLE           1.0000000      ; sigma
   X0              DOUBLE           0.0000000      ; center
     If this parameter is not a structure then it will be created.
USAGE:
  x = findgen(100)/10.
  y = gaussian(x,par=p)
  plot,x,y
RETURNS:
  result
(See general/tools/fitting/gauss2.pro)
FUNCTION:  GAUSSIAN
PURPOSE:
  Evaluates a gaussian function with background.
  This function may be used with the "fitfunc" curve fitting function.
KEYWORDS:
  PARAMETERS: structure with the format:
** Structure <275ac0>, 6 tags, length=48, refs=1:
   H               DOUBLE           1.0000000      ; hieght
   W               DOUBLE           1.0000000      ; width
   X0              DOUBLE           0.0000000      ; center
   A0              DOUBLE           0.0000000
   A1              DOUBLE           0.0000000
   A2              DOUBLE           0.0000000
     If this parameter is not a structure then it will be created.
  P_NAMES:      string array  (see "fitfunc" for details)
  PDER_VALUES:  named variable in which partial derivatives are returned.
USAGE:
  p={h:2.,w:1.5,x0:5.0,a0:0.,a1:0.,a2:0.}
  x = findgen(100)/10.
  y = gaussian(x,par=p)
  plot,x,y
RETURNS:
  p.a2*x^2 + p.a1*x + p.a0 + p.h * exp( - ((x-p.x0)/p.w)^2 )
(See general/tools/fitting/gaussian.pro)
FUNCTION:  MGAUSS
PURPOSE:
  Evaluates multiple gaussian function with background.
  This function may be used with the "fit" curve fitting procedure.
KEYWORDS:
  PARAMETERS: a structure that contain the parameters that define the gaussians
     If this parameter is not a structure then it will be created.
USAGE:
  par = mgauss( numg =4 ) ; get parameter structure with 4 gaussian peaks
  x = findgen(100)/10.
  y = mgauss(x,param = par)
  plot,x,y
RETURNS:
  result
Written by: Davin Larson
 $LastChangedBy: davin-mac $
 $LastChangedDate: 2023-03-13 02:11:23 -0700 (Mon, 13 Mar 2023) $
 $LastChangedRevision: 31620 $
 $URL: svn+ssh://thmsvn@ambrosia.ssl.berkeley.edu/repos/spdsoft/trunk/general/tools/fitting/mgauss.pro $
(See general/tools/fitting/mgauss.pro)
FUNCTION polycurve(x,par=p) PURPOSE: Evaluates a (5th degree) polynomial (can be used with "FIT")
(See general/tools/fitting/polycurve.pro)
FUNCTION polycurve2(x,par=p) PURPOSE: Evaluates a (Nth degree) polynomial (can be used with "FIT")
(See general/tools/fitting/polycurve2.pro)
FUNCTION power_law(x,par=p) PURPOSE: Evaluates a power law function (with background) (can be used with "FIT")
(See general/tools/fitting/power_law.pro)
FUNCTION splfunc USAGE: p = splfunc(x_old,y_old,/set) y = splfunc(x_new,param=p)
(See general/tools/fitting/splfunc.pro)
FUNCTION splinef USAGE: y_new = spline_fit3(x_new,x_old,y_old)
(See general/tools/fitting/spline_fit3.pro)