WarpX
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, 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 ( 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:
= {
}
Definition: WarpXAlgorithmSelection.H:85

◆ current_deposition_algo_to_int

const std::map<std::string, int> current_deposition_algo_to_int
Initial value:
= {
}
Definition: WarpXAlgorithmSelection.H:78
Definition: WarpXAlgorithmSelection.H:77
Definition: WarpXAlgorithmSelection.H:76

◆ electromagnetic_solver_algo_to_int

const std::map<std::string, int> electromagnetic_solver_algo_to_int
Initial value:
= {
}
Definition: WarpXAlgorithmSelection.H:53
Definition: WarpXAlgorithmSelection.H:49
Definition: WarpXAlgorithmSelection.H:52
Definition: WarpXAlgorithmSelection.H:50
Definition: WarpXAlgorithmSelection.H:51

◆ electrostatic_solver_algo_to_int

const std::map<std::string, int> electrostatic_solver_algo_to_int
Initial value:
= {
{"labframe-electromagnetostatic", ElectrostaticSolverAlgo::LabFrameElectroMagnetostatic},
}
Definition: WarpXAlgorithmSelection.H:61
Definition: WarpXAlgorithmSelection.H:60
Definition: WarpXAlgorithmSelection.H:59
Definition: WarpXAlgorithmSelection.H:62

◆ FieldBCType_algo_to_int

const std::map<std::string, int> FieldBCType_algo_to_int
Initial value:
= {
{"absorbing_silver_mueller", FieldBoundaryType::Absorbing_SilverMueller},
}
perfect electric conductor (PEC) with E_tangential=0
Definition: WarpXAlgorithmSelection.H:134
Definition: WarpXAlgorithmSelection.H:133
perfect magnetic conductor (PMC) with B_tangential=0
Definition: WarpXAlgorithmSelection.H:135
Definition: WarpXAlgorithmSelection.H:138
Definition: WarpXAlgorithmSelection.H:136
Definition: WarpXAlgorithmSelection.H:132
Definition: WarpXAlgorithmSelection.H:139
Definition: WarpXAlgorithmSelection.H:140

◆ gathering_algo_to_int

const std::map<std::string, int> gathering_algo_to_int
Initial value:
= {
{"energy-conserving", GatheringAlgo::EnergyConserving },
{"momentum-conserving", GatheringAlgo::MomentumConserving },
}
Definition: WarpXAlgorithmSelection.H:91
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}
}
Definition: WarpXAlgorithmSelection.H:41
Definition: WarpXAlgorithmSelection.H:42
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}
}
Definition: WarpXAlgorithmSelection.H:105
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:
= {
}
load balance according to in-code timer-based weights (i.e., with costs)
Definition: WarpXAlgorithmSelection.H:121
Definition: WarpXAlgorithmSelection.H:124
Definition: WarpXAlgorithmSelection.H:122

◆ MacroscopicSolver_algo_to_int

const std::map<std::string, int> MacroscopicSolver_algo_to_int
Initial value:
= {
}
Definition: WarpXAlgorithmSelection.H:34
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}
}
Definition: WarpXAlgorithmSelection.H:21
Definition: WarpXAlgorithmSelection.H:22

◆ particle_pusher_algo_to_int

const std::map<std::string, int> particle_pusher_algo_to_int
Initial value:
= {
}
Definition: WarpXAlgorithmSelection.H:68
Definition: WarpXAlgorithmSelection.H:70
Definition: WarpXAlgorithmSelection.H:69

◆ ParticleBCType_algo_to_enum

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

◆ psatd_solution_type_to_int

const std::map<std::string, int> psatd_solution_type_to_int
Initial value:
= {
{"second-order", PSATDSolutionType::SecondOrder},
}
Definition: WarpXAlgorithmSelection.H:98
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}
}
Definition: WarpXAlgorithmSelection.H:160
Definition: WarpXAlgorithmSelection.H:159
Definition: WarpXAlgorithmSelection.H:158

◆ 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}
}
Definition: WarpXAlgorithmSelection.H:112
Definition: WarpXAlgorithmSelection.H:113