CMS 3D CMS Logo

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

#include <AlignableDet.h>

Inheritance diagram for AlignableDet:
AlignableComposite Alignable AlignableCSCChamber AlignableDTChamber AlignableDTSuperLayer AlignableSiStripDet

Public Member Functions

virtual void addAlignmentPositionError (const AlignmentPositionError &ape, bool propagateDown)
 
virtual void addAlignmentPositionErrorFromRotation (const RotationType &rot, bool propagateDown)
 
 AlignableDet (const GeomDet *geomDet, bool addComponents=true)
 
virtual AlignmentErrorsExtendedalignmentErrors () const
 Return vector of alignment errors. More...
 
const AlignmentPositionErroralignmentPositionError () const
 alignment position error - for checking only, otherwise use alignmentErrors() above! More...
 
virtual Alignmentsalignments () const
 Return vector of alignment data. More...
 
virtual void setAlignmentPositionError (const AlignmentPositionError &ape, bool propagateDown)
 Set the AlignmentPositionError and, if (propagateDown), to all components. More...
 
void update (const GeomDet *geomDet, bool updateComponents=true)
 
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...
 
void update (align::ID, StructureType aType, const RotationType &rot=RotationType())
 
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), 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 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

AlignmentPositionErrortheAlignmentPositionError
 

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

An AlignableComposite corresponding to a composite GeomDet direct components are AlignableDetUnits or AlignableDets.

Definition at line 8 of file AlignableDet.h.

Constructor & Destructor Documentation

AlignableDet::AlignableDet ( const GeomDet geomDet,
bool  addComponents = true 
)

Constructor: If addComponents = true, creates components for geomDet's components, assuming they are GeomDetUnits

Definition at line 16 of file AlignableDet.cc.

References AlignableComposite::addComponent(), align::AlignableDetUnit, GeomDet::alignmentPositionError(), Alignable::compConstraintType_, GeomDet::components(), Exception, GeomDet::geographicalId(), Alignable::NONE, DetId::rawId(), setAlignmentPositionError(), GeomDet::surface(), Alignable::theSurface, and csvLumiCalc::unit.

16  :
17  AlignableComposite( geomDet ),
19 {
20  // ensure that the surface is not constrained to the average position of the
21  // components:
23 
24  if (geomDet->alignmentPositionError()) {
25  // false: do not propagate APE to (anyway not yet existing) daughters
26  this->setAlignmentPositionError(*(geomDet->alignmentPositionError()), false);
27  }
28 
29  if (addComponents) {
30  if ( geomDet->components().size() == 0 ) { // Is a DetUnit
31  throw cms::Exception("BadHierarchy") << "[AlignableDet] GeomDet with DetId "
32  << geomDet->geographicalId().rawId()
33  << " has no components, use AlignableDetUnit.\n";
34  } else { // Push back all components
35  const std::vector<const GeomDet*>& geomDets = geomDet->components();
36  for (std::vector<const GeomDet*>::const_iterator idet = geomDets.begin();
37  idet != geomDets.end(); ++idet) {
38  const GeomDetUnit *unit = dynamic_cast<const GeomDetUnit*>(*idet);
39  if (!unit) {
40  throw cms::Exception("BadHierarchy")
41  << "[AlignableDet] component not GeomDetUnit, call with addComponents==false"
42  << " and build hierarchy yourself.\n"; // e.g. AlignableDTChamber
43  }
44  this->addComponent(new AlignableDetUnit(unit));
45  }
46  }
47  // Ensure that the surface is not screwed up by addComponent, it must stay the GeomDet's one:
48  theSurface = AlignableSurface(geomDet->surface());
49  } // end addComponents
50 }
AlignableComposite()
default constructor hidden
AlignmentPositionError * theAlignmentPositionError
Definition: AlignableDet.h:51
virtual void setAlignmentPositionError(const AlignmentPositionError &ape, bool propagateDown)
Set the AlignmentPositionError and, if (propagateDown), to all components.
const Plane & surface() const
The nominal surface of the GeomDet.
Definition: GeomDet.h:42
uint32_t rawId() const
get the raw id
Definition: DetId.h:43
DetId geographicalId() const
The label of this GeomDet.
Definition: GeomDet.h:79
virtual std::vector< const GeomDet * > components() const
Returns direct components, if any.
Definition: GeomDet.h:88
CompConstraintType compConstraintType_
Definition: Alignable.h:252
AlignmentPositionError const * alignmentPositionError() const
Return pointer to alignment errors.
Definition: GeomDet.h:95
AlignableSurface theSurface
Definition: Alignable.h:243
virtual void addComponent(Alignable *component)
AlignableDet::~AlignableDet ( )
virtual

Destructor.

Definition at line 54 of file AlignableDet.cc.

References theAlignmentPositionError.

55 {
56 
58 
59 }
AlignmentPositionError * theAlignmentPositionError
Definition: AlignableDet.h:51

Member Function Documentation

void AlignableDet::addAlignmentPositionError ( const AlignmentPositionError ape,
bool  propagateDown 
)
virtual

Add (or set if it does not exist yet) the AlignmentPositionError, if (propagateDown), add also to all components

Reimplemented from AlignableComposite.

Definition at line 133 of file AlignableDet.cc.

References AlignableComposite::addAlignmentPositionError(), and theAlignmentPositionError.

Referenced by addAlignmentPositionErrorFromRotation().

134 {
135 
136  if ( !theAlignmentPositionError ) {
138  } else {
140  }
141 
142  this->AlignableComposite::addAlignmentPositionError( ape, propagateDown );
143 
144 }
AlignmentPositionError * theAlignmentPositionError
Definition: AlignableDet.h:51
virtual void addAlignmentPositionError(const AlignmentPositionError &ape, bool propagateDown)
void AlignableDet::addAlignmentPositionErrorFromRotation ( const RotationType rot,
bool  propagateDown 
)
virtual

Add (or set if it does not exist yet) the AlignmentPositionError resulting from a rotation in the global reference frame, if (propagateDown), add also to all components

Reimplemented from AlignableComposite.

Definition at line 147 of file AlignableDet.cc.

References addAlignmentPositionError(), AlignableComposite::addAlignmentPositionErrorFromRotation(), PV3DBase< T, PVType, FrameType >::basicVector(), TkRotation< T >::multiplyInverse(), Alignable::surface(), AlignableSurface::toGlobal(), and ApeEstimator_cff::width.

149 {
150 
151  // average error calculated by movement of a local point at
152  // (xWidth/2,yLength/2,0) caused by the rotation rot
153  GlobalVector localPositionVector = surface().toGlobal( LocalVector(.5 * surface().width(), .5 * surface().length(), 0.) );
154 
155  LocalVector::BasicVectorType lpvgf = localPositionVector.basicVector();
156  GlobalVector gv( rot.multiplyInverse(lpvgf) - lpvgf );
157 
158  AlignmentPositionError ape( gv.x(),gv.y(),gv.z() );
159  this->addAlignmentPositionError( ape, propagateDown );
160 
162 
163 }
align::LocalVector LocalVector
Definition: Alignable.h:36
virtual void addAlignmentPositionError(const AlignmentPositionError &ape, bool propagateDown)
const AlignableSurface & surface() const
Return the Surface (global position and orientation) of the object.
Definition: Alignable.h:135
align::GlobalPoints toGlobal(const align::LocalPoints &) const
Return in global coord given a set of local points.
virtual void addAlignmentPositionErrorFromRotation(const RotationType &rotation, bool propagateDown)
const BasicVectorType & basicVector() const
Definition: PV3DBase.h:56
AlignmentErrorsExtended * AlignableDet::alignmentErrors ( void  ) const
virtual

Return vector of alignment errors.

Reimplemented from AlignableComposite.

Definition at line 195 of file AlignableDet.cc.

References AlignableComposite::alignmentErrors(), asHepMatrix(), popcon2dropbox::copy(), Alignable::geomDetId(), AlignmentPositionError::globalError(), AlignmentErrorsExtended::m_alignError, GlobalErrorBaseExtended< T, ErrorWeightType >::matrix(), DetId::rawId(), and theAlignmentPositionError.

196 {
197 
198  AlignmentErrorsExtended* m_alignmentErrors = new AlignmentErrorsExtended();
199 
200  // Add associated alignment position error
201  uint32_t detId = this->geomDetId().rawId();
202  CLHEP::HepSymMatrix clhepSymMatrix(6,0);
203  if ( theAlignmentPositionError ) // Might not be set
205  AlignTransformErrorExtended transformError( clhepSymMatrix, detId );
206  m_alignmentErrors->m_alignError.push_back( transformError );
207 
208  // Add those from components
210  std::copy(compAlignmentErrs->m_alignError.begin(), compAlignmentErrs->m_alignError.end(),
211  std::back_inserter(m_alignmentErrors->m_alignError));
212  delete compAlignmentErrs;
213 
214 
215  return m_alignmentErrors;
216 }
CLHEP::HepMatrix asHepMatrix(const ROOT::Math::SMatrix< double, N1, N2, typename ROOT::Math::MatRepStd< double, N1, N2 > > &rm)
Definition: Migration.h:49
AlignmentPositionError * theAlignmentPositionError
Definition: AlignableDet.h:51
const GlobalErrorExtended & globalError() const
uint32_t rawId() const
get the raw id
Definition: DetId.h:43
const AlgebraicSymMatrix66 & matrix() const
std::vector< AlignTransformErrorExtended > m_alignError
const DetId & geomDetId() const
Definition: Alignable.h:186
virtual AlignmentErrorsExtended * alignmentErrors() const
Return vector of alignment errors.
const AlignmentPositionError* AlignableDet::alignmentPositionError ( ) const
inline

alignment position error - for checking only, otherwise use alignmentErrors() above!

Definition at line 47 of file AlignableDet.h.

References theAlignmentPositionError.

Referenced by AlignableDetOrUnitPtr::alignmentPositionError().

AlignmentPositionError * theAlignmentPositionError
Definition: AlignableDet.h:51
Alignments * AlignableDet::alignments ( void  ) const
virtual

Return vector of alignment data.

Reimplemented from AlignableComposite.

Reimplemented in AlignableSiStripDet.

Definition at line 166 of file AlignableDet.cc.

References AlignableComposite::alignments(), popcon2dropbox::copy(), Alignable::geomDetId(), Alignable::globalPosition(), Alignable::globalRotation(), Alignments::m_align, DetId::rawId(), makeMuonMisalignmentScenario::rot, create_public_lumi_plots::transform, x, TkRotation< T >::xx(), TkRotation< T >::xy(), TkRotation< T >::xz(), y, TkRotation< T >::yx(), TkRotation< T >::yy(), TkRotation< T >::yz(), z, TkRotation< T >::zx(), TkRotation< T >::zy(), and TkRotation< T >::zz().

Referenced by AlignableSiStripDet::alignments().

167 {
168 
169  Alignments* m_alignments = new Alignments();
170  RotationType rot( this->globalRotation() );
171 
172  // Get position, rotation, detId
173  CLHEP::Hep3Vector clhepVector( globalPosition().x(), globalPosition().y(), globalPosition().z() );
174  CLHEP::HepRotation clhepRotation( CLHEP::HepRep3x3( rot.xx(), rot.xy(), rot.xz(),
175  rot.yx(), rot.yy(), rot.yz(),
176  rot.zx(), rot.zy(), rot.zz() ) );
177  uint32_t detId = this->geomDetId().rawId();
178 
179  AlignTransform transform( clhepVector, clhepRotation, detId );
180 
181  // Add to alignments container
182  m_alignments->m_align.push_back( transform );
183 
184  // Add those from components
185  Alignments *compAlignments = this->AlignableComposite::alignments();
186  std::copy(compAlignments->m_align.begin(), compAlignments->m_align.end(),
187  std::back_inserter(m_alignments->m_align));
188  delete compAlignments;
189 
190 
191  return m_alignments;
192 }
const RotationType & globalRotation() const
Return the global orientation of the object.
Definition: Alignable.h:141
std::vector< AlignTransform > m_align
Definition: Alignments.h:19
uint32_t rawId() const
get the raw id
Definition: DetId.h:43
virtual Alignments * alignments() const
Return alignment data.
align::RotationType RotationType
Definition: Alignable.h:34
const PositionType & globalPosition() const
Return the global position of the object.
Definition: Alignable.h:138
const DetId & geomDetId() const
Definition: Alignable.h:186
void AlignableDet::setAlignmentPositionError ( const AlignmentPositionError ape,
bool  propagateDown 
)
virtual

Set the AlignmentPositionError and, if (propagateDown), to all components.

Reimplemented from AlignableComposite.

Definition at line 119 of file AlignableDet.cc.

References AlignableComposite::setAlignmentPositionError(), and theAlignmentPositionError.

Referenced by AlignableDet(), and update().

120 {
121 
124  else
126 
127  this->AlignableComposite::setAlignmentPositionError( ape, propagateDown );
128 
129 }
AlignmentPositionError * theAlignmentPositionError
Definition: AlignableDet.h:51
virtual void setAlignmentPositionError(const AlignmentPositionError &ape, bool propagateDown)
void AlignableDet::update ( const GeomDet geomDet,
bool  updateComponents = true 
)

Updater from GeomDet The given GeomDet id has to match the current id.

Definition at line 63 of file AlignableDet.cc.

References GeomDet::alignmentPositionError(), EnergyCorrector::c, AlCaHLTBitMon_QueryRunRegistry::comp, AlignableComposite::components(), GeomDet::components(), Exception, GeomDet::geographicalId(), DetId::rawId(), setAlignmentPositionError(), GeomDet::surface(), Alignable::theSurface, csvLumiCalc::unit, AlignableDetUnit::update(), and AlignableComposite::update().

Referenced by progressbar.ProgressBar::__next__(), MatrixUtil.Matrix::__setitem__(), MatrixUtil.Steps::__setitem__(), Vispa.Gui.VispaWidget.VispaWidget::autosize(), AlignableTrackerBuilder::buildStripDetectorAlignable(), Vispa.Views.LineDecayView.LineDecayContainer::createObject(), Vispa.Views.LineDecayView.LineDecayContainer::deselectAllObjects(), Vispa.Gui.VispaWidgetOwner.VispaWidgetOwner::deselectAllWidgets(), Vispa.Gui.VispaWidget.VispaWidget::enableAutosizing(), dqm-mbProfile.Profile::finish(), progressbar.ProgressBar::finish(), Vispa.Gui.MenuWidget.MenuWidget::leaveEvent(), Vispa.Gui.VispaWidgetOwner.VispaWidgetOwner::mouseMoveEvent(), Vispa.Gui.MenuWidget.MenuWidget::mouseMoveEvent(), Vispa.Views.LineDecayView.LineDecayContainer::mouseMoveEvent(), Vispa.Gui.VispaWidgetOwner.VispaWidgetOwner::mouseReleaseEvent(), Vispa.Views.LineDecayView.LineDecayContainer::objectMoved(), MatrixUtil.Steps::overwrite(), Vispa.Views.LineDecayView.LineDecayContainer::removeObject(), Vispa.Gui.ConnectableWidget.ConnectableWidget::removePorts(), Vispa.Gui.FindDialog.FindDialog::reset(), Vispa.Gui.PortConnection.PointToPointConnection::select(), Vispa.Gui.VispaWidget.VispaWidget::select(), Vispa.Views.LineDecayView.LineDecayContainer::select(), Vispa.Gui.VispaWidget.VispaWidget::setText(), Vispa.Gui.VispaWidget.VispaWidget::setTitle(), Vispa.Gui.ZoomableWidget.ZoomableWidget::setZoom(), Vispa.Views.LineDecayView.LineDecayContainer::setZoom(), AlignableCSCChamber::update(), and Vispa.Gui.PortConnection.PointToPointConnection::updateConnection().

64 {
66 
67  if (geomDet->alignmentPositionError()) {
68  // false: do not propagate APE to daughters (done by their update functions)
69  this->setAlignmentPositionError(*(geomDet->alignmentPositionError()), false);
70  }
71 
72  if (updateComponents) {
73  if (geomDet->components().size() == 0 ) { // Is a DetUnit
74  throw cms::Exception("BadHierarchy")
75  << "[AlignableDet] GeomDet with DetId "
76  << geomDet->geographicalId().rawId()
77  << " has no components, use AlignableDetUnit.\n";
78  } else { // Push back all components
79  const auto& geomDets = geomDet->components();
80  for (const auto& idet: geomDets) {
81  auto unit = dynamic_cast<const GeomDetUnit*>(idet);
82  if (!unit) {
83  throw cms::Exception("BadHierarchy")
84  << "[AlignableDet] component not GeomDetUnit, call with "
85  << "updateComponents==false and build hierarchy yourself.\n";
86  // -> e.g. AlignableDTChamber
87  }
88 
89  const auto components = this->components();
90  auto comp =
91  std::find_if(components.begin(), components.end(),
92  [&unit](const auto& c) {
93  return c->id() == unit->geographicalId().rawId(); });
94 
95  if (comp != components.end()) {
96  auto aliDetUnit = dynamic_cast<AlignableDetUnit*>(*comp);
97  if (aliDetUnit) {
98  aliDetUnit->update(unit);
99  } else {
100  throw cms::Exception("LogicError")
101  << "[AlignableDet::update] cast to 'AlignableDetUnit*' failed "
102  << "while it should not\n";
103  }
104  } else {
105  throw cms::Exception("GeometryMismatch")
106  << "[AlignableDet::update] GeomDet with DetId "
107  << unit->geographicalId().rawId()
108  << " not found in current geometry.\n";
109  }
110  }
111  }
112  // Ensure that the surface is not screwed up by update of components, it must stay the GeomDet's one:
113  theSurface = AlignableSurface(geomDet->surface());
114  } // end updateComponents
115 }
virtual void setAlignmentPositionError(const AlignmentPositionError &ape, bool propagateDown)
Set the AlignmentPositionError and, if (propagateDown), to all components.
const Plane & surface() const
The nominal surface of the GeomDet.
Definition: GeomDet.h:42
void update(const GeomDetUnit *geomDetUnit)
uint32_t rawId() const
get the raw id
Definition: DetId.h:43
DetId geographicalId() const
The label of this GeomDet.
Definition: GeomDet.h:79
virtual std::vector< const GeomDet * > components() const
Returns direct components, if any.
Definition: GeomDet.h:88
virtual Alignables components() const
Return vector of direct components.
void update(align::ID, StructureType aType, const RotationType &rot=RotationType())
AlignmentPositionError const * alignmentPositionError() const
Return pointer to alignment errors.
Definition: GeomDet.h:95
AlignableSurface theSurface
Definition: Alignable.h:243

Member Data Documentation

AlignmentPositionError* AlignableDet::theAlignmentPositionError
private