ARTEMIS
Functions | Variables
WarpXAlgorithmSelection.cpp File Reference
#include "WarpX.H"
#include "WarpXAlgorithmSelection.H"
#include <AMReX.H>
#include <AMReX_ParmParse.H>
#include <algorithm>
#include <cstring>
#include <cctype>
#include <map>
#include <utility>

Functions

int GetAlgorithmInteger (amrex::ParmParse &pp, const char *pp_search_key)
 
int GetFieldBCTypeInteger (std::string BCType)
 
ParticleBoundaryType GetParticleBCTypeInteger (std::string BCType)
 

Variables

const std::map< std::string, int > grid_to_int
 
const std::map< std::string, int > electromagnetic_solver_algo_to_int
 
const std::map< std::string, int > electrostatic_solver_algo_to_int
 
const std::map< std::string, int > particle_pusher_algo_to_int
 
const std::map< std::string, int > current_deposition_algo_to_int
 
const std::map< std::string, int > charge_deposition_algo_to_int
 
const std::map< std::string, int > gathering_algo_to_int
 
const std::map< std::string, int > psatd_solution_type_to_int
 
const std::map< std::string, int > J_in_time_to_int
 
const std::map< std::string, int > rho_in_time_to_int
 
const std::map< std::string, int > load_balance_costs_update_algo_to_int
 
const std::map< std::string, int > MaxwellSolver_medium_algo_to_int
 
const std::map< std::string, int > MacroscopicSolver_algo_to_int
 
const std::map< std::string, int > FieldBCType_algo_to_int
 
const std::map< std::string, ParticleBoundaryTypeParticleBCType_algo_to_enum
 
const std::map< std::string, int > ReductionType_algo_to_int
 
const std::map< std::string, int > IntegrationType_algo_to_int
 
const std::map< std::string, int > CoupledYeeSolver_algo_to_int
 

Function Documentation

◆ GetAlgorithmInteger()

int GetAlgorithmInteger ( amrex::ParmParse pp,
const char *  pp_search_key 
)

◆ GetFieldBCTypeInteger()

int GetFieldBCTypeInteger ( std::string  BCType)

Select BC Type for fields, if field=true else select BCType for particles.

◆ GetParticleBCTypeInteger()

ParticleBoundaryType GetParticleBCTypeInteger ( std::string  BCType)

Select BC Type for particles.

Variable Documentation

◆ charge_deposition_algo_to_int

const std::map<std::string, int> charge_deposition_algo_to_int
Initial value:
= {
}
@ Standard
Definition: WarpXAlgorithmSelection.H:99

◆ CoupledYeeSolver_algo_to_int

const std::map<std::string, int> CoupledYeeSolver_algo_to_int
Initial value:
= {
{"maxwelllondon", CoupledYeeSolver::MaxwellLondon},
}
@ MaxwellLondon
Definition: WarpXAlgorithmSelection.H:28
@ None
Definition: WarpXAlgorithmSelection.H:29

◆ current_deposition_algo_to_int

const std::map<std::string, int> current_deposition_algo_to_int
Initial value:
= {
}
@ Vay
Definition: WarpXAlgorithmSelection.H:92
@ Direct
Definition: WarpXAlgorithmSelection.H:91
@ Esirkepov
Definition: WarpXAlgorithmSelection.H:90

◆ electromagnetic_solver_algo_to_int

const std::map<std::string, int> electromagnetic_solver_algo_to_int
Initial value:
= {
}
@ Yee
Definition: WarpXAlgorithmSelection.H:64
@ CKC
Definition: WarpXAlgorithmSelection.H:65
@ ECT
Definition: WarpXAlgorithmSelection.H:67
@ None
Definition: WarpXAlgorithmSelection.H:63
@ PSATD
Definition: WarpXAlgorithmSelection.H:66

◆ electrostatic_solver_algo_to_int

const std::map<std::string, int> electrostatic_solver_algo_to_int
Initial value:
= {
{"labframe-electromagnetostatic", ElectrostaticSolverAlgo::LabFrameElectroMagnetostatic},
}
@ LabFrameElectroMagnetostatic
Definition: WarpXAlgorithmSelection.H:75
@ Relativistic
Definition: WarpXAlgorithmSelection.H:74
@ LabFrame
Definition: WarpXAlgorithmSelection.H:76
@ None
Definition: WarpXAlgorithmSelection.H:73

◆ FieldBCType_algo_to_int

const std::map<std::string, int> FieldBCType_algo_to_int
Initial value:
= {
{"absorbing_silver_mueller", FieldBoundaryType::Absorbing_SilverMueller},
}
@ PEC
perfect electric conductor (PEC) with E_tangential=0
Definition: WarpXAlgorithmSelection.H:148
@ Periodic
Definition: WarpXAlgorithmSelection.H:147
@ Damped
Definition: WarpXAlgorithmSelection.H:150
@ None
Definition: WarpXAlgorithmSelection.H:154
@ PML
Definition: WarpXAlgorithmSelection.H:146
@ Absorbing_SilverMueller
Definition: WarpXAlgorithmSelection.H:152
@ Neumann
Definition: WarpXAlgorithmSelection.H:153
@ PMC
perfect magnetic conductor (PMC) with B_tangential=0
Definition: WarpXAlgorithmSelection.H:149

◆ gathering_algo_to_int

const std::map<std::string, int> gathering_algo_to_int
Initial value:
= {
{"energy-conserving", GatheringAlgo::EnergyConserving },
{"momentum-conserving", GatheringAlgo::MomentumConserving },
}
@ MomentumConserving
Definition: WarpXAlgorithmSelection.H:106
@ EnergyConserving
Definition: WarpXAlgorithmSelection.H:105

◆ grid_to_int

const std::map<std::string, int> grid_to_int
Initial value:
= {
{"collocated", GridType::Collocated},
{"staggered", GridType::Staggered},
{"hybrid", GridType::Hybrid},
{"default", GridType::Staggered}
}
@ Staggered
Definition: WarpXAlgorithmSelection.H:56
@ Collocated
Definition: WarpXAlgorithmSelection.H:55
@ Hybrid
Definition: WarpXAlgorithmSelection.H:57

◆ IntegrationType_algo_to_int

const std::map<std::string, int> IntegrationType_algo_to_int
Initial value:
= {
}
@ Surface
Definition: WarpXAlgorithmSelection.H:196
@ Volume
Definition: WarpXAlgorithmSelection.H:195

◆ J_in_time_to_int

const std::map<std::string, int> J_in_time_to_int
Initial value:
= {
{"constant", JInTime::Constant},
{"linear", JInTime::Linear},
{"default", JInTime::Constant}
}
@ Linear
Definition: WarpXAlgorithmSelection.H:120
@ Constant
Definition: WarpXAlgorithmSelection.H:119

◆ load_balance_costs_update_algo_to_int

const std::map<std::string, int> load_balance_costs_update_algo_to_int
Initial value:
= {
}
@ Timers
load balance according to in-code timer-based weights (i.e., with costs)
Definition: WarpXAlgorithmSelection.H:135
@ Heuristic
Definition: WarpXAlgorithmSelection.H:136
@ GpuClock
Definition: WarpXAlgorithmSelection.H:138

◆ MacroscopicSolver_algo_to_int

const std::map<std::string, int> MacroscopicSolver_algo_to_int
Initial value:
= {
}
@ BackwardEuler
Definition: WarpXAlgorithmSelection.H:48
@ LaxWendroff
Definition: WarpXAlgorithmSelection.H:49

◆ MaxwellSolver_medium_algo_to_int

const std::map<std::string, int> MaxwellSolver_medium_algo_to_int
Initial value:
= {
{"vacuum", MediumForEM::Vacuum},
{"macroscopic", MediumForEM::Macroscopic},
{"default", MediumForEM::Vacuum}
}
@ Macroscopic
Definition: WarpXAlgorithmSelection.H:22
@ Vacuum
Definition: WarpXAlgorithmSelection.H:21

◆ particle_pusher_algo_to_int

const std::map<std::string, int> particle_pusher_algo_to_int
Initial value:
= {
}
@ HigueraCary
Definition: WarpXAlgorithmSelection.H:84
@ Boris
Definition: WarpXAlgorithmSelection.H:82
@ Vay
Definition: WarpXAlgorithmSelection.H:83

◆ ParticleBCType_algo_to_enum

const std::map<std::string, ParticleBoundaryType> ParticleBCType_algo_to_enum
Initial value:
= {
}
@ Absorbing
particles crossing domain boundary are removed
@ Reflecting
particles are reflected
@ Open
particles cross domain boundary leave with damped j

◆ psatd_solution_type_to_int

const std::map<std::string, int> psatd_solution_type_to_int
Initial value:
= {
{"second-order", PSATDSolutionType::SecondOrder},
}
@ SecondOrder
Definition: WarpXAlgorithmSelection.H:113
@ FirstOrder
Definition: WarpXAlgorithmSelection.H:112

◆ ReductionType_algo_to_int

const std::map<std::string, int> ReductionType_algo_to_int
Initial value:
= {
{"maximum", ReductionType::Maximum},
{"minimum", ReductionType::Minimum},
{"integral", ReductionType::Sum}
}
@ Maximum
Definition: WarpXAlgorithmSelection.H:187
@ Sum
Definition: WarpXAlgorithmSelection.H:189
@ Minimum
Definition: WarpXAlgorithmSelection.H:188

◆ rho_in_time_to_int

const std::map<std::string, int> rho_in_time_to_int
Initial value:
= {
{"constant", RhoInTime::Constant},
{"linear", RhoInTime::Linear},
{"default", RhoInTime::Linear}
}
@ Linear
Definition: WarpXAlgorithmSelection.H:127
@ Constant
Definition: WarpXAlgorithmSelection.H:126