Garfield++ 5.0
A toolkit for the detailed simulation of particle detectors based on ionisation measurement in gases and semiconductors
|
Component for interpolating field maps on a regular mesh. More...
#include <ComponentGrid.hh>
Public Member Functions | |
ComponentGrid () | |
Constructor. | |
~ComponentGrid () | |
Destructor. | |
bool | SetMesh (const unsigned int nx, const unsigned int ny, const unsigned int nz, const double xmin, const double xmax, const double ymin, const double ymax, const double zmin, const double zmax) |
bool | GetMesh (unsigned int &nx, unsigned int &ny, unsigned int &nz, double &xmin, double &xmax, double &ymin, double &ymax, double &zmin, double &zmax) const |
Retrieve the parameters of the grid. | |
void | SetCartesianCoordinates () |
Use Cartesian coordinates (default). | |
void | SetCylindricalCoordinates () |
Use cylindrical coordinates. | |
bool | LoadElectricField (const std::string &filename, const std::string &format, const bool withPotential, const bool withFlag, const double scaleX=1., const double scaleE=1., const double scaleP=1.) |
bool | LoadWeightingField (const std::string &filename, const std::string &format, const bool withPotential, const double scaleX=1., const double scaleE=1., const double scaleP=1.) |
Import (prompt) weighting field from file. | |
bool | LoadWeightingField (const std::string &filename, const std::string &format, const double time, const bool withPotential, const double scaleX=1., const double scaleE=1., const double scaleP=1.) |
Import delayed weighting field from file. | |
void | SetWeightingFieldOffset (const double x, const double y, const double z) |
bool | LoadMagneticField (const std::string &filename, const std::string &format, const double scaleX=1., const double scaleB=1.) |
Import magnetic field values from a file. | |
bool | SaveElectricField (Component *cmp, const std::string &filename, const std::string &fmt) |
bool | SaveWeightingField (Component *cmp, const std::string &id, const std::string &filename, const std::string &fmt) |
bool | GetElectricField (const unsigned int i, const unsigned int j, const unsigned int k, double &v, double &ex, double &ey, double &ez) const |
Return the field at a given node. | |
void | SetMedium (Medium *m) |
Set the medium. | |
Medium * | GetMedium () const |
Get the medium. | |
void | Print () |
Print information about the mesh and the available data. | |
bool | LoadElectronAttachment (const std::string &fname, const std::string &fmt, const unsigned int col, const double scaleX=1.) |
bool | LoadHoleAttachment (const std::string &fname, const std::string &fmt, const unsigned int col, const double scaleX=1.) |
Import hole attachment coefficients from a file. | |
bool | LoadElectronVelocity (const std::string &fname, const std::string &fmt, const double scaleX=1., const double scaleV=1.e-9) |
bool | LoadHoleVelocity (const std::string &fname, const std::string &fmt, const double scaleX=1., const double scaleV=1.e-9) |
Import a map of hole drift velocities from a file. | |
void | Clear () override |
Reset. | |
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 | ElectricField (const double x, const double y, const double z, double &ex, double &ey, double &ez, Medium *&m, int &status) override |
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 |
void | DelayedWeightingField (const double x, const double y, const double z, const double t, double &wx, double &wy, double &wz, const std::string &label) override |
double | DelayedWeightingPotential (const double x, const double y, const double z, const double t, const std::string &label) override |
void | MagneticField (const double x, const double y, const double z, double &bx, double &by, double &bz, int &status) override |
Medium * | GetMedium (const double x, const double y, const double z) override |
Get the medium at a given location (x, y, z). | |
bool | GetVoltageRange (double &vmin, double &vmax) override |
Calculate the voltage range [V]. | |
bool | GetElectricFieldRange (double &exmin, double &exmax, double &eymin, double &eymax, double &ezmin, double &ezmax) |
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 | HasMagneticField () const override |
Does the component have a non-zero magnetic field? | |
bool | HasAttachmentMap () const override |
Does the component have attachment maps? | |
bool | ElectronAttachment (const double x, const double y, const double z, double &att) override |
Get the electron attachment coefficient. | |
bool | HoleAttachment (const double x, const double y, const double z, double &att) override |
Get the hole attachment coefficient. | |
bool | HasVelocityMap () const override |
Does the component have velocity maps? | |
bool | ElectronVelocity (const double x, const double y, const double z, double &vx, double &vy, double &vz) override |
Get the electron drift velocity. | |
bool | HoleVelocity (const double x, const double y, const double z, double &vx, double &vy, double &vz) override |
Get the hole drift velocity. | |
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. | |
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). | |
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 | HasTownsendMap () const |
Does the component have maps of the Townsend 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 | 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 interpolating field maps on a regular mesh.
Definition at line 12 of file ComponentGrid.hh.
Garfield::ComponentGrid::ComponentGrid | ( | ) |
|
inline |
|
inlineoverridevirtual |
Reset.
Reimplemented from Garfield::Component.
Definition at line 145 of file ComponentGrid.hh.
|
overridevirtual |
Calculate the delayed weighting field at a given point and time and for a given electrode.
x,y,z | coordinates [cm]. |
t | time [ns]. |
wx,wy,wz | components of the weighting field [1/cm]. |
label | name of the electrode |
Reimplemented from Garfield::Component.
Definition at line 118 of file ComponentGrid.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 158 of file ComponentGrid.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 56 of file ComponentGrid.cc.
Referenced by ElectricField().
|
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 84 of file ComponentGrid.cc.
|
overridevirtual |
Get the electron attachment coefficient.
Reimplemented from Garfield::Component.
Definition at line 1928 of file ComponentGrid.cc.
|
overridevirtual |
Get the electron drift velocity.
Reimplemented from Garfield::Component.
Definition at line 1601 of file ComponentGrid.cc.
|
overridevirtual |
Get the bounding box coordinates.
Reimplemented from Garfield::Component.
Definition at line 1213 of file ComponentGrid.cc.
bool Garfield::ComponentGrid::GetElectricField | ( | const unsigned int | i, |
const unsigned int | j, | ||
const unsigned int | k, | ||
double & | v, | ||
double & | ex, | ||
double & | ey, | ||
double & | ez ) const |
Return the field at a given node.
Definition at line 1423 of file ComponentGrid.cc.
bool Garfield::ComponentGrid::GetElectricFieldRange | ( | double & | exmin, |
double & | exmax, | ||
double & | eymin, | ||
double & | eymax, | ||
double & | ezmin, | ||
double & | ezmax ) |
Definition at line 1285 of file ComponentGrid.cc.
|
overridevirtual |
Get the coordinates of the elementary cell.
Reimplemented from Garfield::Component.
Definition at line 1254 of file ComponentGrid.cc.
|
inline |
|
overridevirtual |
Get the medium at a given location (x, y, z).
Reimplemented from Garfield::Component.
Definition at line 214 of file ComponentGrid.cc.
bool Garfield::ComponentGrid::GetMesh | ( | unsigned int & | nx, |
unsigned int & | ny, | ||
unsigned int & | nz, | ||
double & | xmin, | ||
double & | xmax, | ||
double & | ymin, | ||
double & | ymax, | ||
double & | zmin, | ||
double & | zmax ) const |
Retrieve the parameters of the grid.
Definition at line 315 of file ComponentGrid.cc.
|
overridevirtual |
Calculate the voltage range [V].
Implements Garfield::Component.
Definition at line 1278 of file ComponentGrid.cc.
|
inlineoverridevirtual |
Does the component have attachment maps?
Reimplemented from Garfield::Component.
Definition at line 178 of file ComponentGrid.hh.
|
overridevirtual |
Does the component have a non-zero magnetic field?
Reimplemented from Garfield::Component.
Definition at line 210 of file ComponentGrid.cc.
|
inlineoverridevirtual |
Does the component have velocity maps?
Reimplemented from Garfield::Component.
Definition at line 186 of file ComponentGrid.hh.
|
overridevirtual |
Get the hole attachment coefficient.
Reimplemented from Garfield::Component.
Definition at line 1938 of file ComponentGrid.cc.
|
overridevirtual |
Get the hole drift velocity.
Reimplemented from Garfield::Component.
Definition at line 1613 of file ComponentGrid.cc.
bool Garfield::ComponentGrid::LoadElectricField | ( | const std::string & | filename, |
const std::string & | format, | ||
const bool | withPotential, | ||
const bool | withFlag, | ||
const double | scaleX = 1., | ||
const double | scaleE = 1., | ||
const double | scaleP = 1. ) |
Import electric field and potential values from a file. The file is supposed to contain one line for each grid point starting with
followed by
Format types are:
If cylindrical coordinates are used, the first coordinate (x) corresponds to the radial distance and the second coordinate (y) corresponds to the azimuth (in radian).
Definition at line 352 of file ComponentGrid.cc.
bool Garfield::ComponentGrid::LoadElectronAttachment | ( | const std::string & | fname, |
const std::string & | fmt, | ||
const unsigned int | col, | ||
const double | scaleX = 1. ) |
Import electron attachment coefficients from a file.
fname | name of the text file. |
fmt | format string, see LoadElectricField. |
col | column in the file which has the attachment coefficient. |
scaleX | scaling factor to be applied to the coordinates. |
Definition at line 1625 of file ComponentGrid.cc.
bool Garfield::ComponentGrid::LoadElectronVelocity | ( | const std::string & | fname, |
const std::string & | fmt, | ||
const double | scaleX = 1., | ||
const double | scaleV = 1.e-9 ) |
Import a map of electron drift velocities from a file.
fname | name of the text file. |
fmt | format string, see LoadElectricField |
scaleX | scaling factor to be applied to the coordinates. |
scaleV | scaling factor to be applied to the velocity components. |
Definition at line 1579 of file ComponentGrid.cc.
bool Garfield::ComponentGrid::LoadHoleAttachment | ( | const std::string & | fname, |
const std::string & | fmt, | ||
const unsigned int | col, | ||
const double | scaleX = 1. ) |
Import hole attachment coefficients from a file.
Definition at line 1633 of file ComponentGrid.cc.
bool Garfield::ComponentGrid::LoadHoleVelocity | ( | const std::string & | fname, |
const std::string & | fmt, | ||
const double | scaleX = 1., | ||
const double | scaleV = 1.e-9 ) |
Import a map of hole drift velocities from a file.
Definition at line 1590 of file ComponentGrid.cc.
bool Garfield::ComponentGrid::LoadMagneticField | ( | const std::string & | filename, |
const std::string & | format, | ||
const double | scaleX = 1., | ||
const double | scaleB = 1. ) |
Import magnetic field values from a file.
Definition at line 407 of file ComponentGrid.cc.
bool Garfield::ComponentGrid::LoadWeightingField | ( | const std::string & | filename, |
const std::string & | format, | ||
const bool | withPotential, | ||
const double | scaleX = 1., | ||
const double | scaleE = 1., | ||
const double | scaleP = 1. ) |
Import (prompt) weighting field from file.
Definition at line 373 of file ComponentGrid.cc.
Referenced by main().
bool Garfield::ComponentGrid::LoadWeightingField | ( | const std::string & | filename, |
const std::string & | format, | ||
const double | time, | ||
const bool | withPotential, | ||
const double | scaleX = 1., | ||
const double | scaleE = 1., | ||
const double | scaleP = 1. ) |
Import delayed weighting field from file.
Definition at line 385 of file ComponentGrid.cc.
|
overridevirtual |
Calculate the magnetic field at a given point.
x,y,z | coordinates [cm]. |
bx,by,bz | components of the magnetic field [Tesla]. |
status | status flag. |
Reimplemented from Garfield::Component.
Definition at line 195 of file ComponentGrid.cc.
void Garfield::ComponentGrid::Print | ( | ) |
Print information about the mesh and the available data.
Definition at line 1447 of file ComponentGrid.cc.
Referenced by main().
bool Garfield::ComponentGrid::SaveElectricField | ( | Component * | cmp, |
const std::string & | filename, | ||
const std::string & | fmt ) |
Export the electric field and potential of a component to a text file.
cmp | Component object for which to export the field/potential |
filename | name of the text file |
fmt | format string, see LoadElectricField |
Definition at line 419 of file ComponentGrid.cc.
bool Garfield::ComponentGrid::SaveWeightingField | ( | Component * | cmp, |
const std::string & | id, | ||
const std::string & | filename, | ||
const std::string & | fmt ) |
Export the weighting field and potential of a component to a text file.
cmp | Component object for which to export the field/potential |
id | identifier of the weighting field |
filename | name of the text file |
fmt | format string, see LoadElectricField |
Definition at line 508 of file ComponentGrid.cc.
|
inline |
Use Cartesian coordinates (default).
Definition at line 34 of file ComponentGrid.hh.
void Garfield::ComponentGrid::SetCylindricalCoordinates | ( | ) |
Use cylindrical coordinates.
Definition at line 332 of file ComponentGrid.cc.
void Garfield::ComponentGrid::SetMedium | ( | Medium * | m | ) |
Set the medium.
Definition at line 1312 of file ComponentGrid.cc.
bool Garfield::ComponentGrid::SetMesh | ( | const unsigned int | nx, |
const unsigned int | ny, | ||
const unsigned int | nz, | ||
const double | xmin, | ||
const double | xmax, | ||
const double | ymin, | ||
const double | ymax, | ||
const double | zmin, | ||
const double | zmax ) |
Define the grid.
nx,ny,nz | number of nodes along ![]() |
xmin,xmax | range along ![]() |
ymin,ymax | range along ![]() |
zmin,zmax | range along ![]() |
Definition at line 257 of file ComponentGrid.cc.
void Garfield::ComponentGrid::SetWeightingFieldOffset | ( | const double | x, |
const double | y, | ||
const double | z ) |
Offset coordinates in the weighting field, such that the same numerical weighting field map can be used for electrodes at different positions.
Definition at line 190 of file ComponentGrid.cc.
|
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 91 of file ComponentGrid.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 104 of file ComponentGrid.cc.