tardis.util.base module

exception tardis.util.base.MalformedElementSymbolError(malformed_element_symbol)[source]

Bases: MalformedError

exception tardis.util.base.MalformedError[source]

Bases: Exception

exception tardis.util.base.MalformedQuantityError(malformed_quantity_string)[source]

Bases: MalformedError

exception tardis.util.base.MalformedSpeciesError(malformed_element_symbol)[source]

Bases: MalformedError

tardis.util.base.atomic_number2element_symbol(atomic_number)[source]

Convert atomic number to string

Parameters
atomic_numberint

Inputted atomic number

Returns
str

Returned corresponding element symbol

tardis.util.base.calculate_luminosity(spec_fname, distance, wavelength_column=0, wavelength_unit=Unit('Angstrom'), flux_column=1, flux_unit=Unit('erg / (Angstrom cm2 s)'))[source]

Calculates luminosity of star.

Parameters
spec_fnamefile or str

File or file name to be read

distancefloat

Distance to star

wavelength_columnint, optional(default = 0)

Column index in which the wavelength is stored

wavelength_unitfloat, optional(default = u.angstrom)

Dictates units used for calculating wavelength.

flux_columnint, optional(default = 1)

Column index in which the flux is stored

flux_unitstr, optional(default = u.Unit(‘erg / (Angstrom cm2 s)’)

Dictates units used for flux

Returns
luminosity.valuefloat

Returned luminosity value of star.

wavelength.min()float

Minimum value of wavelength of light

wavelength.max()float

Maximum value of wavelength of light

tardis.util.base.convert_abundances_format(fname, delimiter='\\s+')[source]

Changes format of file containing abundances into data frame

Parameters
fnamefile, str

File or file name that contains abundance info

delimiterstr, optional(default = ‘s+’)

Determines the separator for splitting file

Returns
DataFrame

Corresponding data frame

tardis.util.base.create_synpp_yaml(radial1d_mdl, fname, shell_no=0, lines_db=None)[source]

Create a yaml file that is readable from syn++

Parameters
radial1d_mdlRadial1DModel

Inputted object that will be read into YAML file

fnamestr

File name for the synpp yaml

shell_noint, optional(default = 0)

Number of shells

lines_dbfile, optional(default = None)
Raises
ValueError

If the current dataset does not contain necessary reference files

tardis.util.base.element_symbol2atomic_number(element_string)[source]

Takes an element symbol and returns its corresponding atomic number

Parameters
element_stringstr

Inputted element symbol

Returns
int

Returned atomic number

tardis.util.base.fix_bar_layout(bar, no_of_packets=None, total_iterations=None)[source]

Fix the layout of progress bars.

Parameters
bartqdm instance

Progress bar to change the layout of.

no_of_packetsint, optional

Number of packets to be propagated.

total_iterationsint, optional

Total number of iterations.

tardis.util.base.int_to_roman(i)[source]

Convert an integer into its roman numeral representation.

Parameters
iint

Integer to be converted into roman numerals

Returns
str

Returns roman numeral representation of i in str format.

tardis.util.base.intensity_black_body(nu, T)[source]

Calculate the intensity of a black-body according to the following formula

\[I(\nu, T) = \frac{2h\nu^3}{c^2}\frac{1} {e^{h\nu \beta_\textrm{rad}} - 1}\]
Parameters
nufloat

Frequency of light

Tfloat

Temperature in kelvin

Returns
Intensityfloat

Returns the intensity of the black body

tardis.util.base.is_notebook()[source]

Checking the shell environment where the simulation is run is Jupyter based

Returns
Trueif the shell environment is IPython Based
Falseif the shell environment is Terminal or anything else
tardis.util.base.is_valid_nuclide_or_elem(input_nuclide)[source]

Parses nuclide string into symbol - mass number format and returns whether the nuclide is either contained in the decay dataset or is a raw element string.

Parameters
input_nuclidestr or int

Nuclide name string or element string.

Returns
bool

Bool indicating if the input nuclide is contained in the decay dataset or is a valid element.

tardis.util.base.parse_quantity(quantity_string)[source]

Changes a string into it’s corresponding astropy.Quantity object.

Parameters
quantity_stringstr

String to be converted into astropy.Quantity

Returns
qu.Quantity

Corresponding astropy.Quantity object for passed string

Raises
MalformedQuantityError

If string is not properly formatted for Astropy Quantity

tardis.util.base.quantity_linspace(start, stop, num, **kwargs)[source]

Essentially the same input parameters as linspace, but calculated for an astropy quantity start and stop.

Parameters
startastropy.Quantity

Starting value of the sequence

stopastropy.Quantity

End value of the sequence

numint

Number of samples to generate

Returns
astropy.Quantity

Returns num evenly spaced characters of type astropy.Quantity

Raises
ValueError

If start and stop values have no unit attribute.

tardis.util.base.reformat_element_symbol(element_string)[source]
Reformat the string so the first letter is uppercase and all subsequent

letters lowercase.

Parameters
element_stringstr

Inputted element symbol

Returns
str

Returned reformatted element symbol

tardis.util.base.roman_to_int(roman_string)[source]

Convert a roman numeral into its corresponding integer.

Parameters
roman_stringstr

Roman numeral to be converted into an integer

Returns
int

Returns integer representation of roman_string

tardis.util.base.species_string_to_tuple(species_string)[source]

Convert a species string to its corresponding tuple representation

Parameters
species_stringstr

String containing species symbol (e.g. Si II, Fe III)

Returns
atomic_number, ion_numbertuple

Returns tuple of length 2 indicating atomic number and ion number

Raises
MalformedSpeciesError

If the inputted string does not match the species format

tardis.util.base.species_tuple_to_string(species_tuple, roman_numerals=True)[source]

Convert a species tuple to its corresponding string representation.

Parameters
species_tupletuple

Tuple of 2 values indicated atomic number and number of electrons missing

roman_numeralsbool, optional(default = TRUE)

Indicates whether the returned ion number is in roman numerals

Returns
element_symbol, roman_ion_numberstr

Returns corresponding string representation of given tuple

tardis.util.base.update_iterations_pbar(i)[source]

Update progress bar for each iteration.

Parameters
iint

Amount by which the progress bar needs to be updated.

tardis.util.base.update_packet_pbar(i, current_iteration, no_of_packets, total_iterations)[source]

Update progress bars as each packet is propagated.

Parameters
iint

Amount by which the progress bar needs to be updated.

current_iterationint

Current iteration number.

no_of_packetsint

Total number of packets in one iteration.

total_iterationsint

Total number of iterations.