Source code for species.data.isochrone_data.iso_sonora_diamondback

"""
Module with a function for adding the Sonora Diamondback
evolutionary tracks to the database.
"""

from pathlib import Path
from zipfile import ZipFile

import h5py
import numpy as np
import pooch

from beartype import beartype

from species.core import constants


[docs] @beartype def add_sonora_diamondback(database: h5py._hl.files.File, input_path: str) -> None: """ Function for adding the isochrone data of `Sonora Diamondback <https://zenodo.org/records/12735103>`_ to the database. Parameters ---------- database : h5py._hl.files.File Database. input_path : str Folder where the data is located. Returns ------- NoneType None """ url = "https://zenodo.org/records/12735103/files/evolution.zip" input_file = "evolution.zip" data_folder = Path(input_path) / "sonora-diamondback-evolution" data_file = Path(data_folder) / input_file if not data_folder.exists(): data_folder.mkdir() if not data_file.exists(): print() pooch.retrieve( url=url, known_hash="1efb4e5297060fa7b0329dec363e0bfff4f6132d2d11b655281cabea091d78ee", fname=input_file, path=data_folder, progressbar=True, ) print("\nUnpacking Sonora Diamondback evolution (830 kB)...", end="", flush=True) with ZipFile(str(data_file)) as zip_object: zip_object.extractall(path=str(data_folder)) print(" [DONE]") url = "https://zenodo.org/records/12735103/files/photometry.zip" input_file = "photometry.zip" data_file = Path(data_folder) / input_file if not data_file.exists(): print() pooch.retrieve( url=url, known_hash="7210f358c6da317d60a19dffb5b18a398e20a565aebaaa297e521ee9076bbc9c", fname=input_file, path=data_folder, progressbar=True, ) print("\nUnpacking Sonora Diamondback photometry (239 kB)...", end="", flush=True) with ZipFile(str(data_file)) as zip_object: zip_object.extractall(path=str(data_folder)) print(" [DONE]") iso_files = [ "nc_m-0.5_age", "nc_m0.0_age", "nc_m+0.5_age", "hybrid_f2_m-0.5_age", "hybrid_f2_m0.0_age", "hybrid_f2_m+0.5_age", "hybrid-grav_f2_m-0.5_age", "hybrid-grav_f2_m0.0_age", "hybrid-grav_f2_m+0.5_age", ] labels = [ "cloud-free, [M/H] = -0.5", "cloud-free, [M/H] = +0.0", "cloud-free, [M/H] = +0.5", "hybrid, fsed = 2, [M/H] = -0.5", "hybrid, fsed = 2, [M/H] = +0.0", "hybrid, fsed = 2, [M/H] = +0.5", "hybrid-grav, fsed = 2, [M/H] = -0.5", "hybrid-grav, fsed = 2, [M/H] = +0.0", "hybrid-grav, fsed = 2, [M/H] = +0.5", ] iso_tags = [ "nc-0.5", "nc+0.0", "nc+0.5", "hybrid-0.5", "hybrid+0.0", "hybrid+0.5", "hybrid-grav-0.5", "hybrid-grav+0.0", "hybrid-grav+0.5", ] for iso_idx, iso_item in enumerate(iso_files): iso_file = f"evolution/{iso_item}" iso_path = Path(data_folder) / iso_file iso_data = [] with open(str(iso_path), encoding="utf-8") as open_file: for line_idx, line_item in enumerate(open_file): if line_idx == 0 or "Gyr" in line_item: continue # age(Gyr) M/Msun log(L/Lsun) Teff(K) log(g) R/Rjup # The data files have R/Rsun, but should be R/Rjup param = list(filter(None, line_item.strip().split(" "))) param = list(map(float, param)) param[0] = 1e3 * param[0] # (Gyr) -> (Myr) param[1] = ( param[1] * constants.M_SUN / constants.M_JUP ) # (Msun) -> (Mjup) iso_data.append( [param[0], param[1], param[2], param[3], param[4], param[5]] ) print( f"\nAdding isochrones: Sonora {labels[iso_idx]}...", end="", flush=True ) iso_data = np.array(iso_data) dset = database.create_dataset( f"isochrones/sonora-diamondback-{iso_tags[iso_idx]}/age", data=iso_data[:, 0], ) # (Myr) database.create_dataset( f"isochrones/sonora-diamondback-{iso_tags[iso_idx]}/mass", data=iso_data[:, 1], ) # (Mjup) database.create_dataset( f"isochrones/sonora-diamondback-{iso_tags[iso_idx]}/log_lum", data=iso_data[:, 2], ) # log(L/Lsun) database.create_dataset( f"isochrones/sonora-diamondback-{iso_tags[iso_idx]}/teff", data=iso_data[:, 3], ) # (K) database.create_dataset( f"isochrones/sonora-diamondback-{iso_tags[iso_idx]}/log_g", data=iso_data[:, 4], ) # log(g) database.create_dataset( f"isochrones/sonora-diamondback-{iso_tags[iso_idx]}/radius", data=iso_data[:, 5], ) # (Rjup) dset.attrs["model"] = "sonora-diamondback" print(" [DONE]") print(f"Database tag: sonora-diamondback-{iso_tags[iso_idx]}")