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

Functions

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

Variables

const std::map< std::string, intgrid_to_int
 
const std::map< std::string, intelectromagnetic_solver_algo_to_int
 
const std::map< std::string, intelectrostatic_solver_algo_to_int
 
const std::map< std::string, intparticle_pusher_algo_to_int
 
const std::map< std::string, intcurrent_deposition_algo_to_int
 
const std::map< std::string, intcharge_deposition_algo_to_int
 
const std::map< std::string, intgathering_algo_to_int
 
const std::map< std::string, intpsatd_solution_type_to_int
 
const std::map< std::string, intJ_in_time_to_int
 
const std::map< std::string, intrho_in_time_to_int
 
const std::map< std::string, intload_balance_costs_update_algo_to_int
 
const std::map< std::string, intMaxwellSolver_medium_algo_to_int
 
const std::map< std::string, intMacroscopicSolver_algo_to_int
 
const std::map< std::string, intFieldBCType_algo_to_int
 
const std::map< std::string, ParticleBoundaryTypeParticleBCType_algo_to_enum
 
const std::map< std::string, intReductionType_algo_to_int
 

Function Documentation

◆ GetAlgorithmInteger()

int GetAlgorithmInteger ( const 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:86

◆ current_deposition_algo_to_int

const std::map<std::string, int> current_deposition_algo_to_int
Initial value:
= {
}
@ Vay
Definition: WarpXAlgorithmSelection.H:79
@ Direct
Definition: WarpXAlgorithmSelection.H:78
@ Esirkepov
Definition: WarpXAlgorithmSelection.H:77

◆ electromagnetic_solver_algo_to_int

const std::map<std::string, int> electromagnetic_solver_algo_to_int
Initial value:
= {
}
@ Yee
Definition: WarpXAlgorithmSelection.H:50
@ HybridPIC
Definition: WarpXAlgorithmSelection.H:54
@ CKC
Definition: WarpXAlgorithmSelection.H:51
@ ECT
Definition: WarpXAlgorithmSelection.H:53
@ None
Definition: WarpXAlgorithmSelection.H:49
@ PSATD
Definition: WarpXAlgorithmSelection.H:52

◆ 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:62
@ Relativistic
Definition: WarpXAlgorithmSelection.H:61
@ LabFrame
Definition: WarpXAlgorithmSelection.H:63
@ None
Definition: WarpXAlgorithmSelection.H:60

◆ 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:135
@ Periodic
Definition: WarpXAlgorithmSelection.H:134
@ Damped
Definition: WarpXAlgorithmSelection.H:137
@ None
Definition: WarpXAlgorithmSelection.H:141
@ PML
Definition: WarpXAlgorithmSelection.H:133
@ Absorbing_SilverMueller
Definition: WarpXAlgorithmSelection.H:139
@ Neumann
Definition: WarpXAlgorithmSelection.H:140
@ PMC
perfect magnetic conductor (PMC) with B_tangential=0
Definition: WarpXAlgorithmSelection.H:136

◆ 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:93
@ EnergyConserving
Definition: WarpXAlgorithmSelection.H:92

◆ 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:42
@ Collocated
Definition: WarpXAlgorithmSelection.H:41
@ Hybrid
Definition: WarpXAlgorithmSelection.H:43

◆ 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:107
@ Constant
Definition: WarpXAlgorithmSelection.H:106

◆ 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:122
@ Heuristic
Definition: WarpXAlgorithmSelection.H:123
@ GpuClock
Definition: WarpXAlgorithmSelection.H:125

◆ MacroscopicSolver_algo_to_int

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

◆ 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:71
@ Boris
Definition: WarpXAlgorithmSelection.H:69
@ Vay
Definition: WarpXAlgorithmSelection.H:70

◆ 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:100
@ FirstOrder
Definition: WarpXAlgorithmSelection.H:99

◆ 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:159
@ Sum
Definition: WarpXAlgorithmSelection.H:161
@ Minimum
Definition: WarpXAlgorithmSelection.H:160

◆ 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:114
@ Constant
Definition: WarpXAlgorithmSelection.H:113