WarpX
Functions | Variables
WarpXAlgorithmSelection.cpp File Reference
#include "WarpX.H"
#include "WarpXAlgorithmSelection.H"
#include "Utils/TextMsg.H"
#include <ablastr/utils/Enums.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)
 
FieldBoundaryType GetFieldBCTypeInteger (std::string BCType)
 
ParticleBoundaryType GetParticleBCTypeInteger (std::string BCType)
 
std::string GetFieldBCTypeString (FieldBoundaryType fb_type)
 

Variables

const std::map< std::string, intevolve_scheme_to_int
 
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, intpoisson_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, FieldBoundaryTypeFieldBCType_algo_to_enum
 
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()

FieldBoundaryType GetFieldBCTypeInteger ( std::string  BCType)

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

◆ GetFieldBCTypeString()

std::string GetFieldBCTypeString ( FieldBoundaryType  fb_type)

Find the name associated with a BC type

◆ 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:101

◆ current_deposition_algo_to_int

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

◆ electromagnetic_solver_algo_to_int

const std::map<std::string, int> electromagnetic_solver_algo_to_int
Initial value:
= {
}
@ Yee
Definition: WarpXAlgorithmSelection.H:57
@ HybridPIC
Definition: WarpXAlgorithmSelection.H:61
@ CKC
Definition: WarpXAlgorithmSelection.H:58
@ ECT
Definition: WarpXAlgorithmSelection.H:60
@ None
Definition: WarpXAlgorithmSelection.H:56
@ PSATD
Definition: WarpXAlgorithmSelection.H:59

◆ 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:69
@ Relativistic
Definition: WarpXAlgorithmSelection.H:68
@ LabFrame
Definition: WarpXAlgorithmSelection.H:70
@ None
Definition: WarpXAlgorithmSelection.H:67

◆ evolve_scheme_to_int

const std::map<std::string, int> evolve_scheme_to_int
Initial value:
= {
{"explicit", EvolveScheme::Explicit },
{"theta_implicit_em", EvolveScheme::ThetaImplicitEM },
{"semi_implicit_em", EvolveScheme::SemiImplicitEM },
{"default", EvolveScheme::Explicit }
}
@ SemiImplicitEM
Definition: WarpXAlgorithmSelection.H:37
@ ThetaImplicitEM
Definition: WarpXAlgorithmSelection.H:36
@ Explicit
Definition: WarpXAlgorithmSelection.H:35

◆ FieldBCType_algo_to_enum

const std::map<std::string, FieldBoundaryType> FieldBCType_algo_to_enum
Initial value:
= {
{"absorbing_silver_mueller", FieldBoundaryType::Absorbing_SilverMueller},
}
@ PMC
perfect magnetic conductor (PMC) with B_tangential=0
@ PEC
perfect electric conductor (PEC) with E_tangential=0

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

◆ grid_to_int

const std::map<std::string, int> grid_to_int

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

◆ 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:137
@ Heuristic
Definition: WarpXAlgorithmSelection.H:138

◆ MacroscopicSolver_algo_to_int

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

◆ 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:26
@ Vacuum
Definition: WarpXAlgorithmSelection.H:25

◆ particle_pusher_algo_to_int

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

◆ ParticleBCType_algo_to_enum

const std::map<std::string, ParticleBoundaryType> ParticleBCType_algo_to_enum
Initial value:
= {
}
@ Absorbing
particles crossing domain boundary are removed
@ None
For r=0 boundary with RZ simulations.
@ Reflecting
particles are reflected
@ Open
particles cross domain boundary leave with damped j
@ Periodic
particles are introduced from the periodic boundary

◆ poisson_solver_algo_to_int

const std::map<std::string, int> poisson_solver_algo_to_int
Initial value:
= {
}
@ IntegratedGreenFunction
Definition: WarpXAlgorithmSelection.H:77
@ Multigrid
Definition: WarpXAlgorithmSelection.H:76

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

◆ 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:176
@ Sum
Definition: WarpXAlgorithmSelection.H:178
@ Minimum
Definition: WarpXAlgorithmSelection.H:177

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