Skip to main content

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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pycfit-1.0.1.tar.gz (87.0 MB view details)

Uploaded Source

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

Hashes for pycfit-1.0.1.tar.gz
Algorithm Hash digest
SHA256 992737ca62de6ddf3ca9322e7a07b9dcc50b6470433efd03bcd2459bf2f189d3
MD5 c3e7e95f0aabe5a34f0721b4243bf1e7
BLAKE2b-256 c9a8fc857046f606fff19e14e8cd512d49b8d9ee1af171caee0bdee09632f04e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page