tardis.montecarlo.montecarlo_numba.interaction module

tardis.montecarlo.montecarlo_numba.interaction.adiabatic_cooling(r_packet)[source]

Adiabatic cooling - equivalent to destruction of the packet

Parameters
r_packet: tardis.montecarlo.montecarlo_numba.r_packet.RPacket
tardis.montecarlo.montecarlo_numba.interaction.bf_cooling(r_packet, time_explosion, numba_plasma)[source]

Bound-Free Cooling - Determine and run bf emission from cooling

Parameters
r_packettardis.montecarlo.montecarlo_numba.r_packet.RPacket
time_explosionfloat
numba_plasmatardis.montecarlo.montecarlo_numba.numba_interface.NumbaPlasma
tardis.montecarlo.montecarlo_numba.interaction.bound_free_emission(r_packet, time_explosion, numba_plasma, continuum_id)[source]

Bound-Free emission - set the frequency from photo-ionization

Parameters
r_packettardis.montecarlo.montecarlo_numba.r_packet.RPacket
time_explosionfloat
numba_plasmatardis.montecarlo.montecarlo_numba.numba_interface.NumbaPlasma
continuum_idint
tardis.montecarlo.montecarlo_numba.interaction.continuum_event(r_packet, time_explosion, numba_plasma, chi_bf_tot, chi_ff, chi_bf_contributions, current_continua)[source]

continuum event handler - activate the macroatom and run the handler

Parameters
r_packettardis.montecarlo.montecarlo_numba.r_packet.RPacket
time_explosionfloat
numba_plasmatardis.montecarlo.montecarlo_numba.numba_interface.NumbaPlasma
continuumtardis.montecarlo.montecarlo_numba.numba_interface.Continuum
tardis.montecarlo.montecarlo_numba.interaction.determine_bf_macro_activation_idx(numba_plasma, nu, chi_bf_contributions, active_continua)[source]

Determine the macro atom activation level after bound-free absorption.

Parameters
nufloat

Comoving frequency of the r-packet.

chi_bf_contributionsnumpy.ndarray, dtype float

Cumulative distribution of bound-free opacities at frequency nu.

active_continuanumpy.ndarray, dtype int

Continuum ids for which absorption is possible for frequency nu.

Returns
float

Macro atom activation idx.

tardis.montecarlo.montecarlo_numba.interaction.determine_continuum_macro_activation_idx(numba_plasma, nu, chi_bf, chi_ff, chi_bf_contributions, active_continua)[source]

Determine the macro atom activation level after a continuum absorption.

Parameters
nufloat

Comoving frequency of the r-packet.

chi_bfnumpy.ndarray, dtype float

Bound-free opacity.

chi_bfnumpy.ndarray, dtype float

Free-free opacity.

chi_bf_contributionsnumpy.ndarray, dtype float

Cumulative distribution of bound-free opacities at frequency nu.

active_continuanumpy.ndarray, dtype int

Continuum ids for which absorption is possible for frequency nu.

Returns
float

Macro atom activation idx.

tardis.montecarlo.montecarlo_numba.interaction.free_free_emission(r_packet, time_explosion, numba_plasma)[source]

Free-Free emission - set the frequency from electron-ion interaction

Parameters
r_packettardis.montecarlo.montecarlo_numba.r_packet.RPacket
time_explosionfloat
numba_plasmatardis.montecarlo.montecarlo_numba.numba_interface.NumbaPlasma
tardis.montecarlo.montecarlo_numba.interaction.get_current_line_id(nu, line_list)[source]

Get the line id corresponding to a frequency nu in a line list

Parameters
nufloat
line_listnp.ndarray
tardis.montecarlo.montecarlo_numba.interaction.line_emission(r_packet, emission_line_id, time_explosion, numba_plasma)[source]

Sets the frequency of the RPacket properly given the emission channel

Parameters
r_packettardis.montecarlo.montecarlo_numba.r_packet.RPacket
emission_line_idint
time_explosionfloat
numba_plasmatardis.montecarlo.montecarlo_numba.numba_interface.NumbaPlasma
tardis.montecarlo.montecarlo_numba.interaction.line_scatter(r_packet, time_explosion, line_interaction_type, numba_plasma)[source]

Line scatter function that handles the scattering itself, including new angle drawn, and calculating nu out using macro atom

Parameters
r_packettardis.montecarlo.montecarlo_numba.r_packet.RPacket
time_explosionfloat
line_interaction_typeenum
numba_plasmatardis.montecarlo.montecarlo_numba.numba_interface.NumbaPlasma
tardis.montecarlo.montecarlo_numba.interaction.macro_atom_event(destination_level_idx, r_packet, time_explosion, numba_plasma)[source]

Macroatom event handler - run the macroatom and handle the result

Parameters
destination_level_idxint
r_packettardis.montecarlo.montecarlo_numba.r_packet.RPacket
time_explosionfloat
numba_plasmatardis.montecarlo.montecarlo_numba.numba_interface.NumbaPlasma
tardis.montecarlo.montecarlo_numba.interaction.sample_nu_free_bound(numba_plasma, shell, continuum_id)[source]
Attributes
nu_fb_samplerfloat

Frequency of the free-bounds emission process

tardis.montecarlo.montecarlo_numba.interaction.sample_nu_free_free(numba_plasma, shell)[source]
Attributes
nu_ff_samplerfloat

Frequency of the free-free emission process

tardis.montecarlo.montecarlo_numba.interaction.scatter(r_packet, time_explosion)[source]
tardis.montecarlo.montecarlo_numba.interaction.thomson_scatter(r_packet, time_explosion)[source]

Thomson scattering — no longer line scattering

  1. get the doppler factor at that position with the old angle

  2. convert the current energy and nu into the comoving frame with the old mu

  3. Scatter and draw new mu - update mu

  4. Transform the comoving energy and nu back using the new mu

Parameters
r_packettardis.montecarlo.montecarlo_numba.r_packet.RPacket
time_explosionfloat

time since explosion in seconds