Skip to content

Commit

Permalink
SpeciesProperties: C, N, O, Cu (#1638)
Browse files Browse the repository at this point in the history
* SpeciesProperties: C, N, O, Cu

Add more ionic species as pre-defined particle species.

* Cu: Add to Ionization Energies
  • Loading branch information
ax3l authored Jan 20, 2021
1 parent db97d71 commit 8d51aa3
Show file tree
Hide file tree
Showing 4 changed files with 146 additions and 68 deletions.
26 changes: 25 additions & 1 deletion Source/Particles/SpeciesPhysicalProperties.H
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@
#include <map>
#include <limits>

enum struct PhysicalSpecies{unspecified=0, electron, positron, photon, hydrogen};
enum struct PhysicalSpecies{unspecified=0, electron, positron, photon, hydrogen, carbon, nitrogen, oxygen, copper};

namespace species
{
Expand All @@ -33,6 +33,14 @@ namespace species
return PhysicalSpecies::photon;
if( species=="hydrogen" )
return PhysicalSpecies::hydrogen;
if( species=="carbon" )
return PhysicalSpecies::carbon;
if( species=="nitrogen" )
return PhysicalSpecies::nitrogen;
if( species=="oxygen" )
return PhysicalSpecies::oxygen;
if( species=="copper" )
return PhysicalSpecies::copper;
amrex::Abort("unknown PhysicalSpecies");
return PhysicalSpecies::unspecified;
}
Expand All @@ -51,6 +59,14 @@ namespace species
return 0.;
case PhysicalSpecies::hydrogen:
return PhysConst::q_e;
case PhysicalSpecies::carbon:
return PhysConst::q_e * amrex::Real(6.0);
case PhysicalSpecies::nitrogen:
return PhysConst::q_e * amrex::Real(7.0);
case PhysicalSpecies::oxygen:
return PhysConst::q_e * amrex::Real(8.0);
case PhysicalSpecies::copper:
return PhysConst::q_e * amrex::Real(29.0);
default:
amrex::Abort("unknown PhysicalSpecies");
return 0.;
Expand All @@ -71,6 +87,14 @@ namespace species
return 0.;
case PhysicalSpecies::hydrogen:
return PhysConst::m_p;
case PhysicalSpecies::carbon:
return PhysConst::m_e * amrex::Real(22032.0);
case PhysicalSpecies::nitrogen:
return PhysConst::m_e * amrex::Real(25716.9);
case PhysicalSpecies::oxygen:
return PhysConst::m_p * amrex::Real(15.8834);
case PhysicalSpecies::copper:
return PhysConst::m_p * amrex::Real(63.0864);
default:
amrex::Abort("unknown PhysicalSpecies");
return 0.;
Expand Down
142 changes: 82 additions & 60 deletions Source/Utils/IonizationEnergiesTable.H
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
/* Copyright 2019 Axel Huebl, Maxence Thevenet
/* Copyright 2019-2021 Axel Huebl, Maxence Thevenet
*
* This file is part of WarpX.
*
Expand Down Expand Up @@ -32,26 +32,27 @@ std::map<std::string, int> ion_map_ids = {
{"S", 15},
{"Cl", 16},
{"Ar", 17},
{"Kr", 18},
{"Rb", 19},
{"Xe", 20},
{"Rn", 21} };
{"Cu", 18},
{"Kr", 19},
{"Rb", 20},
{"Xe", 21},
{"Rn", 22} };

const int nelements = 22;
constexpr int nelements = 23;

const int ion_atomic_numbers[nelements] = {
constexpr int ion_atomic_numbers[nelements] = {
1, 2, 3, 4, 5, 6, 7, 8, 9, 10,
11, 12, 13, 14, 15, 16, 17, 18, 36, 37,
54, 86};
11, 12, 13, 14, 15, 16, 17, 18, 29, 36,
37, 54, 86};

const int ion_energy_offsets[nelements] = {
constexpr int ion_energy_offsets[nelements] = {
0, 1, 3, 6, 10, 15, 21, 28, 36, 45,
55, 66, 78, 91, 105, 120, 136, 153, 171, 207,
244, 298};
55, 66, 78, 91, 105, 120, 136, 153, 171, 200,
236, 273, 327};

const int energies_tab_length = 384;
constexpr int energies_tab_length = 413;

const amrex::Real table_ionization_energies[energies_tab_length]{
constexpr amrex::Real table_ionization_energies[energies_tab_length]{
// H
amrex::Real(13.59843449),
// He
Expand Down Expand Up @@ -133,72 +134,93 @@ const amrex::Real table_ionization_energies[energies_tab_length]{
amrex::Real(479.76), amrex::Real(540.4), amrex::Real(619.0),
amrex::Real(685.5), amrex::Real(755.13), amrex::Real(855.5),
amrex::Real(918.375), amrex::Real(4120.6656), amrex::Real(4426.2228),
// Cu
amrex::Real(7.726380), amrex::Real(20.29239), amrex::Real(36.841),
amrex::Real(57.38), amrex::Real(79.8), amrex::Real(103.0),
amrex::Real(139.0), amrex::Real(166.0), amrex::Real(198.0),
amrex::Real(232.2), amrex::Real(265.33), amrex::Real(367.0),
amrex::Real(401.0), amrex::Real(436.0), amrex::Real(483.1),
amrex::Real(518.7), amrex::Real(552.8), amrex::Real(632.5),
amrex::Real(670.608), amrex::Real(1690.5), amrex::Real(1800),
amrex::Real(1918), amrex::Real(2044), amrex::Real(2179.4),
amrex::Real(2307.3), amrex::Real(2479.1), amrex::Real(2586.954),
amrex::Real(11062.4313), amrex::Real(11567.613),
// Kr
amrex::Real(13.9996053), amrex::Real(24.35984), amrex::Real(35.838),
amrex::Real(50.85), amrex::Real(64.69), amrex::Real(78.49),
amrex::Real(109.13), amrex::Real(125.802), amrex::Real(233.0),
amrex::Real(268), amrex::Real(308), amrex::Real(350), amrex::Real(391),
amrex::Real(446), amrex::Real(492), amrex::Real(540), amrex::Real(591),
amrex::Real(640), amrex::Real(785), amrex::Real(831.6), amrex::Real(882.8),
amrex::Real(268), amrex::Real(308), amrex::Real(350),
amrex::Real(391), amrex::Real(446), amrex::Real(492),
amrex::Real(540), amrex::Real(591), amrex::Real(640),
amrex::Real(785), amrex::Real(831.6), amrex::Real(882.8),
amrex::Real(945), amrex::Real(999.0), amrex::Real(1042),
amrex::Real(1155.0), amrex::Real(1205.23), amrex::Real(2928.9),
amrex::Real(3072), amrex::Real(3228), amrex::Real(3380), amrex::Real(3584),
amrex::Real(3752.0), amrex::Real(3971), amrex::Real(4109.083),
amrex::Real(17296.420), amrex::Real(17936.209),
amrex::Real(3072), amrex::Real(3228), amrex::Real(3380),
amrex::Real(3584), amrex::Real(3752.0), amrex::Real(3971),
amrex::Real(4109.083), amrex::Real(17296.420), amrex::Real(17936.209),
// Rb
amrex::Real(4.1771280), amrex::Real(27.28954), amrex::Real(39.247),
amrex::Real(52.20), amrex::Real(68.44), amrex::Real(82.9),
amrex::Real(98.67), amrex::Real(132.79), amrex::Real(150.628),
amrex::Real(277.12), amrex::Real(313.1), amrex::Real(356.0),
amrex::Real(400), amrex::Real(443), amrex::Real(502), amrex::Real(550),
amrex::Real(601), amrex::Real(654), amrex::Real(706.0), amrex::Real(857),
amrex::Real(905.3), amrex::Real(958.9), amrex::Real(1024),
amrex::Real(1080), amrex::Real(1125), amrex::Real(1242.5),
amrex::Real(1294.57), amrex::Real(3133.3), amrex::Real(3281),
amrex::Real(3443), amrex::Real(3600), amrex::Real(3815), amrex::Real(3988),
amrex::Real(400), amrex::Real(443), amrex::Real(502),
amrex::Real(550), amrex::Real(601), amrex::Real(654),
amrex::Real(706.0), amrex::Real(857), amrex::Real(905.3),
amrex::Real(958.9), amrex::Real(1024), amrex::Real(1080),
amrex::Real(1125), amrex::Real(1242.5), amrex::Real(1294.57),
amrex::Real(3133.3), amrex::Real(3281), amrex::Real(3443),
amrex::Real(3600), amrex::Real(3815), amrex::Real(3988),
amrex::Real(4214), amrex::Real(4356.865), amrex::Real(18305.884),
amrex::Real(18965.516),
// Xe
amrex::Real(12.1298436), amrex::Real(20.975), amrex::Real(31.05),
amrex::Real(42.20), amrex::Real(54.1), amrex::Real(66.703),
amrex::Real(91.6), amrex::Real(105.9778), amrex::Real(179.84),
amrex::Real(202.0), amrex::Real(229.02), amrex::Real(255.0),
amrex::Real(281), amrex::Real(314), amrex::Real(343), amrex::Real(374),
amrex::Real(404), amrex::Real(434), amrex::Real(549), amrex::Real(582),
amrex::Real(616), amrex::Real(650), amrex::Real(700), amrex::Real(736),
amrex::Real(818), amrex::Real(857.0), amrex::Real(1493), amrex::Real(1571),
amrex::Real(1653), amrex::Real(1742), amrex::Real(1826), amrex::Real(1919),
amrex::Real(2023), amrex::Real(2113), amrex::Real(2209), amrex::Real(2300),
amrex::Real(2556), amrex::Real(2637), amrex::Real(2726), amrex::Real(2811),
amrex::Real(2975), amrex::Real(3068), amrex::Real(3243),
amrex::Real(3333.8), amrex::Real(7660), amrex::Real(7889),
amrex::Real(8144), amrex::Real(8382), amrex::Real(8971),
amrex::Real(9243), amrex::Real(9581), amrex::Real(9810.37),
amrex::Real(40271.724), amrex::Real(41299.71),
amrex::Real(281), amrex::Real(314), amrex::Real(343),
amrex::Real(374), amrex::Real(404), amrex::Real(434),
amrex::Real(549), amrex::Real(582), amrex::Real(616),
amrex::Real(650), amrex::Real(700), amrex::Real(736),
amrex::Real(818), amrex::Real(857.0), amrex::Real(1493),
amrex::Real(1571), amrex::Real(1653), amrex::Real(1742),
amrex::Real(1826), amrex::Real(1919), amrex::Real(2023),
amrex::Real(2113), amrex::Real(2209), amrex::Real(2300),
amrex::Real(2556), amrex::Real(2637), amrex::Real(2726),
amrex::Real(2811), amrex::Real(2975), amrex::Real(3068),
amrex::Real(3243), amrex::Real(3333.8), amrex::Real(7660),
amrex::Real(7889), amrex::Real(8144), amrex::Real(8382),
amrex::Real(8971), amrex::Real(9243), amrex::Real(9581),
amrex::Real(9810.37), amrex::Real(40271.724), amrex::Real(41299.71),
// Rn
amrex::Real(10.74850), amrex::Real(21.4), amrex::Real(29.4),
amrex::Real(36.9), amrex::Real(52.9), amrex::Real(64.0), amrex::Real(88.0),
amrex::Real(102.0), amrex::Real(154.0), amrex::Real(173.9),
amrex::Real(195.0), amrex::Real(218.0), amrex::Real(240), amrex::Real(264),
amrex::Real(293), amrex::Real(317), amrex::Real(342), amrex::Real(367),
amrex::Real(488), amrex::Real(520), amrex::Real(550), amrex::Real(580),
amrex::Real(640), amrex::Real(680), amrex::Real(760), amrex::Real(800),
amrex::Real(850), amrex::Real(920), amrex::Real(980), amrex::Real(1050),
amrex::Real(1110), amrex::Real(1180), amrex::Real(1250), amrex::Real(1310),
amrex::Real(1390), amrex::Real(1460), amrex::Real(1520), amrex::Real(1590),
amrex::Real(1660), amrex::Real(1720), amrex::Real(2033), amrex::Real(2094),
amrex::Real(2158), amrex::Real(2227), amrex::Real(2293), amrex::Real(2357),
amrex::Real(2467), amrex::Real(2535), amrex::Real(2606), amrex::Real(2674),
amrex::Real(2944), amrex::Real(3010), amrex::Real(3082), amrex::Real(3149),
amrex::Real(3433), amrex::Real(3510), amrex::Real(3699), amrex::Real(3777),
amrex::Real(6169), amrex::Real(6318), amrex::Real(6476), amrex::Real(6646),
amrex::Real(6807), amrex::Real(6964), amrex::Real(7283), amrex::Real(7450),
amrex::Real(7630), amrex::Real(7800), amrex::Real(8260), amrex::Real(8410),
amrex::Real(8570), amrex::Real(8710), amrex::Real(9610), amrex::Real(9780),
amrex::Real(10120), amrex::Real(10290), amrex::Real(21770),
amrex::Real(22160), amrex::Real(22600), amrex::Real(22990),
amrex::Real(26310), amrex::Real(26830), amrex::Real(27490),
amrex::Real(27903.1), amrex::Real(110842.0), amrex::Real(112843.7)
amrex::Real(36.9), amrex::Real(52.9), amrex::Real(64.0),
amrex::Real(88.0), amrex::Real(102.0), amrex::Real(154.0),
amrex::Real(173.9), amrex::Real(195.0), amrex::Real(218.0),
amrex::Real(240), amrex::Real(264), amrex::Real(293),
amrex::Real(317), amrex::Real(342), amrex::Real(367),
amrex::Real(488), amrex::Real(520), amrex::Real(550),
amrex::Real(580), amrex::Real(640), amrex::Real(680),
amrex::Real(760), amrex::Real(800), amrex::Real(850),
amrex::Real(920), amrex::Real(980), amrex::Real(1050),
amrex::Real(1110), amrex::Real(1180), amrex::Real(1250),
amrex::Real(1310), amrex::Real(1390), amrex::Real(1460),
amrex::Real(1520), amrex::Real(1590), amrex::Real(1660),
amrex::Real(1720), amrex::Real(2033), amrex::Real(2094),
amrex::Real(2158), amrex::Real(2227), amrex::Real(2293),
amrex::Real(2357), amrex::Real(2467), amrex::Real(2535),
amrex::Real(2606), amrex::Real(2674), amrex::Real(2944),
amrex::Real(3010), amrex::Real(3082), amrex::Real(3149),
amrex::Real(3433), amrex::Real(3510), amrex::Real(3699),
amrex::Real(3777), amrex::Real(6169), amrex::Real(6318),
amrex::Real(6476), amrex::Real(6646), amrex::Real(6807),
amrex::Real(6964), amrex::Real(7283), amrex::Real(7450),
amrex::Real(7630), amrex::Real(7800), amrex::Real(8260),
amrex::Real(8410), amrex::Real(8570), amrex::Real(8710),
amrex::Real(9610), amrex::Real(9780), amrex::Real(10120),
amrex::Real(10290), amrex::Real(21770), amrex::Real(22160),
amrex::Real(22600), amrex::Real(22990), amrex::Real(26310),
amrex::Real(26830), amrex::Real(27490), amrex::Real(27903.1),
amrex::Real(110842.0), amrex::Real(112843.7)
};

#endif // #ifndef WARPX_IONIZATION_TABLE_H_
29 changes: 29 additions & 0 deletions Source/Utils/atomic_data.txt
Original file line number Diff line number Diff line change
Expand Up @@ -217,6 +217,35 @@ At. num | Sp. Name | Ion Charge | Ionization Energy (eV) |
18 | Ar XVI | +15 | (918.375) |
18 | Ar XVII | +16 | (4120.6656) |
18 | Ar XVIII | +17 | (4426.2228) |
29 | Cu I | 0 | 7.726380 |
29 | Cu II | +1 | 20.29239 |
29 | Cu III | +2 | 36.841 |
29 | Cu IV | +3 | [57.38] |
29 | Cu V | +4 | [79.8] |
29 | Cu VI | +5 | [103.0] |
29 | Cu VII | +6 | [139.0] |
29 | Cu VIII | +7 | (166.0) |
29 | Cu IX | +8 | (198.0) |
29 | Cu X | +9 | [232.2] |
29 | Cu XI | +10 | 265.33 |
29 | Cu XII | +11 | [367.0] |
29 | Cu XIII | +12 | [401.0] |
29 | Cu XIV | +13 | [436.0] |
29 | Cu XV | +14 | [483.1] |
29 | Cu XVI | +15 | [518.7] |
29 | Cu XVII | +16 | [552.8] |
29 | Cu XVIII | +17 | [632.5] |
29 | Cu XIX | +18 | [670.608] |
29 | Cu XX | +19 | [1690.5] |
29 | Cu XXI | +20 | [1800] |
29 | Cu XXII | +21 | [1918] |
29 | Cu XXIII | +22 | [2044] |
29 | Cu XXIV | +23 | [2179.4] |
29 | Cu XXV | +24 | [2307.3] |
29 | Cu XXVI | +25 | [2479.1] |
29 | Cu XXVII | +26 | (2586.954) |
29 | Cu XXVIII | +27 | (11062.4313) |
29 | Cu XXIX | +28 | (11567.613) |
36 | Kr I | 0 | 13.9996053 |
36 | Kr II | +1 | 24.35984 |
36 | Kr III | +2 | 35.838 |
Expand Down
17 changes: 10 additions & 7 deletions Source/Utils/write_atomic_data_cpp.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
#!/usr/bin/env python3
#
# Copyright 2019-2020 Axel Huebl, Luca Fedeli, Maxence Thevenet
#
#
Expand Down Expand Up @@ -32,6 +34,7 @@
cpp_string += '#ifndef WARPX_IONIZATION_TABLE_H_\n'
cpp_string += '#define WARPX_IONIZATION_TABLE_H_\n\n'
cpp_string += '#include <AMReX_AmrCore.H>\n'
cpp_string += '#include <AMReX_REAL.H>\n'
cpp_string += '#include <map>\n\n'

# Map each element to ID in table
Expand All @@ -42,34 +45,34 @@
cpp_string += ' };\n\n'

# Atomic number of each species
cpp_string += 'const int nelements = ' + str(len(ion_names)) + ';\n\n'
cpp_string += 'const int ion_atomic_numbers[nelements] = {\n '
cpp_string += 'constexpr int nelements = ' + str(len(ion_names)) + ';\n\n'
cpp_string += 'constexpr int ion_atomic_numbers[nelements] = {\n '
for count, atom_num in enumerate(ion_atom_numbers):
if count%10==0 and count>0: cpp_string = cpp_string[:-2] + ',\n '
cpp_string += str(atom_num) + ', '
cpp_string = cpp_string[:-2]
cpp_string += '};\n\n'

# Offset of each element in table of ionization energies
cpp_string += 'const int ion_energy_offsets[nelements] = {\n '
cpp_string += 'constexpr int ion_energy_offsets[nelements] = {\n '
for count, offset in enumerate(ion_offsets):
if count%10==0 and count>0: cpp_string = cpp_string[:-2] + ',\n '
cpp_string += str(offset) + ', '
cpp_string = cpp_string[:-2]
cpp_string += '};\n\n'

# Table of ionization energies
cpp_string += 'const int energies_tab_length = ' + str(len(list_of_tuples)) + ';\n\n'
cpp_string += 'const amrex::Real table_ionization_energies[energies_tab_length]{'
cpp_string += 'constexpr int energies_tab_length = ' + str(len(list_of_tuples)) + ';\n\n'
cpp_string += 'constexpr amrex::Real table_ionization_energies[energies_tab_length]{'
for element in ion_names:
cpp_string += '\n // ' + element + '\n '
regex_command = \
'\n\s+(\d+)\s+\|\s+%s\s+\w+\s+\|\s+\+*(\d+)\s+\|\s+\(*\[*(\d+\.*\d*)' \
%element
list_of_tuples = re.findall( regex_command, text_data )
for count, energy in enumerate([x[2] for x in list_of_tuples]):
if count%7==0 and count>0: cpp_string = cpp_string[:-2] + ',\n '
cpp_string += energy + ', '
if count%3==0 and count>0: cpp_string = cpp_string[:-2] + ',\n '
cpp_string += "amrex::Real(" + energy + '), '
cpp_string = cpp_string[:-1]
cpp_string = cpp_string[:-1]
cpp_string += '\n};\n\n'
Expand Down

0 comments on commit 8d51aa3

Please sign in to comment.