Component Fitting package
Project description
Python Component Fitting Tool (pycfit)
Python program to replicate many spectral fitting functions of the CFIT system from SolarSoft IDL.
Installation
pip install pycfit
🛠 Important: MacOS 26 (Tahoe)
If running under MacOS Tahoe - pycfit must be run from within an ipython session using the gui qt magic command for the GUI components to work properly.
E.G.
Start ipython with the qt gui magic in place:
$> ipython --gui=qt
or, from within an ipython session:
In [1]: %gui qt
Use
Use interactive fitter to find an initial model based on an averaged spectra
import pycfit
# Retrieve sample data
wavelength, intensity, uncertainty = pycfit.data.get_example_single_spectrum()
# Call the GUI fitter
model = pycfit.cfit_gui(wavelength, intensity, uncertainty=uncertainty)
If you export your model from within the GUI, you can initialize a new pyCFIT instance with it later
from pathlib import Path
fname = Path('path/to/saved/model.py')
model = pycfit.cfit_gui(wavelength, intensity, uncertainty=uncertainty, function=fname)
Use the interactive viewer to fit each point of the raster to the initial model and adjust or mask individual point fittings as needed
# Retrieve a small-patch of sample data
wavelength, intensity, uncertainty, mask = pycfit.data.get_example_grid_spectra(patch=True)
# Create a Grid fitter, using the previously defined model
myGrid = pycfit.cfit_grid(model, wavelength, intensity,
uncertainty=uncertainty, mask=mask)
# Fit the whole raster
myGrid.fit(maxiter=100) # Astropy fitter keywords like "maxiter" can be passed through
# Inspect and modify the fits at each point
print(myGrid.shape)
myGrid = pycfit.cfit_grid_gui(myGrid)
# Get results
results = myGrid.get_results()
Contacts:
Software Maintenance:
Ayris Narock: ayris.a.narock@nasa.gov
NASA Official:
Therese Kucera: therese.a.kucera@nasa.gov
License
This project is Copyright (c) National Aeronautics and Space Administration and licensed under
the terms of the Apache Software License 2.0 license. This package is based upon
the Openastronomy packaging guide <https://github.com/OpenAstronomy/packaging-guide>_
which is licensed under the BSD 3-clause licence. See the licenses folder for
more information.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file pycfit-1.0.1.tar.gz.
File metadata
- Download URL: pycfit-1.0.1.tar.gz
- Upload date:
- Size: 87.0 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
992737ca62de6ddf3ca9322e7a07b9dcc50b6470433efd03bcd2459bf2f189d3
|
|
| MD5 |
c3e7e95f0aabe5a34f0721b4243bf1e7
|
|
| BLAKE2b-256 |
c9a8fc857046f606fff19e14e8cd512d49b8d9ee1af171caee0bdee09632f04e
|