Skip to content
forked from aburgasser/splat

SpeX Prism Spectral Analysis Toolkit

License

Notifications You must be signed in to change notification settings

m-samland/splat

 
 

Repository files navigation

# SPLAT: The SpeX Prism Library Analysis Toolkit

## Preamble

SPLAT is a python package built upon numpy, scipy, astropy and matplotlib, as well as some other common packages. SPLAT is designed to interface specifically with the SpeX Prism Library (SPL: http://www.browndwarfs.org/spexprism), an online repository of over 1500 low-resolution, near-infrared spectra of low-temperature stars and brown dwarfs. SPLAT tools allow you to search the library; read in spectra from it; perform basic spectral analyses such as classification, index measurement and spectrophotometry; perform advanced analyses such as spectral model fitting and spectral binary analysis; and plot/tabulate your results.

## Installation and Dependencies

SPLAT is best forked from this github site, which is updated on a semi-regular basis. SPLAT has not yet reached v1.0, so bugs are rampant. Please help us knock them down by sending bug reports to [email protected] or noting them on the github page ("Issues")

Documentation on setting up and using SPLAT are maintained at http://www.browndwarfs.org/splat

There are two additional steps to complete to get full functionality:

  • Copy the file .splat_access into your home directory - this is your access key

  • Set up your environment variables to find the SPLAT code; this can be done in three ways (in the order of which the code looks for this directory):

    • Best: create an environment variable called SPLAT_PATH and set it to the root directory of the SPLAT code (in bsh environment, add the line export SPLAT_PATH=/Users/adam/projects/splat to your .bashrc or .bash_profile)
    • If you use the PYTHONPATH environment variable, add the root directory of the SPLAT code to it (in bsh environment add the line export PYTHONPATH=/Users/adam/projects/splat:${PYTHONPATH} to your .bashrc or .bash_profile)
    • add the root directory of the SPLAT code to your system PATH variable (in bsh environment add the line export PATH=/Users/adam/projects/splat:${PATH} to your .bashrc or .bash_profile)

## Using SPLAT

The best place to start is the code documentation, housed at http://www.browndwarfs.org/splat

Here are some examples:

  • The best way to read in a spectrum is to use getSpectrum:

` import splat splist = splat.getSpectrum(shortname='0415-0935') splist = splat.getSpectrum(young=True) splist = splat.getSpectrum(spt=['M7','L5'],jmag=[14.,99.]) `

In each case, splist is a list of Spectrum objects, which is a container of various aspects of the spectrum and it source. For example, selecting the first spectrum,

` sp = splist[0] `

sp.wave gives the wavelength values of this spectrum, sp.flux the flux values, and sp.noise the flux uncertainty.

You can also read in your own spectrum by passing the Spectrum object a filename:

` sp = splat.pectrum(filename='myspectrum.fits',local=True) `

Note that this file must conform to the standard of the SPL data: the first column is wavelength in microns, second column flux in f_lambda units, third column (optional) is flux uncertainty.

  • To flux calibrate the spectrum, use the object's built in fluxCalibrate() method:

` sp = splat.getSpectrum(shortname='0415-0935')[0] sp.fluxCalibrate('2MASS J',14.0) `

  • To display the spectrum, use the Spectrum object's plot function or plotSpectrum

` sp.plot() splat.plotSpectrum(sp) `

which will pop up a window displaying flux and noise vs. wavelength. You can save this display by adding a filename:

` splat.plotSpectrum(sp,file='spectrum.png') `

You can also compare multiple spectra:

` sp1 = splat.getSpectrum(shortname='0415-0935')[0] sp2 = splat.getSpectrum(shortname='1217-0311')[1] splat.plotSpectrum(sp1,sp2,colors=['k','r']) `

  • To measure spectral indices, use measureIndex or measureIndexSet:

` sp = splat.getSpectrum(shortname='0415-0935')[0] value, error = splat.measureIndex(sp,[1.14,1.165],[1.21,1.235],method='integrate') indices = splat.measureIndexSet(sp,set='burgasser') `

Note that the latter is a dictionary, whose value,error pair can be accessed by the name of the index:

` print indices['H2O-J'] # returns value, error `

  • To classify a spectrum, use the classifyByXXX methods:

` sp = splat.getSpectrum(shortname='0415-0935')[0] spt,unc = splat.classifyByIndex(sp,set='burgasser') spt,unc = splat.classifyByStandard(sp) spt,unc = splat.classifyByTemplate(sp,spt=['M7','L0']) `

  • To compare a spectrum to another spectrum or a model, use compareSpectra:

` sp = splat.getSpectrum(shortname='0415-0935')[0] mdl = splat.loadModel(teff=700,logg=5.0,set='BTSettl2008') # currently BTSettl08 only chi,scale = splat.compareSpectra(sp,mdl) mdl.scale(scale) splat.plotSpectrum(sp,mdl,colors=['k','r']) `

There is a prototype MCMC fitting program that can determine the best fitting model to a spectrum as well

` sp = splat.getSpectrum(shortname='0415-0935')[0] table = splat.modelFitMCMC(sp,initial_guess=[800,5.0,0.],nsamples=1000,step_sizes=[50.,0.5,0.]) `

All of these routines have many options worth exploring, and we are continually adding additional functionality. If there are capabilities you need, please suggest them, or even better contribute your own code!

## Authors

SPLAT is an experimental, collaborative project of research students in Adam Burgasser's UCSD Cool Star Lab, aimed at teaching students how to do research by building their own analysis tools. Contributors to SPLAT include Christian Aganze, Daniella Bardalez Gagliuffi, Adam Burgasser (PI), Caleb Choban, Ivanna Escala, Aishwarya Iyer, Yuhui Jin, Mike Lopez, Alex Mendez, Gretel Mercado, Johnny Parra, Maitrayee Sahi, Melisa Tallis, Tomoki Tamiya and Chris Theissen.

About

SpeX Prism Spectral Analysis Toolkit

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TeX 79.2%
  • Python 20.2%
  • HTML 0.6%