Garfield++ 5.0
A toolkit for the detailed simulation of particle detectors based on ionisation measurement in gases and semiconductors
|
Base class for components based on finite-element field maps. More...
#include <ComponentFieldMap.hh>
Classes | |
struct | Element |
struct | Material |
struct | Node |
struct | WeightingFieldCopy |
Public Member Functions | |
ComponentFieldMap ()=delete | |
Default constructor. | |
ComponentFieldMap (const std::string &name) | |
Constructor. | |
virtual | ~ComponentFieldMap () |
Destructor. | |
bool | Check () |
Check element aspect ratio. | |
void | PrintRange () |
Show x, y, z, V and angular ranges. | |
void | PrintMaterials () |
List all currently defined materials. | |
void | DriftMedium (const size_t imat) |
Flag a field map material as a drift medium. | |
void | NotDriftMedium (const size_t imat) |
Flag a field map materials as a non-drift medium. | |
size_t | GetNumberOfMaterials () const |
Return the number of materials in the field map. | |
double | GetPermittivity (const size_t imat) const |
Return the relative permittivity of a field map material. | |
double | GetConductivity (const size_t imat) const |
Return the conductivity of a field map material. | |
void | SetMedium (const size_t imat, Medium *medium) |
Associate a field map material with a Medium object. | |
Medium * | GetMedium (const size_t imat) const |
Return the Medium associated to a field map material. | |
void | SetGas (Medium *medium) |
virtual size_t | GetNumberOfElements () const |
Return the number of mesh elements. | |
bool | GetElement (const size_t i, double &vol, double &dmin, double &dmax) const |
Return the volume and aspect ratio of a mesh element. | |
virtual bool | GetElement (const size_t i, size_t &mat, bool &drift, std::vector< size_t > &nodes) const |
Return the material and node indices of a mesh element. | |
virtual size_t | GetNumberOfNodes () const |
virtual bool | GetNode (const size_t i, double &x, double &y, double &z) const |
double | GetPotential (const size_t i) const |
void | EnableCheckMapIndices (const bool on=true) |
void | EnableDeleteBackgroundElements (const bool on=true) |
Option to eliminate mesh elements in conductors (default: on). | |
void | EnableTetrahedralTreeForElementSearch (const bool on=true) |
void | EnableConvergenceWarnings (const bool on=true) |
Medium * | GetMedium (const double x, const double y, const double z) override |
Get the medium at a given location (x, y, z). | |
void | ElectricField (const double x, const double y, const double z, double &ex, double &ey, double &ez, Medium *&m, int &status) override |
void | ElectricField (const double x, const double y, const double z, double &ex, double &ey, double &ez, double &v, Medium *&m, int &status) override |
Calculate the drift field [V/cm] and potential [V] at (x, y, z). | |
void | WeightingField (const double x, const double y, const double z, double &wx, double &wy, double &wz, const std::string &label) override |
double | WeightingPotential (const double x, const double y, const double z, const std::string &label) override |
double | DelayedWeightingPotential (double x, double y, double z, const double t, const std::string &label) override |
bool | IsInBoundingBox (const double x, const double y, const double z) const |
bool | GetBoundingBox (double &xmin, double &ymin, double &zmin, double &xmax, double &ymax, double &zmax) override |
Get the bounding box coordinates. | |
bool | GetElementaryCell (double &xmin, double &ymin, double &zmin, double &xmax, double &ymax, double &zmax) override |
Get the coordinates of the elementary cell. | |
bool | GetVoltageRange (double &vmin, double &vmax) override |
Calculate the voltage range [V]. | |
void | CopyWeightingPotential (const std::string &label, const std::string &labelSource, const double x, const double y, const double z, const double alpha, const double beta, const double gamma) |
std::array< double, 3 > | ElectricField (const double x, const double y, const double z) |
Calculate the drift field [V/cm] at (x, y, z). | |
![]() | |
Component ()=delete | |
Default constructor. | |
Component (const std::string &name) | |
Constructor. | |
virtual | ~Component () |
Destructor. | |
virtual void | SetGeometry (Geometry *geo) |
Define the geometry. | |
virtual void | Clear () |
Reset. | |
std::array< double, 3 > | ElectricField (const double x, const double y, const double z) |
Calculate the drift field [V/cm] at (x, y, z). | |
virtual double | ElectricPotential (const double x, const double y, const double z) |
Calculate the (drift) electrostatic potential [V] at (x, y, z). | |
virtual void | DelayedWeightingField (const double x, const double y, const double z, const double t, double &wx, double &wy, double &wz, const std::string &label) |
virtual void | MagneticField (const double x, const double y, const double z, double &bx, double &by, double &bz, int &status) |
void | SetMagneticField (const double bx, const double by, const double bz) |
Set a constant magnetic field. | |
virtual bool | IsReady () |
Ready for use? | |
double | IntegrateFluxCircle (const double xc, const double yc, const double r, const unsigned int nI=50) |
double | IntegrateFluxSphere (const double xc, const double yc, const double zc, const double r, const unsigned int nI=20) |
double | IntegrateFluxParallelogram (const double x0, const double y0, const double z0, const double dx1, const double dy1, const double dz1, const double dx2, const double dy2, const double dz2, const unsigned int nU=20, const unsigned int nV=20) |
double | IntegrateWeightingFluxParallelogram (const std::string &label, const double x0, const double y0, const double z0, const double dx1, const double dy1, const double dz1, const double dx2, const double dy2, const double dz2, const unsigned int nU=20, const unsigned int nV=20) |
double | IntegrateFluxLine (const double x0, const double y0, const double z0, const double x1, const double y1, const double z1, const double xp, const double yp, const double zp, const unsigned int nI, const int isign=0) |
virtual bool | CrossedWire (const double x0, const double y0, const double z0, const double x1, const double y1, const double z1, double &xc, double &yc, double &zc, const bool centre, double &rc) |
virtual bool | InTrapRadius (const double q0, const double x0, const double y0, const double z0, double &xw, double &yw, double &rw) |
virtual bool | CrossedPlane (const double x0, const double y0, const double z0, const double x1, const double y1, const double z1, double &xc, double &yc, double &zc) |
void | EnablePeriodicityX (const bool on=true) |
Enable simple periodicity in the ![]() | |
void | EnablePeriodicityY (const bool on=true) |
Enable simple periodicity in the ![]() | |
void | EnablePeriodicityZ (const bool on=true) |
Enable simple periodicity in the ![]() | |
void | IsPeriodic (bool &perx, bool &pery, bool &perz) |
Return periodicity flags. | |
void | EnableMirrorPeriodicityX (const bool on=true) |
Enable mirror periodicity in the ![]() | |
void | EnableMirrorPeriodicityY (const bool on=true) |
Enable mirror periodicity in the ![]() | |
void | EnableMirrorPeriodicityZ (const bool on=true) |
Enable mirror periodicity in the ![]() | |
void | IsMirrorPeriodic (bool &perx, bool &pery, bool &perz) |
Return mirror periodicity flags. | |
void | EnableAxialPeriodicityX (const bool on=true) |
Enable axial periodicity in the ![]() | |
void | EnableAxialPeriodicityY (const bool on=true) |
Enable axial periodicity in the ![]() | |
void | EnableAxialPeriodicityZ (const bool on=true) |
Enable axial periodicity in the ![]() | |
void | IsAxiallyPeriodic (bool &perx, bool &pery, bool &perz) |
Return axial periodicity flags. | |
void | EnableRotationSymmetryX (const bool on=true) |
Enable rotation symmetry around the ![]() | |
void | EnableRotationSymmetryY (const bool on=true) |
Enable rotation symmetry around the ![]() | |
void | EnableRotationSymmetryZ (const bool on=true) |
Enable rotation symmetry around the ![]() | |
void | IsRotationSymmetric (bool &rotx, bool &roty, bool &rotz) |
Return rotation symmetry flags. | |
void | EnableDebugging () |
Switch on debugging messages. | |
void | DisableDebugging () |
Switch off debugging messages. | |
virtual bool | HasMagneticField () const |
Does the component have a non-zero magnetic field? | |
virtual bool | HasTownsendMap () const |
Does the component have maps of the Townsend coefficient? | |
virtual bool | HasAttachmentMap () const |
Does the component have attachment maps? | |
virtual bool | HasVelocityMap () const |
Does the component have velocity maps? | |
virtual bool | ElectronAttachment (const double, const double, const double, double &eta) |
Get the electron attachment coefficient. | |
virtual bool | HoleAttachment (const double, const double, const double, double &eta) |
Get the hole attachment coefficient. | |
virtual bool | ElectronTownsend (const double, const double, const double, double &alpha) |
Get the electron Townsend coefficient. | |
virtual bool | HoleTownsend (const double, const double, const double, double &alpha) |
Get the hole Townsend coefficient. | |
virtual bool | ElectronVelocity (const double, const double, const double, double &vx, double &vy, double &vz) |
Get the electron drift velocity. | |
virtual bool | HoleVelocity (const double, const double, const double, double &vx, double &vy, double &vz) |
Get the hole drift velocity. | |
virtual bool | GetElectronLifetime (const double, const double, const double, double &etau) |
virtual bool | GetHoleLifetime (const double, const double, const double, double &htau) |
virtual double | StepSizeHint () |
Protected Types | |
enum class | ElementType { Unknown = 0 , Serendipity = 5 , CurvedTetrahedron = 13 } |
Protected Member Functions | |
void | Reset () override |
Reset the component. | |
void | Prepare () |
virtual void | SetRange () |
void | UpdatePeriodicity () override |
Verify periodicities. | |
void | UpdatePeriodicity2d () |
void | UpdatePeriodicityCommon () |
bool | SetDefaultDriftMedium () |
Find lowest epsilon, check for eps = 0, set default drift media flags. | |
int | Field (const double x, const double y, const double z, double &fx, double &fy, double &fz, int &iel, const std::vector< double > &potentials) const |
Compute the electric/weighting field. | |
double | Potential (const double x, const double y, const double z, const std::vector< double > &potentials) const |
Compute the electrostatic/weighting potential. | |
int | FindElement5 (const double x, const double y, double &t1, double &t2, double &t3, double &t4, double jac[4][4], double &det) const |
Find the element for a point in curved quadratic quadrilaterals. | |
int | FindElement13 (const double x, const double y, const double z, double &t1, double &t2, double &t3, double &t4, double jac[4][4], double &det) const |
Find the element for a point in curved quadratic tetrahedra. | |
int | FindElementCube (const double x, const double y, const double z, double &t1, double &t2, double &t3, TMatrixD *&jac, std::vector< TMatrixD * > &dN) const |
Find the element for a point in a cube. | |
void | MapCoordinates (double &xpos, double &ypos, double &zpos, bool &xmirrored, bool &ymirrored, bool &zmirrored, double &rcoordinate, double &rotation) const |
Move (xpos, ypos, zpos) to field map coordinates. | |
void | UnmapFields (double &ex, double &ey, double &ez, const double xpos, const double ypos, const double zpos, const bool xmirrored, const bool ymirrored, const bool zmirrored, const double rcoordinate, const double rotation) const |
Move (ex, ey, ez) to global coordinates. | |
virtual double | GetElementVolume (const size_t i) const |
virtual void | GetAspectRatio (const size_t i, double &dmin, double &dmax) const |
void | PrintWarning (const std::string &header) |
void | PrintNotReady (const std::string &header) const |
void | PrintCouldNotOpen (const std::string &header, const std::string &filename) const |
void | PrintElement (const std::string &header, const double x, const double y, const double z, const double t1, const double t2, const double t3, const double t4, const size_t i, const std::vector< double > &potential) const |
void | TimeInterpolation (const double t, double &f0, double &f1, int &i0, int &i1) |
Interpolation of potential between two time slices. | |
Static Protected Member Functions | |
static double | ScalingFactor (std::string unit) |
static double | Potential3 (const std::array< double, 6 > &v, const std::array< double, 3 > &t) |
Interpolate the potential in a triangle. | |
static void | Field3 (const std::array< double, 6 > &v, const std::array< double, 3 > &t, double jac[4][4], const double det, double &ex, double &ey) |
Interpolate the field in a triangle. | |
static double | Potential5 (const std::array< double, 8 > &v, const std::array< double, 2 > &t) |
Interpolate the potential in a curved quadrilateral. | |
static void | Field5 (const std::array< double, 8 > &v, const std::array< double, 2 > &t, double jac[4][4], const double det, double &ex, double &ey) |
Interpolate the field in a curved quadrilateral. | |
static double | Potential13 (const std::array< double, 10 > &v, const std::array< double, 4 > &t) |
Interpolate the potential in a curved quadratic tetrahedron. | |
static void | Field13 (const std::array< double, 10 > &v, const std::array< double, 4 > &t, double jac[4][4], const double det, double &ex, double &ey, double &ez) |
Interpolate the field in a curved quadratic tetrahedron. | |
static int | ReadInteger (char *token, int def, bool &error) |
static double | ReadDouble (char *token, double def, bool &error) |
Protected Attributes | |
bool | m_is3d = true |
ElementType | m_elementType = ElementType::CurvedTetrahedron |
std::vector< Element > | m_elements |
std::vector< int > | m_elementIndices |
std::vector< bool > | m_degenerate |
std::vector< std::array< double, 3 > > | m_bbMin |
std::vector< std::array< double, 3 > > | m_bbMax |
std::vector< std::array< std::array< double, 3 >, 4 > > | m_w12 |
std::vector< Node > | m_nodes |
std::vector< double > | m_pot |
std::map< std::string, std::vector< double > > | m_wpot |
std::map< std::string, std::vector< std::vector< double > > > | m_dwpot |
std::vector< Material > | m_materials |
std::map< std::string, WeightingFieldCopy > | m_wfieldCopies |
std::vector< double > | m_wdtimes |
bool | m_hasBoundingBox = false |
std::array< double, 3 > | m_minBoundingBox = {{0., 0., 0.}} |
std::array< double, 3 > | m_maxBoundingBox = {{0., 0., 0.}} |
std::array< double, 3 > | m_mapmin = {{0., 0., 0.}} |
std::array< double, 3 > | m_mapmax = {{0., 0., 0.}} |
std::array< double, 3 > | m_mapamin = {{0., 0., 0.}} |
std::array< double, 3 > | m_mapamax = {{0., 0., 0.}} |
std::array< double, 3 > | m_mapna = {{0., 0., 0.}} |
std::array< double, 3 > | m_cells = {{0., 0., 0.}} |
double | m_mapvmin = 0. |
double | m_mapvmax = 0. |
std::array< bool, 3 > | m_setang |
bool | m_deleteBackground = true |
bool | m_warning = false |
unsigned int | m_nWarnings = 0 |
bool | m_printConvergenceWarnings = true |
![]() | |
std::string | m_className = "Component" |
Class name. | |
Geometry * | m_geometry = nullptr |
Pointer to the geometry. | |
std::array< double, 3 > | m_b0 = {{0., 0., 0.}} |
Constant magnetic field. | |
bool | m_ready = false |
Ready for use? | |
bool | m_debug = false |
Switch on/off debugging messages. | |
std::array< bool, 3 > | m_periodic = {{false, false, false}} |
Simple periodicity in x, y, z. | |
std::array< bool, 3 > | m_mirrorPeriodic = {{false, false, false}} |
Mirror periodicity in x, y, z. | |
std::array< bool, 3 > | m_axiallyPeriodic = {{false, false, false}} |
Axial periodicity in x, y, z. | |
std::array< bool, 3 > | m_rotationSymmetric = {{false, false, false}} |
Rotation symmetry around x-axis, y-axis, z-axis. | |
Friends | |
class | ViewFEMesh |
Base class for components based on finite-element field maps.
Definition at line 19 of file ComponentFieldMap.hh.
|
strongprotected |
Enumerator | |
---|---|
Unknown | |
Serendipity | |
CurvedTetrahedron |
Definition at line 140 of file ComponentFieldMap.hh.
|
delete |
Default constructor.
Referenced by Garfield::ComponentAnsys121::ComponentAnsys121(), Garfield::ComponentAnsys123::ComponentAnsys123(), Garfield::ComponentComsol::ComponentComsol(), Garfield::ComponentCST::ComponentCST(), Garfield::ComponentElmer::ComponentElmer(), Garfield::ComponentElmer::ComponentElmer(), and Garfield::ComponentElmer2d::ComponentElmer2d().
Garfield::ComponentFieldMap::ComponentFieldMap | ( | const std::string & | name | ) |
|
virtual |
bool Garfield::ComponentFieldMap::Check | ( | ) |
Check element aspect ratio.
Definition at line 386 of file ComponentFieldMap.cc.
void Garfield::ComponentFieldMap::CopyWeightingPotential | ( | const std::string & | label, |
const std::string & | labelSource, | ||
const double | x, | ||
const double | y, | ||
const double | z, | ||
const double | alpha, | ||
const double | beta, | ||
const double | gamma ) |
Makes a weighting potential copy of a imported map which can be translated and rotated.
label | name of new electrode |
labelSource | name of the source electrode that will be copied |
x | translation in the x-direction. |
y | translation in the y-direction. |
z | translation in the z-direction. |
alpha | rotation around the x-axis. |
beta | rotation around the y-axis. |
gamma | rotation around the z-axis. |
Definition at line 2823 of file ComponentFieldMap.cc.
|
overridevirtual |
Calculate the delayed weighting potential at a given point and time and for a given electrode.
x,y,z | coordinates [cm]. |
t | time [ns]. |
label | name of the electrode |
Reimplemented from Garfield::Component.
Definition at line 234 of file ComponentFieldMap.cc.
void Garfield::ComponentFieldMap::DriftMedium | ( | const size_t | imat | ) |
Flag a field map material as a drift medium.
Definition at line 541 of file ComponentFieldMap.cc.
std::array< double, 3 > Garfield::Component::ElectricField | ( | const double | x, |
const double | y, | ||
const double | z ) |
Calculate the drift field [V/cm] at (x, y, z).
Definition at line 55 of file Component.cc.
|
overridevirtual |
Calculate the drift field [V/cm] and potential [V] at (x, y, z).
Implements Garfield::Component.
Definition at line 24 of file ComponentFieldMap.cc.
|
overridevirtual |
Calculate the drift field at given point.
x,y,z | coordinates [cm]. |
ex,ey,ez | components of the electric field [V/cm]. |
m | pointer to the medium at this location. |
status | status flag |
Status flags:
0: Inside an active medium > 0: Inside a wire of type X -4 ... -1: On the side of a plane where no wires are -5: Inside the mesh but not in an active medium -6: Outside the mesh -10: Unknown potential type (should not occur) other: Other cases (should not occur)
Implements Garfield::Component.
Definition at line 31 of file ComponentFieldMap.cc.
Referenced by ElectricField().
|
inline |
Definition at line 68 of file ComponentFieldMap.hh.
|
inline |
Enable or disable warnings that the calculation of the local coordinates did not achieve the requested precision.
Definition at line 84 of file ComponentFieldMap.hh.
|
inline |
Option to eliminate mesh elements in conductors (default: on).
Definition at line 72 of file ComponentFieldMap.hh.
|
inline |
Enable or disable the usage of the tetrahedral tree for searching the element in the mesh.
Definition at line 78 of file ComponentFieldMap.hh.
|
protected |
Compute the electric/weighting field.
Definition at line 67 of file ComponentFieldMap.cc.
Referenced by ElectricField(), and WeightingField().
|
staticprotected |
Interpolate the field in a curved quadratic tetrahedron.
Definition at line 851 of file ComponentFieldMap.cc.
Referenced by Field().
|
staticprotected |
Interpolate the field in a triangle.
Definition at line 792 of file ComponentFieldMap.cc.
Referenced by Field().
|
staticprotected |
Interpolate the field in a curved quadrilateral.
Definition at line 816 of file ComponentFieldMap.cc.
Referenced by Field().
|
protected |
Find the element for a point in curved quadratic tetrahedra.
Definition at line 976 of file ComponentFieldMap.cc.
Referenced by DelayedWeightingPotential(), Field(), GetMedium(), and Potential().
|
protected |
Find the element for a point in curved quadratic quadrilaterals.
Definition at line 871 of file ComponentFieldMap.cc.
Referenced by DelayedWeightingPotential(), Field(), GetMedium(), and Potential().
|
protected |
Find the element for a point in a cube.
Definition at line 1068 of file ComponentFieldMap.cc.
|
protectedvirtual |
Reimplemented in Garfield::ComponentCST.
Definition at line 671 of file ComponentFieldMap.cc.
Referenced by GetElement().
|
overridevirtual |
Get the bounding box coordinates.
Reimplemented from Garfield::Component.
Definition at line 2419 of file ComponentFieldMap.cc.
double Garfield::ComponentFieldMap::GetConductivity | ( | const size_t | imat | ) | const |
Return the conductivity of a field map material.
Definition at line 577 of file ComponentFieldMap.cc.
bool Garfield::ComponentFieldMap::GetElement | ( | const size_t | i, |
double & | vol, | ||
double & | dmin, | ||
double & | dmax ) const |
Return the volume and aspect ratio of a mesh element.
Definition at line 628 of file ComponentFieldMap.cc.
Referenced by Check().
|
virtual |
Return the material and node indices of a mesh element.
Reimplemented in Garfield::ComponentCST.
Definition at line 721 of file ComponentFieldMap.cc.
|
overridevirtual |
Get the coordinates of the elementary cell.
Reimplemented from Garfield::Component.
Definition at line 2433 of file ComponentFieldMap.cc.
|
protectedvirtual |
Reimplemented in Garfield::ComponentCST.
Definition at line 640 of file ComponentFieldMap.cc.
Referenced by Check(), and GetElement().
|
overridevirtual |
Get the medium at a given location (x, y, z).
Reimplemented from Garfield::Component.
Definition at line 328 of file ComponentFieldMap.cc.
Medium * Garfield::ComponentFieldMap::GetMedium | ( | const size_t | imat | ) | const |
Return the Medium associated to a field map material.
Definition at line 601 of file ComponentFieldMap.cc.
|
virtual |
Reimplemented in Garfield::ComponentCST.
Definition at line 739 of file ComponentFieldMap.cc.
|
inlinevirtual |
Return the number of mesh elements.
Reimplemented in Garfield::ComponentCST.
Definition at line 56 of file ComponentFieldMap.hh.
|
inline |
Return the number of materials in the field map.
Definition at line 41 of file ComponentFieldMap.hh.
|
inlinevirtual |
double Garfield::ComponentFieldMap::GetPermittivity | ( | const size_t | imat | ) | const |
Return the relative permittivity of a field map material.
Definition at line 569 of file ComponentFieldMap.cc.
double Garfield::ComponentFieldMap::GetPotential | ( | const size_t | i | ) | const |
Definition at line 751 of file ComponentFieldMap.cc.
|
inlineoverridevirtual |
Calculate the voltage range [V].
Implements Garfield::Component.
Definition at line 116 of file ComponentFieldMap.hh.
|
inline |
Definition at line 105 of file ComponentFieldMap.hh.
|
protected |
Move (xpos, ypos, zpos) to field map coordinates.
Definition at line 2446 of file ComponentFieldMap.cc.
Referenced by Garfield::ComponentCST::Coordinate2Index(), DelayedWeightingPotential(), Field(), GetMedium(), and Potential().
void Garfield::ComponentFieldMap::NotDriftMedium | ( | const size_t | imat | ) |
Flag a field map materials as a non-drift medium.
Definition at line 555 of file ComponentFieldMap.cc.
|
protected |
Compute the electrostatic/weighting potential.
Definition at line 133 of file ComponentFieldMap.cc.
Referenced by ElectricField(), and WeightingPotential().
|
staticprotected |
Interpolate the potential in a curved quadratic tetrahedron.
Definition at line 839 of file ComponentFieldMap.cc.
Referenced by DelayedWeightingPotential(), and Potential().
|
staticprotected |
Interpolate the potential in a triangle.
Definition at line 782 of file ComponentFieldMap.cc.
Referenced by DelayedWeightingPotential(), and Potential().
|
staticprotected |
Interpolate the potential in a curved quadrilateral.
Definition at line 804 of file ComponentFieldMap.cc.
Referenced by DelayedWeightingPotential(), and Potential().
|
protected |
Definition at line 2121 of file ComponentFieldMap.cc.
Referenced by Garfield::ComponentAnsys121::Initialise(), Garfield::ComponentAnsys123::Initialise(), Garfield::ComponentComsol::Initialise(), Garfield::ComponentCST::Initialise(), Garfield::ComponentElmer2d::Initialise(), and Garfield::ComponentElmer::Initialise().
|
protected |
Definition at line 2785 of file ComponentFieldMap.cc.
Referenced by Garfield::ComponentAnsys121::Initialise(), Garfield::ComponentAnsys123::Initialise(), Garfield::ComponentComsol::Initialise(), Garfield::ComponentCST::Initialise(), Garfield::ComponentCST::Initialise(), Garfield::ComponentElmer2d::Initialise(), Garfield::ComponentElmer::Initialise(), Garfield::ComponentComsol::SetDynamicWeightingPotential(), and Garfield::ComponentCST::SetWeightingField().
|
protected |
Definition at line 2792 of file ComponentFieldMap.cc.
Referenced by Field(), GetMedium(), and Potential().
void Garfield::ComponentFieldMap::PrintMaterials | ( | ) |
List all currently defined materials.
Definition at line 511 of file ComponentFieldMap.cc.
Referenced by Garfield::ComponentAnsys121::Initialise(), Garfield::ComponentAnsys123::Initialise(), and Garfield::ComponentCST::Initialise().
|
protected |
Definition at line 2780 of file ComponentFieldMap.cc.
Referenced by Check(), DriftMedium(), ElectricField(), GetMedium(), NotDriftMedium(), PrintMaterials(), Garfield::ComponentAnsys121::SetWeightingField(), Garfield::ComponentAnsys123::SetWeightingField(), Garfield::ComponentElmer2d::SetWeightingField(), Garfield::ComponentElmer::SetWeightingField(), UpdatePeriodicity2d(), and UpdatePeriodicityCommon().
void Garfield::ComponentFieldMap::PrintRange | ( | ) |
Show x, y, z, V and angular ranges.
Definition at line 2390 of file ComponentFieldMap.cc.
Referenced by SetRange(), and UpdatePeriodicityCommon().
|
protected |
Definition at line 2773 of file ComponentFieldMap.cc.
Referenced by DelayedWeightingPotential(), GetMedium(), and Garfield::ComponentCST::WeightingField().
|
staticprotected |
Definition at line 2660 of file ComponentFieldMap.cc.
Referenced by Garfield::ComponentAnsys121::Initialise(), Garfield::ComponentAnsys123::Initialise(), Garfield::ComponentCST::Initialise(), Garfield::ComponentElmer2d::Initialise(), Garfield::ComponentElmer::Initialise(), and Garfield::ComponentCST::SetWeightingField().
|
staticprotected |
Definition at line 2651 of file ComponentFieldMap.cc.
Referenced by Garfield::ComponentAnsys121::Initialise(), Garfield::ComponentAnsys123::Initialise(), Garfield::ComponentCST::Initialise(), Garfield::ComponentElmer2d::Initialise(), Garfield::ComponentElmer::Initialise(), and Garfield::ComponentCST::SetWeightingField().
|
overrideprotectedvirtual |
Reset the component.
Implements Garfield::Component.
Definition at line 2099 of file ComponentFieldMap.cc.
Referenced by Garfield::ComponentAnsys121::Initialise(), Garfield::ComponentAnsys123::Initialise(), Garfield::ComponentComsol::Initialise(), Garfield::ComponentCST::Initialise(), Garfield::ComponentElmer2d::Initialise(), and Garfield::ComponentElmer::Initialise().
|
staticprotected |
Definition at line 2637 of file ComponentFieldMap.cc.
Referenced by Garfield::ComponentAnsys121::Initialise(), Garfield::ComponentAnsys123::Initialise(), Garfield::ComponentComsol::Initialise(), Garfield::ComponentCST::Initialise(), Garfield::ComponentCST::Initialise(), Garfield::ComponentElmer2d::Initialise(), and Garfield::ComponentElmer::Initialise().
|
protected |
Find lowest epsilon, check for eps = 0, set default drift media flags.
Definition at line 755 of file ComponentFieldMap.cc.
Referenced by Garfield::ComponentAnsys121::Initialise(), Garfield::ComponentAnsys123::Initialise(), Garfield::ComponentComsol::Initialise(), Garfield::ComponentCST::Initialise(), Garfield::ComponentElmer2d::Initialise(), and Garfield::ComponentElmer::Initialise().
void Garfield::ComponentFieldMap::SetGas | ( | Medium * | medium | ) |
Associate all field map materials with a relative permittivity of unity to a given Medium class.
Definition at line 609 of file ComponentFieldMap.cc.
Referenced by main().
void Garfield::ComponentFieldMap::SetMedium | ( | const size_t | imat, |
Medium * | medium ) |
Associate a field map material with a Medium object.
Definition at line 585 of file ComponentFieldMap.cc.
|
protectedvirtual |
Reimplemented in Garfield::ComponentCST.
Definition at line 2299 of file ComponentFieldMap.cc.
Referenced by Prepare().
|
protected |
Interpolation of potential between two time slices.
Definition at line 2883 of file ComponentFieldMap.cc.
Referenced by DelayedWeightingPotential().
|
protected |
Move (ex, ey, ez) to global coordinates.
Definition at line 2563 of file ComponentFieldMap.cc.
Referenced by Field().
|
inlineoverrideprotectedvirtual |
Verify periodicities.
Implements Garfield::Component.
Definition at line 244 of file ComponentFieldMap.hh.
Referenced by Garfield::ComponentCST::Initialise(), Prepare(), and Garfield::ComponentCST::ShiftComponent().
|
protected |
Definition at line 2271 of file ComponentFieldMap.cc.
Referenced by UpdatePeriodicity().
|
protected |
Definition at line 2152 of file ComponentFieldMap.cc.
Referenced by UpdatePeriodicity().
|
overridevirtual |
Calculate the weighting field at a given point and for a given electrode.
x,y,z | coordinates [cm]. |
wx,wy,wz | components of the weighting field [1/cm]. |
label | name of the electrode |
Reimplemented from Garfield::Component.
Definition at line 190 of file ComponentFieldMap.cc.
|
overridevirtual |
Calculate the weighting potential at a given point.
x,y,z | coordinates [cm]. |
label | name of the electrode. |
Reimplemented from Garfield::Component.
Definition at line 207 of file ComponentFieldMap.cc.
|
friend |
Definition at line 135 of file ComponentFieldMap.hh.
Referenced by ViewFEMesh.
|
protected |
Definition at line 160 of file ComponentFieldMap.hh.
Referenced by FindElement13(), FindElement5(), and Reset().
|
protected |
Definition at line 159 of file ComponentFieldMap.hh.
Referenced by FindElement13(), FindElement5(), and Reset().
|
protected |
Definition at line 214 of file ComponentFieldMap.hh.
Referenced by PrintRange(), and UpdatePeriodicityCommon().
|
protected |
Definition at line 157 of file ComponentFieldMap.hh.
Referenced by Check(), DelayedWeightingPotential(), Field(), FindElement5(), GetElement(), Garfield::ComponentAnsys121::Initialise(), Garfield::ComponentAnsys123::Initialise(), Garfield::ComponentComsol::Initialise(), Garfield::ComponentElmer2d::Initialise(), Garfield::ComponentElmer::Initialise(), Potential(), PrintElement(), and Reset().
|
protected |
Definition at line 222 of file ComponentFieldMap.hh.
Referenced by Garfield::ComponentCST::ComponentCST(), EnableDeleteBackgroundElements(), Garfield::ComponentAnsys121::Initialise(), and Garfield::ComponentAnsys123::Initialise().
|
protected |
Definition at line 176 of file ComponentFieldMap.hh.
Referenced by DelayedWeightingPotential(), Reset(), and Garfield::ComponentComsol::SetDynamicWeightingPotential().
|
protected |
Definition at line 155 of file ComponentFieldMap.hh.
Referenced by FindElement13(), FindElement5(), and Prepare().
|
protected |
Definition at line 154 of file ComponentFieldMap.hh.
Referenced by Check(), DelayedWeightingPotential(), ElectricField(), Field(), FindElement13(), FindElement5(), FindElementCube(), GetAspectRatio(), GetElement(), GetElement(), GetElementVolume(), GetMedium(), GetNumberOfElements(), Garfield::ComponentAnsys121::Initialise(), Garfield::ComponentAnsys123::Initialise(), Garfield::ComponentComsol::Initialise(), Garfield::ComponentElmer2d::Initialise(), Garfield::ComponentElmer::Initialise(), Potential(), Prepare(), PrintElement(), and Reset().
|
protected |
Definition at line 145 of file ComponentFieldMap.hh.
Referenced by Garfield::ComponentAnsys121::ComponentAnsys121(), Garfield::ComponentElmer2d::ComponentElmer2d(), DelayedWeightingPotential(), Field(), GetAspectRatio(), GetElement(), GetElementVolume(), GetMedium(), Potential(), Prepare(), and PrintElement().
|
protected |
Definition at line 204 of file ComponentFieldMap.hh.
Referenced by Reset(), Garfield::ComponentCST::SetRange(), and SetRange().
|
protected |
Definition at line 138 of file ComponentFieldMap.hh.
Referenced by Check(), Garfield::ComponentAnsys121::ComponentAnsys121(), Garfield::ComponentElmer2d::ComponentElmer2d(), Field(), GetMedium(), Potential(), Garfield::ComponentCST::SetRange(), SetRange(), and UpdatePeriodicity().
|
protected |
Definition at line 212 of file ComponentFieldMap.hh.
Referenced by MapCoordinates(), SetRange(), and UpdatePeriodicityCommon().
|
protected |
Definition at line 211 of file ComponentFieldMap.hh.
Referenced by MapCoordinates(), SetRange(), and UpdatePeriodicityCommon().
|
protected |
Definition at line 210 of file ComponentFieldMap.hh.
Referenced by GetElementaryCell(), MapCoordinates(), PrintRange(), Garfield::ComponentCST::SetRange(), SetRange(), Garfield::ComponentAnsys121::SetRangeZ(), Garfield::ComponentElmer2d::SetRangeZ(), and UpdatePeriodicityCommon().
|
protected |
Definition at line 209 of file ComponentFieldMap.hh.
Referenced by GetElementaryCell(), MapCoordinates(), PrintRange(), Garfield::ComponentCST::SetRange(), SetRange(), Garfield::ComponentAnsys121::SetRangeZ(), Garfield::ComponentElmer2d::SetRangeZ(), and UpdatePeriodicityCommon().
|
protected |
Definition at line 213 of file ComponentFieldMap.hh.
Referenced by PrintRange(), and UpdatePeriodicityCommon().
|
protected |
Definition at line 217 of file ComponentFieldMap.hh.
Referenced by GetVoltageRange(), PrintRange(), Garfield::ComponentCST::SetRange(), and SetRange().
|
protected |
Definition at line 216 of file ComponentFieldMap.hh.
Referenced by GetVoltageRange(), PrintRange(), Garfield::ComponentCST::SetRange(), and SetRange().
|
protected |
Definition at line 188 of file ComponentFieldMap.hh.
Referenced by DriftMedium(), ElectricField(), GetConductivity(), Garfield::ComponentCST::GetElement(), GetElement(), Garfield::ComponentCST::GetMedium(), GetMedium(), GetMedium(), GetNumberOfMaterials(), GetPermittivity(), Garfield::ComponentAnsys121::Initialise(), Garfield::ComponentAnsys123::Initialise(), Garfield::ComponentComsol::Initialise(), Garfield::ComponentCST::Initialise(), Garfield::ComponentCST::Initialise(), Garfield::ComponentElmer2d::Initialise(), Garfield::ComponentElmer::Initialise(), NotDriftMedium(), PrintMaterials(), Reset(), SetDefaultDriftMedium(), SetGas(), SetMedium(), and Garfield::ComponentCST::WeightingField().
|
protected |
Definition at line 206 of file ComponentFieldMap.hh.
Referenced by Garfield::ComponentAnsys121::ComponentAnsys121(), Garfield::ComponentCST::ComponentCST(), Garfield::ComponentElmer2d::ComponentElmer2d(), Field(), GetBoundingBox(), GetMedium(), IsInBoundingBox(), Potential(), Garfield::ComponentCST::SetRange(), SetRange(), Garfield::ComponentAnsys121::SetRangeZ(), Garfield::ComponentCST::SetRangeZ(), Garfield::ComponentElmer2d::SetRangeZ(), and UpdatePeriodicityCommon().
|
protected |
Definition at line 205 of file ComponentFieldMap.hh.
Referenced by Garfield::ComponentAnsys121::ComponentAnsys121(), Garfield::ComponentCST::ComponentCST(), Garfield::ComponentElmer2d::ComponentElmer2d(), Field(), GetBoundingBox(), GetMedium(), IsInBoundingBox(), Potential(), Garfield::ComponentCST::SetRange(), SetRange(), Garfield::ComponentAnsys121::SetRangeZ(), Garfield::ComponentCST::SetRangeZ(), Garfield::ComponentElmer2d::SetRangeZ(), and UpdatePeriodicityCommon().
|
protected |
Definition at line 169 of file ComponentFieldMap.hh.
Referenced by FindElement13(), FindElement5(), FindElementCube(), GetAspectRatio(), GetElementVolume(), GetNode(), GetNumberOfNodes(), Garfield::ComponentAnsys121::Initialise(), Garfield::ComponentAnsys123::Initialise(), Garfield::ComponentComsol::Initialise(), Garfield::ComponentElmer2d::Initialise(), Garfield::ComponentElmer::Initialise(), Prepare(), PrintElement(), Reset(), Garfield::ComponentComsol::SetDynamicWeightingPotential(), SetRange(), Garfield::ComponentAnsys121::SetWeightingField(), Garfield::ComponentAnsys123::SetWeightingField(), Garfield::ComponentElmer2d::SetWeightingField(), Garfield::ComponentElmer::SetWeightingField(), and Garfield::ComponentComsol::SetWeightingPotential().
|
protected |
Definition at line 226 of file ComponentFieldMap.hh.
Referenced by PrintWarning(), and Reset().
|
protected |
Definition at line 172 of file ComponentFieldMap.hh.
Referenced by ElectricField(), ElectricField(), GetMedium(), GetPotential(), Garfield::ComponentAnsys121::Initialise(), Garfield::ComponentAnsys123::Initialise(), Garfield::ComponentComsol::Initialise(), Garfield::ComponentElmer2d::Initialise(), Garfield::ComponentElmer::Initialise(), Reset(), and SetRange().
|
protected |
Definition at line 230 of file ComponentFieldMap.hh.
Referenced by EnableConvergenceWarnings().
|
protected |
Definition at line 219 of file ComponentFieldMap.hh.
Referenced by SetRange().
|
protected |
Definition at line 162 of file ComponentFieldMap.hh.
Referenced by FindElement13(), Prepare(), and Reset().
|
protected |
Definition at line 225 of file ComponentFieldMap.hh.
Referenced by DelayedWeightingPotential(), GetMedium(), PrintWarning(), Reset(), UpdatePeriodicity2d(), UpdatePeriodicityCommon(), and Garfield::ComponentCST::WeightingField().
|
protected |
Definition at line 201 of file ComponentFieldMap.hh.
Referenced by DelayedWeightingPotential(), Garfield::ComponentComsol::SetDynamicWeightingPotential(), Garfield::ComponentComsol::SetTimeInterval(), and TimeInterpolation().
|
protected |
Definition at line 199 of file ComponentFieldMap.hh.
Referenced by CopyWeightingPotential(), DelayedWeightingPotential(), Reset(), and WeightingPotential().
|
protected |
Definition at line 174 of file ComponentFieldMap.hh.
Referenced by CopyWeightingPotential(), Garfield::ComponentComsol::Initialise(), Reset(), Garfield::ComponentComsol::SetDynamicWeightingPotential(), Garfield::ComponentAnsys121::SetWeightingField(), Garfield::ComponentAnsys123::SetWeightingField(), Garfield::ComponentElmer2d::SetWeightingField(), Garfield::ComponentElmer::SetWeightingField(), Garfield::ComponentComsol::SetWeightingPotential(), WeightingField(), and WeightingPotential().