-
-
Notifications
You must be signed in to change notification settings - Fork 421
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Gamma ray spectra dep #2793
base: master
Are you sure you want to change the base?
Gamma ray spectra dep #2793
Changes from 26 commits
ddc060c
cc6a1e5
1be314c
82dc7de
cf0258d
05f09f5
6e5f459
8d2179d
0ab1571
6dd1c54
ca8c054
9e8c19a
101c037
8484acd
1d0398e
76115ad
906935e
099f7a7
bc5c0c6
9f83760
8d39eb0
0a5ac59
8fb6f48
cd6e099
112f98a
984b95e
0f9976e
923b98c
00a34a0
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -47,6 +47,7 @@ Atharwa Kharkar <[email protected]> atharwa_24 <[email protected] | |
Atul Kumar <[email protected]> | ||
|
||
Anirban Dutta <[email protected]> | ||
Anirban Dutta <[email protected]> | ||
|
||
Barnabás Barna <[email protected]> | ||
|
||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -31,7 +31,8 @@ | |
("nu_cmf", float64), | ||
("status", int64), | ||
("shell", int64), | ||
("time_current", float64), | ||
("time_start", float64), | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I don't think this is a good name for a variable that is updated once the packet has travelled a distance. |
||
("time_index", float64), | ||
("tau", float64), | ||
] | ||
|
||
|
@@ -52,7 +53,8 @@ | |
nu_cmf, | ||
status, | ||
shell, | ||
time_current, | ||
time_start, | ||
time_index, | ||
): | ||
self.location = location | ||
self.direction = direction | ||
|
@@ -62,7 +64,8 @@ | |
self.nu_cmf = nu_cmf | ||
self.status = status | ||
self.shell = shell | ||
self.time_current = time_current | ||
self.time_start = time_start | ||
self.time_index = time_index | ||
# TODO: rename to tau_event | ||
self.tau = -np.log(np.random.random()) | ||
|
||
|
@@ -94,7 +97,8 @@ | |
nu_cmf, | ||
status, | ||
shell, | ||
time_current, | ||
time_start, | ||
time_index, | ||
): | ||
self.location = location | ||
self.direction = direction | ||
|
@@ -104,8 +108,8 @@ | |
self.nu_cmf = nu_cmf | ||
self.status = status | ||
self.shell = shell | ||
self.time_current = time_current | ||
self.number_of_packets = len(self.energy_rf) | ||
self.time_current = time_start | ||
self.time_index = time_index | ||
self.tau = -np.log(np.random.random(self.number_of_packets)) | ||
|
||
|
||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,7 +1,6 @@ | ||
import numpy as np | ||
from numba import njit | ||
|
||
from tardis.energy_input.gamma_ray_estimators import deposition_estimator_kasen | ||
from tardis.energy_input.gamma_ray_grid import ( | ||
distance_trace, | ||
move_packet, | ||
|
@@ -38,17 +37,16 @@ | |
pair_creation_opacity_type, | ||
electron_number_density_time, | ||
mass_density_time, | ||
inv_volume_time, | ||
iron_group_fraction_per_shell, | ||
inner_velocities, | ||
outer_velocities, | ||
times, | ||
dt_array, | ||
times, | ||
effective_time_array, | ||
energy_bins, | ||
energy_df_rows, | ||
energy_plot_df_rows, | ||
energy_out, | ||
total_energy, | ||
energy_deposited_gamma, | ||
packets_info_array, | ||
): | ||
"""Propagates packets through the simulation | ||
|
@@ -103,21 +101,20 @@ | |
escaped_packets = 0 | ||
scattered_packets = 0 | ||
packet_count = len(packets) | ||
# Logging does not work with numba. Using print instead. | ||
print("Entering gamma ray loop for " + str(packet_count) + " packets") | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I would much prefer using logging, and just doing it right above the function call rather than inside the function. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yep now this is moving from being in-development, we should formalize some of these logs (which has already been done in some of the other major functions) |
||
|
||
deposition_estimator = np.zeros_like(energy_df_rows) | ||
|
||
for i in range(packet_count): | ||
packet = packets[i] | ||
time_index = get_index(packet.time_current, times) | ||
time_index = packet.time_index | ||
|
||
andrewfullard marked this conversation as resolved.
Show resolved
Hide resolved
|
||
if time_index < 0: | ||
print(packet.time_current, time_index) | ||
print(packet.time_start, time_index) | ||
raise ValueError("Packet time index less than 0!") | ||
|
||
scattered = False | ||
|
||
initial_energy = packet.energy_cmf | ||
# Not used now. Useful for the deposition estimator. | ||
# initial_energy = packet.energy_cmf | ||
|
||
while packet.status == GXPacketStatus.IN_PROCESS: | ||
# Get delta-time value for this step | ||
|
@@ -129,7 +126,7 @@ | |
doppler_factor = doppler_factor_3d( | ||
packet.direction, | ||
packet.location, | ||
effective_time_array[time_index], | ||
times[time_index], | ||
) | ||
|
||
kappa = kappa_calculation(comoving_energy) | ||
|
@@ -210,21 +207,10 @@ | |
distance_interaction, distance_boundary, distance_time | ||
) | ||
|
||
packet.time_current += distance / C_CGS | ||
packet.time_start += distance / C_CGS | ||
|
||
packet = move_packet(packet, distance) | ||
|
||
deposition_estimator[packet.shell, time_index] += ( | ||
(initial_energy * 1000) | ||
* distance | ||
* (packet.energy_cmf / initial_energy) | ||
* deposition_estimator_kasen( | ||
comoving_energy, | ||
mass_density_time[packet.shell, time_index], | ||
iron_group_fraction_per_shell[packet.shell], | ||
) | ||
) | ||
|
||
if distance == distance_time: | ||
time_index += 1 | ||
|
||
|
@@ -234,7 +220,7 @@ | |
else: | ||
packet.shell = get_index( | ||
packet.get_location_r(), | ||
inner_velocities * effective_time_array[time_index], | ||
inner_velocities * times[time_index], | ||
) | ||
|
||
elif distance == distance_interaction: | ||
|
@@ -246,47 +232,36 @@ | |
|
||
packet, ejecta_energy_gained = process_packet_path(packet) | ||
|
||
# Save packets to dataframe rows | ||
# convert KeV to eV / s / cm^3 | ||
energy_df_rows[packet.shell, time_index] += ( | ||
ejecta_energy_gained * 1000 | ||
) | ||
|
||
energy_plot_df_rows[i] = np.array( | ||
[ | ||
i, | ||
ejecta_energy_gained * 1000 | ||
# * inv_volume_time[packet.shell, time_index] | ||
/ dt, | ||
packet.get_location_r(), | ||
packet.time_current, | ||
packet.shell, | ||
compton_opacity, | ||
photoabsorption_opacity, | ||
pair_creation_opacity, | ||
] | ||
) | ||
# Ejecta gains energy from the packets (gamma-rays) | ||
energy_deposited_gamma[ | ||
packet.shell, time_index | ||
] += ejecta_energy_gained | ||
# Ejecta gains energy from both gamma-rays and positrons | ||
total_energy[packet.shell, time_index] += ejecta_energy_gained | ||
|
||
if packet.status == GXPacketStatus.PHOTOABSORPTION: | ||
# Packet destroyed, go to the next packet | ||
break | ||
else: | ||
packet.status = GXPacketStatus.IN_PROCESS | ||
scattered = True | ||
packet.status = GXPacketStatus.IN_PROCESS | ||
scattered = True | ||
|
||
else: | ||
packet.shell += shell_change | ||
|
||
if packet.shell > len(mass_density_time[:, 0]) - 1: | ||
rest_energy = packet.nu_rf * H_CGS_KEV | ||
lum_rf = (packet.energy_rf * 1.6022e-9) / dt | ||
bin_index = get_index(rest_energy, energy_bins) | ||
bin_width = ( | ||
energy_bins[bin_index + 1] - energy_bins[bin_index] | ||
) | ||
energy_out[bin_index, time_index] += rest_energy / ( | ||
bin_width * dt | ||
freq_bin_width = bin_width / H_CGS_KEV | ||
energy_out[bin_index, time_index] += ( | ||
packet.energy_rf | ||
/ dt | ||
/ freq_bin_width # Take light crossing time into account | ||
) | ||
|
||
luminosity = packet.energy_rf / dt | ||
packet.status = GXPacketStatus.ESCAPED | ||
escaped_packets += 1 | ||
if scattered: | ||
|
@@ -303,22 +278,20 @@ | |
packet.nu_cmf, | ||
packet.nu_rf, | ||
packet.energy_cmf, | ||
lum_rf, | ||
luminosity, | ||
packet.energy_rf, | ||
packet.shell, | ||
] | ||
) | ||
|
||
print("Escaped packets:", escaped_packets) | ||
print("Scattered packets:", scattered_packets) | ||
print("Number of escaped packets:", escaped_packets) | ||
print("Number of scattered packets:", scattered_packets) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. See note about print statements above There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think these |
||
|
||
return ( | ||
energy_df_rows, | ||
energy_plot_df_rows, | ||
energy_out, | ||
deposition_estimator, | ||
bin_width, | ||
packets_info_array, | ||
energy_deposited_gamma, | ||
total_energy, | ||
) | ||
|
||
|
||
|
@@ -355,7 +328,7 @@ | |
doppler_factor = doppler_factor_3d( | ||
packet.direction, | ||
packet.location, | ||
packet.time_current, | ||
packet.time_start, | ||
) | ||
|
||
packet.nu_rf = packet.nu_cmf / doppler_factor | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,10 +1,12 @@ | ||
import logging | ||
|
||
import astropy.units as u | ||
import numpy as np | ||
import pandas as pd | ||
import astropy.units as u | ||
import radioactivedecay as rd | ||
|
||
from tardis.energy_input.util import KEV2ERG | ||
from tardis.model.matter.decay import IsotopicMassFraction | ||
|
||
logger = logging.getLogger(__name__) | ||
logging.basicConfig(level=logging.INFO) | ||
|
@@ -51,6 +53,7 @@ | |
---------- | ||
isotope_dict : Dict | ||
dictionary of isotopes for each shell with their ``masses``. | ||
|
||
Returns | ||
------- | ||
inv : Dict | ||
|
@@ -83,10 +86,10 @@ | |
cumulative_decay_df : pd.DataFrame | ||
total decays for x g of isotope for time 't' | ||
""" | ||
time_delta = u.Quantity(time_delta, u.s) | ||
time_delta = u.Quantity(time_delta, u.d) | ||
total_decays = {} | ||
for shell, inventory in inventories.items(): | ||
total_decays[shell] = inventory.cumulative_decays(time_delta.value) | ||
total_decays[shell] = inventory.cumulative_decays(time_delta.value, "d") | ||
|
||
flattened_dict = {} | ||
|
||
|
@@ -125,7 +128,6 @@ | |
dataframe of isotopes for each shell with their decay mode, number of decays, radiation type, | ||
radiation energy and radiation intensity. | ||
""" | ||
|
||
gamma_ray_lines = gamma_ray_lines.rename_axis( | ||
"isotope" | ||
) # renaming "Isotope" in nndc to "isotope" | ||
|
@@ -167,3 +169,98 @@ | |
) | ||
|
||
return isotope_decay_df | ||
|
||
|
||
def time_evolve_mass_fraction(raw_isotope_mass_fraction, time_array): | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Maybe combine this with the time_evolve_cumilative_decay function below, and just have the combined function return both the new mass fractions and cumulative decays. |
||
""" | ||
Function to evolve the mass fraction of isotopes with time. | ||
|
||
Parameters | ||
---------- | ||
raw_isotope_mass_fraction : pd.DataFrame | ||
isotope mass fraction in mass fractions. | ||
time_array : np.array | ||
array of time in days. | ||
|
||
Returns | ||
------- | ||
time_evolved_isotope_mass_fraction : pd.DataFrame | ||
time evolved mass fraction of isotopes. | ||
""" | ||
initial_isotope_mass_fraction = raw_isotope_mass_fraction | ||
isotope_mass_fraction_list = [] | ||
dt = np.diff(time_array) | ||
t_start = time_array[:-1] | ||
t_end = time_array[1:] | ||
t_start_index = np.indices(t_start.shape)[0] | ||
|
||
for time in dt: | ||
decayed_isotope_mass_fraction = IsotopicMassFraction( | ||
initial_isotope_mass_fraction | ||
).decay(time) | ||
isotope_mass_fraction_list.append(decayed_isotope_mass_fraction) | ||
initial_isotope_mass_fraction = decayed_isotope_mass_fraction | ||
|
||
time_keys = list(zip(t_start, t_end, t_start_index)) | ||
|
||
time_evolved_isotope_mass_fraction = pd.concat( | ||
isotope_mass_fraction_list, keys=time_keys, names=["time_start", "time_end", "time_index"], | ||
) | ||
|
||
return time_evolved_isotope_mass_fraction | ||
|
||
|
||
def time_evolve_cumulative_decay( | ||
raw_isotope_mass_fraction, shell_masses, gamma_ray_lines, time_array | ||
): | ||
""" | ||
Function to calculate the total decays for each isotope for each shell at each time step. | ||
|
||
Parameters | ||
---------- | ||
raw_isotope_mass_fraction : pd.DataFrame | ||
isotope abundance in mass fractions. | ||
shell_masses : numpy.ndarray | ||
shell masses in units of g | ||
gamma_ray_lines : pd.DataFrame | ||
gamma ray lines from nndc stored as a pandas dataframe. | ||
time_array : numpy.ndarray | ||
array of time steps in days. | ||
|
||
Returns | ||
------- | ||
time_evolve_decay_df : pd.DataFrame | ||
dataframe of isotopes for each shell with their decay mode, number of decays, radiation type, | ||
radiation energy and radiation intensity at each time step. | ||
|
||
""" | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This function duplicates some code from the function above that could be factored out into a different function |
||
isotope_decay_df_list = [] | ||
initial_isotope_mass_fraction = raw_isotope_mass_fraction | ||
|
||
dt = np.diff(time_array) | ||
t_start = time_array[:-1] | ||
t_end = time_array[1:] | ||
t_start_index = np.indices(time_array.shape)[0] | ||
# Do not append dataframes to empty lists. This will be modified in future. | ||
for time in dt: | ||
isotope_dict = create_isotope_dicts( | ||
initial_isotope_mass_fraction, shell_masses | ||
) | ||
inventories = create_inventories_dict(isotope_dict) | ||
total_decays = calculate_total_decays(inventories, time) | ||
isotope_df_time = create_isotope_decay_df(total_decays, gamma_ray_lines) | ||
isotope_decay_df_list.append(isotope_df_time) | ||
|
||
decayed_isotope_mass_fraction = IsotopicMassFraction( | ||
initial_isotope_mass_fraction | ||
).decay(time) | ||
|
||
initial_isotope_mass_fraction = decayed_isotope_mass_fraction | ||
|
||
time_keys = list(zip(t_start, t_end, t_start_index)) | ||
|
||
time_evolved_decay_df = pd.concat( | ||
isotope_decay_df_list, keys=time_keys, names=["time_start", "time_end", "time_index"], | ||
) | ||
|
||
return time_evolved_decay_df |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Change mailmap!