From 8d51aa33dd30eae3bc3379586c2a3ddc2dbca120 Mon Sep 17 00:00:00 2001 From: Axel Huebl Date: Wed, 20 Jan 2021 14:03:54 -0800 Subject: [PATCH] SpeciesProperties: C, N, O, Cu (#1638) * SpeciesProperties: C, N, O, Cu Add more ionic species as pre-defined particle species. * Cu: Add to Ionization Energies --- Source/Particles/SpeciesPhysicalProperties.H | 26 +++- Source/Utils/IonizationEnergiesTable.H | 142 +++++++++++-------- Source/Utils/atomic_data.txt | 29 ++++ Source/Utils/write_atomic_data_cpp.py | 17 ++- 4 files changed, 146 insertions(+), 68 deletions(-) diff --git a/Source/Particles/SpeciesPhysicalProperties.H b/Source/Particles/SpeciesPhysicalProperties.H index 7f918fd9e34..addefce7e49 100644 --- a/Source/Particles/SpeciesPhysicalProperties.H +++ b/Source/Particles/SpeciesPhysicalProperties.H @@ -16,7 +16,7 @@ #include #include -enum struct PhysicalSpecies{unspecified=0, electron, positron, photon, hydrogen}; +enum struct PhysicalSpecies{unspecified=0, electron, positron, photon, hydrogen, carbon, nitrogen, oxygen, copper}; namespace species { @@ -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; } @@ -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.; @@ -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.; diff --git a/Source/Utils/IonizationEnergiesTable.H b/Source/Utils/IonizationEnergiesTable.H index 4a870a67ba5..25040522178 100644 --- a/Source/Utils/IonizationEnergiesTable.H +++ b/Source/Utils/IonizationEnergiesTable.H @@ -1,4 +1,4 @@ -/* Copyright 2019 Axel Huebl, Maxence Thevenet +/* Copyright 2019-2021 Axel Huebl, Maxence Thevenet * * This file is part of WarpX. * @@ -32,26 +32,27 @@ std::map 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 @@ -133,29 +134,42 @@ 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 @@ -163,42 +177,50 @@ const amrex::Real table_ionization_energies[energies_tab_length]{ 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_ diff --git a/Source/Utils/atomic_data.txt b/Source/Utils/atomic_data.txt index cd58e076a8b..ead20a623d5 100644 --- a/Source/Utils/atomic_data.txt +++ b/Source/Utils/atomic_data.txt @@ -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 | diff --git a/Source/Utils/write_atomic_data_cpp.py b/Source/Utils/write_atomic_data_cpp.py index 12cafad0c70..9070b71acf9 100644 --- a/Source/Utils/write_atomic_data_cpp.py +++ b/Source/Utils/write_atomic_data_cpp.py @@ -1,3 +1,5 @@ +#!/usr/bin/env python3 +# # Copyright 2019-2020 Axel Huebl, Luca Fedeli, Maxence Thevenet # # @@ -32,6 +34,7 @@ cpp_string += '#ifndef WARPX_IONIZATION_TABLE_H_\n' cpp_string += '#define WARPX_IONIZATION_TABLE_H_\n\n' cpp_string += '#include \n' +cpp_string += '#include \n' cpp_string += '#include \n\n' # Map each element to ID in table @@ -42,8 +45,8 @@ 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) + ', ' @@ -51,7 +54,7 @@ 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) + ', ' @@ -59,8 +62,8 @@ 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 = \ @@ -68,8 +71,8 @@ %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'