-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgen_equilibrium_table.py
100 lines (86 loc) · 3.08 KB
/
gen_equilibrium_table.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
####################################################
# Calculate equilibrium chemistry values for a range
# of temperatures and densities & store as HDF5
####################################################
import numpy as np
import yt
from pygrackle import \
chemistry_data, \
setup_fluid_container
from pygrackle.utilities.physical_constants import \
cm_per_mpc as Mpc, \
amu_cgs as m_u, \
mass_sun_cgs as Msun, \
keV_per_K as kboltz, \
sec_per_Myr, \
cm_per_kpc
# 1e-29 to 1e-23 g/cm**3
# 6.5e4 to 1.5e6 K
size_1d = 60 # square table; length of each side
Z = 0.3 # solar units
dens = np.logspace(np.log10(1e-31), np.log10(1e-23), size_1d) # cgs
temp = np.logspace(np.log10(3e3), np.log10(3e6), size_1d) # K
d, t = np.meshgrid(dens, temp)
# Set solver parameters
chem = chemistry_data()
chem.use_grackle = 1
chem.with_radiative_cooling = 0
chem.primordial_chemistry = 2
chem.metal_cooling = 1
chem.UVbackground = 1
chem.cmb_temperature_floor = 1
chem.grackle_data_file = b"/home/claire/grackle/input/CloudyData_UVB=HM2012.h5"
chem.use_specific_heating_rate = 0
chem.use_volumetric_heating_rate = 0
# Set units
chem.comoving_coordinates = 0 # proper units
chem.a_units = 1.0
chem.a_value = 1.0
chem.density_units = 1.67e-27
chem.length_units = 1638.4 * cm_per_kpc
chem.time_units = sec_per_Myr
chem.velocity_units = chem.a_units \
* (chem.length_units / chem.a_value) \
/ chem.time_units
# Call convenience function for setting up a fluid container.
# This container holds the solver parameters, units, and fields.
fc = setup_fluid_container(chem,
density=d.ravel(),
temperature=t.ravel(),
metal_mass_fraction=0.01295*Z,
converge=True,
tolerance=1e-7, # default: 0.01
max_iterations=10000000000)
# Save as fraction
dataset = {'HI' :fc['HI'] /fc['density'],
'HII' :fc['HII'] /fc['density'],
'HeI' :fc['HeI'] /fc['density'],
'HeII' :fc['HeII'] /fc['density'],
'HeIII':fc['HeIII']/fc['density'],
'HM' :fc['HM'] /fc['density'],
'H2I' :fc['H2I'] /fc['density'],
'H2II' :fc['H2II'] /fc['density'],
'de' :fc['de'] /fc['density'],
'metal':fc['metal']/fc['density'],
'density': dens,
'temperature': temp}
field_types = {'HI' :'table',
'HII' :'table',
'HeI' :'table',
'HeII' :'table',
'HeIII':'table',
'HM' :'table',
'H2I' :'table',
'H2II' :'table',
'de' :'table',
'metal':'table',
'density': 'indexer',
'temperature': 'indexer'}
# sum = np.zeros(size_1d**2)
# for field in dataset:
# if field_types[field] == 'table':
# sum += dataset[field]
# print(sum)
# assert np.allclose(sum, np.ones(size_1d**2))
yt.save_as_dataset(None, f'equilibrium_table_{size_1d}_0{Z*100:.0f}-Zsun.h5', dataset,
field_types = field_types)