CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Private Attributes | Friends
AlignableCSCEndcap Class Reference

#include <AlignableCSCEndcap.h>

Inheritance diagram for AlignableCSCEndcap:
AlignableComposite Alignable

Public Member Functions

 AlignableCSCEndcap (const std::vector< AlignableCSCStation * > cscStations)
 The constructor simply copies the vector of stations and computes the surface from them. More...
 
AlignmentErrorsalignmentErrors () const
 Return vector of alignment errors. More...
 
Alignmentsalignments () const
 Return alignment data. More...
 
virtual std::vector< Alignable * > components () const
 Return vector of direct components. More...
 
RotationType computeOrientation ()
 Just initialize to default given by default constructor of a RotationType. More...
 
PositionType computePosition ()
 Compute average z position from all components (x and y forced to 0) More...
 
AlignableSurface computeSurface ()
 
void dump (void) const
 Recursive printout of the muon End Cap structure. More...
 
AlignableCSCStationstation (int i)
 Return AlignableCSCEndcap station at given index. More...
 
 ~AlignableCSCEndcap ()
 Clean delete of the vector and its elements. More...
 
- Public Member Functions inherited from AlignableComposite
virtual void addAlignmentPositionError (const AlignmentPositionError &ape, bool propagateDown)
 
virtual void addAlignmentPositionErrorFromLocalRotation (const RotationType &rotation, bool propagateDown)
 
virtual void addAlignmentPositionErrorFromRotation (const RotationType &rotation, bool propagateDown)
 
virtual void addComponent (Alignable *component)
 
virtual void addSurfaceDeformation (const SurfaceDeformation *deformation, bool propagateDown)
 
 AlignableComposite (align::ID id, StructureType aType, const RotationType &rot=RotationType())
 
virtual StructureType alignableObjectId () const
 Return the alignable type identifier. More...
 
virtual void move (const GlobalVector &displacement)
 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...
 
virtual void recursiveComponents (Alignables &result) const
 Provide all components, subcomponents etc. (cf. description in base class) More...
 
virtual void rotateInGlobalFrame (const RotationType &rotation)
 Rotation interpreted in global reference frame. More...
 
virtual void setAlignmentPositionError (const AlignmentPositionError &ape, bool propagateDown)
 
virtual void setSurfaceDeformation (const SurfaceDeformation *deformation, bool propagateDown)
 Set the surface deformation parameters - if (!propagateDown) do not affect daughters. More...
 
virtual int surfaceDeformationIdPairs (std::vector< std::pair< int, SurfaceDeformation * > > &) const
 Return surface deformations. More...
 
virtual ~AlignableComposite ()
 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) 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...
 
Alignablemother () const
 Return pointer to container alignable (if any) More...
 
virtual void restoreCachedTransformation ()
 restore the previously cached transformation, also for possible components More...
 
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...
 
virtual ~Alignable ()
 Destructor. More...
 

Private Attributes

std::vector
< AlignableCSCStation * > 
theCSCStations
 

Friends

std::ostream & operator<< (std::ostream &, const AlignableCSCEndcap &)
 Printout muon End Cap information (not recursive) More...
 

Additional Inherited Members

- Public Types inherited from Alignable
typedef align::Alignables Alignables
 
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 Member Functions inherited from AlignableComposite
 AlignableComposite (const GeomDet *geomDet)
 Constructor from GeomDet, only for use in AlignableDet. More...
 
void setSurface (const AlignableSurface &s)
 
- Protected Member Functions inherited from Alignable
void addDisplacement (const GlobalVector &displacement)
 
void addRotation (const RotationType &rotation)
 
- Protected Attributes inherited from AlignableComposite
StructureType theStructureType
 
- Protected Attributes inherited from Alignable
GlobalVector theCachedDisplacement
 
RotationType theCachedRotation
 
AlignableSurface theCachedSurface
 
Alignables theDeepComponents
 
DetId theDetId
 
GlobalVector theDisplacement
 
align::ID theId
 
RotationType theRotation
 
AlignableSurface theSurface
 

Detailed Description

Concrete class for muon CSC Endcap alignable.

Misalignment can be de-/reactivated (forwarded to components).

Definition at line 30 of file AlignableCSCEndcap.h.

Constructor & Destructor Documentation

AlignableCSCEndcap::AlignableCSCEndcap ( const std::vector< AlignableCSCStation * >  cscStations)

The constructor simply copies the vector of stations and computes the surface from them.

Definition at line 17 of file AlignableCSCEndcap.cc.

References computeSurface(), AlignableComposite::setSurface(), and theCSCStations.

18  : AlignableComposite(cscStations[0]->id(), align::AlignableCSCEndcap)
19 {
20 
21  theCSCStations.insert( theCSCStations.end(), cscStations.begin(), cscStations.end() );
22 
24 
25 }
AlignableComposite()
default constructor hidden
void setSurface(const AlignableSurface &s)
AlignableSurface computeSurface()
std::vector< AlignableCSCStation * > theCSCStations
AlignableCSCEndcap::~AlignableCSCEndcap ( )

Clean delete of the vector and its elements.

Definition at line 29 of file AlignableCSCEndcap.cc.

References theCSCStations.

30 {
31  for ( std::vector<AlignableCSCStation*>::iterator iter = theCSCStations.begin();
32  iter != theCSCStations.end(); iter++)
33  delete *iter;
34 
35 }
std::vector< AlignableCSCStation * > theCSCStations

Member Function Documentation

AlignmentErrors * AlignableCSCEndcap::alignmentErrors ( void  ) const
virtual

Return vector of alignment errors.

Reimplemented from AlignableComposite.

Definition at line 133 of file AlignableCSCEndcap.cc.

References components(), filterCSVwithJSON::copy, i, AlignmentErrors::m_alignError, and python.multivaluedict::sort().

134 {
135 
136  std::vector<Alignable*> comp = this->components();
137  AlignmentErrors* m_alignmentErrors = new AlignmentErrors();
138 
139  // Add components recursively
140  for ( std::vector<Alignable*>::iterator i=comp.begin(); i!=comp.end(); i++ )
141  {
142  AlignmentErrors* tmpAlignmentErrors = (*i)->alignmentErrors();
143  std::copy( tmpAlignmentErrors->m_alignError.begin(), tmpAlignmentErrors->m_alignError.end(),
144  std::back_inserter(m_alignmentErrors->m_alignError) );
145  delete tmpAlignmentErrors;
146  }
147 
148  std::sort( m_alignmentErrors->m_alignError.begin(), m_alignmentErrors->m_alignError.end(),
150 
151  return m_alignmentErrors;
152 
153 }
int i
Definition: DBlmapReader.cc:9
std::vector< AlignTransformError > m_alignError
virtual std::vector< Alignable * > components() const
Return vector of direct components.
Alignments * AlignableCSCEndcap::alignments ( void  ) const
virtual

Return alignment data.

Reimplemented from AlignableComposite.

Definition at line 110 of file AlignableCSCEndcap.cc.

References components(), filterCSVwithJSON::copy, i, Alignments::m_align, and python.multivaluedict::sort().

111 {
112 
113  std::vector<Alignable*> comp = this->components();
114  Alignments* m_alignments = new Alignments();
115  // Add components recursively
116  for ( std::vector<Alignable*>::iterator i=comp.begin(); i!=comp.end(); i++ )
117  {
118  Alignments* tmpAlignments = (*i)->alignments();
119  std::copy( tmpAlignments->m_align.begin(), tmpAlignments->m_align.end(),
120  std::back_inserter(m_alignments->m_align) );
121  delete tmpAlignments;
122  }
123 
124  std::sort( m_alignments->m_align.begin(), m_alignments->m_align.end(),
126 
127  return m_alignments;
128 
129 }
int i
Definition: DBlmapReader.cc:9
virtual std::vector< Alignable * > components() const
Return vector of direct components.
std::vector< AlignTransform > m_align
Definition: Alignments.h:14
virtual std::vector<Alignable*> AlignableCSCEndcap::components ( ) const
inlinevirtual

Return vector of direct components.

Reimplemented from AlignableComposite.

Definition at line 39 of file AlignableCSCEndcap.h.

References query::result, and theCSCStations.

Referenced by alignmentErrors(), and alignments().

40  {
41 
42  std::vector<Alignable*> result;
43  result.insert( result.end(), theCSCStations.begin(), theCSCStations.end() );
44  return result;
45 
46  }
tuple result
Definition: query.py:137
std::vector< AlignableCSCStation * > theCSCStations
AlignableCSCEndcap::RotationType AlignableCSCEndcap::computeOrientation ( )

Just initialize to default given by default constructor of a RotationType.

Definition at line 78 of file AlignableCSCEndcap.cc.

Referenced by computeSurface().

79 {
80  return RotationType();
81 }
align::RotationType RotationType
Definition: Alignable.h:36
AlignableCSCEndcap::PositionType AlignableCSCEndcap::computePosition ( )

Compute average z position from all components (x and y forced to 0)

Definition at line 61 of file AlignableCSCEndcap.cc.

References theCSCStations, and PV3DBase< T, PVType, FrameType >::z().

Referenced by computeSurface().

62 {
63 
64  float zz = 0.;
65 
66  for ( std::vector<AlignableCSCStation*>::iterator ilayer = theCSCStations.begin();
67  ilayer != theCSCStations.end(); ilayer++ )
68  zz += (*ilayer)->globalPosition().z();
69 
70  zz /= static_cast<float>(theCSCStations.size());
71 
72  return PositionType( 0.0, 0.0, zz );
73 
74 }
std::vector< AlignableCSCStation * > theCSCStations
align::PositionType PositionType
Definition: Alignable.h:35
AlignableSurface AlignableCSCEndcap::computeSurface ( )

Returns surface corresponding to current position and orientation, as given by average on all components

Definition at line 51 of file AlignableCSCEndcap.cc.

References computeOrientation(), and computePosition().

Referenced by AlignableCSCEndcap().

52 {
53 
55 
56 }
RotationType computeOrientation()
Just initialize to default given by default constructor of a RotationType.
PositionType computePosition()
Compute average z position from all components (x and y forced to 0)
void AlignableCSCEndcap::dump ( void  ) const
virtual

Recursive printout of the muon End Cap structure.

Recursive printout of whole Half Barrel structure.

Reimplemented from AlignableComposite.

Definition at line 98 of file AlignableCSCEndcap.cc.

References theCSCStations.

99 {
100 
101  edm::LogInfo("AlignableDump") << (*this);
102  for ( std::vector<AlignableCSCStation*>::const_iterator iLayer = theCSCStations.begin();
103  iLayer != theCSCStations.end(); iLayer++ )
104  (*iLayer)->dump();
105 
106 }
std::vector< AlignableCSCStation * > theCSCStations
AlignableCSCStation & AlignableCSCEndcap::station ( int  i)

Return AlignableCSCEndcap station at given index.

Definition at line 38 of file AlignableCSCEndcap.cc.

References edm::hlt::Exception, i, Alignable::size(), and theCSCStations.

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

39 {
40 
41  if (i >= size() )
42  throw cms::Exception("LogicError") << "Station index (" << i << ") out of range";
43 
44  return *theCSCStations[i];
45 
46 }
int i
Definition: DBlmapReader.cc:9
std::vector< AlignableCSCStation * > theCSCStations
int size() const
Return number of direct components.
Definition: Alignable.h:67

Friends And Related Function Documentation

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

Printout muon End Cap information (not recursive)

Definition at line 85 of file AlignableCSCEndcap.cc.

86 {
87 
88  os << "This EndCap contains " << b.theCSCStations.size() << " CSC stations" << std::endl;
89  os << "(phi, r, z) = (" << b.globalPosition().phi() << ","
90  << b.globalPosition().perp() << "," << b.globalPosition().z();
91  os << "), orientation:" << std::endl<< b.globalRotation() << std::endl;
92  return os;
93 
94 }
T perp() const
Definition: PV3DBase.h:71
Geom::Phi< T > phi() const
Definition: PV3DBase.h:68
const RotationType & globalRotation() const
Return the global orientation of the object.
Definition: Alignable.h:132
T z() const
Definition: PV3DBase.h:63
std::vector< AlignableCSCStation * > theCSCStations
const PositionType & globalPosition() const
Return the global position of the object.
Definition: Alignable.h:129

Member Data Documentation

std::vector<AlignableCSCStation*> AlignableCSCEndcap::theCSCStations
private