Garfield++ 5.0
A toolkit for the detailed simulation of particle detectors based on ionisation measurement in gases and semiconductors
|
Basis. More...
#include <vec.h>
Public Member Functions | |
vec | Gex () const |
vec | Gey () const |
vec | Gez () const |
basis | switch_xyz () const |
Change ex=ez; ey=ex; ez=ey. | |
basis () | |
Nominal basis. | |
basis (const std::string &pname) | |
Nominal basis. | |
basis (const vec &p, const std::string &fname) | |
basis (const vec &p, const vec &c, const std::string &pname) | |
basis (const basis &pb, const std::string &pname) | |
Same basis with other name, useful for later turning. | |
basis (const vec &pex, const vec &pey, const vec &pez, const std::string &pname) | |
Direct definitions of basis by three perpendicular unit-length vectors. | |
virtual basis * | copy () const |
virtual void | print (std::ostream &file, int l) const |
virtual | ~basis () |
![]() | |
virtual | ~absref () |
Destructor. | |
virtual void | down (const abssyscoor *fasc) |
Convert numbering representation of object to basical system of fasc. | |
virtual void | up (const abssyscoor *fasc) |
Convert numbering representation of objects to new system. | |
virtual void | turn (const vec &dir, vfloat angle) |
Turn around axis doing via center of coordinate system along dir. | |
virtual void | shift (const vec &dir) |
Public Attributes | |
std::string | name |
Protected Member Functions | |
virtual absref_transmit | get_components () override |
Protected Attributes | |
vec | ex |
vec | ey |
vec | ez |
Static Protected Attributes | |
static absref absref::* | aref [3] |
Friends | |
std::ostream & | operator<< (std::ostream &file, const basis &b) |
Heed::basis::basis | ( | ) |
Nominal basis.
Definition at line 281 of file vec.cpp.
Referenced by basis(), copy(), operator<<, and switch_xyz().
Heed::basis::basis | ( | const std::string & | pname | ) |
Heed::basis::basis | ( | const vec & | p, |
const std::string & | fname ) |
Longitudinal basis. z-axis is parallel to p. y-axis is vector product of z_new and z_old x-axis is vector product of y_new and z_new If p is parallel to z_old, the copy of old basis is created. If p is anti-parallel to z_old, the inverted copy of old basis is created.
More sophisticated basis. ez is parallel to p, ez=unit_vec(p) ey is perpendicular to plane which have p and c, ey=unit_vec(ez||c) ex is vector product of y and z, ex=ey||ez If p is parallel to c, or p is anti-parallel to c, vecerror=1 if(length(p)==0||length(c)==0)) vecerror=1;
Heed::basis::basis | ( | const basis & | pb, |
const std::string & | pname ) |
Direct definitions of basis by three perpendicular unit-length vectors.
Definition at line 351 of file vec.cpp.
|
overrideprotectedvirtual |
|
inline |
|
inline |
|
inline |
|
virtual |
basis Heed::basis::switch_xyz | ( | ) | const |
|
friend |
|
staticprotected |
Definition at line 321 of file vec.h.
Referenced by get_components().
|
protected |
|
protected |
|
protected |
std::string Heed::basis::name |
Definition at line 324 of file vec.h.
Referenced by basis(), basis(), basis(), basis(), basis(), basis(), operator<<, and switch_xyz().