Toolkit for fitting and manipulating spectroscopic data in python
Project description
This is a code framework designed to allow for analysis of spectroscopic data from a wide variety of astronomical instruments. It is motivated by the lack of general spectroscopic analysis tools applicable at multiple wavelengths (compare to IRAF, SPLAT, etc. - these are wavelength-specific and/or do not make user scripting easy).
Initial implementation focuses on optical and radio applications, e.g. gaussian and voigt profile fitting, baseline/continuum fitting, and equivalent width measurements. However, the design is meant to be extensible. We want additional features to be trivial to implement.
In that vein, there is a growing set of spectral models implemented. The model and hyperfinemodel classes makes model implementation quite straightforward, if not trivial (you still have to plug in the right frequency offsets and relative line strengths).
Plotting is straightforward, as is usually the case with matplotlib-based codes. We have a few different methods of error bar plotting implemented, a decent (and expanding) units class for pretty printing of spectroscopic units, and different methods of fit plotting.
We’re also looking for more users to give us more use cases! Contact us at pyspeckit@gmail.com
Requirements: matplotlib numpy
Preferably at least one of: pyfits atpy asciitable
Optional: scipy
A good model for our code is atpy, from which we derived inspiration for the “register functions” capability.
Authors: Adam Ginsburg Jordan Mirocha (or both of us at pyspeckit@gmail.com)
The PySpecKit logo uses the Voyager 1 image of Earth known as the “Pale Blue Dot” [ original source | reprocessed image ]
CHANGES
Release 0.1.7
Added cross-correlation
Added (some) unit tests
New interactive slider widget for manipulating models (Spectrum.specfit.add_sliders())
Subtle but very significant bug-fix: parinfo is now a single uniform list, based on the ParinfoList class.
You can now fit based on what you see by using the ‘use_window_limits=True’ kwarg .. warning:: This changes the default behavior in interactive mode!
lmfit-py can now be used for fitting via the ‘use_lmfit’ kwarg
BUGFIX: SpectroscopicAxis can be converted between units even when scalar
velocity frames are read from FITS headers following the VELDEF conventions
Release 0.1.6
H2CO fit / plot wrapper
bugfixes
setup.py no longer tries to write config files
Release 0.1.5
Added GBT (GBTIDL SDFITS file) and ALFALFA (ALFALFA idlsave .src) readers
added extinction model (just a function, not a complete model yet)
Release 0.1.4
removed setuptools & distribute (they fail)
added hydrogen.py to models
first release to inherit from astropy’s Spectrum1D
Release 0.1.3
some internal cleanup / refactoring
override slicing (__getitem__ features)
parallel moment & fitting in Cubes repaired
Release 0.1.2
added MIT license, moved mpfit and parallel_map inside pyspeckit as
submodules
Release 0.1.1
bugfixes and versioning work
Release 0.1.0
Initial creation
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 pyspeckit-0.1.7.tar.gz
.
File metadata
- Download URL: pyspeckit-0.1.7.tar.gz
- Upload date:
- Size: 204.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d16634dac4f6d9e125954a95ecdffcaf164a73201006cef07f5e4f6ba6726a50 |
|
MD5 | 94f7490a5f7dd05dc5b1036213de108e |
|
BLAKE2b-256 | cb42649bb0b68ce4429bae1676a636387fc1fb8f7d2f221217f1c2df3cbc5a13 |