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

Simple component with electric field given by a user function. More...

#include <ComponentUser.hh>

+ Inheritance diagram for Garfield::ComponentUser:

Public Member Functions

 ComponentUser ()
 Constructor.
 
 ~ComponentUser ()
 Destructor.
 
void SetElectricField (std::function< void(const double, const double, const double, double &, double &, double &)>)
 Set the function to be called for calculating the electric field.
 
void SetElectricField (const std::string &expression)
 Set the expression to be used for calculating the electric field.
 
void SetPotential (std::function< double(const double, const double, const double)>)
 Set the function to be called for calculating the electric potential.
 
void SetPotential (const std::string &expression)
 Set the expression to be used for calculating the electric potential.
 
void SetWeightingField (std::function< void(const double, const double, const double, double &, double &, double &)>, const std::string &label)
 Set the function to be called for calculating the weighting field.
 
void SetWeightingField (const std::string &expression, const std::string &label)
 Set the expression to be used for calculating the weighting field.
 
void SetWeightingPotential (std::function< double(const double, const double, const double)>, const std::string &label)
 Set the function to be called for calculating the weighting potential.
 
void SetWeightingPotential (const std::string &expression, const std::string &label)
 Set the expression to be used for calculating the weighting potential.
 
void SetDelayedWeightingField (std::function< void(const double, const double, const double, const double, double &, double &, double &)>, const std::string &label)
 Set the function to be called for calculating the delayed weighting field.
 
void SetDelayedWeightingField (const std::string &expression, const std::string &label)
 Set the expression to be used for calculating the delayed weighting field.
 
void SetDelayedWeightingPotential (std::function< double(const double, const double, const double, const double)>, const std::string &label)
 
void SetDelayedWeightingPotential (const std::string &expression, const std::string &label)
 
void SetMagneticField (std::function< void(const double, const double, const double, double &, double &, double &)>)
 Set the function to be called for calculating the magnetic field.
 
void SetMagneticField (const std::string &expression)
 Set the expression to be used for calculating the magnetic field.
 
void SetArea (const double xmin, const double ymin, const double zmin, const double xmax, const double ymax, const double zmax)
 
void UnsetArea ()
 Remove the explicit limits of the active area.
 
void SetMedium (Medium *medium)
 Set the medium in the active area.
 
MediumGetMedium (const double x, const double y, const double z) override
 Get the medium at a given location (x, y, z).
 
void ElectricField (const double x, const double y, const double z, double &ex, double &ey, double &ez, Medium *&m, int &status) override
 
void ElectricField (const double x, const double y, const double z, double &ex, double &ey, double &ez, double &v, Medium *&m, int &status) override
 Calculate the drift field [V/cm] and potential [V] at (x, y, z).
 
bool GetVoltageRange (double &vmin, double &vmax) override
 Calculate the voltage range [V].
 
void MagneticField (const double x, const double y, const double z, double &bx, double &by, double &bz, 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
 
bool GetBoundingBox (double &xmin, double &ymin, double &zmin, double &xmax, double &ymax, double &zmax) override
 Get the bounding box coordinates.
 
bool HasMagneticField () const override
 Does the component have a non-zero magnetic field?
 
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).
 
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 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

Simple component with electric field given by a user function.

Definition at line 13 of file ComponentUser.hh.

Constructor & Destructor Documentation

◆ ComponentUser()

Garfield::ComponentUser::ComponentUser ( )

Constructor.

Definition at line 73 of file ComponentUser.cc.

73: Component("User") {}
Component()=delete
Default constructor.

◆ ~ComponentUser()

Garfield::ComponentUser::~ComponentUser ( )
inline

Destructor.

Definition at line 18 of file ComponentUser.hh.

18{}

Member Function Documentation

◆ DelayedWeightingField()

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

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 from Garfield::Component.

Definition at line 158 of file ComponentUser.cc.

161 {
162 wx = wy = wz = 0.;
163 if (m_dwfield.count(label) > 0) {
164 m_dwfield[label](x, y, z, t, wx, wy, wz);
165 }
166}

◆ DelayedWeightingPotential()

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

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 from Garfield::Component.

Definition at line 168 of file ComponentUser.cc.

170 {
171
172 double v = 0.;
173 if (m_dwpot.count(label) > 0) v = m_dwpot[label](x, y, z, t);
174 return v;
175}

◆ 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::ComponentUser::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 99 of file ComponentUser.cc.

102 {
103 if (!m_efield) {
104 ex = ey = ez = v = 0.;
105 m = nullptr;
106 status = -10;
107 return;
108 }
109 m_efield(x, y, z, ex, ey, ez);
110
111 v = m_epot ? m_epot(x, y, z) : 0.;
112 m = GetMedium(x, y, z);
113 if (!m) {
114 if (m_debug) {
115 std::cerr << m_className << "::ElectricField:\n (" << x << ", " << y
116 << ", " << z << ") is not inside a medium.\n";
117 }
118 status = -6;
119 return;
120 }
121
122 status = m->IsDriftable() ? 0 : -5;
123}
Medium * GetMedium(const double x, const double y, const double z) override
Get the medium at a given location (x, y, z).
bool m_debug
Switch on/off debugging messages.
Definition Component.hh:371
std::string m_className
Class name.
Definition Component.hh:359

◆ ElectricField() [3/3]

void Garfield::ComponentUser::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 75 of file ComponentUser.cc.

77 {
78 if (!m_efield) {
79 ex = ey = ez = 0.;
80 m = nullptr;
81 status = -10;
82 return;
83 }
84
85 m_efield(x, y, z, ex, ey, ez);
86 m = GetMedium(x, y, z);
87 if (!m) {
88 if (m_debug) {
89 std::cerr << m_className << "::ElectricField:\n (" << x << ", " << y
90 << ", " << z << ") is not inside a medium.\n";
91 }
92 status = -6;
93 return;
94 }
95
96 status = m->IsDriftable() ? 0 : -5;
97}

◆ GetBoundingBox()

bool Garfield::ComponentUser::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 177 of file ComponentUser.cc.

179 {
180
181 if (!m_hasArea) {
182 return Component::GetBoundingBox(xmin, ymin, zmin, xmax, ymax, zmax);
183 }
184 xmin = m_xmin[0];
185 ymin = m_xmin[1];
186 zmin = m_xmin[2];
187 xmax = m_xmax[0];
188 ymax = m_xmax[1];
189 zmax = m_xmax[2];
190 return true;
191}
virtual bool GetBoundingBox(double &xmin, double &ymin, double &zmin, double &xmax, double &ymax, double &zmax)
Get the bounding box coordinates.
Definition Component.cc:120

◆ GetMedium()

Medium * Garfield::ComponentUser::GetMedium ( const double x,
const double y,
const double z )
inlineoverridevirtual

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

Reimplemented from Garfield::Component.

Definition at line 87 of file ComponentUser.hh.

87 {
88 return !m_hasArea ? Component::GetMedium(x, y, z) :
89 InArea(x, y, z) ? m_medium : nullptr;
90 }
virtual Medium * GetMedium(const double x, const double y, const double z)
Get the medium at a given location (x, y, z).
Definition Component.cc:24

Referenced by ElectricField(), and ElectricField().

◆ GetVoltageRange()

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

Calculate the voltage range [V].

Implements Garfield::Component.

Definition at line 125 of file ComponentUser.cc.

125 {
126 vmin = vmax = 0.;
127 return false;
128}

◆ HasMagneticField()

bool Garfield::ComponentUser::HasMagneticField ( ) const
overridevirtual

Does the component have a non-zero magnetic field?

Reimplemented from Garfield::Component.

Definition at line 193 of file ComponentUser.cc.

193 {
194 return m_bfield ? true : Component::HasMagneticField();
195}
virtual bool HasMagneticField() const
Does the component have a non-zero magnetic field?
Definition Component.cc:155

◆ MagneticField()

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

Calculate the magnetic field at a given point.

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

Reimplemented from Garfield::Component.

Definition at line 130 of file ComponentUser.cc.

132 {
133 if (!m_bfield) {
134 Component::MagneticField(x, y, z, bx, by, bz, status);
135 return;
136 }
137 m_bfield(x, y, z, bx, by, bz);
138 status = 0;
139}
virtual void MagneticField(const double x, const double y, const double z, double &bx, double &by, double &bz, int &status)
Definition Component.cc:102

◆ SetArea()

void Garfield::ComponentUser::SetArea ( const double xmin,
const double ymin,
const double zmin,
const double xmax,
const double ymax,
const double zmax )

Set the limits of the active area explicitly (instead of using a Geometry object).

Definition at line 384 of file ComponentUser.cc.

386 {
387
388 m_xmin[0] = std::min(xmin, xmax);
389 m_xmin[1] = std::min(ymin, ymax);
390 m_xmin[2] = std::min(zmin, zmax);
391 m_xmax[0] = std::max(xmin, xmax);
392 m_xmax[1] = std::max(ymin, ymax);
393 m_xmax[2] = std::max(zmin, zmax);
394 m_hasArea = true;
395}

◆ SetDelayedWeightingField() [1/2]

void Garfield::ComponentUser::SetDelayedWeightingField ( const std::string & expression,
const std::string & label )

Set the expression to be used for calculating the delayed weighting field.

Definition at line 312 of file ComponentUser.cc.

313 {
314
315 std::string fname = label;
316 RemoveSpecialCharacters(fname);
317 fname = "fComponentUserDWfield" + fname;
318 auto fPtr = MakeFieldFunction(fname, expression, true, false, true);
319 if (!fPtr) {
320 std::cerr << m_className << "::SetDelayedWeightingField: "
321 << "Could not convert the expression.\n";
322 return;
323 }
324 typedef std::function<void(const double, const double, const double,
325 const double, double&, double&, double&)> Fcn;
326 Fcn& f = *((Fcn *) fPtr);
327 m_dwfield[label] = f;
328}

◆ SetDelayedWeightingField() [2/2]

void Garfield::ComponentUser::SetDelayedWeightingField ( std::function< void(const double, const double, const double, const double, double &, double &, double &)> f,
const std::string & label )

Set the function to be called for calculating the delayed weighting field.

Definition at line 299 of file ComponentUser.cc.

302 {
303
304 if (!f) {
305 std::cerr << m_className << "::SetDelayedWeightingField: "
306 << "Function is empty.\n";
307 return;
308 }
309 m_dwfield[label] = f;
310}

◆ SetDelayedWeightingPotential() [1/2]

void Garfield::ComponentUser::SetDelayedWeightingPotential ( const std::string & expression,
const std::string & label )

Set the expression to be used for calculating the delayed weighting potential.

Definition at line 342 of file ComponentUser.cc.

343 {
344 std::string fname = label;
345 RemoveSpecialCharacters(fname);
346 fname = "fComponentUserDWpot" + fname;
347 auto fPtr = MakePotentialFunction(fname, expression, true);
348 if (!fPtr) {
349 std::cerr << m_className << "::SetDelayedWeightingPotential: "
350 << "Could not convert the expression.\n";
351 return;
352 }
353 typedef std::function<double(const double, const double, const double,
354 const double)> Fcn;
355 Fcn& f = *((Fcn *) fPtr);
356 m_dwpot[label] = f;
357}

◆ SetDelayedWeightingPotential() [2/2]

void Garfield::ComponentUser::SetDelayedWeightingPotential ( std::function< double(const double, const double, const double, const double)> f,
const std::string & label )

Set the function to be called for calculating the delayed weighting potential.

Definition at line 330 of file ComponentUser.cc.

333 {
334 if (!f) {
335 std::cerr << m_className << "::SetDelayedWeightingPotential: "
336 << "Function is empty.\n";
337 return;
338 }
339 m_dwpot[label] = f;
340}

◆ SetElectricField() [1/2]

void Garfield::ComponentUser::SetElectricField ( const std::string & expression)

Set the expression to be used for calculating the electric field.

Definition at line 208 of file ComponentUser.cc.

208 {
209 const std::string fname = "fComponentUserEfield";
210 auto fPtr = MakeFieldFunction(fname, expression);
211 if (!fPtr) {
212 std::cerr << m_className << "::SetElectricField: "
213 << "Could not convert the expression.\n";
214 return;
215 }
216 typedef std::function<void(const double, const double, const double,
217 double&, double&, double&)> Fcn;
218 Fcn& f = *((Fcn *) fPtr);
219 m_efield = f;
220 m_ready = true;
221}
bool m_ready
Ready for use?
Definition Component.hh:368

◆ SetElectricField() [2/2]

void Garfield::ComponentUser::SetElectricField ( std::function< void(const double, const double, const double, double &, double &, double &)> f)

Set the function to be called for calculating the electric field.

Definition at line 197 of file ComponentUser.cc.

199 {
200 if (!f) {
201 std::cerr << m_className << "::SetElectricField: Function is empty.\n";
202 return;
203 }
204 m_efield = f;
205 m_ready = true;
206}

◆ SetMagneticField() [1/2]

void Garfield::ComponentUser::SetMagneticField ( const std::string & expression)

Set the expression to be used for calculating the magnetic field.

Definition at line 369 of file ComponentUser.cc.

369 {
370
371 const std::string fname = "fComponentUserBfield";
372 auto fPtr = MakeFieldFunction(fname, expression, false, true);
373 if (!fPtr) {
374 std::cerr << m_className << "::SetMagneticField: "
375 << "Could not convert the expression.\n";
376 return;
377 }
378 typedef std::function<void(const double, const double, const double,
379 double&, double&, double&)> Fcn;
380 Fcn& f = *((Fcn *) fPtr);
381 m_bfield = f;
382}

◆ SetMagneticField() [2/2]

void Garfield::ComponentUser::SetMagneticField ( std::function< void(const double, const double, const double, double &, double &, double &)> f)

Set the function to be called for calculating the magnetic field.

Definition at line 359 of file ComponentUser.cc.

361 {
362 if (!f) {
363 std::cerr << m_className << "::SetMagneticField: Function is empty.\n";
364 return;
365 }
366 m_bfield = f;
367}

◆ SetMedium()

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

Set the medium in the active area.

Definition at line 85 of file ComponentUser.hh.

85{ m_medium = medium; }

◆ SetPotential() [1/2]

void Garfield::ComponentUser::SetPotential ( const std::string & expression)

Set the expression to be used for calculating the electric potential.

Definition at line 232 of file ComponentUser.cc.

232 {
233 const std::string fname = "fComponentUserEpot";
234 auto fPtr = MakePotentialFunction(fname, expression);
235 if (!fPtr) {
236 std::cerr << m_className << "::SetPotential: "
237 << "Could not convert the expression.\n";
238 return;
239 }
240 typedef std::function<double(const double, const double, const double)> Fcn;
241 Fcn& f = *((Fcn *) fPtr);
242 m_epot = f;
243}

◆ SetPotential() [2/2]

void Garfield::ComponentUser::SetPotential ( std::function< double(const double, const double, const double)> f)

Set the function to be called for calculating the electric potential.

Definition at line 223 of file ComponentUser.cc.

224 {
225 if (!f) {
226 std::cerr << m_className << "::SetPotential: Function is empty.\n";
227 return;
228 }
229 m_epot = f;
230}

◆ SetWeightingField() [1/2]

void Garfield::ComponentUser::SetWeightingField ( const std::string & expression,
const std::string & label )

Set the expression to be used for calculating the weighting field.

Definition at line 256 of file ComponentUser.cc.

257 {
258 std::string fname = label;
259 RemoveSpecialCharacters(fname);
260 fname = "fComponentUserWfield" + fname;
261 auto fPtr = MakeFieldFunction(fname, expression, true);
262 if (!fPtr) {
263 std::cerr << m_className << "::SetWeightingField: "
264 << "Could not convert the expression.\n";
265 return;
266 }
267 typedef std::function<void(const double, const double, const double,
268 double&, double&, double&)> Fcn;
269 Fcn& f = *((Fcn *) fPtr);
270 m_wfield[label] = f;
271}

◆ SetWeightingField() [2/2]

void Garfield::ComponentUser::SetWeightingField ( std::function< void(const double, const double, const double, double &, double &, double &)> f,
const std::string & label )

Set the function to be called for calculating the weighting field.

Definition at line 245 of file ComponentUser.cc.

248 {
249 if (!f) {
250 std::cerr << m_className << "::SetWeightingField: Function is empty.\n";
251 return;
252 }
253 m_wfield[label] = f;
254}

◆ SetWeightingPotential() [1/2]

void Garfield::ComponentUser::SetWeightingPotential ( const std::string & expression,
const std::string & label )

Set the expression to be used for calculating the weighting potential.

Definition at line 283 of file ComponentUser.cc.

284 {
285 std::string fname = label;
286 RemoveSpecialCharacters(fname);
287 fname = "fComponentUserWpot" + fname;
288 auto fPtr = MakePotentialFunction(fname, expression);
289 if (!fPtr) {
290 std::cerr << m_className << "::SetWeightingPotential: "
291 << "Could not convert the expression.\n";
292 return;
293 }
294 typedef std::function<double(const double, const double, const double)> Fcn;
295 Fcn& f = *((Fcn *) fPtr);
296 m_wpot[label] = f;
297}

◆ SetWeightingPotential() [2/2]

void Garfield::ComponentUser::SetWeightingPotential ( std::function< double(const double, const double, const double)> f,
const std::string & label )

Set the function to be called for calculating the weighting potential.

Definition at line 273 of file ComponentUser.cc.

275 {
276 if (!f) {
277 std::cerr << m_className << "::SetWeightingPotential: Function is empty.\n";
278 return;
279 }
280 m_wpot[label] = f;
281}

◆ UnsetArea()

void Garfield::ComponentUser::UnsetArea ( )

Remove the explicit limits of the active area.

Definition at line 397 of file ComponentUser.cc.

397 {
398 m_xmin.fill(0.);
399 m_xmax.fill(0.);
400 m_hasArea = false;
401}

◆ WeightingField()

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

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 from Garfield::Component.

Definition at line 141 of file ComponentUser.cc.

143 {
144 wx = wy = wz = 0.;
145 if (m_wfield.count(label) > 0) {
146 m_wfield[label](x, y, z, wx, wy, wz);
147 }
148}

◆ WeightingPotential()

double Garfield::ComponentUser::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 150 of file ComponentUser.cc.

152 {
153 double v = 0.;
154 if (m_wpot.count(label) > 0) v = m_wpot[label](x, y, z);
155 return v;
156}

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