Belle II Software  release-08-01-10
TOPGeoModule Class Reference

Geometry parameters of a module (optical components + positioning) More...

#include <TOPGeoModule.h>

Inheritance diagram for TOPGeoModule:
Collaboration diagram for TOPGeoModule:

Public Member Functions

 TOPGeoModule ()
 Default constructor.
 
 TOPGeoModule (int moduleID, double radius, double phi, double backwardZ, const std::string &name="TOPModule")
 Useful constructor. More...
 
 TOPGeoModule (const TOPGeoModule &module)
 Copy constructor.
 
TOPGeoModuleoperator= (const TOPGeoModule &module)
 Assignment operator.
 
 ~TOPGeoModule ()
 Destructor.
 
void setModuleCNumber (unsigned moduleCNumber)
 Sets module construction number (0 = ideal module = default) More...
 
void setBarSegment1 (const TOPGeoBarSegment &bar)
 Sets bar segment No.1 (forward bar) More...
 
void setBarSegment2 (const TOPGeoBarSegment &bar)
 Sets bar segment No.2 (backward bar) More...
 
void setMirrorSegment (const TOPGeoMirrorSegment &mirror)
 Sets mirror segment. More...
 
void setPrism (const TOPGeoPrism &prism)
 Sets prism. More...
 
void setPMTArray (const TOPGeoPMTArray &array)
 Sets PMT array. More...
 
void setDecoupledPMT (unsigned pmtID)
 Sets PMT as optically decoupled. More...
 
void generateDecoupledPMTs (double fraction)
 Generate randomly a fraction of PMT's to be optically decoupled. More...
 
void setBrokenGlue (int glueID, double fraction, double angle, const std::string &material)
 Sets glue to be broken (delaminated) More...
 
void setPeelOffRegions (double thickness, const std::string &material)
 Sets parameters of the peel-off cookie volumes. More...
 
void appendPeelOffRegion (unsigned ID, double fraction, double angle)
 Appends peel-off cookie region. More...
 
void setPMTArrayDisplacement (const TOPGeoPMTArrayDisplacement &displ)
 Sets PMT array displacement. More...
 
void setModuleDisplacement (const TOPGeoModuleDisplacement &displ)
 Sets module displacement. More...
 
int getModuleID () const
 Returns module ID. More...
 
double getRadius () const
 Returns radius of the bar central plane in Belle II frame. More...
 
double getPhi () const
 Returns module azimuthal angle in Belle II frame. More...
 
double getBackwardZ () const
 Returns the z position of prism-bar joint in Belle II frame. More...
 
unsigned getModuleCNumber () const
 Returns module construction number (0 = ideal module) More...
 
const TOPGeoBarSegmentgetBarSegment1 () const
 Returns bar segment No.1 (forward bar) More...
 
const TOPGeoBarSegmentgetBarSegment2 () const
 Returns bar segment No.2 (backward bar) More...
 
const TOPGeoMirrorSegmentgetMirrorSegment () const
 Returns mirror segment. More...
 
const TOPGeoPrismgetPrism () const
 Returns prism. More...
 
const TOPGeoPMTArraygetPMTArray () const
 Returns PMT array. More...
 
const TOPGeoPMTArrayDisplacementgetPMTArrayDisplacement () const
 Returns PMT array displacement. More...
 
const TOPGeoModuleDisplacementgetModuleDisplacement () const
 Returns module displacement. More...
 
double getBarLength () const
 Returns bar length (w/o prism) including glue joints. More...
 
double getFullLength () const
 Returns full length (including prism, wavelenght filter and glue joints) More...
 
double getForwardZ () const
 Returns the z position of the bar forward end in Belle II frame. More...
 
double getBarThickness () const
 Returns average bar thickness (weigthed by segment lengths) More...
 
double getBarWidth () const
 Returns average bar width (weigthed by segment lengths) More...
 
double getSurfaceReflectivity (double energy) const
 Returns average surface reflectivity at given photon energy (weigthed by segment lengths) More...
 
double getSigmaAlpha () const
 Returns average surface roughness parameter (weigthed by segment lengths) More...
 
double getZc () const
 Returns z of bar center (w/o prism) in Belle II frame. More...
 
double getInnerRadius () const
 Returns inner surface radius in Belle II frame. More...
 
const ROOT::Math::Transform3D & getTransformation () const
 Returns transformation from internal (= nominal & displaced) to Belle II frame. More...
 
const ROOT::Math::Transform3D & getTransformationNominal () const
 Returns transformation from nominal to Belle II frame. More...
 
ROOT::Math::XYZPoint pointToLocal (const ROOT::Math::XYZPoint &point) const
 Transforms 3D point from Belle II to module internal (= nominal & displaced) frame. More...
 
ROOT::Math::XYZVector momentumToLocal (const ROOT::Math::XYZVector &momentum) const
 Transforms momentum vector from Belle II to module internal (= nominal & displaced) frame. More...
 
ROOT::Math::XYZPoint pointToGlobal (const ROOT::Math::XYZPoint &point) const
 Transforms 3D point from module internal (= nominal & displaced) frame to Belle II frame. More...
 
ROOT::Math::XYZVector momentumToGlobal (const ROOT::Math::XYZVector &momentum) const
 Transforms momentum vector from module internal (= nominal & displaced) frame to Belle II frame. More...
 
ROOT::Math::XYZPoint pointGlobalToNominal (const ROOT::Math::XYZPoint &point) const
 Transforms 3D point from Belle II to module nominal frame. More...
 
ROOT::Math::XYZVector momentumGlobalToNominal (const ROOT::Math::XYZVector &momentum) const
 Transforms momentum vector from Belle II to module nominal frame. More...
 
ROOT::Math::XYZPoint pointNominalToGlobal (const ROOT::Math::XYZPoint &point) const
 Transforms 3D point from module nominal frame to Belle II frame. More...
 
ROOT::Math::XYZVector momentumNominalToGlobal (const ROOT::Math::XYZVector &momentum) const
 Transforms momentum vector from module nominal frame to Belle II frame. More...
 
bool isConsistent () const override
 Check for consistency of data members. More...
 
void print (const std::string &title="Module geometry parameters") const override
 Print the content of the class. More...
 
void setName (const std::string &name)
 Sets object name. More...
 
const std::string & getName () const
 Returns object name. More...
 
virtual void printSurface (const GeoOpticalSurface &surface) const
 Print the content of optical surface. More...
 
double getReflectivity (const GeoOpticalSurface &surface, double energy) const
 Returns reflectivity of optical surface at given photon energy. More...
 

Protected Member Functions

void printUnderlined (const std::string &title) const
 Print the content of the class. More...
 
 ClassDef (TOPGeoBase, 1)
 ClassDef.
 

Protected Attributes

std::string m_name
 geometry object name
 

Static Protected Attributes

static double s_unit = Unit::cm
 conversion unit for length
 
static std::string s_unitName
 conversion unit name
 

Private Member Functions

void setTransformation () const
 Sets transformation cache.
 
 ClassDefOverride (TOPGeoModule, 3)
 do not write out More...
 

Private Attributes

int m_moduleID = 0
 module ID
 
float m_radius = 0
 radius of bar central plane in Belle II frame
 
float m_phi = 0
 azimuthal angle in Belle II frame
 
float m_backwardZ = 0
 z position of prism-bar joint in Belle II frame
 
unsigned m_moduleCNumber = 0
 module construction number, 0 = ideal module
 
TOPGeoBarSegment m_bar1
 bar segment 1 (forward bar)
 
TOPGeoBarSegment m_bar2
 bar segment 2 (backward bar)
 
TOPGeoMirrorSegment m_mirror
 mirror segment
 
TOPGeoPrism m_prism
 prism
 
TOPGeoPMTArray m_pmtArray
 geometry parameters of PMT array
 
TOPGeoPMTArrayDisplacement m_arrayDisplacement
 PMT array displacement.
 
TOPGeoModuleDisplacement m_moduleDisplacement
 module displacement
 
ROOT::Math::Transform3D * m_transform = 0
 cache for transformation from internal (= nominal & displaced) to Belle II frame
 
ROOT::Math::Transform3D * m_transformNominal = 0
 do not write out More...
 

Detailed Description

Geometry parameters of a module (optical components + positioning)

Definition at line 31 of file TOPGeoModule.h.

Constructor & Destructor Documentation

◆ TOPGeoModule()

TOPGeoModule ( int  moduleID,
double  radius,
double  phi,
double  backwardZ,
const std::string &  name = "TOPModule" 
)
inline

Useful constructor.

Parameters
moduleIDmodule ID
radiusradius of the bar central plane in Belle II frame
phiazimuthal angle in Belle II frame
backwardZz position of prism-bar joint in Belle II frame
nameobject name

Definition at line 48 of file TOPGeoModule.h.

49  : TOPGeoBase(name),
50  m_moduleID(moduleID), m_radius(radius), m_phi(phi), m_backwardZ(backwardZ)
51  {}
TOPGeoBase()
Default constructor.
Definition: TOPGeoBase.h:31
float m_backwardZ
z position of prism-bar joint in Belle II frame
Definition: TOPGeoModule.h:421
float m_phi
azimuthal angle in Belle II frame
Definition: TOPGeoModule.h:420
float m_radius
radius of bar central plane in Belle II frame
Definition: TOPGeoModule.h:419
int m_moduleID
module ID
Definition: TOPGeoModule.h:418

Member Function Documentation

◆ appendPeelOffRegion()

void appendPeelOffRegion ( unsigned  ID,
double  fraction,
double  angle 
)
inline

Appends peel-off cookie region.

Parameters
IDregion ID (1-based)
fractionfraction of the area
angleangle of the area

Definition at line 142 of file TOPGeoModule.h.

◆ ClassDefOverride()

ClassDefOverride ( TOPGeoModule  ,
 
)
private

do not write out

ClassDef

◆ generateDecoupledPMTs()

void generateDecoupledPMTs ( double  fraction)
inline

Generate randomly a fraction of PMT's to be optically decoupled.

Parameters
fractiondecoupled fraction

Definition at line 114 of file TOPGeoModule.h.

◆ getBackwardZ()

double getBackwardZ ( void  ) const
inline

Returns the z position of prism-bar joint in Belle II frame.

Returns
z position

Definition at line 188 of file TOPGeoModule.h.

◆ getBarLength()

double getBarLength ( ) const
inline

Returns bar length (w/o prism) including glue joints.

Returns
length

Definition at line 248 of file TOPGeoModule.h.

◆ getBarSegment1()

const TOPGeoBarSegment& getBarSegment1 ( ) const
inline

Returns bar segment No.1 (forward bar)

Returns
bar segment geometry parameters

Definition at line 200 of file TOPGeoModule.h.

◆ getBarSegment2()

const TOPGeoBarSegment& getBarSegment2 ( ) const
inline

Returns bar segment No.2 (backward bar)

Returns
bar segment geometry parameters

Definition at line 206 of file TOPGeoModule.h.

◆ getBarThickness()

double getBarThickness ( ) const
inline

Returns average bar thickness (weigthed by segment lengths)

Returns
average bar thickness

Definition at line 269 of file TOPGeoModule.h.

◆ getBarWidth()

double getBarWidth ( ) const
inline

Returns average bar width (weigthed by segment lengths)

Returns
average bar width

Definition at line 280 of file TOPGeoModule.h.

◆ getForwardZ()

double getForwardZ ( void  ) const
inline

Returns the z position of the bar forward end in Belle II frame.

Returns
z position

Definition at line 263 of file TOPGeoModule.h.

◆ getFullLength()

double getFullLength ( ) const
inline

Returns full length (including prism, wavelenght filter and glue joints)

Returns
length

Definition at line 257 of file TOPGeoModule.h.

◆ getInnerRadius()

double getInnerRadius ( ) const
inline

Returns inner surface radius in Belle II frame.

Returns
radius

Definition at line 320 of file TOPGeoModule.h.

◆ getMirrorSegment()

const TOPGeoMirrorSegment& getMirrorSegment ( ) const
inline

Returns mirror segment.

Returns
mirror segment geometry parameters

Definition at line 212 of file TOPGeoModule.h.

◆ getModuleCNumber()

unsigned getModuleCNumber ( ) const
inline

Returns module construction number (0 = ideal module)

Returns
construction number

Definition at line 194 of file TOPGeoModule.h.

◆ getModuleDisplacement()

const TOPGeoModuleDisplacement& getModuleDisplacement ( ) const
inline

Returns module displacement.

Returns
module displacement parameters

Definition at line 239 of file TOPGeoModule.h.

◆ getModuleID()

int getModuleID ( ) const
inline

Returns module ID.

Returns
module ID

Definition at line 170 of file TOPGeoModule.h.

◆ getName()

const std::string& getName ( void  ) const
inlineinherited

Returns object name.

Returns
object name

Definition at line 51 of file TOPGeoBase.h.

◆ getPhi()

double getPhi ( void  ) const
inline

Returns module azimuthal angle in Belle II frame.

Returns
azimuthal angle

Definition at line 182 of file TOPGeoModule.h.

◆ getPMTArray()

const TOPGeoPMTArray& getPMTArray ( ) const
inline

Returns PMT array.

Returns
PMT array geometry parameters

Definition at line 224 of file TOPGeoModule.h.

◆ getPMTArrayDisplacement()

const TOPGeoPMTArrayDisplacement& getPMTArrayDisplacement ( ) const
inline

Returns PMT array displacement.

Returns
PMT array displacement parameters

Definition at line 230 of file TOPGeoModule.h.

◆ getPrism()

const TOPGeoPrism& getPrism ( ) const
inline

Returns prism.

Returns
prism geometry parameters

Definition at line 218 of file TOPGeoModule.h.

◆ getRadius()

double getRadius ( ) const
inline

Returns radius of the bar central plane in Belle II frame.

Returns
radius

Definition at line 176 of file TOPGeoModule.h.

◆ getSigmaAlpha()

double getSigmaAlpha ( ) const
inline

Returns average surface roughness parameter (weigthed by segment lengths)

Returns
average surface roughness

Definition at line 303 of file TOPGeoModule.h.

◆ getSurfaceReflectivity()

double getSurfaceReflectivity ( double  energy) const
inline

Returns average surface reflectivity at given photon energy (weigthed by segment lengths)

Parameters
energyphoton energy in [eV]
Returns
average reflectivity

Definition at line 292 of file TOPGeoModule.h.

◆ getTransformation()

const ROOT::Math::Transform3D& getTransformation ( ) const
inline

Returns transformation from internal (= nominal & displaced) to Belle II frame.

Returns
transformation

Definition at line 326 of file TOPGeoModule.h.

◆ getTransformationNominal()

const ROOT::Math::Transform3D& getTransformationNominal ( ) const
inline

Returns transformation from nominal to Belle II frame.

Returns
transformation

Definition at line 336 of file TOPGeoModule.h.

◆ getZc()

double getZc ( ) const
inline

Returns z of bar center (w/o prism) in Belle II frame.

Returns
z coordinate if bar center

Definition at line 314 of file TOPGeoModule.h.

◆ setBarSegment1()

void setBarSegment1 ( const TOPGeoBarSegment bar)
inline

Sets bar segment No.1 (forward bar)

Parameters
barsegment No.1 geometry parameters

Definition at line 78 of file TOPGeoModule.h.

◆ setBarSegment2()

void setBarSegment2 ( const TOPGeoBarSegment bar)
inline

Sets bar segment No.2 (backward bar)

Parameters
barsegment No.2 geometry parameters

Definition at line 84 of file TOPGeoModule.h.

◆ setDecoupledPMT()

void setDecoupledPMT ( unsigned  pmtID)
inline

Sets PMT as optically decoupled.

Parameters
pmtIDID of PMT to be set as decoupled (1-based)

Definition at line 108 of file TOPGeoModule.h.

◆ setMirrorSegment()

void setMirrorSegment ( const TOPGeoMirrorSegment mirror)
inline

Sets mirror segment.

Parameters
mirrormirror segment geometry parameters

Definition at line 90 of file TOPGeoModule.h.

◆ setModuleCNumber()

void setModuleCNumber ( unsigned  moduleCNumber)
inline

Sets module construction number (0 = ideal module = default)

Parameters
moduleCNumberconstruction number

Definition at line 72 of file TOPGeoModule.h.

◆ setModuleDisplacement()

void setModuleDisplacement ( const TOPGeoModuleDisplacement displ)
inline

Sets module displacement.

Parameters
displmodule displacement parameters

Definition at line 161 of file TOPGeoModule.h.

◆ setName()

void setName ( const std::string &  name)
inlineinherited

Sets object name.

Parameters
nameobject name

Definition at line 45 of file TOPGeoBase.h.

◆ setPMTArray()

void setPMTArray ( const TOPGeoPMTArray array)
inline

Sets PMT array.

Parameters
arrayPMT array geometry parameters

Definition at line 102 of file TOPGeoModule.h.

◆ setPMTArrayDisplacement()

void setPMTArrayDisplacement ( const TOPGeoPMTArrayDisplacement displ)
inline

Sets PMT array displacement.

Parameters
displPMT array displacement parameters

Definition at line 152 of file TOPGeoModule.h.

◆ setPrism()

void setPrism ( const TOPGeoPrism prism)
inline

Sets prism.

Parameters
prismprism geometry parameters

Definition at line 96 of file TOPGeoModule.h.

Member Data Documentation

◆ m_transformNominal

ROOT::Math::Transform3D* m_transformNominal = 0
mutableprivate

do not write out

cache for transformation from nominal to Belle II frame

Definition at line 435 of file TOPGeoModule.h.


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