The Imfit class¶
The core of PyImfit is the Imfit class, which acts as a wrapper around the underlying C++ ModelObject instance. It holds a ModelDescription instance which describes the model to be fit to the data (or just used to generate a model image, if no actual fitting is to be done). In the (usual) case of fitting the model to an image, it also holds the data image, optional PSF images, and parameters that describe the image (A/D gain, etc.).
It also has methods for running a fit and for inspecting the results.
- class pyimfit.fitting.FitResult¶
Represents the result of fitting an image. Constructed by Imfit.getFitResult method.
- solverName¶
Which solver was used (e.g., “LM”, “NM”, “DE”)
- Type:
str
- fitConverged¶
Whether fit converged or not
- Type:
bool
- nIter¶
Number of iterations performed during fit
- Type:
int
- fitStat¶
Final fit-statistic value
- Type:
float
- fitStatReduced¶
Final reduced fit-statistic value
- Type:
float
- aic¶
Final Akaike Information Criterion value
- Type:
float
- bic¶
Final Bayesian Information Criterion value
- Type:
float
- params¶
The best-fit vector of parameter values.
- Type:
ndarray
- paramErrs¶
Cooresponding uncertainties on best-fit parameter values, if L-M fit was done.
- Type:
ndarray
Notes
There may be additional attributes not listed above depending of the specific solver. Since this class is essentially a subclass of dict with attribute accessors, one can see which attributes are available using the keys() method.
- class pyimfit.fitting.Imfit(model_descr: ModelDescription | dict, psf=None, psfNormalization=True, quiet=True, maxThreads=0, chunk_size=10, subsampling=True, zeroPoint=None)¶
The main class for fitting models to images using Imfit. Can also be used to create images based on models.
Due to some library limitations, this object can only fit the model specified in the constructor. If you want to fit several models, you need to create one instance of
Imfit
for each model. On the other hand, one instance can be used to fit the same model to any number of images, or to fit and then create the model image.- AIC¶
- BIC¶
- fitConverged¶
- fitError¶
- fitStatistic¶
- fitTerminated¶
- nIter¶
- nPegged¶
- nValidPixles¶
- numberedParameterNames¶
- parameterErrors¶
- reducedFitStatistic¶
See also
parse_config_file
- property AIC¶
bias-corrected Akaike Information Criterion for the fit.
- Type:
float
- property BIC¶
Bayesian Information Criterion for the fit.
- Type:
float
- computeFitStatistic(newParameters)¶
Returns the fit-statistic value for the specified parameter vector. (Which fit statistic will calculated is set by the loadData() or fit() methods.)
- Parameters:
newParameters (ndarray of float) –
- Returns:
fitStatistic
- Return type:
float
- doFit(solver='LM', ftol=1e-08, verbose=None)¶
Fit the model to previously supplied data image.
- Parameters:
solver (string, optional) –
- One of the following solvers (optimization algorithms) to be used for the fit:
'LM'
: Levenberg-Marquardt.'NM'
: Nelder-Mead Simplex.'DE'
: Differential Evolution.
ftol (float, optional) – fractional tolerance in fit statistic for determining fit convergence
verbose (int or None, optional) – set this to an integer to specify a feedback level for the fit (this overrides the Imfit object’s internal verbosity setting)
- Returns:
result
- Return type:
FitResult object
Examples
TODO: Examples of doFit().
- fit(image, error=None, mask=None, solver='LM', ftol=1e-08, verbose=None, **kwargs)¶
Supply data image (and optionally mask and/or error images) and image info, then fit the model to the data.
- Parameters:
image (2-D numpy array (ndarray or MaskedArray)) – Image to be fitted. Can be a masked array.
error (2-D numpy array, optional) – error/weight image, same shape as
image
. If not set, errors are generated fromimage
. See also the keyword argsuse_poisson_mlr
,use_cash_statistics
, anduse_model_for_errors
.mask (2-D numpy array, optional) – Array containing the masked pixels; must have the same shape as
image
. Pixels set toTrue
are bad by default (see the kwargmask_format
for other options). If not set andimage
is a masked array, then its mask is used. If both masks are present, the final mask is composed by masking any pixel that is masked in either of the input masks.solver (string, optional) –
- One of the following solvers (optimization algorithms) to be used for the fit:
'LM'
: Levenberg-Marquardt.'NM'
: Nelder-Mead Simplex.'DE'
: Differential Evolution.
ftol (float, optional) – fractional tolerance in fit statistic for determining fit convergence
verbose (int or None, optional) – set this to an integer to specify a feedback level for the fit (this overrides the Imfit object’s internal verbosity setting)
keywords. (See loadData() for list of allowed extra) –
- Returns:
result
- Return type:
FitResult object
- property fitConverged¶
indicates whether fit converged.
- Type:
bool
- property fitStatistic¶
the \(\chi^2\), Poisson MLR, or Cash statistic of the fit.
- Type:
float
- property fitTerminated¶
indicates whether fit terminated for any reason.
- Type:
bool
- getFitResult()¶
Returns a summary of the fitting process.
- Returns:
result
- Return type:
FitResult object
- getModelAsDict()¶
Returns current model (including parameter values) as a dict suitable for use with ModelDescription.dict_to_ModelDescription class method.
- Returns:
model_dict
- Return type:
dict
- getModelDescription()¶
- Returns:
model – A copy of the currently fitted model, or a copy of the template model if no fitting has taken place yet.
- Return type:
ModelDescription
- getModelFluxes(newParameters=None)¶
Computes and returns total and individual-function fluxes for the current model and current (or user-supplied) parameter values.
- Parameters:
newParameters (1-D numpy array of float, optional) – vector of parameter values to use in computing model (default is to use current parameter values, e.g., from most rencent fit, instead)
- Returns:
(totalFlux, individualFluxes) – totalFlux = total flux (or magnitude) of model individualFluxes = numpy ndarray of fluxes/magnitudes for each image-function in the model
- Return type:
tuple of (float, ndarray of float)
- getModelImage(shape=None, newParameters=None, includeMask=False)¶
Computes and returns the image described by the currently fitted model, the input model if no fit was performed, or user-supplied parameters.
- Parameters:
shape (tuple, optional) – Shape of the image in (Y, X) = (nRows, nColumns) format. Do NOT supply this if Imfit object’s image shape has already been defined via loadData() or fit() method!
newParameters (1-D numpy array of float, optional) – vector of parameter values to use in computing model (default is to use current parameter values, e.g., from fit)
includeMask (bool, optional) – Specifies whether output should be numpy masked array, if there is a mask image associated with the data image.
- Returns:
image – Image computed from the current model. If a mask is associated with the original data image, then the returned image is a numpy masked array
- Return type:
2-D numpy array
- getModelMagnitudes(newParameters=None, zeroPoint=None)¶
Computes and returns total and individual-function magnitudes for the current model and current (or user-supplied) parameter values.
- Parameters:
newParameters (1-D numpy array of float, optional) – vector of parameter values to use in computing model (default is to use current parameter values, e.g., from most rencent fit, instead)
zeroPoint (float, optional) –
- If present, returned values are magnitudes, computed as
zeroPoint - 2.5*log10(flux)
(default is to use value of object’s zeroPoint property)
- Returns:
(totalMag, individualMags) – totalFlux = total flux (or magnitude) of model individualFluxes = numpy ndarray of fluxes/magnitudes for each image-function in the model
- Return type:
tuple of (float, ndarray of float)
- getParameterErrors()¶
Returns current best-fit model parameter uncertainties (from L-M minimization).
- Returns:
errors – A 1D array containing the Levenberg-Marquardt parameter uncertainties.
- Return type:
ndarray of float
- getParameterLimits()¶
Returns a list containing lower and upper limits for all parameters in the model.
- Returns:
parameterLimits – [(lower_limit, upper_limit)_1, (lower_limit, upper_limit)_2, …]
- Return type:
list of 2-element tuples of float
- getRawParameters()¶
Returns current model parameter values.
- Returns:
raw_params – A 1D array containing all the model parameter values.
- Return type:
ndarray of float
- loadData(image, error=None, mask=None, **kwargs)¶
Supply the underlying ModelObject instance with data image and error model, optionally including error and/or mask images.
- Parameters:
image (2-D numpy array (ndarray or MaskedArray)) – Image to be fitted. Can be a masked array.
error (2-D numpy array, optional) – error/weight image, same shape as
image
. If not set, errors are generated fromimage
. See also the keyword argsuse_poisson_mlr
,use_cash_statistics
, anduse_model_for_errors
.mask (2-D numpy array, optional) – Array containing the masked pixels; must have the same shape as
image
. Pixels set toTrue
are bad by default (see the kwargmask_format
for other options). If not set andimage
is a masked array, then its mask is used. If both masks are present, the final mask is composed by masking any pixel that is masked in either of the input masks.
- Keyword Arguments:
n_combined (integer) – Number of images which were averaged to make final image (if counts are average or median). Default: 1
exp_time (float) – Exposure time in seconds (only if image is in ADU/sec). Default: 1.0
gain (float) – Image gain (e-/ADU). Default: 1.0
read_noise (float) – Image read noise (Gaussian sigma, in e-). Default: 0.0
original_sky (float) – Original sky background (ADUs) which has already been subtracted from image. Default: 0.0
error_type (string) –
- Values in
error
should be interpreted as: 'sigma'
(default).'weight'
.'variance'
.
- Values in
mask_format (string) –
- Values in
mask
should be interpreted as: 'zero_is_good'
(default).'zero_is_bad'
.
- Values in
psf_oversampling_list (list of PsfOversampling) – List of PsfOversampling objects, describing oversampling regions, PSFs, and oversampling scales.
use_poisson_mlr (boolean) – Use Poisson MLR (maximum-likelihood-ratio) statistic instead of chi^2. Takes precedence over
error
,use_model_for_errors`, and ``use_cash_statistics
. Default:False
use_cash_statistics (boolean) – Use Cash statistic instead of chi^2 or Poisson MLR. Takes precedence over
error
anduse_model_for_errors
. Default:False
use_model_for_errors (boolean) – Use model values (instead of data) to estimate errors for chi^2 computation. Takes precedence over
error
. Default:False
- property nIter¶
number of solver iterations during fit.
- Type:
int
- property nPegged¶
number of parameters pegged against limits at end of fit.
- Type:
int
- property nValidPixels¶
number of non-masked pixels in data image.
- Type:
int
- property numberedParameterNames¶
List of parameter names for the current model, annotated by function number. E.g., [“X0_1”, “Y0_1”, “PA_1”, “ell_1”, “I_0_1”, “h_1”, …]
- Type:
list of str
- property parameterErrors¶
estimated parameter errors from fit (L-M solver only)
- Type:
ndarray of float or None
- property reducedFitStatistic¶
the “reduced” \(\chi^2\) or Poisson MLR of the fit.
- Type:
float
- runBootstrap(nIterations, ftol=1e-08, verboseFlag=False, seed=0, getColumnNames=False)¶
Do bootstrap resampling for a model.
- Parameters:
nIterations (int) – How many bootstrap samples to generate and fit
ftol (float, optional) – fractional tolerance in fit statistic for determining fit convergence
verboseFlag (bool, optional) – if True, a progress bar is printed during the boostrap iterations
seed (int, optional) – random number seed (default is to use system clock)
getColumnNames (bool, optional) – if True, then column (parameter) names are returned as well
- Returns:
bootstrapOutput (2-D ndarray of float)
OR
(columnNames, bootstrapOutput) (tuple of (list of str, 2-D ndarray of float))
- saveCurrentModelToFile(filename: str, includeImageOptions=False)¶
Saves the current model description and parameter values to a text file in Imfit-configuration-file format.
- Parameters:
filename (str) – Name for the output file
includeImageOptions (bool, optional) – if True, then image-description options (“GAIN”, etc.) are also written to the output file
- property zeroPoint¶
photometric zero point (used by getModelMagnitudes method).
- Type:
float
- pyimfit.fitting.MakePsfOversampler(psfImage, oversampleScale, regionSpec, psfNormalization=True)¶
Helper function to generate PsfOversampling objects (corrects input psfImage, sets up region string, etc.).
- Parameters:
psfImage (2-D numpy array) – the oversampled PSF image
oversampleScale (int) –
- oversampling scale of psfImage relative to data image: number of PSF-image
pixels per data-image pixel in one dimension (must be >= 1)
regionSpec (sequence of int) – specifies inclusive boundaries of image region to be oversampled [x1,x2,y1,y2]
psfNormalization (bool, optional) – Normalize the PSF image before using. Default:
True
.
- Returns:
oversampleInfo
- Return type:
instance of PsfOversampling class