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 Member Functions | Private Attributes
AlignableSiStripDet Class Reference

#include <AlignableSiStripDet.h>

Inheritance diagram for AlignableSiStripDet:
AlignableDet AlignableComposite Alignable

Public Member Functions

 AlignableSiStripDet (const GluedGeomDet *geomDet)
 Constructor. More...
 
virtual Alignmentsalignments () const
 first consistify with component detunits, then call method from AlignableDet More...
 
virtual ~AlignableSiStripDet ()
 reduntantly make destructor virtual More...
 
- Public Member Functions inherited from AlignableDet
virtual void addAlignmentPositionError (const AlignmentPositionError &ape, bool propagateDown)
 
virtual void addAlignmentPositionErrorFromRotation (const RotationType &rot, bool propagateDown)
 
 AlignableDet (const GeomDet *geomDet, bool addComponents=true)
 
virtual AlignmentErrorsalignmentErrors () const
 Return vector of alignment errors. More...
 
const AlignmentPositionErroralignmentPositionError () const
 alignment position error - for checking only, otherwise use alignmentErrors() above! More...
 
virtual void setAlignmentPositionError (const AlignmentPositionError &ape, bool propagateDown)
 Set the AlignmentPositionError and, if (propagateDown), to all components. More...
 
virtual ~AlignableDet ()
 Destructor. More...
 
- Public Member Functions inherited from AlignableComposite
virtual void addAlignmentPositionErrorFromLocalRotation (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 Alignables components () const
 Return vector of direct components. More...
 
virtual void dump () const
 Recursive printout of alignable structure. 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 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...
 
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 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...
 
const 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 Member Functions

void consistifyAlignments ()
 make alignments consistent with daughters More...
 

Private Attributes

const BoundstheMonoBounds
 
StripGeomDetTypetheMonoType
 
const BoundstheStereoBounds
 
StripGeomDetTypetheStereoType
 

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
Alignables theDeepComponents
 
DetId theDetId
 
GlobalVector theDisplacement
 
align::ID theId
 
RotationType theRotation
 
AlignableSurface theSurface
 

Detailed Description

An alignable for GluedDets in Strip tracker, taking care of consistency with AlignableDet components.

First implementation April/May 2008

Author
Gero Flucke, Hamburg University
Date:
2008/07/13 12:26:41
Revision:
1.4

Definition at line 23 of file AlignableSiStripDet.h.

Constructor & Destructor Documentation

AlignableSiStripDet::AlignableSiStripDet ( const GluedGeomDet geomDet)

Constructor.

Definition at line 29 of file AlignableSiStripDet.cc.

References AlignableComposite::components(), edm::hlt::Exception, GeomDet::geographicalId(), GluedGeomDet::monoDet(), and GluedGeomDet::stereoDet().

30  : AlignableDet(gluedDet, true), // true: adding DetUnits
31  theMonoBounds (gluedDet->monoDet() ->surface().bounds().clone()),
32  theStereoBounds(gluedDet->stereoDet()->surface().bounds().clone()),
33  theMonoType (static_cast<const StripGeomDetUnit*>(gluedDet->monoDet()) ->specificType()),
34  theStereoType(static_cast<const StripGeomDetUnit*>(gluedDet->stereoDet())->specificType())
35 {
36  // It is not allowed to store a pointer to GeomDet within objects with a life time
37  // longer than an Event:
38  // GeomDet comes from TrackerGeometry that is created from GeometricDet that depends on
39  // IdealGeometryRecord from EventSetup, so it could change in next event!
40  // ==> Need to store directly what I need from it.
41  // Unfortunately the current way with references for the type does not solve that,
42  // either. But currently no way out, see header file.
43 
44  // check order mono/stereo
45  const Alignables units(this->components());
46  if (units.size() != 2
47  || gluedDet->monoDet()->geographicalId() != units[0]->geomDetId()
48  || gluedDet->stereoDet()->geographicalId() != units[1]->geomDetId()) {
49  throw cms::Exception("LogicError")
50  << "[AlignableSiStripDet] " << "Either != 2 components or "
51  << "mono/stereo in wrong order for consistifyAlignments.";
52  }
53 }
StripGeomDetType & theMonoType
StripGeomDetType & theStereoType
const Bounds * theStereoBounds
AlignableDet(const GeomDet *geomDet, bool addComponents=true)
Definition: AlignableDet.cc:16
virtual Alignables components() const
Return vector of direct components.
align::Alignables Alignables
Definition: Alignable.h:39
const Bounds * theMonoBounds
AlignableSiStripDet::~AlignableSiStripDet ( )
virtual

reduntantly make destructor virtual

Definition at line 56 of file AlignableSiStripDet.cc.

References theMonoBounds, and theStereoBounds.

57 {
58  delete theMonoBounds;
59  delete theStereoBounds;
60 }
const Bounds * theStereoBounds
const Bounds * theMonoBounds

Member Function Documentation

Alignments * AlignableSiStripDet::alignments ( void  ) const
virtual

first consistify with component detunits, then call method from AlignableDet

Reimplemented from AlignableDet.

Definition at line 63 of file AlignableSiStripDet.cc.

References AlignableDet::alignments(), and consistifyAlignments().

64 {
65  const_cast<AlignableSiStripDet*>(this)->consistifyAlignments();
66 
67  return this->AlignableDet::alignments();
68 }
virtual Alignments * alignments() const
Return vector of alignment data.
void consistifyAlignments()
make alignments consistent with daughters
void AlignableSiStripDet::consistifyAlignments ( )
private

make alignments consistent with daughters

Definition at line 71 of file AlignableSiStripDet.cc.

References Alignable::addDisplacement(), Alignable::addRotation(), BoundPlane::build(), AlignableComposite::components(), BoundingBox::corners(), Alignable::globalPosition(), Alignable::globalRotation(), i, evf::evtn::offset(), L1TEmulatorMonitor_cff::p, GloballyPositioned< T >::position(), MediumProperties::radLen(), GloballyPositioned< T >::rotation(), Alignable::rotation(), theMonoBounds, Alignable::theRotation, theStereoBounds, Alignable::theSurface, PV3DBase< T, PVType, FrameType >::x(), MediumProperties::xi(), PV3DBase< T, PVType, FrameType >::y(), and PV3DBase< T, PVType, FrameType >::z().

Referenced by alignments().

72 {
73  // make alignments consistent with daughters, calling method from geometry
74 
75  // The aim of all this gymnastics is to have the alignments calculated the same way as
76  // in PlaneBuilderForGluedDet::plane(const std::vector<const GeomDetUnit*> &detComps);
77  //
78  // So we take the (new) position and orientation from the AligableDetUnits,
79  // but bounds and GeomDetType from original GeomDetUnits to create new a new glued
80  // surface.
81 
82  const PositionType oldPos(theSurface.position()); // From old surface for keeping...
83  const RotationType oldRot(theSurface.rotation()); // ...track of changes.
84 
85  const Alignables aliUnits(this->components()); // order mono==0, stereo==1 checked in ctr.
86 
88  = BoundPlane::build(aliUnits[0]->globalPosition(), aliUnits[0]->globalRotation(),
89  *theMonoBounds);
90 
92  = BoundPlane::build(aliUnits[1]->globalPosition(), aliUnits[1]->globalRotation(),
94 
95  Surface::PositionType::BasicVectorType posSum = monoPlane->position().basicVector();
96  posSum += stereoPlane->position().basicVector();
97  Surface::PositionType meanPos(posSum/(float)aliUnits.size());
98  Surface::RotationType rotation = monoPlane->rotation();
99 
100  BoundPlane::BoundPlanePointer tmpPlane = BoundPlane::build(meanPos, rotation, OpenBounds());
101 
102  const MediumProperties* mp = monoPlane->mediumProperties();
103  MediumProperties newmp(0,0);
104  if (mp != 0) newmp = MediumProperties(mp->radLen()*2.0,mp->xi()*2.0);
105 
106  std::vector<GlobalPoint> corners;
107  std::vector<GlobalPoint> monoDC = BoundingBox().corners(*monoPlane);
108  corners.insert(corners.end(), monoDC.begin(), monoDC.end());
109  std::vector<GlobalPoint> stereoDC = BoundingBox().corners(*stereoPlane);
110  corners.insert(corners.end(), stereoDC.begin(), stereoDC.end());
111 
112  float xmin(0), xmax(0), ymin(0), ymax(0), zmin(0), zmax(0);
113  for (std::vector<GlobalPoint>::const_iterator i=corners.begin();
114  i!=corners.end();
115  ++i) {
116  LocalPoint p = tmpPlane->toLocal(*i);
117  if (p.x() < xmin) xmin = p.x();
118  if (p.x() > xmax) xmax = p.x();
119  if (p.y() < ymin) ymin = p.y();
120  if (p.y() > ymax) ymax = p.y();
121  if (p.z() < zmin) zmin = p.z();
122  if (p.z() > zmax) zmax = p.z();
123  }
124 
125  LocalVector localOffset((xmin+xmax)/2., (ymin+ymax)/2., (zmin+zmax)/2.);
126  GlobalVector offset(tmpPlane->toGlobal(localOffset));
127 
128  theSurface = AlignableSurface(BoundPlane(meanPos+offset, rotation,
129  RectangularPlaneBounds((xmax-xmin)/2, (ymax-ymin)/2, (zmax-zmin)/2),
130  &newmp));
131 
132  // But do not forget to keep track of movements/rotations:
133  const GlobalVector theMovement(theSurface.position().basicVector() - oldPos.basicVector());
134  // Seems to be correct down to delta angles 4.*1e-8:
135  const RotationType theRotation(oldRot.multiplyInverse(theSurface.rotation()));
136  this->addDisplacement(theMovement);
137  this->addRotation(theRotation);
138 
139 // this->dumpCompareEuler(oldRot, theSurface.rotation());
140 
141 // if (movement.mag2()) { // > 1.e-10) {
142 // edm::LogWarning("Alignment") << "@SUB=consistifyAlignments"
143 // << "Delta: " << movement.x() << " " << movement.y() << " " << movement.z()
144 // << "\nPos: " << oldPos.perp() << " " << oldPos.phi() << " " << oldPos.z();
145 // }
146 }
int i
Definition: DBlmapReader.cc:9
float radLen() const
RotationType theRotation
Definition: Alignable.h:219
T y() const
Definition: PV3DBase.h:57
const RotationType & globalRotation() const
Return the global orientation of the object.
Definition: Alignable.h:132
static BoundPlanePointer build(const PositionType &pos, const RotationType &rot, const Bounds *bounds, MediumProperties *mp=0)
Definition: BoundPlane.h:26
static std::vector< GlobalPoint > corners(const BoundPlane &)
Definition: BoundingBox.cc:24
const RotationType & rotation() const
Return change of orientation since the creation of the object.
Definition: Alignable.h:138
T z() const
Definition: PV3DBase.h:58
unsigned int offset(bool)
float xi() const
void addRotation(const RotationType &rotation)
Definition: Alignable.cc:206
align::RotationType RotationType
Definition: Alignable.h:36
void addDisplacement(const GlobalVector &displacement)
Definition: Alignable.cc:198
const Bounds * theStereoBounds
align::PositionType PositionType
Definition: Alignable.h:35
Unlimited (trivial) bounds.
Definition: OpenBounds.h:10
const RotationType & rotation() const
virtual Alignables components() const
Return vector of direct components.
const PositionType & globalPosition() const
Return the global position of the object.
Definition: Alignable.h:129
T x() const
Definition: PV3DBase.h:56
const PositionType & position() const
align::Alignables Alignables
Definition: Alignable.h:39
AlignableSurface theSurface
Definition: Alignable.h:216
const Bounds * theMonoBounds

Member Data Documentation

const Bounds* AlignableSiStripDet::theMonoBounds
private

The following four members are needed to recalculate the surface in consistifyAlignments, to get rid of a GluedDet* which is disregarded since it could become an invalid pointer in the next event (theoretically...). But this solution is not better, the references for the types would become invalid together with the GeomDets they are taken from. StripGeomDetType has neither clone() and nor a decent copy constructor, so I cannot go the the same way as for the bounds. Sigh!

Definition at line 45 of file AlignableSiStripDet.h.

Referenced by consistifyAlignments(), and ~AlignableSiStripDet().

StripGeomDetType& AlignableSiStripDet::theMonoType
private

Definition at line 47 of file AlignableSiStripDet.h.

const Bounds* AlignableSiStripDet::theStereoBounds
private

Definition at line 46 of file AlignableSiStripDet.h.

Referenced by consistifyAlignments(), and ~AlignableSiStripDet().

StripGeomDetType& AlignableSiStripDet::theStereoType
private

Definition at line 48 of file AlignableSiStripDet.h.