Skip to content

jwpetley/CoSpecPy

Repository files navigation

CoSpecPy - SDSS Composites Made Easy

This is a package written for the purpose of creating composite spectra from SDSS data releases.

Future releases will contain additional features for plotting and uncertainty information. Connections to astropy Tables and queries are also a possibility.

Full documentation for this project can be found at https://cospecpy.readthedocs.io/en/latest/

Install Instructions

Requires a Python version later than 3.6.

Install using pip available through:

pip install CoSpecPy

Or alternatively you can clone this GitHub repository, navigate to the directory you have just cloned and run:

python setup.py install

Quick Start

Here are a couple of examples using the early stages of the Composite and DownloadHandler classes. We can create spectra using the example 50 SDSS URLs provided or by specifying the RA and DEC of your targets of interest. Make sure that either wget or aria2 is installed on your machine.

from CoSpecPy import DownloadHandler, Composite # Import the Handler

output_dir = "/path/to/output"

ra = [] # Input you ra values here
dec = [] # Input you dec values here

example_handler = DownloadHandler(download_method = "wget", #Download method (aria2 or wget)
no_of_connections = 1, batch_size="10", #Connections only apply to aria2, batches not implemented
 download_folder=output_dir) # output folder

#Example download with wget
example_handler.download_example()

#This will download the 50 example spectra in CoSpecPy/data/example_speclist.txt to your chosen output

example_composite = Composite(name = "example_composite") #Creation of Composite Class
example_composite.set_wavelength_grid(w_min = 1000, w_max = 3000, steps = 2500) #Add the desired wavelength grid in Angstrom
example_composite.set_normalisation(norm_low = 2575, norm_high = 2625) #Add desired normalisation range in Angstrom
example_composite.composite_from_downloads(output_dir) # Will create the composite
example_composite.plot_composite() # Plots the composite stored in the composite class with bootstrapped uncertainties

# Now rest and create using the ra and dec list
example_composite.reset_composite()
example_composite.composite_from_coords(ra, dec) # Will download SDSS DR14 catalogue if not already present (~750 MB)
example_composite.plot_composite()

Output should look something like this

./example.png

Download Dependencies

The DownloadHandler requires use of either wget or aria2 to download from the SDSS servers.

wget is GNU Wget is a free software package for retrieving files using HTTP, HTTPS, FTP and FTPS. Information and documentation can be found here https://www.gnu.org/software/wget/. For a quick Debian/Ubuntu install try:

sudo apt-get install wget

aria2 is a lightweight multi-protocol & multi-source command-line download utility and can be far faster than wget when used with this package. Information and documentation can be found here https://aria2.github.io/. For a quick Debian/Ubuntu install try:

sudo apt-get install -y aria2

Features Implemented

  • Download of spectra list using either aria2 or wget. aria2 allows for easy opening of multiple connections for a much faster download.

  • Example included with DownloadHandler.download_example()

  • Batch-split downloads given spectra list

  • Spectral composite making from downloads - Options for wavelength grid, normalisation range, uncertainty estimation, plotting

  • Helper functions to go from an astropy.Table through to composite making

Future Features

  • Possible inclusion of SDSS querying to create the fetch information for speclist
  • Long-term, add external features such as redenning estimation

About

SDSS Composite Making Package

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages