CMS 3D CMS Logo

List of all members | Public Member Functions | Private Attributes | Friends
AlignableGEMEndcap Class Reference

#include <AlignableGEMEndcap.h>

Inheritance diagram for AlignableGEMEndcap:
AlignableComposite Alignable

Public Member Functions

 AlignableGEMEndcap (const std::vector< AlignableGEMStation * > &GEMStations)
 
AlignmentErrorsExtendedalignmentErrors () const override
 Return vector of alignment errors. More...
 
Alignmentsalignments () const override
 Return alignment data. More...
 
RotationType computeOrientation ()
 
PositionType computePosition ()
 
AlignableSurface computeSurface ()
 
void dump (void) const override
 Recursive printout of alignable structure. More...
 
AlignableGEMStationstation (int i)
 
- Public Member Functions inherited from AlignableComposite
void addAlignmentPositionError (const AlignmentPositionError &ape, bool propagateDown) override
 
void addAlignmentPositionErrorFromLocalRotation (const RotationType &rotation, bool propagateDown) override
 
void addAlignmentPositionErrorFromRotation (const RotationType &rotation, bool propagateDown) override
 
void addComponent (Alignable *component) final
 
void addSurfaceDeformation (const SurfaceDeformation *deformation, bool propagateDown) override
 
 AlignableComposite (align::ID id, StructureType aType, const RotationType &rot=RotationType())
 
StructureType alignableObjectId () const override
 Return the alignable type identifier. More...
 
const Alignablescomponents () const override
 Return vector of direct components. More...
 
void move (const GlobalVector &displacement) override
 Move with respect to the global reference frame. More...
 
virtual void moveComponentLocal (const int i, const LocalVector &localDisplacement)
 Move a single component with respect to the local reference frame. More...
 
virtual void moveComponentsLocal (const LocalVector &localDisplacement)
 Move with respect to the local reference frame. More...
 
void recursiveComponents (Alignables &result) const override
 Provide all components, subcomponents etc. (cf. description in base class) More...
 
void rotateInGlobalFrame (const RotationType &rotation) override
 Rotation interpreted in global reference frame. More...
 
void setAlignmentPositionError (const AlignmentPositionError &ape, bool propagateDown) override
 
void setSurfaceDeformation (const SurfaceDeformation *deformation, bool propagateDown) override
 Set the surface deformation parameters - if (!propagateDown) do not affect daughters. More...
 
int surfaceDeformationIdPairs (std::vector< std::pair< int, SurfaceDeformation * > > &) const override
 Return surface deformations. More...
 
void update (align::ID, StructureType aType, const RotationType &rot=RotationType())
 
 ~AlignableComposite () override
 deleting its components More...
 
- Public Member Functions inherited from Alignable
 Alignable (align::ID, const AlignableSurface &)
 
 Alignable (align::ID, const RotationType &)
 
AlignmentParametersalignmentParameters () const
 Get the AlignmentParameters. More...
 
virtual void cacheTransformation ()
 cache the current position, rotation and other parameters (e.g. surface deformations), also for possible components More...
 
virtual void cacheTransformation (const align::RunNumber &)
 
virtual CompConstraintType compConstraintType () const
 Return the alignable type of contraints wrt. its components. More...
 
const AlignablesdeepComponents () const
 
const GlobalVectordisplacement () const
 Return change of the global position since the creation of the object. More...
 
bool firstCompsWithParams (Alignables &paramComps) const
 
const DetIdgeomDetId () const
 
const PositionTypeglobalPosition () const
 Return the global position of the object. More...
 
const RotationTypeglobalRotation () const
 Return the global orientation of the object. More...
 
align::ID id () const
 Return the ID of Alignable, i.e. DetId of 'first' component GeomDet(Unit). More...
 
bool lastCompsWithParams (Alignables &paramComps) const
 
Alignablemother () const
 Return pointer to container alignable (if any) More...
 
virtual void recenterSurface ()
 Recenter surface object without moving possible components. More...
 
virtual void restoreCachedTransformation ()
 restore the previously cached transformation, also for possible components More...
 
virtual void restoreCachedTransformation (const align::RunNumber &)
 
virtual void rotateAroundGlobalAxis (const GlobalVector &axis, Scalar radians)
 Rotation around arbitratry global axis. More...
 
virtual void rotateAroundGlobalX (Scalar radians)
 Rotation around global x-axis. More...
 
virtual void rotateAroundGlobalY (Scalar radians)
 Rotation around global y-axis. More...
 
virtual void rotateAroundGlobalZ (Scalar radians)
 Rotation around global z-axis. More...
 
virtual void rotateAroundLocalAxis (const LocalVector &axis, Scalar radians)
 Rotation around arbitratry local axis. More...
 
virtual void rotateAroundLocalX (Scalar radians)
 Rotation around local x-axis. More...
 
virtual void rotateAroundLocalY (Scalar radians)
 Rotation around local y-axis. More...
 
virtual void rotateAroundLocalZ (Scalar radians)
 Rotation around local z-axis. More...
 
virtual void rotateInLocalFrame (const RotationType &rotation)
 Rotation intepreted in the local reference frame. More...
 
const RotationTyperotation () const
 Return change of orientation since the creation of the object. More...
 
void setAlignmentParameters (AlignmentParameters *dap)
 Set the AlignmentParameters. More...
 
void setMother (Alignable *mother)
 Assign mother to alignable. More...
 
void setSurvey (const SurveyDet *)
 Set survey info. More...
 
int size () const
 Return number of direct components. More...
 
const AlignableSurfacesurface () const
 Return the Surface (global position and orientation) of the object. More...
 
AlignmentSurfaceDeformationssurfaceDeformations () const
 Return surface deformations, sorted by DetId. More...
 
const SurveyDetsurvey () const
 Return survey info. More...
 
void update (align::ID, const AlignableSurface &)
 
virtual ~Alignable ()
 Destructor. More...
 

Private Attributes

std::vector< AlignableGEMStation * > theGEMStations
 

Friends

std::ostream & operator<< (std::ostream &, const AlignableGEMEndcap &)
 

Additional Inherited Members

- Public Types inherited from Alignable
typedef align::Alignables Alignables
 
enum  CompConstraintType { CompConstraintType::NONE, CompConstraintType::POSITION, CompConstraintType::POSITION_Z }
 
typedef align::GlobalVector GlobalVector
 
typedef align::LocalVector LocalVector
 
typedef align::PositionType PositionType
 
typedef align::RotationType RotationType
 
typedef align::Scalar Scalar
 
typedef align::StructureType StructureType
 
- Protected Types inherited from Alignable
template<class T >
using Cache = std::map< align::RunNumber, T >
 
- Protected Member Functions inherited from AlignableComposite
 AlignableComposite (const GeomDet *geomDet)
 Constructor from GeomDet, only for use in AlignableDet. More...
 
void setSurface (const AlignableSurface &s)
 
void update (const GeomDet *geomDet)
 
template<class T >
void update (T)=delete
 
- Protected Member Functions inherited from Alignable
void addDisplacement (const GlobalVector &displacement)
 
void addRotation (const RotationType &rotation)
 
virtual void updateMother (const GlobalVector &shift)
 
- Protected Attributes inherited from AlignableComposite
StructureType theStructureType
 
- Protected Attributes inherited from Alignable
CompConstraintType compConstraintType_ {CompConstraintType::NONE}
 
Cache< GlobalVectordisplacementsCache_
 
Cache< RotationTyperotationsCache_
 
Cache< AlignableSurfacesurfacesCache_
 
GlobalVector theCachedDisplacement
 
RotationType theCachedRotation
 
AlignableSurface theCachedSurface
 
Alignables theDeepComponents
 
DetId theDetId
 
GlobalVector theDisplacement
 
align::ID theId
 
RotationType theRotation
 
AlignableSurface theSurface
 

Detailed Description

Definition at line 18 of file AlignableGEMEndcap.h.

Constructor & Destructor Documentation

◆ AlignableGEMEndcap()

AlignableGEMEndcap::AlignableGEMEndcap ( const std::vector< AlignableGEMStation * > &  GEMStations)

Definition at line 11 of file AlignableGEMEndcap.cc.

12  : AlignableComposite(GEMStations[0]->id(), align::AlignableGEMEndcap) {
13  theGEMStations.insert(theGEMStations.end(), GEMStations.begin(), GEMStations.end());
14 
15  for (const auto& station : GEMStations) {
16  const auto mother = station->mother();
17  this->addComponent(station);
19  }
20 
23 }

References AlignableComposite::addComponent(), Alignable::compConstraintType_, computeSurface(), Alignable::mother(), Alignable::POSITION_Z, Alignable::setMother(), AlignableComposite::setSurface(), station(), and theGEMStations.

Member Function Documentation

◆ alignmentErrors()

AlignmentErrorsExtended * AlignableGEMEndcap::alignmentErrors ( void  ) const
overridevirtual

Return vector of alignment errors.

Reimplemented from AlignableComposite.

Definition at line 79 of file AlignableGEMEndcap.cc.

79  {
80  AlignmentErrorsExtended* m_alignmentErrors = new AlignmentErrorsExtended();
81 
82  for (const auto& i : this->components()) {
83  std::unique_ptr<AlignmentErrorsExtended> tmpAlignmentErrorsExtended{i->alignmentErrors()};
84  std::copy(tmpAlignmentErrorsExtended->m_alignError.begin(),
85  tmpAlignmentErrorsExtended->m_alignError.end(),
86  std::back_inserter(m_alignmentErrors->m_alignError));
87  }
88 
89  std::sort(m_alignmentErrors->m_alignError.begin(), m_alignmentErrors->m_alignError.end());
90 
91  return m_alignmentErrors;
92 }

References AlignableComposite::components(), filterCSVwithJSON::copy, mps_fire::i, AlignmentErrorsExtended::m_alignError, and jetUpdater_cfi::sort.

◆ alignments()

Alignments * AlignableGEMEndcap::alignments ( void  ) const
overridevirtual

Return alignment data.

Reimplemented from AlignableComposite.

Definition at line 66 of file AlignableGEMEndcap.cc.

66  {
67  Alignments* m_alignments = new Alignments();
68 
69  for (const auto& i : this->components()) {
70  std::unique_ptr<Alignments> tmpAlignments{i->alignments()};
71  std::copy(tmpAlignments->m_align.begin(), tmpAlignments->m_align.end(), std::back_inserter(m_alignments->m_align));
72  }
73 
74  std::sort(m_alignments->m_align.begin(), m_alignments->m_align.end());
75 
76  return m_alignments;
77 }

References AlignableComposite::components(), filterCSVwithJSON::copy, mps_fire::i, Alignments::m_align, and jetUpdater_cfi::sort.

◆ computeOrientation()

AlignableGEMEndcap::RotationType AlignableGEMEndcap::computeOrientation ( )

Definition at line 48 of file AlignableGEMEndcap.cc.

48 { return RotationType(); }

Referenced by computeSurface().

◆ computePosition()

AlignableGEMEndcap::PositionType AlignableGEMEndcap::computePosition ( )

Definition at line 36 of file AlignableGEMEndcap.cc.

36  {
37  float zz = 0.;
38 
39  for (std::vector<AlignableGEMStation*>::iterator ilayer = theGEMStations.begin(); ilayer != theGEMStations.end();
40  ilayer++)
41  zz += (*ilayer)->globalPosition().z();
42 
43  zz /= static_cast<float>(theGEMStations.size());
44 
45  return PositionType(0.0, 0.0, zz);
46 }

References theGEMStations, and geometryCSVtoXML::zz.

Referenced by computeSurface().

◆ computeSurface()

AlignableSurface AlignableGEMEndcap::computeSurface ( )

Definition at line 32 of file AlignableGEMEndcap.cc.

32  {
34 }

References computeOrientation(), and computePosition().

Referenced by AlignableGEMEndcap().

◆ dump()

void AlignableGEMEndcap::dump ( void  ) const
overridevirtual

Recursive printout of alignable structure.

Reimplemented from AlignableComposite.

Definition at line 58 of file AlignableGEMEndcap.cc.

58  {
59  edm::LogInfo("AlignableDump") << (*this);
60  for (std::vector<AlignableGEMStation*>::const_iterator iLayer = theGEMStations.begin();
61  iLayer != theGEMStations.end();
62  iLayer++)
63  (*iLayer)->dump();
64 }

References theGEMStations.

◆ station()

AlignableGEMStation & AlignableGEMEndcap::station ( int  i)

Definition at line 25 of file AlignableGEMEndcap.cc.

25  {
26  if (i >= size())
27  throw cms::Exception("LogicError") << "Station index (" << i << ") out of range";
28 
29  return *theGEMStations[i];
30 }

References Exception, mps_fire::i, Alignable::size(), and theGEMStations.

Referenced by AlignableGEMEndcap(), geometryXMLparser.DTAlignable::index(), and geometryXMLparser.CSCAlignable::index().

Friends And Related Function Documentation

◆ operator<<

std::ostream& operator<< ( std::ostream &  os,
const AlignableGEMEndcap b 
)
friend

Definition at line 50 of file AlignableGEMEndcap.cc.

50  {
51  os << "This EndCap contains " << b.theGEMStations.size() << " GEM stations" << std::endl;
52  os << "(phi, r, z) = (" << b.globalPosition().phi() << "," << b.globalPosition().perp() << ","
53  << b.globalPosition().z();
54  os << "), orientation:" << std::endl << b.globalRotation() << std::endl;
55  return os;
56 }

Member Data Documentation

◆ theGEMStations

std::vector<AlignableGEMStation*> AlignableGEMEndcap::theGEMStations
private

Definition at line 39 of file AlignableGEMEndcap.h.

Referenced by AlignableGEMEndcap(), computePosition(), dump(), and station().

AlignableGEMEndcap::theGEMStations
std::vector< AlignableGEMStation * > theGEMStations
Definition: AlignableGEMEndcap.h:39
mps_fire.i
i
Definition: mps_fire.py:428
geometryCSVtoXML.zz
zz
Definition: geometryCSVtoXML.py:19
AlignableGEMEndcap::computeOrientation
RotationType computeOrientation()
Definition: AlignableGEMEndcap.cc:48
filterCSVwithJSON.copy
copy
Definition: filterCSVwithJSON.py:36
AlignableComposite::components
const Alignables & components() const override
Return vector of direct components.
Definition: AlignableComposite.h:45
Alignable::CompConstraintType::POSITION_Z
edm::LogInfo
Log< level::Info, false > LogInfo
Definition: MessageLogger.h:125
AlignableComposite::setSurface
void setSurface(const AlignableSurface &s)
Definition: AlignableComposite.h:112
AlignableGEMEndcap::computeSurface
AlignableSurface computeSurface()
Definition: AlignableGEMEndcap.cc:32
Alignable::PositionType
align::PositionType PositionType
Definition: Alignable.h:30
Alignable::compConstraintType_
CompConstraintType compConstraintType_
Definition: Alignable.h:246
AlignableComposite::addComponent
void addComponent(Alignable *component) final
Definition: AlignableComposite.cc:53
b
double b
Definition: hdecay.h:118
align::AlignableGEMEndcap
Definition: StructureType.h:84
jetUpdater_cfi.sort
sort
Definition: jetUpdater_cfi.py:29
AlignableComposite::AlignableComposite
AlignableComposite()
default constructor hidden
Definition: AlignableComposite.h:118
Alignable::RotationType
align::RotationType RotationType
Definition: Alignable.h:31
AlignmentErrorsExtended
Definition: AlignmentErrorsExtended.h:10
Alignable::setMother
void setMother(Alignable *mother)
Assign mother to alignable.
Definition: Alignable.h:94
AlignableSurface
Definition: AlignableSurface.h:20
AlignableGEMEndcap::computePosition
PositionType computePosition()
Definition: AlignableGEMEndcap.cc:36
Exception
Definition: hltDiff.cc:245
Alignments::m_align
std::vector< AlignTransform > m_align
Definition: Alignments.h:19
AlignmentErrorsExtended::m_alignError
std::vector< AlignTransformErrorExtended > m_alignError
Definition: AlignmentErrorsExtended.h:19
AlignableGEMEndcap::station
AlignableGEMStation & station(int i)
Definition: AlignableGEMEndcap.cc:25
Alignments
Definition: Alignments.h:10
Alignable::mother
Alignable * mother() const
Return pointer to container alignable (if any)
Definition: Alignable.h:91
Alignable::size
int size() const
Return number of direct components.
Definition: Alignable.h:68