Garfield++ 5.0
A toolkit for the detailed simulation of particle detectors based on ionisation measurement in gases and semiconductors
Loading...
Searching...
No Matches
Garfield::Component Class Referenceabstract

Abstract base class for components. More...

#include <Component.hh>

+ Inheritance diagram for Garfield::Component:

Public Member Functions

 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.
 
virtual MediumGetMedium (const double x, const double y, const double z)
 Get the medium at a given location (x, y, z).
 
virtual void ElectricField (const double x, const double y, const double z, double &ex, double &ey, double &ez, Medium *&m, int &status)=0
 
virtual void ElectricField (const double x, const double y, const double z, double &ex, double &ey, double &ez, double &v, Medium *&m, int &status)=0
 Calculate the drift field [V/cm] and potential [V] at (x, y, z).
 
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 bool GetVoltageRange (double &vmin, double &vmax)=0
 Calculate the voltage range [V].
 
virtual void WeightingField (const double x, const double y, const double z, double &wx, double &wy, double &wz, const std::string &label)
 
virtual double WeightingPotential (const double x, const double y, const double z, 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 GetBoundingBox (double &xmin, double &ymin, double &zmin, double &xmax, double &ymax, double &zmax)
 Get the bounding box coordinates.
 
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 $x$ direction.
 
void EnablePeriodicityY (const bool on=true)
 Enable simple periodicity in the $y$ direction.
 
void EnablePeriodicityZ (const bool on=true)
 Enable simple periodicity in the $z$ direction.
 
void IsPeriodic (bool &perx, bool &pery, bool &perz)
 Return periodicity flags.
 
void EnableMirrorPeriodicityX (const bool on=true)
 Enable mirror periodicity in the $x$ direction.
 
void EnableMirrorPeriodicityY (const bool on=true)
 Enable mirror periodicity in the $y$ direction.
 
void EnableMirrorPeriodicityZ (const bool on=true)
 Enable mirror periodicity in the $y$ direction.
 
void IsMirrorPeriodic (bool &perx, bool &pery, bool &perz)
 Return mirror periodicity flags.
 
void EnableAxialPeriodicityX (const bool on=true)
 Enable axial periodicity in the $x$ direction.
 
void EnableAxialPeriodicityY (const bool on=true)
 Enable axial periodicity in the $y$ direction.
 
void EnableAxialPeriodicityZ (const bool on=true)
 Enable axial periodicity in the $z$ direction.
 
void IsAxiallyPeriodic (bool &perx, bool &pery, bool &perz)
 Return axial periodicity flags.
 
void EnableRotationSymmetryX (const bool on=true)
 Enable rotation symmetry around the $x$ axis.
 
void EnableRotationSymmetryY (const bool on=true)
 Enable rotation symmetry around the $y$ axis.
 
void EnableRotationSymmetryZ (const bool on=true)
 Enable rotation symmetry around the $z$ axis.
 
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 Member Functions

virtual void Reset ()=0
 Reset the component.
 
virtual void UpdatePeriodicity ()=0
 Verify periodicities.
 

Protected Attributes

std::string m_className = "Component"
 Class name.
 
Geometrym_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.
 

Detailed Description

Abstract base class for components.

Definition at line 13 of file Component.hh.

Constructor & Destructor Documentation

◆ Component() [1/2]

◆ Component() [2/2]

Garfield::Component::Component ( const std::string & name)

Constructor.

Definition at line 11 of file Component.cc.

11 {
12 m_className = "Component" + name;
13}
std::string m_className
Class name.
Definition Component.hh:359

◆ ~Component()

virtual Garfield::Component::~Component ( )
inlinevirtual

Destructor.

Definition at line 20 of file Component.hh.

20{}

Member Function Documentation

◆ Clear()

void Garfield::Component::Clear ( )
virtual

Reset.

Reimplemented in Garfield::ComponentGrid, and Garfield::ComponentVoxel.

Definition at line 29 of file Component.cc.

29 {
30 m_geometry = nullptr;
31 m_ready = false;
32 // Reset periodicities.
33 m_periodic.fill(false);
34 m_mirrorPeriodic.fill(false);
35 m_axiallyPeriodic.fill(false);
36 m_rotationSymmetric.fill(false);
37 // Reset the magnetic field.
38 m_b0.fill(0.);
39 Reset();
40}
std::array< bool, 3 > m_rotationSymmetric
Rotation symmetry around x-axis, y-axis, z-axis.
Definition Component.hh:380
std::array< bool, 3 > m_mirrorPeriodic
Mirror periodicity in x, y, z.
Definition Component.hh:376
virtual void Reset()=0
Reset the component.
std::array< bool, 3 > m_periodic
Simple periodicity in x, y, z.
Definition Component.hh:374
Geometry * m_geometry
Pointer to the geometry.
Definition Component.hh:362
bool m_ready
Ready for use?
Definition Component.hh:368
std::array< double, 3 > m_b0
Constant magnetic field.
Definition Component.hh:365
std::array< bool, 3 > m_axiallyPeriodic
Axial periodicity in x, y, z.
Definition Component.hh:378

◆ CrossedPlane()

bool Garfield::Component::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 )
virtual

Determine whether the line between two points crosses a plane.

Reimplemented in Garfield::ComponentAnalyticField.

Definition at line 148 of file Component.cc.

151 {
152 return false;
153}

◆ CrossedWire()

bool Garfield::Component::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

Determine whether the line between two points crosses a wire.

Parameters
x0,y0,z0first point [cm].
x1,y1,z1second point [cm]
xc,yc,zcpoint [cm] where the line crosses the wire or the coordinates of the wire centre.
centreflag whether to return the coordinates of the line-wire crossing point or of the wire centre.
rcradius [cm] of the wire.

Reimplemented in Garfield::ComponentAnalyticField, and Garfield::ComponentNeBem2d.

Definition at line 131 of file Component.cc.

135 {
136 return false;
137}

◆ DelayedWeightingField()

void Garfield::Component::DelayedWeightingField ( const double x,
const double y,
const double z,
const double t,
double & wx,
double & wy,
double & wz,
const std::string & label )
virtual

Calculate the delayed weighting field at a given point and time and for a given electrode.

Parameters
x,y,zcoordinates [cm].
ttime [ns].
wx,wy,wzcomponents of the weighting field [1/cm].
labelname of the electrode

Reimplemented in Garfield::ComponentGrid, Garfield::ComponentTcadBase< N >, Garfield::ComponentTcadBase< 2 >, Garfield::ComponentTcadBase< 3 >, Garfield::ComponentUser, and Garfield::ComponentVoxel.

Definition at line 70 of file Component.cc.

73 {
74 if (m_debug) {
75 std::cerr << m_className << "::DelayedWeightingField: Not implemented.\n";
76 }
77 wx = wy = wz = 0.;
78}
bool m_debug
Switch on/off debugging messages.
Definition Component.hh:371

◆ DelayedWeightingPotential()

double Garfield::Component::DelayedWeightingPotential ( const double x,
const double y,
const double z,
const double t,
const std::string & label )
virtual

Calculate the delayed weighting potential at a given point and time and for a given electrode.

Parameters
x,y,zcoordinates [cm].
ttime [ns].
labelname of the electrode

Reimplemented in Garfield::ComponentFieldMap, Garfield::ComponentGrid, Garfield::ComponentTcadBase< N >, Garfield::ComponentTcadBase< 2 >, Garfield::ComponentTcadBase< 3 >, Garfield::ComponentUser, and Garfield::ComponentVoxel.

Definition at line 89 of file Component.cc.

93 {
94 if (m_debug) {
95 std::cerr << m_className
96 << "::DelayedWeightingPotential: Not implemented.\n";
97 }
98 return 0.;
99}

◆ DisableDebugging()

void Garfield::Component::DisableDebugging ( )
inline

Switch off debugging messages.

Definition at line 294 of file Component.hh.

294{ m_debug = false; }

◆ ElectricField() [1/3]

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 42 of file Component.cc.

43 {
44 double ex = 0., ey = 0., ez = 0.;
45 Medium* medium = nullptr;
46 int status = 0;
47 ElectricField(x, y, z, ex, ey, ez, medium, status);
48 std::array<double, 3> efield = {ex, ey, ez};
49 return efield;
50}
virtual void ElectricField(const double x, const double y, const double z, double &ex, double &ey, double &ez, Medium *&m, int &status)=0

◆ ElectricField() [2/3]

virtual void Garfield::Component::ElectricField ( const double x,
const double y,
const double z,
double & ex,
double & ey,
double & ez,
double & v,
Medium *& m,
int & status )
pure virtual

◆ ElectricField() [3/3]

virtual void Garfield::Component::ElectricField ( const double x,
const double y,
const double z,
double & ex,
double & ey,
double & ez,
Medium *& m,
int & status )
pure virtual

Calculate the drift field at given point.

Parameters
x,y,zcoordinates [cm].
ex,ey,ezcomponents of the electric field [V/cm].
mpointer to the medium at this location.
statusstatus 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)

Implemented in Garfield::ComponentAnalyticField, Garfield::ComponentConstant, Garfield::ComponentCST, Garfield::ComponentFieldMap, Garfield::ComponentGrid, Garfield::ComponentNeBem2d, Garfield::ComponentNeBem3d, Garfield::ComponentNeBem3dMap, Garfield::ComponentParallelPlate, Garfield::ComponentTcad2d, Garfield::ComponentTcad3d, Garfield::ComponentUser, and Garfield::ComponentVoxel.

Referenced by ElectricField(), IntegrateFluxCircle(), IntegrateFluxLine(), IntegrateFluxSphere(), and Garfield::ComponentGrid::SaveElectricField().

◆ ElectricPotential()

double Garfield::Component::ElectricPotential ( const double x,
const double y,
const double z )
virtual

Calculate the (drift) electrostatic potential [V] at (x, y, z).

Definition at line 52 of file Component.cc.

53 {
54 double ex = 0., ey = 0., ez = 0., v = 0.;
55 Medium* medium = nullptr;
56 int status = 0;
57 ElectricField(x, y, z, ex, ey, ez, v, medium, status);
58 return v;
59}

◆ ElectronAttachment()

virtual bool Garfield::Component::ElectronAttachment ( const double ,
const double ,
const double ,
double & eta )
inlinevirtual

Get the electron attachment coefficient.

Reimplemented in Garfield::ComponentGrid, Garfield::ComponentTcadBase< N >, Garfield::ComponentTcadBase< 2 >, and Garfield::ComponentTcadBase< 3 >.

Definition at line 307 of file Component.hh.

308 {
309 eta = 0;
310 return false;
311 }

◆ ElectronTownsend()

virtual bool Garfield::Component::ElectronTownsend ( const double ,
const double ,
const double ,
double & alpha )
inlinevirtual

Get the electron Townsend coefficient.

Reimplemented in Garfield::ComponentTcadBase< N >, Garfield::ComponentTcadBase< 2 >, and Garfield::ComponentTcadBase< 3 >.

Definition at line 319 of file Component.hh.

320 {
321 alpha = 0;
322 return false;
323 }

◆ ElectronVelocity()

virtual bool Garfield::Component::ElectronVelocity ( const double ,
const double ,
const double ,
double & vx,
double & vy,
double & vz )
inlinevirtual

Get the electron drift velocity.

Reimplemented in Garfield::ComponentGrid, Garfield::ComponentTcadBase< N >, Garfield::ComponentTcadBase< 2 >, and Garfield::ComponentTcadBase< 3 >.

Definition at line 331 of file Component.hh.

333 {
334 vx = vy = vz = 0;
335 return false;
336 }

◆ EnableAxialPeriodicityX()

void Garfield::Component::EnableAxialPeriodicityX ( const bool on = true)
inline

Enable axial periodicity in the $x$ direction.

Definition at line 248 of file Component.hh.

248 {
249 m_axiallyPeriodic[0] = on;
251 }
virtual void UpdatePeriodicity()=0
Verify periodicities.

◆ EnableAxialPeriodicityY()

void Garfield::Component::EnableAxialPeriodicityY ( const bool on = true)
inline

Enable axial periodicity in the $y$ direction.

Definition at line 253 of file Component.hh.

253 {
254 m_axiallyPeriodic[1] = on;
256 }

◆ EnableAxialPeriodicityZ()

void Garfield::Component::EnableAxialPeriodicityZ ( const bool on = true)
inline

Enable axial periodicity in the $z$ direction.

Definition at line 258 of file Component.hh.

258 {
259 m_axiallyPeriodic[2] = on;
261 }

◆ EnableDebugging()

void Garfield::Component::EnableDebugging ( )
inline

Switch on debugging messages.

Definition at line 292 of file Component.hh.

292{ m_debug = true; }

◆ EnableMirrorPeriodicityX()

void Garfield::Component::EnableMirrorPeriodicityX ( const bool on = true)
inline

Enable mirror periodicity in the $x$ direction.

Definition at line 226 of file Component.hh.

226 {
227 m_mirrorPeriodic[0] = on;
229 }

◆ EnableMirrorPeriodicityY()

void Garfield::Component::EnableMirrorPeriodicityY ( const bool on = true)
inline

Enable mirror periodicity in the $y$ direction.

Definition at line 231 of file Component.hh.

231 {
232 m_mirrorPeriodic[1] = on;
234 }

Referenced by main().

◆ EnableMirrorPeriodicityZ()

void Garfield::Component::EnableMirrorPeriodicityZ ( const bool on = true)
inline

Enable mirror periodicity in the $y$ direction.

Definition at line 236 of file Component.hh.

236 {
237 m_mirrorPeriodic[2] = on;
239 }

◆ EnablePeriodicityX()

void Garfield::Component::EnablePeriodicityX ( const bool on = true)
inline

Enable simple periodicity in the $x$ direction.

Definition at line 204 of file Component.hh.

204 {
205 m_periodic[0] = on;
207 }

Referenced by main().

◆ EnablePeriodicityY()

void Garfield::Component::EnablePeriodicityY ( const bool on = true)
inline

Enable simple periodicity in the $y$ direction.

Definition at line 209 of file Component.hh.

209 {
210 m_periodic[1] = on;
212 }

◆ EnablePeriodicityZ()

void Garfield::Component::EnablePeriodicityZ ( const bool on = true)
inline

Enable simple periodicity in the $z$ direction.

Definition at line 214 of file Component.hh.

214 {
215 m_periodic[2] = on;
217 }

◆ EnableRotationSymmetryX()

void Garfield::Component::EnableRotationSymmetryX ( const bool on = true)
inline

Enable rotation symmetry around the $x$ axis.

Definition at line 270 of file Component.hh.

270 {
271 m_rotationSymmetric[0] = on;
273 }

◆ EnableRotationSymmetryY()

void Garfield::Component::EnableRotationSymmetryY ( const bool on = true)
inline

Enable rotation symmetry around the $y$ axis.

Definition at line 275 of file Component.hh.

275 {
276 m_rotationSymmetric[1] = on;
278 }

◆ EnableRotationSymmetryZ()

void Garfield::Component::EnableRotationSymmetryZ ( const bool on = true)
inline

Enable rotation symmetry around the $z$ axis.

Definition at line 280 of file Component.hh.

280 {
281 m_rotationSymmetric[2] = on;
283 }

◆ GetBoundingBox()

bool Garfield::Component::GetBoundingBox ( double & xmin,
double & ymin,
double & zmin,
double & xmax,
double & ymax,
double & zmax )
virtual

◆ GetElectronLifetime()

virtual bool Garfield::Component::GetElectronLifetime ( const double ,
const double ,
const double ,
double & etau )
inlinevirtual

Reimplemented in Garfield::ComponentTcadBase< N >, Garfield::ComponentTcadBase< 2 >, and Garfield::ComponentTcadBase< 3 >.

Definition at line 344 of file Component.hh.

345 {
346 etau = -1;
347 return false;
348 }

◆ GetElementaryCell()

bool Garfield::Component::GetElementaryCell ( double & xmin,
double & ymin,
double & zmin,
double & xmax,
double & ymax,
double & zmax )
virtual

Get the coordinates of the elementary cell.

Reimplemented in Garfield::ComponentAnalyticField, Garfield::ComponentFieldMap, Garfield::ComponentGrid, Garfield::ComponentNeBem2d, Garfield::ComponentTcad2d, Garfield::ComponentTcad3d, and Garfield::ComponentVoxel.

Definition at line 126 of file Component.cc.

127 {
128 return GetBoundingBox(xmin, ymin, zmin, xmax, ymax, zmax);
129}
virtual bool GetBoundingBox(double &xmin, double &ymin, double &zmin, double &xmax, double &ymax, double &zmax)
Get the bounding box coordinates.
Definition Component.cc:120

Referenced by Garfield::ViewBase::PlotLimits().

◆ GetHoleLifetime()

virtual bool Garfield::Component::GetHoleLifetime ( const double ,
const double ,
const double ,
double & htau )
inlinevirtual

Reimplemented in Garfield::ComponentTcadBase< N >, Garfield::ComponentTcadBase< 2 >, and Garfield::ComponentTcadBase< 3 >.

Definition at line 349 of file Component.hh.

350 {
351 htau = -1;
352 return false;
353 }

◆ GetMedium()

Medium * Garfield::Component::GetMedium ( const double x,
const double y,
const double z )
virtual

◆ GetVoltageRange()

◆ HasAttachmentMap()

virtual bool Garfield::Component::HasAttachmentMap ( ) const
inlinevirtual

Does the component have attachment maps?

Reimplemented in Garfield::ComponentGrid, Garfield::ComponentTcadBase< N >, Garfield::ComponentTcadBase< 2 >, and Garfield::ComponentTcadBase< 3 >.

Definition at line 302 of file Component.hh.

302{ return false; }

◆ HasMagneticField()

bool Garfield::Component::HasMagneticField ( ) const
virtual

Does the component have a non-zero magnetic field?

Reimplemented in Garfield::ComponentGrid, Garfield::ComponentUser, and Garfield::ComponentVoxel.

Definition at line 155 of file Component.cc.

155 {
156 return fabs(m_b0[0]) > Small || fabs(m_b0[1]) > Small ||
157 fabs(m_b0[2]) > Small;
158}
DoubleAc fabs(const DoubleAc &f)
Definition DoubleAc.h:615

Referenced by Garfield::ComponentGrid::HasMagneticField(), Garfield::ComponentUser::HasMagneticField(), and Garfield::ComponentVoxel::HasMagneticField().

◆ HasTownsendMap()

virtual bool Garfield::Component::HasTownsendMap ( ) const
inlinevirtual

Does the component have maps of the Townsend coefficient?

Reimplemented in Garfield::ComponentTcadBase< N >, Garfield::ComponentTcadBase< 2 >, and Garfield::ComponentTcadBase< 3 >.

Definition at line 300 of file Component.hh.

300{ return false; }

◆ HasVelocityMap()

virtual bool Garfield::Component::HasVelocityMap ( ) const
inlinevirtual

Does the component have velocity maps?

Reimplemented in Garfield::ComponentGrid, Garfield::ComponentTcadBase< N >, Garfield::ComponentTcadBase< 2 >, and Garfield::ComponentTcadBase< 3 >.

Definition at line 304 of file Component.hh.

304{ return false; }

◆ HoleAttachment()

virtual bool Garfield::Component::HoleAttachment ( const double ,
const double ,
const double ,
double & eta )
inlinevirtual

Get the hole attachment coefficient.

Reimplemented in Garfield::ComponentGrid, Garfield::ComponentTcadBase< N >, Garfield::ComponentTcadBase< 2 >, and Garfield::ComponentTcadBase< 3 >.

Definition at line 313 of file Component.hh.

314 {
315 eta = 0;
316 return false;
317 }

◆ HoleTownsend()

virtual bool Garfield::Component::HoleTownsend ( const double ,
const double ,
const double ,
double & alpha )
inlinevirtual

Get the hole Townsend coefficient.

Reimplemented in Garfield::ComponentTcadBase< N >, Garfield::ComponentTcadBase< 2 >, and Garfield::ComponentTcadBase< 3 >.

Definition at line 325 of file Component.hh.

326 {
327 alpha = 0;
328 return false;
329 }

◆ HoleVelocity()

virtual bool Garfield::Component::HoleVelocity ( const double ,
const double ,
const double ,
double & vx,
double & vy,
double & vz )
inlinevirtual

Get the hole drift velocity.

Reimplemented in Garfield::ComponentGrid, Garfield::ComponentTcadBase< N >, Garfield::ComponentTcadBase< 2 >, and Garfield::ComponentTcadBase< 3 >.

Definition at line 338 of file Component.hh.

340 {
341 vx = vy = vz = 0;
342 return false;
343 }

◆ IntegrateFluxCircle()

double Garfield::Component::IntegrateFluxCircle ( const double xc,
const double yc,
const double r,
const unsigned int nI = 50 )

Integrate the normal component of the electric field over a circle.

Parameters
xc,yccentre of the circle [cm]
rradius [cm]
nInumber of intervals for the integration
Returns
charge enclosed in the circle [fC / cm]

Definition at line 160 of file Component.cc.

161 {
162 // FLDIN2, FCHK3
163 if (nI == 0) {
164 std::cerr << m_className << "::IntegrateFluxCircle:\n"
165 << " Number of intervals must be > 0.\n";
166 return 0.;
167 }
168 // Number of Gaussian quadrature points per interval.
169 constexpr size_t nG = 6;
172
173 // Width and half-width of intervals.
174 const double d = TwoPi / nI;
175 const double h = 0.5 * d;
176 // Arguments of ElectricField.
177 double ex = 0., ey = 0., ez = 0.;
178 Medium* m = nullptr;
179 int status = 0;
180 // Perform the integration.
181 double s = 0.;
182 for (size_t i = 0; i < nG; ++i) {
183 const double phi0 = h * (1. + tg[i]);
184 for (unsigned int k = 0; k < nI; ++k) {
185 const double phi = phi0 + k * d;
186 const double cp = cos(phi);
187 const double sp = sin(phi);
188 ElectricField(xc + cp * r, yc + sp * r, 0., ex, ey, ez, m, status);
189 s += wg[i] * r * (ex * cp + ey * sp);
190 }
191 }
192 return h * s * VacuumPermittivity;
193}
constexpr std::array< double, 6 > GaussLegendreWeights6()
Definition Numerics.hh:49
constexpr std::array< double, 6 > GaussLegendreNodes6()
Definition Numerics.hh:44
DoubleAc cos(const DoubleAc &f)
Definition DoubleAc.cpp:432
DoubleAc sin(const DoubleAc &f)
Definition DoubleAc.cpp:384

◆ IntegrateFluxLine()

double Garfield::Component::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 )

Integrate the electric field flux through a line from (x0,y0,z0) to (x1,y1,z1) along a direction (xp,yp,zp).

Parameters
x0,y0,z0coordinates of the starting point
x1,y1,z1coordinates of the end point
xp,yp,zpnormal vector
nInumber of intervals for the integration
isigninclude both negative and positive contributions (0) or only contributions with a given polarity (+1,-1)

Definition at line 341 of file Component.cc.

346 {
347 // FLDIN5
348 // Normalise the norm vector.
349 const double pmag2 = xp * xp + yp * yp + zp * zp;
350 if (pmag2 <= 0.) {
351 std::cerr << m_className << "::IntegrateFluxLine:\n"
352 << " Normal vector has zero length; flux set to 0.\n";
353 return 0.;
354 }
355 const double pmag = sqrt(pmag2);
356 const double xn = xp / pmag;
357 const double yn = yp / pmag;
358 const double zn = zp / pmag;
359
360 // Check integration points.
361 if (nI <= 1) {
362 std::cerr << m_className << "::IntegrateFluxLine:\n"
363 << " Number of points to integrate over must be > 1.\n";
364 return 0.;
365 }
366 // Ensure the segment has non-zero length.
367 const double vx = x1 - x0;
368 const double vy = y1 - y0;
369 const double vz = z1 - z0;
370 const double vmag2 = vx * vx + vy * vy + vz * vz;
371 if (vmag2 <= 0.) {
372 std::cerr << m_className << "::IntegrateFluxLine:\n"
373 << " Segment has zero length; flux set to 0.\n";
374 return 0.;
375 }
376 const double vmag = sqrt(vmag2);
377 // Segment should be perpendicular to the norm vector.
378 if (fabs(vx * xn + vy * yn + vz * zn) > 1.e-4 * vmag) {
379 std::cerr << m_className << "::IntegrateFluxLine:\n"
380 << " Segment is not perpendicular to norm vector.\n";
381 return 0.;
382 }
383
384 // Perform the integration.
385 constexpr size_t nG = 6;
388
389 const double d = 1. / nI;
390 const double h = 0.5 * d;
391 // Arguments of ElectricField.
392 double ex = 0., ey = 0., ez = 0.;
393 Medium* m = nullptr;
394 int status = 0;
395 double s = 0.;
396 for (size_t i = 0; i < nG; ++i) {
397 const double u0 = h * (1. + tg[i]);
398 for (unsigned int k = 0; k < nI; ++k) {
399 const double u = u0 + k * d;
400 const double x = x0 + u * vx;
401 const double y = y0 + u * vy;
402 const double z = z0 + u * vz;
403 ElectricField(x, y, z, ex, ey, ez, m, status);
404 double fn = ex * xn + ey * yn + ez * zn;
405 if (isign != 0) {
406 // TODO: -1?
407 fn = isign * fn > 0 ? fabs(fn) : -1.;
408 }
409 s += wg[i] * fn;
410 }
411 }
412 return s * vmag;
413}
DoubleAc sqrt(const DoubleAc &f)
Definition DoubleAc.cpp:314

◆ IntegrateFluxParallelogram()

double Garfield::Component::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 )

Integrate the normal component of the electric field over a parallelogram.

Parameters
x0,y0,z0coordinates of one of the corners [cm]
dx1,dy1,dz1vector to one of the adjacent corners [cm]
dx2,dy2,dz2vector to the other adjacent corner [cm]
nU,nVnumber of integration points in the two directions
Returns
flux [V cm]

Definition at line 250 of file Component.cc.

253 {
254
256 x0, y0, z0, dx1, dy1, dz1, dx2, dy2, dz2, nU, nV, false, "");
257}
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)
Definition Component.cc:250

Referenced by IntegrateFluxParallelogram(), and IntegrateWeightingFluxParallelogram().

◆ IntegrateFluxSphere()

double Garfield::Component::IntegrateFluxSphere ( const double xc,
const double yc,
const double zc,
const double r,
const unsigned int nI = 20 )

Integrate the normal component of the electric field over a sphere.

Parameters
xc,yc,zccentre of the sphere [cm]
rradius of the sphere [cm]
nInumber of integration intervals in phi and theta
Returns
charge enclosed in the sphere [fC]

Definition at line 195 of file Component.cc.

197 {
198 // FLDIN3, FCHK2, FCHK1
199 if (nI == 0) {
200 std::cerr << m_className << "::IntegrateFluxSphere:\n"
201 << " Number of intervals must be > 0.\n";
202 return 0.;
203 }
204 // Number of Gaussian quadrature points.
205 constexpr size_t nG = 6;
208
209 const double r2 = r * r;
210 // Width and half-width of theta intervals.
211 const double dt = Pi / nI;
212 const double ht = 0.5 * dt;
213 // Width and half-width of phi intervals.
214 const double dp = TwoPi / nI;
215 const double hp = 0.5 * dp;
216 // Arguments of ElectricField.
217 double ex = 0., ey = 0., ez = 0.;
218 Medium* m = nullptr;
219 int status = 0;
220 // Perform the integration.
221 double s2 = 0.;
222 // Loop over theta.
223 for (size_t i = 0; i < nG; ++i) {
224 const double theta0 = ht * (1. + tg[i]) - HalfPi;
225 for (unsigned int k = 0; k < nI; ++k) {
226 const double theta = theta0 + k * dt;
227 const double ct = cos(theta);
228 const double st = sin(theta);
229 const double z = zc + st * r;
230 double s1 = 0.;
231 // Loop over phi.
232 for (size_t ii = 0; ii < nG; ++ii) {
233 const double phi0 = hp * (1. + tg[ii]);
234 for (unsigned int kk = 0; kk < nI; ++kk) {
235 const double phi = phi0 + kk * dp;
236 const double cp = cos(phi);
237 const double sp = sin(phi);
238 const double x = xc + cp * ct * r;
239 const double y = yc + sp * ct * r;
240 ElectricField(x, y, z, ex, ey, ez, m, status);
241 s1 += wg[ii] * ((ex * cp + ey * sp) * ct + ez * st);
242 }
243 }
244 s2 += wg[i] * r2 * ct * hp * s1;
245 }
246 }
247 return ht * s2 * VacuumPermittivity;
248}

◆ IntegrateWeightingFluxParallelogram()

double Garfield::Component::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 )

Integrate the normal component of the weighting field over a parallelogram.

Definition at line 259 of file Component.cc.

262 {
263
265 x0, y0, z0, dx1, dy1, dz1, dx2, dy2, dz2, nU, nV, true, id);
266}

◆ InTrapRadius()

bool Garfield::Component::InTrapRadius ( const double q0,
const double x0,
const double y0,
const double z0,
double & xw,
double & yw,
double & rw )
virtual

Determine whether a particle is inside the trap radius of a wire.

Parameters
q0charge of the particle [in elementary charges].
x0,y0,z0position [cm] of the particle.
xw,ywcoordinates of the wire (if applicable).
rwradius of the wire (if applicable).

Reimplemented in Garfield::ComponentAnalyticField, and Garfield::ComponentNeBem2d.

Definition at line 139 of file Component.cc.

141 {
142 xw = x0;
143 yw = y0;
144 rw = 0.;
145 return false;
146}

◆ IsAxiallyPeriodic()

void Garfield::Component::IsAxiallyPeriodic ( bool & perx,
bool & pery,
bool & perz )
inline

Return axial periodicity flags.

Definition at line 263 of file Component.hh.

263 {
264 perx = m_axiallyPeriodic[0];
265 pery = m_axiallyPeriodic[1];
266 perz = m_axiallyPeriodic[2];
267 }

◆ IsMirrorPeriodic()

void Garfield::Component::IsMirrorPeriodic ( bool & perx,
bool & pery,
bool & perz )
inline

Return mirror periodicity flags.

Definition at line 241 of file Component.hh.

241 {
242 perx = m_mirrorPeriodic[0];
243 pery = m_mirrorPeriodic[1];
244 perz = m_mirrorPeriodic[2];
245 }

◆ IsPeriodic()

void Garfield::Component::IsPeriodic ( bool & perx,
bool & pery,
bool & perz )
inline

Return periodicity flags.

Definition at line 219 of file Component.hh.

219 {
220 perx = m_periodic[0];
221 pery = m_periodic[1];
222 perz = m_periodic[2];
223 }

◆ IsReady()

virtual bool Garfield::Component::IsReady ( )
inlinevirtual

Ready for use?

Definition at line 112 of file Component.hh.

112{ return m_ready; }

◆ IsRotationSymmetric()

void Garfield::Component::IsRotationSymmetric ( bool & rotx,
bool & roty,
bool & rotz )
inline

Return rotation symmetry flags.

Definition at line 285 of file Component.hh.

285 {
286 rotx = m_rotationSymmetric[0];
287 roty = m_rotationSymmetric[1];
288 rotz = m_rotationSymmetric[2];
289 }

◆ MagneticField()

void Garfield::Component::MagneticField ( const double x,
const double y,
const double z,
double & bx,
double & by,
double & bz,
int & status )
virtual

Calculate the magnetic field at a given point.

Parameters
x,y,zcoordinates [cm].
bx,by,bzcomponents of the magnetic field [Tesla].
statusstatus flag.

Reimplemented in Garfield::ComponentGrid, Garfield::ComponentNeBem3dMap, Garfield::ComponentUser, and Garfield::ComponentVoxel.

Definition at line 102 of file Component.cc.

103 {
104 bx = m_b0[0];
105 by = m_b0[1];
106 bz = m_b0[2];
107 if (m_debug) {
108 std::cout << m_className << "::MagneticField: Field at (" << x << ", " << y
109 << ", " << z << ") is (" << bx << ", " << by << ", " << bz
110 << ")\n";
111 }
112 status = 0;
113}

Referenced by Garfield::ComponentGrid::MagneticField(), Garfield::ComponentNeBem3dMap::MagneticField(), Garfield::ComponentUser::MagneticField(), and Garfield::ComponentVoxel::MagneticField().

◆ Reset()

virtual void Garfield::Component::Reset ( )
protectedpure virtual

Reset the component.

Implemented in Garfield::ComponentFieldMap, and Garfield::ComponentNeBem3d.

Referenced by Clear().

◆ SetGeometry()

void Garfield::Component::SetGeometry ( Geometry * geo)
virtual

Define the geometry.

Definition at line 15 of file Component.cc.

15 {
16 // Make sure the geometry is defined
17 if (!geo) {
18 std::cerr << m_className << "::SetGeometry: Null pointer.\n";
19 return;
20 }
21 m_geometry = geo;
22}

◆ SetMagneticField()

void Garfield::Component::SetMagneticField ( const double bx,
const double by,
const double bz )

Set a constant magnetic field.

Definition at line 115 of file Component.cc.

116 {
117 m_b0 = {bx, by, bz};
118}

Referenced by main().

◆ StepSizeHint()

virtual double Garfield::Component::StepSizeHint ( )
inlinevirtual

Reimplemented in Garfield::ComponentAnalyticField.

Definition at line 355 of file Component.hh.

355{ return -1.; }

◆ UpdatePeriodicity()

◆ WeightingField()

void Garfield::Component::WeightingField ( const double x,
const double y,
const double z,
double & wx,
double & wy,
double & wz,
const std::string & label )
virtual

Calculate the weighting field at a given point and for a given electrode.

Parameters
x,y,zcoordinates [cm].
wx,wy,wzcomponents of the weighting field [1/cm].
labelname of the electrode

Reimplemented in Garfield::ComponentAnalyticField, Garfield::ComponentConstant, Garfield::ComponentCST, Garfield::ComponentFieldMap, Garfield::ComponentGrid, Garfield::ComponentNeBem3d, Garfield::ComponentNeBem3dMap, Garfield::ComponentTcadBase< N >, Garfield::ComponentTcadBase< 2 >, Garfield::ComponentTcadBase< 3 >, Garfield::ComponentUser, and Garfield::ComponentVoxel.

Definition at line 61 of file Component.cc.

63 {
64 if (m_debug) {
65 std::cerr << m_className << "::WeightingField: Function not implemented.\n";
66 }
67 wx = wy = wz = 0.;
68}

Referenced by Garfield::ComponentGrid::SaveWeightingField().

◆ WeightingPotential()

double Garfield::Component::WeightingPotential ( const double x,
const double y,
const double z,
const std::string & label )
virtual

Calculate the weighting potential at a given point.

Parameters
x,y,zcoordinates [cm].
labelname of the electrode.
Returns
weighting potential [dimensionless].

Reimplemented in Garfield::ComponentAnalyticField, Garfield::ComponentConstant, Garfield::ComponentCST, Garfield::ComponentFieldMap, Garfield::ComponentGrid, Garfield::ComponentNeBem3d, Garfield::ComponentNeBem3dMap, Garfield::ComponentParallelPlate, Garfield::ComponentTcadBase< N >, Garfield::ComponentTcadBase< 2 >, Garfield::ComponentTcadBase< 3 >, Garfield::ComponentUser, and Garfield::ComponentVoxel.

Definition at line 80 of file Component.cc.

82 {
83 if (m_debug) {
84 std::cerr << m_className << "::WeightingPotential: Not implemented.\n";
85 }
86 return 0.;
87}

Referenced by Garfield::ComponentGrid::SaveWeightingField().

Member Data Documentation

◆ m_axiallyPeriodic

◆ m_b0

std::array<double, 3> Garfield::Component::m_b0 = {{0., 0., 0.}}
protected

Constant magnetic field.

Definition at line 365 of file Component.hh.

365{{0., 0., 0.}};

Referenced by Clear(), HasMagneticField(), MagneticField(), and SetMagneticField().

◆ m_className

std::string Garfield::Component::m_className = "Component"
protected

Class name.

Definition at line 359 of file Component.hh.

Referenced by Garfield::ComponentNeBem2d::AddChargeDistribution(), Garfield::ComponentParallelPlate::AddPixel(), Garfield::ComponentAnalyticField::AddPixelOnPlanePhi(), Garfield::ComponentAnalyticField::AddPixelOnPlaneR(), Garfield::ComponentAnalyticField::AddPixelOnPlaneX(), Garfield::ComponentAnalyticField::AddPixelOnPlaneY(), Garfield::ComponentParallelPlate::AddPlane(), Garfield::ComponentAnalyticField::AddPlanePhi(), Garfield::ComponentAnalyticField::AddPlaneR(), Garfield::ComponentAnalyticField::AddPlaneX(), Garfield::ComponentNeBem3d::AddPlaneX(), Garfield::ComponentAnalyticField::AddPlaneY(), Garfield::ComponentNeBem3d::AddPlaneY(), Garfield::ComponentNeBem3d::AddPlaneZ(), Garfield::ComponentAnalyticField::AddReadout(), Garfield::ComponentNeBem2d::AddRegion(), Garfield::ComponentNeBem2d::AddSegment(), Garfield::ComponentParallelPlate::AddStrip(), Garfield::ComponentAnalyticField::AddStripOnPlanePhi(), Garfield::ComponentAnalyticField::AddStripOnPlaneR(), Garfield::ComponentAnalyticField::AddStripOnPlaneX(), Garfield::ComponentAnalyticField::AddStripOnPlaneY(), Garfield::ComponentAnalyticField::AddTube(), Garfield::ComponentAnalyticField::AddWire(), Garfield::ComponentNeBem2d::AddWire(), Garfield::ComponentFieldMap::Check(), Component(), Garfield::ComponentCST::Coordinate2Index(), Garfield::ComponentFieldMap::CopyWeightingPotential(), Garfield::ComponentAnalyticField::CrossedWire(), DelayedWeightingField(), Garfield::ComponentTcadBase< 2 >::DelayedWeightingField(), DelayedWeightingPotential(), Garfield::ComponentFieldMap::DriftMedium(), Garfield::ComponentConstant::ElectricField(), Garfield::ComponentFieldMap::ElectricField(), Garfield::ComponentGrid::ElectricField(), Garfield::ComponentNeBem3d::ElectricField(), Garfield::ComponentNeBem3dMap::ElectricField(), Garfield::ComponentParallelPlate::ElectricField(), Garfield::ComponentParallelPlate::ElectricField(), Garfield::ComponentTcad2d::ElectricField(), Garfield::ComponentTcad3d::ElectricField(), Garfield::ComponentUser::ElectricField(), Garfield::ComponentUser::ElectricField(), Garfield::ComponentVoxel::ElectricField(), Garfield::ComponentAnalyticField::ElectricFieldAtWire(), Garfield::ComponentGrid::ElectronAttachment(), Garfield::ComponentGrid::ElectronVelocity(), Garfield::ComponentTcadBase< N >::EnableVelocityMap(), Garfield::ComponentTcadBase< 2 >::EnableVelocityMap(), Garfield::ComponentFieldMap::Field(), Garfield::ComponentFieldMap::FindElement13(), Garfield::ComponentFieldMap::FindElement5(), Garfield::ComponentFieldMap::FindElementCube(), Garfield::ComponentAnalyticField::ForcesOnWire(), Garfield::ComponentFieldMap::GetConductivity(), Garfield::ComponentGrid::GetElectricField(), Garfield::ComponentGrid::GetElectricFieldRange(), Garfield::ComponentNeBem3dMap::GetElectricFieldRange(), Garfield::ComponentVoxel::GetElectricFieldRange(), Garfield::ComponentCST::GetElement(), Garfield::ComponentFieldMap::GetElement(), Garfield::ComponentFieldMap::GetElement(), Garfield::ComponentNeBem3d::GetElement(), Garfield::ComponentNeBem3dMap::GetElement(), Garfield::ComponentNeBem3dMap::GetElement(), Garfield::ComponentTcad2d::GetElement(), Garfield::ComponentTcad3d::GetElement(), Garfield::ComponentVoxel::GetElement(), Garfield::ComponentVoxel::GetElement(), Garfield::ComponentCST::GetMedium(), Garfield::ComponentFieldMap::GetMedium(), Garfield::ComponentFieldMap::GetMedium(), Garfield::ComponentGrid::GetMedium(), Garfield::ComponentNeBem3dMap::GetMedium(), Garfield::ComponentNeBem3dMap::GetMedium(), Garfield::ComponentTcad2d::GetMedium(), Garfield::ComponentTcad3d::GetMedium(), Garfield::ComponentVoxel::GetMedium(), Garfield::ComponentVoxel::GetMedium(), Garfield::ComponentCST::GetNode(), Garfield::ComponentFieldMap::GetNode(), Garfield::ComponentTcad2d::GetNode(), Garfield::ComponentTcad3d::GetNode(), Garfield::ComponentFieldMap::GetPermittivity(), Garfield::ComponentAnalyticField::GetPlanePhi(), Garfield::ComponentAnalyticField::GetPlaneR(), Garfield::ComponentAnalyticField::GetPlaneX(), Garfield::ComponentNeBem3d::GetPlaneX(), Garfield::ComponentAnalyticField::GetPlaneY(), Garfield::ComponentNeBem3d::GetPlaneY(), Garfield::ComponentNeBem3d::GetPlaneZ(), Garfield::ComponentNeBem3d::GetPrimitive(), Garfield::ComponentNeBem3d::GetPrimitive(), Garfield::ComponentTcadBase< N >::GetRegion(), Garfield::ComponentAnalyticField::GetVoltageRange(), Garfield::ComponentConstant::GetVoltageRange(), Garfield::ComponentNeBem3d::GetVolume(), Garfield::ComponentAnalyticField::GetWire(), Garfield::ComponentGrid::HoleAttachment(), Garfield::ComponentGrid::HoleVelocity(), Garfield::ComponentAnsys121::Initialise(), Garfield::ComponentAnsys123::Initialise(), Garfield::ComponentComsol::Initialise(), Garfield::ComponentCST::Initialise(), Garfield::ComponentCST::Initialise(), Garfield::ComponentElmer2d::Initialise(), Garfield::ComponentElmer::Initialise(), Garfield::ComponentNeBem2d::Initialise(), Garfield::ComponentNeBem3d::Initialise(), Garfield::ComponentTcadBase< N >::Initialise(), IntegrateFluxCircle(), IntegrateFluxLine(), IntegrateFluxSphere(), Garfield::ComponentAnalyticField::InTrapRadius(), Garfield::ComponentTcadBase< N >::LoadData(), Garfield::ComponentNeBem3dMap::LoadElectricField(), Garfield::ComponentVoxel::LoadElectricField(), Garfield::ComponentTcadBase< N >::LoadGrid(), Garfield::ComponentNeBem3dMap::LoadMagneticField(), Garfield::ComponentVoxel::LoadMagneticField(), Garfield::ComponentNeBem3dMap::LoadMapInfo(), Garfield::ComponentTcadBase< N >::LoadWeightingField(), Garfield::ComponentTcadBase< 2 >::LoadWeightingField(), Garfield::ComponentVoxel::LoadWeightingField(), Garfield::ComponentVoxel::LoadWeightingField(), Garfield::ComponentParallelPlate::LoadWeightingPotentialGrid(), MagneticField(), Garfield::ComponentTcadBase< 2 >::MapCoordinates(), Garfield::ComponentAnalyticField::MultipoleMoments(), Garfield::ComponentFieldMap::NotDriftMedium(), Garfield::ComponentAnalyticField::OptimiseOnGrid(), Garfield::ComponentAnalyticField::OptimiseOnTrack(), Garfield::ComponentAnalyticField::OptimiseOnWires(), Garfield::ComponentFieldMap::Prepare(), Garfield::ComponentGrid::Print(), Garfield::ComponentAnalyticField::PrintCell(), Garfield::ComponentAnalyticField::PrintCharges(), Garfield::ComponentFieldMap::PrintCouldNotOpen(), Garfield::ComponentFieldMap::PrintElement(), Garfield::ComponentFieldMap::PrintMaterials(), Garfield::ComponentFieldMap::PrintNotReady(), Garfield::ComponentFieldMap::PrintRange(), Garfield::ComponentNeBem3dMap::PrintRegions(), Garfield::ComponentTcadBase< N >::PrintRegions(), Garfield::ComponentVoxel::PrintRegions(), Garfield::ComponentFieldMap::PrintWarning(), Garfield::ComponentTcadBase< N >::ReadDataset(), Garfield::ComponentGrid::SaveElectricField(), Garfield::ComponentGrid::SaveWeightingField(), Garfield::ComponentTcadBase< N >::SetAcceptor(), Garfield::ComponentAnalyticField::SetCartesianCoordinates(), Garfield::ComponentGrid::SetCylindricalCoordinates(), Garfield::ComponentFieldMap::SetDefaultDriftMedium(), Garfield::ComponentUser::SetDelayedWeightingField(), Garfield::ComponentUser::SetDelayedWeightingField(), Garfield::ComponentUser::SetDelayedWeightingPotential(), Garfield::ComponentUser::SetDelayedWeightingPotential(), Garfield::ComponentTcadBase< N >::SetDonor(), Garfield::ComponentTcadBase< N >::SetDriftRegion(), Garfield::ComponentTcadBase< 2 >::SetDriftRegion(), Garfield::ComponentComsol::SetDynamicWeightingPotential(), Garfield::ComponentConstant::SetElectricField(), Garfield::ComponentUser::SetElectricField(), Garfield::ComponentUser::SetElectricField(), Garfield::ComponentFieldMap::SetGas(), SetGeometry(), Garfield::ComponentAnalyticField::SetGravity(), Garfield::ComponentUser::SetMagneticField(), Garfield::ComponentUser::SetMagneticField(), Garfield::ComponentNeBem2d::SetMaxNumberOfIterations(), Garfield::ComponentFieldMap::SetMedium(), Garfield::ComponentGrid::SetMedium(), Garfield::ComponentNeBem3dMap::SetMedium(), Garfield::ComponentTcadBase< N >::SetMedium(), Garfield::ComponentTcadBase< N >::SetMedium(), Garfield::ComponentVoxel::SetMedium(), Garfield::ComponentGrid::SetMesh(), Garfield::ComponentNeBem3dMap::SetMesh(), Garfield::ComponentVoxel::SetMesh(), Garfield::ComponentNeBem3d::SetMinMaxNumberOfElements(), Garfield::ComponentNeBem3d::SetMirrorPeriodicityX(), Garfield::ComponentNeBem3d::SetMirrorPeriodicityY(), Garfield::ComponentNeBem3d::SetMirrorPeriodicityZ(), Garfield::ComponentAnalyticField::SetNumberOfCellCopies(), Garfield::ComponentNeBem2d::SetNumberOfCollocationPoints(), Garfield::ComponentNeBem2d::SetNumberOfDivisions(), Garfield::ComponentAnalyticField::SetNumberOfSteps(), Garfield::ComponentAnalyticField::SetOptimisationParameters(), Garfield::ComponentAnalyticField::SetPeriodicityPhi(), Garfield::ComponentAnalyticField::SetPeriodicityX(), Garfield::ComponentNeBem3d::SetPeriodicityX(), Garfield::ComponentAnalyticField::SetPeriodicityY(), Garfield::ComponentNeBem3d::SetPeriodicityY(), Garfield::ComponentNeBem3d::SetPeriodicityZ(), Garfield::ComponentAnalyticField::SetPolarCoordinates(), Garfield::ComponentUser::SetPotential(), Garfield::ComponentUser::SetPotential(), Garfield::ComponentFieldMap::SetRange(), Garfield::ComponentAnsys121::SetRangeZ(), Garfield::ComponentCST::SetRangeZ(), Garfield::ComponentElmer2d::SetRangeZ(), Garfield::ComponentNeBem2d::SetRangeZ(), Garfield::ComponentTcad2d::SetRangeZ(), Garfield::ComponentAnalyticField::SetScanningArea(), Garfield::ComponentAnalyticField::SetScanningAreaFirstOrder(), Garfield::ComponentAnalyticField::SetScanningGrid(), Garfield::ComponentNeBem3d::SetTargetElementSize(), Garfield::ComponentComsol::SetTimeInterval(), Garfield::ComponentParallelPlate::Setup(), Garfield::ComponentAnsys121::SetWeightingField(), Garfield::ComponentAnsys123::SetWeightingField(), Garfield::ComponentCST::SetWeightingField(), Garfield::ComponentElmer2d::SetWeightingField(), Garfield::ComponentElmer::SetWeightingField(), Garfield::ComponentTcadBase< N >::SetWeightingField(), Garfield::ComponentTcadBase< N >::SetWeightingField(), Garfield::ComponentUser::SetWeightingField(), Garfield::ComponentUser::SetWeightingField(), Garfield::ComponentTcadBase< N >::SetWeightingFieldShift(), Garfield::ComponentComsol::SetWeightingPotential(), Garfield::ComponentConstant::SetWeightingPotential(), Garfield::ComponentTcadBase< N >::SetWeightingPotential(), Garfield::ComponentTcadBase< 2 >::SetWeightingPotential(), Garfield::ComponentUser::SetWeightingPotential(), Garfield::ComponentUser::SetWeightingPotential(), Garfield::ComponentParallelPlate::SetWeightingPotentialGrid(), Garfield::ComponentCST::ShiftComponent(), Garfield::ComponentTcadBase< N >::UnsetDriftRegion(), Garfield::ComponentTcadBase< 2 >::UpdateAttachment(), Garfield::ComponentNeBem3d::UpdatePeriodicity(), Garfield::ComponentTcadBase< N >::UpdatePeriodicity(), Garfield::ComponentFieldMap::UpdatePeriodicity2d(), Garfield::ComponentFieldMap::UpdatePeriodicityCommon(), WeightingField(), Garfield::ComponentConstant::WeightingField(), Garfield::ComponentNeBem3d::WeightingField(), WeightingPotential(), Garfield::ComponentCST::WeightingPotential(), and Garfield::ComponentAnalyticField::WireDisplacement().

◆ m_debug

bool Garfield::Component::m_debug = false
protected

Switch on/off debugging messages.

Definition at line 371 of file Component.hh.

Referenced by Garfield::ComponentNeBem2d::AddRegion(), Garfield::ComponentNeBem2d::AddSegment(), Garfield::ComponentNeBem2d::AddWire(), Garfield::ComponentCST::Coordinate2Index(), DelayedWeightingField(), DelayedWeightingPotential(), DisableDebugging(), Garfield::ComponentConstant::ElectricField(), Garfield::ComponentFieldMap::ElectricField(), Garfield::ComponentNeBem3dMap::ElectricField(), Garfield::ComponentParallelPlate::ElectricField(), Garfield::ComponentParallelPlate::ElectricField(), Garfield::ComponentUser::ElectricField(), Garfield::ComponentUser::ElectricField(), EnableDebugging(), Garfield::ComponentFieldMap::Field(), Garfield::ComponentFieldMap::FindElement13(), Garfield::ComponentFieldMap::FindElement5(), Garfield::ComponentFieldMap::FindElementCube(), Garfield::ComponentAnalyticField::ForcesOnWire(), Garfield::ComponentNeBem3dMap::GetElement(), Garfield::ComponentCST::GetMedium(), Garfield::ComponentFieldMap::GetMedium(), Garfield::ComponentAnsys121::Initialise(), Garfield::ComponentAnsys123::Initialise(), Garfield::ComponentCST::Initialise(), Garfield::ComponentCST::Initialise(), Garfield::ComponentElmer2d::Initialise(), Garfield::ComponentElmer::Initialise(), Garfield::ComponentNeBem2d::Initialise(), Garfield::ComponentNeBem3d::Initialise(), Garfield::ComponentAnalyticField::InTrapRadius(), Garfield::ComponentTcadBase< N >::LoadData(), Garfield::ComponentTcadBase< N >::LoadGrid(), MagneticField(), Garfield::ComponentAnalyticField::MultipoleMoments(), Garfield::ComponentAnalyticField::OptimiseOnGrid(), Garfield::ComponentAnalyticField::OptimiseOnTrack(), Garfield::ComponentAnalyticField::OptimiseOnWires(), Garfield::ComponentFieldMap::Potential(), Garfield::ComponentTcadBase< N >::ReadDataset(), Garfield::ComponentFieldMap::SetMedium(), Garfield::ComponentFieldMap::SetRange(), Garfield::ComponentParallelPlate::Setup(), Garfield::ComponentCST::SetWeightingField(), Garfield::ComponentFieldMap::UpdatePeriodicityCommon(), WeightingField(), Garfield::ComponentConstant::WeightingField(), WeightingPotential(), and Garfield::ComponentCST::WeightingPotential().

◆ m_geometry

◆ m_mirrorPeriodic

std::array<bool, 3> Garfield::Component::m_mirrorPeriodic = {{false, false, false}}
protected

◆ m_periodic

std::array<bool, 3> Garfield::Component::m_periodic = {{false, false, false}}
protected

Simple periodicity in x, y, z.

Definition at line 374 of file Component.hh.

374{{false, false, false}};

Referenced by Clear(), EnablePeriodicityX(), EnablePeriodicityY(), EnablePeriodicityZ(), Garfield::ComponentGrid::GetBoundingBox(), Garfield::ComponentNeBem3dMap::GetBoundingBox(), Garfield::ComponentTcad2d::GetBoundingBox(), Garfield::ComponentTcad3d::GetBoundingBox(), Garfield::ComponentVoxel::GetBoundingBox(), Garfield::ComponentNeBem3dMap::GetElement(), Garfield::ComponentVoxel::GetElement(), Garfield::ComponentGrid::GetMedium(), Garfield::ComponentAnalyticField::GetPeriodicityPhi(), Garfield::ComponentAnalyticField::GetPeriodicityX(), Garfield::ComponentNeBem3d::GetPeriodicityX(), Garfield::ComponentAnalyticField::GetPeriodicityY(), Garfield::ComponentNeBem3d::GetPeriodicityY(), Garfield::ComponentNeBem3d::GetPeriodicityZ(), IsPeriodic(), Garfield::ComponentFieldMap::MapCoordinates(), Garfield::ComponentTcadBase< N >::MapCoordinates(), Garfield::ComponentFieldMap::PrintRange(), Garfield::ComponentGrid::SetCylindricalCoordinates(), Garfield::ComponentGrid::SetMesh(), Garfield::ComponentNeBem3d::SetMirrorPeriodicityX(), Garfield::ComponentNeBem3d::SetMirrorPeriodicityY(), Garfield::ComponentNeBem3d::SetMirrorPeriodicityZ(), Garfield::ComponentAnalyticField::SetPeriodicityPhi(), Garfield::ComponentAnalyticField::SetPeriodicityX(), Garfield::ComponentNeBem3d::SetPeriodicityX(), Garfield::ComponentAnalyticField::SetPeriodicityY(), Garfield::ComponentNeBem3d::SetPeriodicityY(), Garfield::ComponentNeBem3d::SetPeriodicityZ(), Garfield::ComponentNeBem3d::UpdatePeriodicity(), Garfield::ComponentTcadBase< N >::UpdatePeriodicity(), Garfield::ComponentFieldMap::UpdatePeriodicity2d(), and Garfield::ComponentFieldMap::UpdatePeriodicityCommon().

◆ m_ready

bool Garfield::Component::m_ready = false
protected

Ready for use?

Definition at line 368 of file Component.hh.

Referenced by Garfield::ComponentNeBem3d::AddPlaneX(), Garfield::ComponentNeBem3d::AddPlaneY(), Garfield::ComponentNeBem3d::AddPlaneZ(), Garfield::ComponentNeBem2d::AddSegment(), Garfield::ComponentNeBem2d::AddWire(), Garfield::ComponentFieldMap::Check(), Clear(), Garfield::ComponentFieldMap::DelayedWeightingPotential(), Garfield::ComponentFieldMap::DriftMedium(), Garfield::ComponentNeBem3d::ElectricField(), Garfield::ComponentNeBem3dMap::ElectricField(), Garfield::ComponentTcad2d::ElectricField(), Garfield::ComponentTcad3d::ElectricField(), Garfield::ComponentVoxel::ElectricField(), Garfield::ComponentTcadBase< N >::EnableVelocityMap(), Garfield::ComponentFieldMap::Field(), Garfield::ComponentFieldMap::GetBoundingBox(), Garfield::ComponentNeBem3dMap::GetBoundingBox(), Garfield::ComponentTcad2d::GetBoundingBox(), Garfield::ComponentTcad3d::GetBoundingBox(), Garfield::ComponentVoxel::GetBoundingBox(), Garfield::ComponentNeBem3dMap::GetElectricFieldRange(), Garfield::ComponentVoxel::GetElectricFieldRange(), Garfield::ComponentNeBem3dMap::GetElement(), Garfield::ComponentVoxel::GetElement(), Garfield::ComponentFieldMap::GetElementaryCell(), Garfield::ComponentTcad2d::GetElementaryCell(), Garfield::ComponentTcad3d::GetElementaryCell(), Garfield::ComponentVoxel::GetElementaryCell(), Garfield::ComponentFieldMap::GetMedium(), Garfield::ComponentNeBem3dMap::GetMedium(), Garfield::ComponentTcad2d::GetMedium(), Garfield::ComponentTcad3d::GetMedium(), Garfield::ComponentVoxel::GetMedium(), Garfield::ComponentNeBem2d::GetRegion(), Garfield::ComponentNeBem3dMap::GetVoltageRange(), Garfield::ComponentTcadBase< N >::GetVoltageRange(), Garfield::ComponentVoxel::GetVoltageRange(), Garfield::ComponentAnsys121::Initialise(), Garfield::ComponentAnsys123::Initialise(), Garfield::ComponentComsol::Initialise(), Garfield::ComponentCST::Initialise(), Garfield::ComponentCST::Initialise(), Garfield::ComponentElmer2d::Initialise(), Garfield::ComponentElmer::Initialise(), Garfield::ComponentNeBem2d::Initialise(), Garfield::ComponentNeBem3d::Initialise(), Garfield::ComponentTcadBase< N >::Initialise(), IsReady(), Garfield::ComponentNeBem3dMap::LoadElectricField(), Garfield::ComponentVoxel::LoadElectricField(), Garfield::ComponentFieldMap::NotDriftMedium(), Garfield::ComponentFieldMap::Potential(), Garfield::ComponentFieldMap::PrintMaterials(), Garfield::ComponentNeBem3dMap::PrintRegions(), Garfield::ComponentVoxel::PrintRegions(), Garfield::ComponentFieldMap::Reset(), Garfield::ComponentNeBem3d::Reset(), Garfield::ComponentComsol::SetDynamicWeightingPotential(), Garfield::ComponentConstant::SetElectricField(), Garfield::ComponentUser::SetElectricField(), Garfield::ComponentUser::SetElectricField(), Garfield::ComponentNeBem2d::SetNumberOfCollocationPoints(), Garfield::ComponentNeBem2d::SetNumberOfDivisions(), Garfield::ComponentFieldMap::SetRange(), Garfield::ComponentAnsys121::SetWeightingField(), Garfield::ComponentAnsys123::SetWeightingField(), Garfield::ComponentCST::SetWeightingField(), Garfield::ComponentElmer2d::SetWeightingField(), Garfield::ComponentElmer::SetWeightingField(), Garfield::ComponentTcadBase< N >::SetWeightingField(), Garfield::ComponentTcadBase< N >::SetWeightingField(), Garfield::ComponentComsol::SetWeightingPotential(), Garfield::ComponentTcadBase< N >::SetWeightingPotential(), Garfield::ComponentTcadBase< N >::UpdatePeriodicity(), Garfield::ComponentFieldMap::UpdatePeriodicity2d(), Garfield::ComponentFieldMap::UpdatePeriodicityCommon(), Garfield::ComponentCST::WeightingField(), Garfield::ComponentFieldMap::WeightingField(), Garfield::ComponentCST::WeightingPotential(), and Garfield::ComponentFieldMap::WeightingPotential().

◆ m_rotationSymmetric


The documentation for this class was generated from the following files: