ATLAS Offline Software
Loading...
Searching...
No Matches
BinnedLayerMaterial.h
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2021 CERN for the benefit of the ATLAS collaboration
3*/
4
6// BinnedLayerMaterial.h, (c) ATLAS Detector software
8
9#ifndef TRKGEOMETRY_BINNEDLAYERMATERIAL_H
10#define TRKGEOMETRY_BINNEDLAYERMATERIAL_H
11
12//Trk
17//Gaudi
18#include "GaudiKernel/MsgStream.h"
19
21
22namespace Trk {
23
24
32
34
35 public:
38
41
51 BinnedLayerMaterial(const Trk::BinUtility& binutility,
52 const MaterialPropertiesVector& fullProperties,
53 double splitFactor=0.);
54
64 BinnedLayerMaterial(const Trk::BinUtility& binutility,
65 const MaterialPropertiesMatrix& fullProperties,
66 double splitFactor=0.);
67
70
72 virtual ~BinnedLayerMaterial() override;
73
75 virtual BinnedLayerMaterial* clone() const override;
76
79
81 virtual BinnedLayerMaterial& operator*=(double scale) override;
82
84 virtual const BinUtility* binUtility() const override;
85
87 virtual void updateBinning(BinUtility* bu) override;
88
91
93 virtual const MaterialProperties* fullMaterial(const Amg::Vector3D& gp) const override;
94
96 virtual const MaterialProperties* material(size_t bin0, size_t bin1 ) const override;
97
99 virtual MsgStream& dump(MsgStream& sl) const override;
100
102 virtual std::ostream& dump(std::ostream& sl) const override;
103
104 private:
105 friend class ::BinnedLayerMaterialCnv_p1;
106
108
111
113 void clearMaterial();
114
116 void fillMaterial(const MaterialPropertiesMatrix& matMatrix);
117
118 };
119
120
122 { return m_binUtility; }
123
126
127 inline const MaterialProperties* BinnedLayerMaterial::material(size_t bin0, size_t bin1 ) const
128 {
129 return m_fullMaterial[bin1][bin0];
130 }
131
133 if (bu){
134 delete m_binUtility;
135 m_binUtility = bu;
136 }
137 }
138
139
140}
141
142#endif
A generic symmetric BinUtility, for fully symmetric binning in terms of binning grid and binning type...
Definition BinUtility.h:39
BinnedLayerMaterial & operator=(const BinnedLayerMaterial &lmp)
Assignment operator.
virtual ~BinnedLayerMaterial() override
Destructor.
virtual const MaterialProperties * material(size_t bin0, size_t bin1) const override
Access the single bin.
void fillMaterial(const MaterialPropertiesMatrix &matMatrix)
helper method - to refill the material
virtual BinnedLayerMaterial * clone() const override
Pseudo-Constructor clone()
virtual const BinUtility * binUtility() const override
Return the BinUtility.
void clearMaterial()
helper method - to clear the material
MaterialPropertiesMatrix m_fullMaterial
The five different MaterialProperties.
virtual BinnedLayerMaterial & operator*=(double scale) override
Scale operator.
virtual void updateBinning(BinUtility *bu) override
Update the BinUtility if necessary - passing ownership of the utility class.
const MaterialPropertiesMatrix & fullMaterial() const
Return method for full material description of the Layer - for all bins.
BinUtility * m_binUtility
the helper for the bin finding
BinnedLayerMaterial()
Default Constructor - needed by POOL.
Material with information about thickness of material.
Eigen::Matrix< double, 3, 1 > Vector3D
Ensure that the ATLAS eigen extensions are properly loaded.
std::vector< const MaterialProperties * > MaterialPropertiesVector
Useful typedefs.
std::vector< std::vector< const MaterialProperties * > > MaterialPropertiesMatrix
-event-from-file