# 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 keySet 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)
- 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
## 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.