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::ComponentParallelPlate Class Reference

Component for parallel-plate geometries. More...

#include <ComponentParallelPlate.hh>

+ Inheritance diagram for Garfield::ComponentParallelPlate:

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)
 
MediumGetMedium (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).
 
- Public Member Functions inherited from Garfield::Component
 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 $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 ()
 

Additional Inherited Members

- Protected Attributes inherited from Garfield::Component
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

Component for parallel-plate geometries.

Definition at line 17 of file ComponentParallelPlate.hh.

Constructor & Destructor Documentation

◆ ComponentParallelPlate()

Garfield::ComponentParallelPlate::ComponentParallelPlate ( )

Constructor.

Definition at line 15 of file ComponentParallelPlate.cc.

15: Component("ParallelPlate") {}
Component()=delete
Default constructor.

◆ ~ComponentParallelPlate()

Garfield::ComponentParallelPlate::~ComponentParallelPlate ( )
inline

Destructor.

Definition at line 22 of file ComponentParallelPlate.hh.

22{}

Member Function Documentation

◆ AddPixel()

void Garfield::ComponentParallelPlate::AddPixel ( double x,
double z,
double lx,
double lz,
const std::string & label,
bool fromAnode = true )

Add a pixel electrode.

Parameters
x,zposition of the center of the electrode in the xz-plane.
lxwidth in the along $x$.
lzwidth in the along $z$.
labelgive name using a string.
fromAnodeis $true$ is the electrode is the andode and $false$ if it is the cathode.

Definition at line 290 of file ComponentParallelPlate.cc.

292 {
293
294 // Here I switch conventions back with the y-axis the direction of drift.
295
296 const auto it = std::find(m_readout.cbegin(), m_readout.cend(), label);
297 if (it != m_readout.end() && m_readout.size() > 0) {
298 std::cerr << m_className << "::AddPixel:\n"
299 << "Note that the label " << label << " is already in use.\n";
300 }
301 Electrode pixel;
302 pixel.label = label;
303 pixel.ind = structureelectrode::Pixel;
304 pixel.xpos = z;
305 pixel.ypos = x;
306 pixel.lx = lz_input;
307 pixel.ly = lx_input;
308
309 pixel.formAnode = anode;
310
311 m_readout.push_back(label);
312 m_readout_p.push_back(std::move(pixel));
313 std::cout << m_className << "::AddPixel: Added pixel electrode.\n";
314}
std::string m_className
Class name.
Definition Component.hh:359

◆ AddPlane()

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.

337 {
338 const auto it = std::find(m_readout.cbegin(), m_readout.cend(), label);
339 if (it != m_readout.end() && m_readout.size() > 0) {
340 std::cerr << m_className << "::AddPlane:\n"
341 << "Note that the label " << label << " is already in use.\n";
342 }
343 Electrode plate;
344 plate.label = label;
345 plate.ind = structureelectrode::Plane;
346
347 plate.formAnode = anode;
348
349 m_readout.push_back(label);
350 m_readout_p.push_back(std::move(plate));
351
352 std::cout << m_className << "::AddPlane: Added plane electrode.\n";
353}

◆ AddStrip()

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.

317 {
318 const auto it = std::find(m_readout.cbegin(), m_readout.cend(), label);
319 if (it != m_readout.end() && m_readout.size() > 0) {
320 std::cerr << m_className << "::AddStrip:\n"
321 << "Note that the label " << label << " is already in use.\n";
322 }
323 Electrode strip;
324 strip.label = label;
325 strip.ind = structureelectrode::Strip;
326 strip.xpos = z;
327 strip.lx = lz_input;
328
329 strip.formAnode = anode;
330
331 m_readout.push_back(label);
332 m_readout_p.push_back(std::move(strip));
333
334 std::cout << m_className << "::AddStrip: Added strip electrode.\n";
335}

◆ DisablePotentialCalculationOutsideGasGap()

void Garfield::ComponentParallelPlate::DisablePotentialCalculationOutsideGasGap ( )
inline

Definition at line 137 of file ComponentParallelPlate.hh.

137 {
138 m_getPotentialInPlate = false;
139 }

◆ 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 55 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}
void ElectricField(const double x, const double y, const double z, double &ex, double &ey, double &ez, Medium *&m, int &status) override

◆ ElectricField() [2/3]

void Garfield::ComponentParallelPlate::ElectricField ( const double x,
const double y,
const double z,
double & ex,
double & ey,
double & ez,
double & v,
Medium *& m,
int & status )
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.

188 {
189 // Here I switch conventions back with the y-axis the direction of drift.
190
191 ex = ey = ez = v = 0;
192
193 int im = -1;
194 double epsM = -1;
195 if (!getLayer(y, im, epsM)) {
196 if (m_debug)
197 std::cout << m_className << "::ElectricField: Not inside geometry.\n";
198 status = -6;
199 return;
200 }
201
202 ey = constEFieldLayer(im);
203
204 v = -m_V - (y - m_z[im - 1]) * constEFieldLayer(im);
205 for (int i = 1; i <= im - 1; i++) {
206 v -= (m_z[i] - m_z[i - 1]) * constEFieldLayer(i);
207 }
208
209 m = m_geometry ? m_geometry->GetMedium(x, y, z) : m_medium;
210
211 if (!m) {
212 if (m_debug) {
213 std::cout << m_className << "::ElectricField: No medium at (" << x << ", "
214 << y << ", " << z << ").\n";
215 }
216 status = -6;
217 return;
218 }
219
220 if (epsM == 1) {
221 status = 0;
222 } else {
223 status = -5;
224 }
225}
bool getLayer(const double y, int &m, double &epsM)
bool m_debug
Switch on/off debugging messages.
Definition Component.hh:371
Geometry * m_geometry
Pointer to the geometry.
Definition Component.hh:362

◆ ElectricField() [3/3]

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

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)

Implements Garfield::Component.

Definition at line 148 of file ComponentParallelPlate.cc.

151 {
152 // Here I switch conventions back with the y-axis the direction of drift.
153
154 ex = ey = ez = 0;
155
156 int im = -1;
157 double epsM = -1;
158 if (!getLayer(y, im, epsM)) {
159 if (m_debug)
160 std::cout << m_className << "::ElectricField: Not inside geometry.\n";
161 status = -6;
162 return;
163 }
164
165 ey = constEFieldLayer(im);
166
167 m = m_geometry ? m_geometry->GetMedium(x, y, z) : m_medium;
168
169 if (!m) {
170 if (m_debug) {
171 std::cout << m_className << "::ElectricField: No medium at (" << x << ", "
172 << y << ", " << z << ").\n";
173 }
174 status = -6;
175 return;
176 }
177
178 if (epsM == 1) {
179 status = 0;
180 } else {
181 status = -5;
182 }
183}

◆ GetBoundingBox()

bool Garfield::ComponentParallelPlate::GetBoundingBox ( double & xmin,
double & ymin,
double & zmin,
double & xmax,
double & ymax,
double & zmax )
overridevirtual

Get the bounding box coordinates.

Reimplemented from Garfield::Component.

Definition at line 81 of file ComponentParallelPlate.cc.

83 {
84 // If a geometry is present, try to get the bounding box from there.
85
86 // Here I switch conventions back with the y-axis the direction of drift.
87 if (m_geometry) {
88 if (m_geometry->GetBoundingBox(x0, y0, z0, x1, y1, z1)) return true;
89 }
90 z0 = -std::numeric_limits<double>::infinity();
91 x0 = -std::numeric_limits<double>::infinity();
92 z1 = +std::numeric_limits<double>::infinity();
93 x1 = +std::numeric_limits<double>::infinity();
94
95 y0 = 0.;
96 y1 = m_z.back();
97 return true;
98}

◆ getLayer()

bool Garfield::ComponentParallelPlate::getLayer ( const double y,
int & m,
double & epsM )
inline

Definition at line 115 of file ComponentParallelPlate.hh.

115 {
116
117 int mholer = -1;
118
119 for (int i = 1; i < m_N; i++) {
120 if (y <= m_z[i]) {
121 mholer = i;
122 break;
123 }
124 }
125 if (mholer == -1) return false;
126
127 m = mholer;
128 epsM = m_epsHolder[m - 1];
129 return true;
130 }

Referenced by Garfield::AvalancheGrid::AsignLayerIndex(), ElectricField(), and ElectricField().

◆ GetMedium()

Medium * Garfield::ComponentParallelPlate::GetMedium ( const double x,
const double y,
const double z )
overridevirtual

Get the medium at a given location (x, y, z).

Reimplemented from Garfield::Component.

Definition at line 355 of file ComponentParallelPlate.cc.

356 {
357 if (m_geometry) {
358 return m_geometry->GetMedium(x, y, z);
359 } else if (m_medium) {
360 return m_medium;
361 }
362 return nullptr;
363}

◆ GetVoltageRange()

bool Garfield::ComponentParallelPlate::GetVoltageRange ( double & vmin,
double & vmax )
overridevirtual

Calculate the voltage range [V].

Implements Garfield::Component.

Definition at line 227 of file ComponentParallelPlate.cc.

227 {
228 if (m_V == 0) return false;
229
230 if (m_V < 0) {
231 vmin = m_V;
232 vmax = 0;
233 } else {
234 vmin = 0;
235 vmax = m_V;
236 }
237 return true;
238}

◆ LoadWeightingPotentialGrid()

void Garfield::ComponentParallelPlate::LoadWeightingPotentialGrid ( const std::string & label)
inline

This will load a previously calculated grid of time-dependant weighting potential values.

Definition at line 91 of file ComponentParallelPlate.hh.

91 {
92 for (auto &electrode : m_readout_p) {
93 if (electrode.label == label) {
94 if (electrode.grid.LoadWeightingField(label + "map", "xyz", true)) {
95 std::cerr
97 << "::LoadWeightingPotentialGrid: Weighting potential set for "
98 << label << ".\n";
99 electrode.m_usegrid = true;
100 return;
101 }
102 }
103 }
104 std::cerr << m_className
105 << "::LoadWeightingPotentialGrid: Could not find file for "
106 << label << ".\n";
107 }

Referenced by SetWeightingPotentialGrid().

◆ NumberOfLayers()

int Garfield::ComponentParallelPlate::NumberOfLayers ( )
inline

Definition at line 131 of file ComponentParallelPlate.hh.

131{ return m_N - 1; }

Referenced by Garfield::AvalancheGrid::AsignLayerIndex().

◆ SetIntegrationPrecision()

void Garfield::ComponentParallelPlate::SetIntegrationPrecision ( const double eps)
inline

Definition at line 133 of file ComponentParallelPlate.hh.

133{ m_precision = eps; }

◆ SetIntegrationUpperbound()

void Garfield::ComponentParallelPlate::SetIntegrationUpperbound ( const double p)
inline

Definition at line 135 of file ComponentParallelPlate.hh.

135{ m_upperBoundIntegration = p; }

◆ SetMedium()

void Garfield::ComponentParallelPlate::SetMedium ( Medium * medium)
inline

Setting the medium.

Definition at line 66 of file ComponentParallelPlate.hh.

66{ m_medium = medium; }

◆ Setup()

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.

Parameters
Namount of layers in the geometry, this includes the gas gaps $y$.
dthickness of the layers starting from the bottom to the top lauer along $y$.
epsrelative permittivities of the layers starting from the bottom to the top lauer along $y$ . Here, the gas gaps having a value of 1.
sigmaIndexIndices of the resistive layers (optional).
Vapplied potential difference between the parallel plates.

Definition at line 17 of file ComponentParallelPlate.cc.

19 {
20
21 // Here I switch conventions with the z-axis the direction of drift.
22 std::vector<double> placeHolder(N + 1, 0);
23
24 const int Nholder1 = eps.size();
25 const int Nholder2 = d.size();
26 if (N != Nholder1 || N != Nholder2) {
27 std::cout << m_className
28 << "::Inconsistency between the number of layers, permittivities "
29 "and thicknesses given.\n";
30 return;
31 } else if (N < 2) {
32
33 std::cout << m_className
34 << "::Setup:: Number of layers must be larger then 1.\n";
35 return;
36 }
37
38 if (m_debug) std::cout << m_className << "::Setup:: Loading parameters.\n";
39 m_epsHolder = eps;
40 m_eps = placeHolder;
41
42 m_dHolder = d;
43 m_d = placeHolder;
44 m_N = N + 1;
45 m_V = V;
46
47 if (sigmaIndex.size() == 0) {
48 for (int i = 0; i < N; i++) {
49 if (eps[i] != 1) sigmaIndex.push_back(i + 1);
50 }
51 }
52
53 m_sigmaIndex = sigmaIndex;
54
55 std::vector<double> m_zHolder(N + 1);
56 m_zHolder[0] = 0;
57 for (int i = 1; i <= N; i++) {
58 m_zHolder[i] = m_zHolder[i - 1] + m_dHolder[i - 1];
59
60 if (m_debug)
61 std::cout << m_className << "Setup:: layer " << i
62 << ":: z = " << m_zHolder[i]
63 << ", epsr = " << m_epsHolder[i - 1] << ".\n";
64 }
65 m_z = m_zHolder;
66
67 if (m_debug) std::cout << m_className << "Setup:: Constructing matrices.\n";
68 constructGeometryMatrices(m_N);
69
70 if (m_debug)
71 std::cout << m_className
72 << "Setup:: Computing weighting potential functions.\n";
73 setHIntegrand();
74 setwpStripIntegrand();
75 setwpPixelIntegrand();
76
77 std::cout << m_className << "Setup:: Geometry with N = " << N
78 << " layers set.\n";
79}

◆ SetWeightingPotentialGrid()

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.

Parameters
xmin,ymin,zminminimum value of the interval in the $x$-, $y$- and $z$-direction.
xmax,ymax,zmaxmaximum value of the interval in the $x$-, $y$- and $z$-direction.
xsteps,ysteps,zstepsmumber of grid nodes in the $x$-, $y$- and $z$-direction.
labelgive name using a string.

Definition at line 595 of file ComponentParallelPlate.cc.

599 {
600
601 for (auto &electrode : m_readout_p) {
602 if (electrode.label == label) {
603 if (electrode.m_usegrid) {
604 std::cerr << m_className
605 << "::SetWeightingPotentialGrid: Overwriting grid.\n";
606 }
607
608 if (electrode.grid.SetMesh(xsteps, ysteps, zsteps, xmin, xmax, ymin, ymax,
609 zmin, zmax)) {
610 std::cerr << m_className << "::SetWeightingPotentialGrid: Mesh set for "
611 << label << " (for " << xsteps *ysteps *zsteps
612 << " points).\n";
613 }
614
615 electrode.grid.SaveWeightingField(this, label, label + "map", "xyz");
616
618 }
619 }
620}
void LoadWeightingPotentialGrid(const std::string &label)

Referenced by SetWeightingPotentialGrids().

◆ 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.

625 {
626
627 for (auto &electrode : m_readout_p) {
628 SetWeightingPotentialGrid(xmin, xmax, xsteps, ymin, ymax, ysteps, zmin,
629 zmax, zsteps, electrode.label);
630 }
631}
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)

◆ WeightingPotential()

double Garfield::ComponentParallelPlate::WeightingPotential ( const double x,
const double y,
const double z,
const std::string & label )
overridevirtual

Calculate the weighting potential at a given point.

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

Reimplemented from Garfield::Component.

Definition at line 240 of file ComponentParallelPlate.cc.

243 {
244
245 // Here I switch conventions back with the y-axis the direction of drift.
246
247 double ret = 0.;
248
249 for (auto &electrode : m_readout_p) {
250 if (electrode.label == label) {
251 double yin = y;
252 if (!electrode.formAnode) yin = m_z.back() - y;
253 if (!electrode.m_usegrid) {
254 ret += IntegratePromptPotential(electrode, z, x, yin);
255 } else {
256 ret += FindWeightingPotentialInGrid(electrode, z, x, yin);
257 }
258 }
259 }
260 return ret;
261}

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