Garfield++ 5.0
A toolkit for the detailed simulation of particle detectors based on ionisation measurement in gases and semiconductors
|
Component for parallel-plate geometries. More...
#include <ComponentParallelPlate.hh>
Public Member Functions | |
ComponentParallelPlate () | |
Constructor. | |
~ComponentParallelPlate () | |
Destructor. | |
void | Setup (const int N, std::vector< double > eps, std::vector< double > d, const double V, std::vector< int > sigmaIndex={}) |
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). | |
double | WeightingPotential (const double x, const double y, const double z, const std::string &label) override |
bool | GetVoltageRange (double &vmin, double &vmax) override |
Calculate the voltage range [V]. | |
void | AddPixel (double x, double z, double lx, double lz, const std::string &label, bool fromAnode=true) |
void | AddStrip (double z, double lz, const std::string &label, bool fromAnode=true) |
Add strip electrode. | |
void | AddPlane (const std::string &label, bool fromAnode=true) |
void | SetMedium (Medium *medium) |
Setting the medium. | |
void | SetWeightingPotentialGrid (const double xmin, const double xmax, const double xsteps, const double ymin, const double ymax, const double ysteps, const double zmin, const double zmax, const double zsteps, const std::string &label) |
void | SetWeightingPotentialGrids (const double xmin, const double xmax, const double xsteps, const double ymin, const double ymax, const double ysteps, const double zmin, const double zmax, const double zsteps) |
void | LoadWeightingPotentialGrid (const std::string &label) |
Medium * | GetMedium (const double x, const double y, const double z) override |
Get the medium at a given location (x, y, z). | |
bool | GetBoundingBox (double &xmin, double &ymin, double &zmin, double &xmax, double &ymax, double &zmax) override |
Get the bounding box coordinates. | |
bool | getLayer (const double y, int &m, double &epsM) |
int | NumberOfLayers () |
void | SetIntegrationPrecision (const double eps) |
void | SetIntegrationUpperbound (const double p) |
void | DisablePotentialCalculationOutsideGasGap () |
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 | WeightingField (const double x, const double y, const double z, double &wx, double &wy, double &wz, const std::string &label) |
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 double | DelayedWeightingPotential (const double x, const double y, const double z, const double t, 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? | |
virtual bool | GetElementaryCell (double &xmin, double &ymin, double &zmin, double &xmax, double &ymax, double &zmax) |
Get the coordinates of the elementary cell. | |
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 () |
Additional Inherited Members | |
![]() | |
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. | |
Component for parallel-plate geometries.
Definition at line 17 of file ComponentParallelPlate.hh.
Garfield::ComponentParallelPlate::ComponentParallelPlate | ( | ) |
|
inline |
void Garfield::ComponentParallelPlate::AddPixel | ( | double | x, |
double | z, | ||
double | lx, | ||
double | lz, | ||
const std::string & | label, | ||
bool | fromAnode = true ) |
Add a pixel electrode.
x,z | position of the center of the electrode in the xz-plane. |
lx | width in the along ![]() |
lz | width in the along ![]() |
label | give name using a string. |
fromAnode | is ![]() ![]() |
Definition at line 290 of file ComponentParallelPlate.cc.
void Garfield::ComponentParallelPlate::AddPlane | ( | const std::string & | label, |
bool | fromAnode = true ) |
Add plane electrode, if you want to read the signal from the cathode set the second argument to false.
Definition at line 337 of file ComponentParallelPlate.cc.
void Garfield::ComponentParallelPlate::AddStrip | ( | double | z, |
double | lz, | ||
const std::string & | label, | ||
bool | fromAnode = true ) |
Add strip electrode.
Definition at line 316 of file ComponentParallelPlate.cc.
|
inline |
Definition at line 137 of file ComponentParallelPlate.hh.
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 185 of file ComponentParallelPlate.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 148 of file ComponentParallelPlate.cc.
|
overridevirtual |
Get the bounding box coordinates.
Reimplemented from Garfield::Component.
Definition at line 81 of file ComponentParallelPlate.cc.
|
inline |
Definition at line 115 of file ComponentParallelPlate.hh.
Referenced by Garfield::AvalancheGrid::AsignLayerIndex(), ElectricField(), and ElectricField().
|
overridevirtual |
Get the medium at a given location (x, y, z).
Reimplemented from Garfield::Component.
Definition at line 355 of file ComponentParallelPlate.cc.
|
overridevirtual |
Calculate the voltage range [V].
Implements Garfield::Component.
Definition at line 227 of file ComponentParallelPlate.cc.
|
inline |
This will load a previously calculated grid of time-dependant weighting potential values.
Definition at line 91 of file ComponentParallelPlate.hh.
Referenced by SetWeightingPotentialGrid().
|
inline |
Definition at line 131 of file ComponentParallelPlate.hh.
Referenced by Garfield::AvalancheGrid::AsignLayerIndex().
|
inline |
Definition at line 133 of file ComponentParallelPlate.hh.
|
inline |
Definition at line 135 of file ComponentParallelPlate.hh.
|
inline |
Setting the medium.
Definition at line 66 of file ComponentParallelPlate.hh.
void Garfield::ComponentParallelPlate::Setup | ( | const int | N, |
std::vector< double > | eps, | ||
std::vector< double > | d, | ||
const double | V, | ||
std::vector< int > | sigmaIndex = {} ) |
Define the geometry.
N | amount of layers in the geometry, this includes the gas gaps ![]() |
d | thickness of the layers starting from the bottom to the top lauer along ![]() |
eps | relative permittivities of the layers starting from the bottom to the top lauer along ![]() |
sigmaIndex | Indices of the resistive layers (optional). |
V | applied potential difference between the parallel plates. |
Definition at line 17 of file ComponentParallelPlate.cc.
void Garfield::ComponentParallelPlate::SetWeightingPotentialGrid | ( | const double | xmin, |
const double | xmax, | ||
const double | xsteps, | ||
const double | ymin, | ||
const double | ymax, | ||
const double | ysteps, | ||
const double | zmin, | ||
const double | zmax, | ||
const double | zsteps, | ||
const std::string & | label ) |
Calculate time-dependent weighting potential on a grid.
xmin,ymin,zmin | minimum value of the interval in the ![]() ![]() ![]() |
xmax,ymax,zmax | maximum value of the interval in the ![]() ![]() ![]() |
xsteps,ysteps,zsteps | mumber of grid nodes in the ![]() ![]() ![]() |
label | give name using a string. |
Definition at line 595 of file ComponentParallelPlate.cc.
Referenced by SetWeightingPotentialGrids().
void Garfield::ComponentParallelPlate::SetWeightingPotentialGrids | ( | const double | xmin, |
const double | xmax, | ||
const double | xsteps, | ||
const double | ymin, | ||
const double | ymax, | ||
const double | ysteps, | ||
const double | zmin, | ||
const double | zmax, | ||
const double | zsteps ) |
This will calculate all electrodes time-dependent weighting potential on the specified grid.
Definition at line 622 of file ComponentParallelPlate.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 240 of file ComponentParallelPlate.cc.