Source code for species.data.spec_data.spec_kesseli2017
"""
Module for adding O5 through L3 SDSS stellar spectra from
Kesseli et al. (2017) to the database.
"""
from pathlib import Path
import h5py
import numpy as np
import pooch
from astropy.io import fits
from beartype import beartype
from species.util.data_util import extract_tarfile, remove_directory
[docs]
@beartype
def add_kesseli2017(input_path: str, database: h5py._hl.files.File) -> None:
"""
Function for adding the SDSS stellar spectra from
Kesseli et al. (2017) to the database.
Parameters
----------
input_path : str
Path of the data folder.
database : h5py._hl.files.File
The HDF5 database.
Returns
-------
NoneType
None
"""
url = "https://cdsarc.u-strasbg.fr/viz-bin/nph-Cat/tar.gz?J/ApJS/230/16"
input_file = "J_ApJS_230_16.tar.gz"
data_file = Path(input_path) / input_file
data_folder = Path(input_path) / "kesseli+2017/"
if not data_file.exists():
print()
pooch.retrieve(
url=url,
known_hash=None,
fname=input_file,
path=input_path,
progressbar=True,
)
if data_folder.exists():
remove_directory(data_folder)
print(
"\nUnpacking SDSS spectra from Kesseli et al. 2017 (145 MB)...",
end="",
flush=True,
)
extract_tarfile(str(data_file), str(data_folder))
print(" [DONE]")
fits_folder = Path(data_folder) / "fits"
print_message = ""
print()
spec_files = sorted(fits_folder.glob("*"))
for file_item in spec_files:
data = fits.getdata(file_item, ext=1)
wavelength = 1e-4 * 10.0 ** data["LogLam"] # (um)
flux = data["Flux"] # Normalized units
error = data["PropErr"] # Normalized units
name = file_item.stem.replace("_", " ")
file_split = file_item.stem.split("_")
sptype = file_split[0].split(".")[0]
spdata = np.column_stack([wavelength, flux, error])
empty_message = len(print_message) * " "
print(f"\r{empty_message}", end="")
print_message = f"Adding spectra... {name}"
print(f"\r{print_message}", end="")
dset = database.create_dataset(f"spectra/kesseli+2017/{name}", data=spdata)
dset.attrs["name"] = str(name).encode()
dset.attrs["sptype"] = str(sptype).encode()
empty_message = len(print_message) * " "
print(f"\r{empty_message}", end="")
print_message = "Adding spectra... [DONE]"
print(f"\r{print_message}")