Garfield++ 5.0
A toolkit for the detailed simulation of particle detectors based on ionisation measurement in gases and semiconductors
|
#include <ComponentNeBem3d.hh>
Public Member Functions | |
ComponentNeBem3d () | |
Constructor. | |
~ComponentNeBem3d () | |
Destructor. | |
Medium * | GetMedium (const double x, const double y, const double z) override |
Get the medium at a given location (x, y, z). | |
void | AddPlaneX (const double x, const double voltage) |
Add a plane at constant x. | |
void | AddPlaneY (const double y, const double voltage) |
Add a plane at constant y. | |
void | AddPlaneZ (const double z, const double voltage) |
Add a plane at constant z. | |
unsigned int | GetNumberOfPlanesX () const |
Get the number of equipotential planes at constant x. | |
unsigned int | GetNumberOfPlanesY () const |
Get the number of equipotential planes at constant y. | |
unsigned int | GetNumberOfPlanesZ () const |
Get the number of equipotential planes at constant z. | |
bool | GetPlaneX (const unsigned int i, double &x, double &v) const |
Retrieve the parameters of a plane at constant x. | |
bool | GetPlaneY (const unsigned int i, double &y, double &v) const |
Retrieve the parameters of a plane at constant y. | |
bool | GetPlaneZ (const unsigned int i, double &z, double &v) const |
Retrieve the parameters of a plane at constant z. | |
unsigned int | GetNumberOfPrimitives () const |
bool | GetPrimitive (const unsigned int i, double &a, double &b, double &c, std::vector< double > &xv, std::vector< double > &yv, std::vector< double > &zv, int &interface, double &v, double &q, double &lambda) const |
bool | GetPrimitive (const unsigned int i, double &a, double &b, double &c, std::vector< double > &xv, std::vector< double > &yv, std::vector< double > &zv, int &vol1, int &vol2) const |
bool | GetVolume (const unsigned int vol, int &shape, int &material, double &eps, double &potential, double &charge, int &bc) |
int | GetVolume (const double x, const double y, const double z) |
unsigned int | GetNumberOfElements () const |
bool | GetElement (const unsigned int i, std::vector< double > &xv, std::vector< double > &yv, std::vector< double > &zv, int &interface, double &bc, double &lambda) const |
bool | Initialise () |
void | SetTargetElementSize (const double length) |
void | SetMinMaxNumberOfElements (const unsigned int nmin, const unsigned int nmax) |
void | SetNewModel (const unsigned int NewModel) |
void | SetNewMesh (const unsigned int NewMesh) |
void | SetNewBC (const unsigned int NewBC) |
void | SetNewPP (const unsigned int NewPP) |
void | SetModelOptions (const unsigned int NewModel, const unsigned int NewMesh, const unsigned int NewBC, const unsigned int NewPP) |
void | SetStoreInflMatrix (const unsigned int OptStoreInflMatrix) |
void | SetReadInflMatrix (const unsigned int OptReadInflMatrix) |
void | SetStoreInvMatrix (const unsigned int OptStoreInvMatrix) |
void | SetReadInvMatrix (const unsigned int OptReadInvMatrix) |
void | SetStorePrimitives (const unsigned int OptStorePrimitives) |
void | SetReadPrimitives (const unsigned int OptReadPrimitives) |
void | SetStoreElements (const unsigned int OptStoreElements) |
void | SetReadElements (const unsigned int OptReadElements) |
void | SetFormattedFile (const unsigned int OptFormattedFile) |
void | SetUnformattedFile (const unsigned int OptUnformattedFile) |
void | SetStoreReadOptions (const unsigned int OptStoreInflMatrix, const unsigned int OptReadInflMatrix, const unsigned int OptStoreInvMatrix, const unsigned int OptReadInvMatrix, const unsigned int OptStorePrimitives, const unsigned int OptReadPrimitives, const unsigned int OptStoreElements, const unsigned int OptReadElements, const unsigned int OptFormattedFile, const unsigned int OptUnformattedFile) |
void | SetReuseModel (void) |
void | SetSystemChargeZero (const unsigned int OptSystemChargeZero) |
void | SetValidateSolution (const unsigned int OptValidateSolution) |
void | SetForceValidation (const unsigned int OptForceValidation) |
void | SetRepeatLHMatrix (const unsigned int OptRepeatLHMatrix) |
void | SetComputeOptions (const unsigned int OptSystemChargeZero, const unsigned int OptValidateSolution, const unsigned int OptForceValidation, const unsigned int OptRepeatLHMatrix) |
void | SetFastVolOptions (const unsigned int OptFastVol, const unsigned int OptCreateFastPF, const unsigned int OptReadFastPF) |
void | SetFastVolVersion (const unsigned int VersionFV) |
void | SetFastVolBlocks (const unsigned int NbBlocksFV) |
void | SetWtFldFastVolOptions (const unsigned int IdWtField, const unsigned int OptWtFldFastVol, const unsigned int OptCreateWtFldFastPF, const unsigned int OptReadWtFldFastPF) |
void | SetWtFldFastVolVersion (const unsigned int IdWtField, const unsigned int VersionWtFldFV) |
void | SetWtFldFastVolBlocks (const unsigned int IdWtField, const unsigned int NbBlocksWtFldFV) |
void | SetKnownChargeOptions (const unsigned int OptKnownCharge) |
void | SetChargingUpOptions (const unsigned int OptChargingUp) |
void | UseLUInversion () |
Invert the influence matrix using lower-upper (LU) decomposition. | |
void | UseSVDInversion () |
Invert the influence matrix using singular value decomposition. | |
void | SetPeriodicCopies (const unsigned int nx, const unsigned int ny, const unsigned int nz) |
void | GetPeriodicCopies (unsigned int &nx, unsigned int &ny, unsigned int &nz) const |
Retrieve the number of periodic copies used by neBEM. | |
void | SetPeriodicityX (const double s) |
Set the periodic length [cm] in the x-direction. | |
void | SetPeriodicityY (const double s) |
Set the periodic length [cm] in the y-direction. | |
void | SetPeriodicityZ (const double s) |
Set the periodic length [cm] in the z-direction. | |
void | SetMirrorPeriodicityX (const double s) |
Set the periodic length [cm] in the x-direction. | |
void | SetMirrorPeriodicityY (const double s) |
Set the periodic length [cm] in the y-direction. | |
void | SetMirrorPeriodicityZ (const double s) |
Set the periodic length [cm] in the z-direction. | |
bool | GetPeriodicityX (double &s) const |
Get the periodic length in the x-direction. | |
bool | GetPeriodicityY (double &s) const |
Get the periodic length in the y-direction. | |
bool | GetPeriodicityZ (double &s) const |
Get the periodic length in the z-direction. | |
void | SetNumberOfThreads (const unsigned int n) |
Set the number of threads to be used by neBEM. | |
void | SetPrimAfter (const int n) |
void | SetWtFldPrimAfter (const int n) |
void | SetOptRmPrim (const unsigned int n) |
Set option related to removal of primitives. | |
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 | 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 |
std::array< double, 3 > | ElectricField (const double x, const double y, const double z) |
Calculate the drift field [V/cm] at (x, y, z). | |
![]() | |
Component ()=delete | |
Default constructor. | |
Component (const std::string &name) | |
Constructor. | |
virtual | ~Component () |
Destructor. | |
virtual void | SetGeometry (Geometry *geo) |
Define the geometry. | |
virtual void | Clear () |
Reset. | |
std::array< double, 3 > | ElectricField (const double x, const double y, const double z) |
Calculate the drift field [V/cm] at (x, y, z). | |
virtual double | ElectricPotential (const double x, const double y, const double z) |
Calculate the (drift) electrostatic potential [V] at (x, y, z). | |
virtual void | 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 ![]() | |
void | EnablePeriodicityY (const bool on=true) |
Enable simple periodicity in the ![]() | |
void | EnablePeriodicityZ (const bool on=true) |
Enable simple periodicity in the ![]() | |
void | IsPeriodic (bool &perx, bool &pery, bool &perz) |
Return periodicity flags. | |
void | EnableMirrorPeriodicityX (const bool on=true) |
Enable mirror periodicity in the ![]() | |
void | EnableMirrorPeriodicityY (const bool on=true) |
Enable mirror periodicity in the ![]() | |
void | EnableMirrorPeriodicityZ (const bool on=true) |
Enable mirror periodicity in the ![]() | |
void | IsMirrorPeriodic (bool &perx, bool &pery, bool &perz) |
Return mirror periodicity flags. | |
void | EnableAxialPeriodicityX (const bool on=true) |
Enable axial periodicity in the ![]() | |
void | EnableAxialPeriodicityY (const bool on=true) |
Enable axial periodicity in the ![]() | |
void | EnableAxialPeriodicityZ (const bool on=true) |
Enable axial periodicity in the ![]() | |
void | IsAxiallyPeriodic (bool &perx, bool &pery, bool &perz) |
Return axial periodicity flags. | |
void | EnableRotationSymmetryX (const bool on=true) |
Enable rotation symmetry around the ![]() | |
void | EnableRotationSymmetryY (const bool on=true) |
Enable rotation symmetry around the ![]() | |
void | EnableRotationSymmetryZ (const bool on=true) |
Enable rotation symmetry around the ![]() | |
void | IsRotationSymmetric (bool &rotx, bool &roty, bool &rotz) |
Return rotation symmetry flags. | |
void | EnableDebugging () |
Switch on debugging messages. | |
void | DisableDebugging () |
Switch off debugging messages. | |
virtual bool | HasMagneticField () const |
Does the component have a non-zero magnetic field? | |
virtual bool | HasTownsendMap () const |
Does the component have maps of the Townsend coefficient? | |
virtual bool | HasAttachmentMap () const |
Does the component have attachment maps? | |
virtual bool | HasVelocityMap () const |
Does the component have velocity maps? | |
virtual bool | ElectronAttachment (const double, const double, const double, double &eta) |
Get the electron attachment coefficient. | |
virtual bool | HoleAttachment (const double, const double, const double, double &eta) |
Get the hole attachment coefficient. | |
virtual bool | ElectronTownsend (const double, const double, const double, double &alpha) |
Get the electron Townsend coefficient. | |
virtual bool | HoleTownsend (const double, const double, const double, double &alpha) |
Get the hole Townsend coefficient. | |
virtual bool | ElectronVelocity (const double, const double, const double, double &vx, double &vy, double &vz) |
Get the electron drift velocity. | |
virtual bool | HoleVelocity (const double, const double, const double, double &vx, double &vy, double &vz) |
Get the hole drift velocity. | |
virtual bool | GetElectronLifetime (const double, const double, const double, double &etau) |
virtual bool | GetHoleLifetime (const double, const double, const double, double &htau) |
virtual double | StepSizeHint () |
Protected Member Functions | |
void | Reset () override |
Reset the component. | |
void | UpdatePeriodicity () override |
Verify periodicities. | |
Additional Inherited Members | |
![]() | |
std::string | m_className = "Component" |
Class name. | |
Geometry * | m_geometry = nullptr |
Pointer to the geometry. | |
std::array< double, 3 > | m_b0 = {{0., 0., 0.}} |
Constant magnetic field. | |
bool | m_ready = false |
Ready for use? | |
bool | m_debug = false |
Switch on/off debugging messages. | |
std::array< bool, 3 > | m_periodic = {{false, false, false}} |
Simple periodicity in x, y, z. | |
std::array< bool, 3 > | m_mirrorPeriodic = {{false, false, false}} |
Mirror periodicity in x, y, z. | |
std::array< bool, 3 > | m_axiallyPeriodic = {{false, false, false}} |
Axial periodicity in x, y, z. | |
std::array< bool, 3 > | m_rotationSymmetric = {{false, false, false}} |
Rotation symmetry around x-axis, y-axis, z-axis. | |
Interface to neBEM.
Definition at line 12 of file ComponentNeBem3d.hh.
Garfield::ComponentNeBem3d::ComponentNeBem3d | ( | ) |
|
inline |
void Garfield::ComponentNeBem3d::AddPlaneX | ( | const double | x, |
const double | voltage ) |
Add a plane at constant x.
Definition at line 492 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::AddPlaneY | ( | const double | y, |
const double | voltage ) |
Add a plane at constant y.
Definition at line 518 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::AddPlaneZ | ( | const double | z, |
const double | voltage ) |
Add a plane at constant z.
Definition at line 544 of file ComponentNeBem3d.cc.
std::array< double, 3 > Garfield::Component::ElectricField | ( | const double | x, |
const double | y, | ||
const double | z ) |
Calculate the drift field [V/cm] at (x, y, z).
Definition at line 55 of file Component.cc.
|
overridevirtual |
Calculate the drift field [V/cm] and potential [V] at (x, y, z).
Implements Garfield::Component.
Definition at line 405 of file ComponentNeBem3d.cc.
|
overridevirtual |
Calculate the drift field at given point.
x,y,z | coordinates [cm]. |
ex,ey,ez | components of the electric field [V/cm]. |
m | pointer to the medium at this location. |
status | status flag |
Status flags:
0: Inside an active medium > 0: Inside a wire of type X -4 ... -1: On the side of a plane where no wires are -5: Inside the mesh but not in an active medium -6: Outside the mesh -10: Unknown potential type (should not occur) other: Other cases (should not occur)
Implements Garfield::Component.
Definition at line 445 of file ComponentNeBem3d.cc.
Referenced by ElectricField().
bool Garfield::ComponentNeBem3d::GetElement | ( | const unsigned int | i, |
std::vector< double > & | xv, | ||
std::vector< double > & | yv, | ||
std::vector< double > & | zv, | ||
int & | interface, | ||
double & | bc, | ||
double & | lambda ) const |
Definition at line 3438 of file ComponentNeBem3d.cc.
|
overridevirtual |
Get the medium at a given location (x, y, z).
Reimplemented from Garfield::Component.
Definition at line 386 of file ComponentNeBem3d.cc.
Referenced by ElectricField().
|
inline |
Definition at line 52 of file ComponentNeBem3d.hh.
unsigned int Garfield::ComponentNeBem3d::GetNumberOfPlanesX | ( | ) | const |
Get the number of equipotential planes at constant x.
Definition at line 570 of file ComponentNeBem3d.cc.
unsigned int Garfield::ComponentNeBem3d::GetNumberOfPlanesY | ( | ) | const |
Get the number of equipotential planes at constant y.
Definition at line 579 of file ComponentNeBem3d.cc.
unsigned int Garfield::ComponentNeBem3d::GetNumberOfPlanesZ | ( | ) | const |
Get the number of equipotential planes at constant z.
Definition at line 588 of file ComponentNeBem3d.cc.
|
inline |
Definition at line 40 of file ComponentNeBem3d.hh.
|
inline |
Retrieve the number of periodic copies used by neBEM.
Definition at line 157 of file ComponentNeBem3d.hh.
bool Garfield::ComponentNeBem3d::GetPeriodicityX | ( | double & | s | ) | const |
Get the periodic length in the x-direction.
Definition at line 906 of file ComponentNeBem3d.cc.
bool Garfield::ComponentNeBem3d::GetPeriodicityY | ( | double & | s | ) | const |
Get the periodic length in the y-direction.
Definition at line 915 of file ComponentNeBem3d.cc.
bool Garfield::ComponentNeBem3d::GetPeriodicityZ | ( | double & | s | ) | const |
Get the periodic length in the z-direction.
Definition at line 924 of file ComponentNeBem3d.cc.
bool Garfield::ComponentNeBem3d::GetPlaneX | ( | const unsigned int | i, |
double & | x, | ||
double & | v ) const |
Retrieve the parameters of a plane at constant x.
Definition at line 597 of file ComponentNeBem3d.cc.
bool Garfield::ComponentNeBem3d::GetPlaneY | ( | const unsigned int | i, |
double & | y, | ||
double & | v ) const |
Retrieve the parameters of a plane at constant y.
Definition at line 608 of file ComponentNeBem3d.cc.
bool Garfield::ComponentNeBem3d::GetPlaneZ | ( | const unsigned int | i, |
double & | z, | ||
double & | v ) const |
Retrieve the parameters of a plane at constant z.
Definition at line 619 of file ComponentNeBem3d.cc.
bool Garfield::ComponentNeBem3d::GetPrimitive | ( | const unsigned int | i, |
double & | a, | ||
double & | b, | ||
double & | c, | ||
std::vector< double > & | xv, | ||
std::vector< double > & | yv, | ||
std::vector< double > & | zv, | ||
int & | interface, | ||
double & | v, | ||
double & | q, | ||
double & | lambda ) const |
Definition at line 3344 of file ComponentNeBem3d.cc.
bool Garfield::ComponentNeBem3d::GetPrimitive | ( | const unsigned int | i, |
double & | a, | ||
double & | b, | ||
double & | c, | ||
std::vector< double > & | xv, | ||
std::vector< double > & | yv, | ||
std::vector< double > & | zv, | ||
int & | vol1, | ||
int & | vol2 ) const |
Definition at line 3368 of file ComponentNeBem3d.cc.
|
overridevirtual |
Calculate the voltage range [V].
Implements Garfield::Component.
Definition at line 452 of file ComponentNeBem3d.cc.
int Garfield::ComponentNeBem3d::GetVolume | ( | const double | x, |
const double | y, | ||
const double | z ) |
Definition at line 3425 of file ComponentNeBem3d.cc.
bool Garfield::ComponentNeBem3d::GetVolume | ( | const unsigned int | vol, |
int & | shape, | ||
int & | material, | ||
double & | eps, | ||
double & | potential, | ||
double & | charge, | ||
int & | bc ) |
Definition at line 3389 of file ComponentNeBem3d.cc.
bool Garfield::ComponentNeBem3d::Initialise | ( | ) |
Retrieve surface panels, remove contacts and cut polygons to rectangles and right-angle triangles.
Definition at line 933 of file ComponentNeBem3d.cc.
Referenced by ElectricField().
|
overrideprotectedvirtual |
Reset the component.
Implements Garfield::Component.
Definition at line 3456 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetChargingUpOptions | ( | const unsigned int | OptChargingUp | ) |
Definition at line 822 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetComputeOptions | ( | const unsigned int | OptSystemChargeZero, |
const unsigned int | OptValidateSolution, | ||
const unsigned int | OptForceValidation, | ||
const unsigned int | OptRepeatLHMatrix ) |
Definition at line 760 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetFastVolBlocks | ( | const unsigned int | NbBlocksFV | ) |
Definition at line 785 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetFastVolOptions | ( | const unsigned int | OptFastVol, |
const unsigned int | OptCreateFastPF, | ||
const unsigned int | OptReadFastPF ) |
Definition at line 771 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetFastVolVersion | ( | const unsigned int | VersionFV | ) |
Definition at line 780 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetForceValidation | ( | const unsigned int | OptForceValidation | ) |
Definition at line 751 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetFormattedFile | ( | const unsigned int | OptFormattedFile | ) |
Definition at line 706 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetKnownChargeOptions | ( | const unsigned int | OptKnownCharge | ) |
Definition at line 816 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetMinMaxNumberOfElements | ( | const unsigned int | nmin, |
const unsigned int | nmax ) |
Set the smallest and largest allowed number of elements along the lenght of a primitive.
Definition at line 639 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetMirrorPeriodicityX | ( | const double | s | ) |
Set the periodic length [cm] in the x-direction.
Definition at line 870 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetMirrorPeriodicityY | ( | const double | s | ) |
Set the periodic length [cm] in the y-direction.
Definition at line 882 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetMirrorPeriodicityZ | ( | const double | s | ) |
Set the periodic length [cm] in the z-direction.
Definition at line 894 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetModelOptions | ( | const unsigned int | NewModel, |
const unsigned int | NewMesh, | ||
const unsigned int | NewBC, | ||
const unsigned int | NewPP ) |
void Garfield::ComponentNeBem3d::SetNewBC | ( | const unsigned int | NewBC | ) |
Definition at line 658 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetNewMesh | ( | const unsigned int | NewMesh | ) |
Definition at line 654 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetNewModel | ( | const unsigned int | NewModel | ) |
Definition at line 650 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetNewPP | ( | const unsigned int | NewPP | ) |
Definition at line 660 of file ComponentNeBem3d.cc.
|
inline |
Set the number of threads to be used by neBEM.
Definition at line 183 of file ComponentNeBem3d.hh.
|
inline |
Set option related to removal of primitives.
Definition at line 196 of file ComponentNeBem3d.hh.
void Garfield::ComponentNeBem3d::SetPeriodicCopies | ( | const unsigned int | nx, |
const unsigned int | ny, | ||
const unsigned int | nz ) |
Set the parameters
Definition at line 826 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetPeriodicityX | ( | const double | s | ) |
Set the periodic length [cm] in the x-direction.
Definition at line 834 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetPeriodicityY | ( | const double | s | ) |
Set the periodic length [cm] in the y-direction.
Definition at line 846 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetPeriodicityZ | ( | const double | s | ) |
Set the periodic length [cm] in the z-direction.
Definition at line 858 of file ComponentNeBem3d.cc.
|
inline |
Set the number of repetitions after which primitive properties are used for the physical field. A negative value (default) implies all the elements are always evaluated.
Definition at line 188 of file ComponentNeBem3d.hh.
void Garfield::ComponentNeBem3d::SetReadElements | ( | const unsigned int | OptReadElements | ) |
Definition at line 702 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetReadInflMatrix | ( | const unsigned int | OptReadInflMatrix | ) |
Definition at line 677 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetReadInvMatrix | ( | const unsigned int | OptReadInvMatrix | ) |
Definition at line 685 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetReadPrimitives | ( | const unsigned int | OptReadPrimitives | ) |
Definition at line 694 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetRepeatLHMatrix | ( | const unsigned int | OptRepeatLHMatrix | ) |
Definition at line 756 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetReuseModel | ( | void | ) |
Definition at line 734 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetStoreElements | ( | const unsigned int | OptStoreElements | ) |
Definition at line 698 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetStoreInflMatrix | ( | const unsigned int | OptStoreInflMatrix | ) |
Set storing options (OptStoreInflMatrix, OptStoreInvMatrix, OptStoreInvMatrix, OptStoreInvMatrix) OptStorePrimitives, OptStorePrimitives) OptStoreElements, OptStoreElements) OptFormattedFile, OptUnformattedFile)
Definition at line 672 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetStoreInvMatrix | ( | const unsigned int | OptStoreInvMatrix | ) |
Definition at line 681 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetStorePrimitives | ( | const unsigned int | OptStorePrimitives | ) |
Definition at line 689 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetStoreReadOptions | ( | const unsigned int | OptStoreInflMatrix, |
const unsigned int | OptReadInflMatrix, | ||
const unsigned int | OptStoreInvMatrix, | ||
const unsigned int | OptReadInvMatrix, | ||
const unsigned int | OptStorePrimitives, | ||
const unsigned int | OptReadPrimitives, | ||
const unsigned int | OptStoreElements, | ||
const unsigned int | OptReadElements, | ||
const unsigned int | OptFormattedFile, | ||
const unsigned int | OptUnformattedFile ) |
Definition at line 715 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetSystemChargeZero | ( | const unsigned int | OptSystemChargeZero | ) |
Other functions to be, are void SetPlotOptions(OptGnuplot=0, OptGnuplotPrimitives=0, OptGnuplotElements=0, OptPrimitiveFiles=0, OptElementFiles=0)
Definition at line 741 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetTargetElementSize | ( | const double | length | ) |
Set the default value of the target linear size of the elements produced by neBEM's discretisation process.
Definition at line 630 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetUnformattedFile | ( | const unsigned int | OptUnformattedFile | ) |
Definition at line 710 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetValidateSolution | ( | const unsigned int | OptValidateSolution | ) |
Definition at line 746 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetWtFldFastVolBlocks | ( | const unsigned int | IdWtField, |
const unsigned int | NbBlocksWtFldFV ) |
Definition at line 809 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetWtFldFastVolOptions | ( | const unsigned int | IdWtField, |
const unsigned int | OptWtFldFastVol, | ||
const unsigned int | OptCreateWtFldFastPF, | ||
const unsigned int | OptReadWtFldFastPF ) |
Definition at line 791 of file ComponentNeBem3d.cc.
void Garfield::ComponentNeBem3d::SetWtFldFastVolVersion | ( | const unsigned int | IdWtField, |
const unsigned int | VersionWtFldFV ) |
Definition at line 802 of file ComponentNeBem3d.cc.
|
inline |
Set the number of repetitions after which primitive properties are used for the weighting field. A negative value (default) implies all the elements are always evaluated.
Definition at line 193 of file ComponentNeBem3d.hh.
|
overrideprotectedvirtual |
Verify periodicities.
Implements Garfield::Component.
Definition at line 3465 of file ComponentNeBem3d.cc.
Referenced by SetMirrorPeriodicityX(), SetMirrorPeriodicityY(), SetMirrorPeriodicityZ(), SetPeriodicityX(), SetPeriodicityY(), and SetPeriodicityZ().
|
inline |
Invert the influence matrix using lower-upper (LU) decomposition.
Definition at line 147 of file ComponentNeBem3d.hh.
|
inline |
Invert the influence matrix using singular value decomposition.
Definition at line 149 of file ComponentNeBem3d.hh.
|
overridevirtual |
Calculate the weighting field at a given point and for a given electrode.
x,y,z | coordinates [cm]. |
wx,wy,wz | components of the weighting field [1/cm]. |
label | name of the electrode |
Reimplemented from Garfield::Component.
Definition at line 458 of file ComponentNeBem3d.cc.
|
overridevirtual |
Calculate the weighting potential at a given point.
x,y,z | coordinates [cm]. |
label | name of the electrode. |
Reimplemented from Garfield::Component.
Definition at line 478 of file ComponentNeBem3d.cc.