Skip to content

Commit

Permalink
Merge branch 'main' into development
Browse files Browse the repository at this point in the history
  • Loading branch information
zingale committed Oct 15, 2023
2 parents 9a858fe + 4e4764d commit 8b2c485
Show file tree
Hide file tree
Showing 24 changed files with 15,853 additions and 1 deletion.
3 changes: 2 additions & 1 deletion .github/workflows/macos_build_cell_primordial_chem.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,8 @@ jobs:

- name: Install dependencies
run: |
brew install cmake openmpi python3
brew install cmake openmpi python3 || true
brew link --overwrite python@3.11
- name: Compile and run
run: |
Expand Down
148 changes: 148 additions & 0 deletions networks/He-C-Fe-group/55co-55fe_electroncapture.dat

Large diffs are not rendered by default.

148 changes: 148 additions & 0 deletions networks/He-C-Fe-group/55fe-55co_betadecay.dat

Large diffs are not rendered by default.

148 changes: 148 additions & 0 deletions networks/He-C-Fe-group/56co-56fe_electroncapture.dat

Large diffs are not rendered by default.

148 changes: 148 additions & 0 deletions networks/He-C-Fe-group/56co-56ni_betadecay.dat

Large diffs are not rendered by default.

148 changes: 148 additions & 0 deletions networks/He-C-Fe-group/56fe-56co_betadecay.dat

Large diffs are not rendered by default.

148 changes: 148 additions & 0 deletions networks/He-C-Fe-group/56ni-56co_electroncapture.dat

Large diffs are not rendered by default.

148 changes: 148 additions & 0 deletions networks/He-C-Fe-group/57co-57ni_betadecay.dat

Large diffs are not rendered by default.

148 changes: 148 additions & 0 deletions networks/He-C-Fe-group/57ni-57co_electroncapture.dat

Large diffs are not rendered by default.

Binary file added networks/He-C-Fe-group/He-C-Fe-group.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
140 changes: 140 additions & 0 deletions networks/He-C-Fe-group/He-C-Fe-group.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,140 @@
import pynucastro as pyna
from pynucastro.rates import ReacLibRate, TabularRate

DO_DERIVED_RATES = True

reaclib_lib = pyna.ReacLibLibrary()
weak_lib = pyna.TabularLibrary()

# these are the nuclei we have in subch_simple

all_reactants = ["p",
"he4", "c12", "o16", "ne20", "mg24", "si28", "s32",
"ar36", "ca40", "ti44", "cr48", "fe52", "ni56",
"cu59", "zn60",
"al27", "p31", "cl35", "k39", "sc43", "v47", "mn51", "co55",
"n13", "n14", "f18", "ne21", "na22", "na23"]

# create a library of ReacLib rates

core_lib = reaclib_lib.linking_nuclei(all_reactants)

# in this list, we have the reactants, the actual reactants,
# and modified products that we will use instead

other_rates = [("c12(c12,n)mg23", "mg24"),
("o16(o16,n)s31", "s32"),
("o16(c12,n)si27", "si28")]

for r, mp in other_rates:
_r = reaclib_lib.get_rate_by_name(r)
_r.modify_products(mp)
core_lib.add_rate(_r)

# finally, the aprox nets don't include the reverse rates for
# C12+C12, C12+O16, and O16+O16, so remove those

for r in core_lib.get_rates():
if sorted(r.products) in [[pyna.Nucleus("c12"), pyna.Nucleus("c12")],
[pyna.Nucleus("c12"), pyna.Nucleus("o16")],
[pyna.Nucleus("o16"), pyna.Nucleus("o16")]]:
core_lib.remove_rate(r)

# C12+Ne20 and reverse
# (a,g) links between Na23 and Al27
# (a,g) links between Al27 and P31

rates_to_remove = ["p31(p,c12)ne20",
"si28(a,c12)ne20",
"ne20(c12,p)p31",
"ne20(c12,a)si28",
"na23(a,g)al27",
"al27(g,a)na23",
"al27(a,g)p31",
"p31(g,a)al27"]

for r in rates_to_remove:
print("removing: ", r)
_r = core_lib.get_rate_by_name(r)
core_lib.remove_rate(_r)

# now create a list of iron group nuclei and find both the
# ReacLib and weak / tabular rates linking these.

iron_peak = ["n", "p", "he4",
"mn51", "mn55",
"fe52", "fe53", "fe54", "fe55", "fe56",
"co55", "co56", "co57",
"ni56", "ni57", "ni58",
"cu59", "zn60"]

iron_reaclib = reaclib_lib.linking_nuclei(iron_peak)

iron_weak_lib = weak_lib.linking_nuclei(iron_peak)

# add the libraries

all_lib = core_lib + iron_reaclib + iron_weak_lib

if DO_DERIVED_RATES:
rates_to_derive = []
for r in all_lib.get_rates():
if r.reverse:
# this rate was computed using detailed balance, regardless
# of whether Q < 0 or not. We want to remove it and then
# recompute it
rates_to_derive.append(r)

# now for each of those derived rates, look to see if the pair exists

for r in rates_to_derive:
fr = all_lib.get_rate_by_nuclei(r.products, r.reactants)
if fr:
print(f"modifying {r} from {fr}")
all_lib.remove_rate(r)
d = pyna.DerivedRate(rate=fr, compute_Q=False, use_pf=True)
all_lib.add_rate(d)

# combine all three libraries into a single network

net = pyna.AmrexAstroCxxNetwork(libraries=[all_lib],
symmetric_screening=False)

# we will have duplicate rates -- we want to remove any ReacLib rates
# that we have tabular rates for

dupes = net.find_duplicate_links()

rates_to_remove = []
for d in dupes:
for r in d:
if isinstance(r, ReacLibRate):
rates_to_remove.append(r)

net.remove_rates(rates_to_remove)

# now we approximate some (alpha, p)(p, gamma) links

net.make_ap_pg_approx(intermediate_nuclei=["cl35", "k39", "sc43", "v47"])
net.remove_nuclei(["cl35", "k39", "sc43", "v47"])

# let's make a figure

T = 6.e9
rho = 9.e7
comp = pyna.Composition(net.unique_nuclei)
comp.set_all(1.0)
comp.normalize()

fig = net.plot(rho=rho, T=T, comp=comp,
rotated=True, curved_edges=True, hide_xalpha=True,
size=(1800, 900),
node_size=500, node_shape="s", node_font_size=10)

fig.savefig("He-C-Fe-group.png")

print(f"number of nuclei = {len(net.unique_nuclei)}")
print(f"number of ReacLib rates = {len(net.reaclib_rates)}")
print(f"number of tabular rates = {len(net.tabular_rates)}")

net.write_network()
14 changes: 14 additions & 0 deletions networks/He-C-Fe-group/Make.package
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
CEXE_headers += network_properties.H

ifeq ($(USE_REACT),TRUE)
CEXE_sources += actual_network_data.cpp
CEXE_headers += actual_network.H
CEXE_headers += tfactors.H
CEXE_headers += partition_functions.H
CEXE_headers += actual_rhs.H
CEXE_headers += reaclib_rates.H
CEXE_headers += table_rates.H
CEXE_sources += table_rates_data.cpp
USE_SCREENING = TRUE
USE_NEUTRINOS = TRUE
endif
7 changes: 7 additions & 0 deletions networks/He-C-Fe-group/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
# He-C-Fe-group

This is a network for He and C burning with a heavy emphasis on iron
group. It has the same basic structure as ``subch_approx`` for the
main alpha-chain. At high mass number, a lot of nuclei in the iron
group are added and weak rates from the Langanke tables are used to
link them. Neutrons are only present in the links in the iron group.
2 changes: 2 additions & 0 deletions networks/He-C-Fe-group/_parameters
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
@namespace: network

Loading

0 comments on commit 8b2c485

Please sign in to comment.