CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
AlignmentParameterStore.h
Go to the documentation of this file.
1 #ifndef Alignment_CommonAlignmentAlgorithm_AlignmentParameterStore_h
2 #define Alignment_CommonAlignmentAlgorithm_AlignmentParameterStore_h
3 
8 
16 
17 namespace edm { class ParameterSet; }
19 class TrackerTopology;
20 
22 {
23 
24 public:
25 
26  typedef std::vector<AlignmentParameters*> Parameters;
27  typedef std::map< std::pair<Alignable*,Alignable*>,AlgebraicMatrix > Correlations;
28  typedef std::vector<unsigned int> DetIds;
29 
32 
34  virtual ~AlignmentParameterStore();
35 
39  selectParameters( const std::vector <AlignableDet*>& alignabledets ) const;
42  selectParameters( const std::vector <AlignableDetOrUnitPtr>& alignabledets ) const;
45  selectParameters( const std::vector <Alignable*>& alignables ) const;
46 
48  void updateParameters(const CompositeAlignmentParameters& aap, bool updateCorrelations = true);
49 
51  const align::Alignables& alignables(void) const { return theAlignables; }
52 
55 
57  int numObjects(void) const { return theAlignables.size(); }
58 
61 
63  const unsigned int numCorrelations( void ) const { return theCorrelationsStore->size(); }
64 
66 /* Alignable* alignableFromGeomDet( const GeomDet* geomDet ) const; */
67 
69  Alignable* alignableFromAlignableDet( const AlignableDetOrUnitPtr& alignableDet ) const;
70 
72 /* Alignable* alignableFromDetId(const unsigned int& detId) const; */
73 
75  void applyParameters(void);
76 
78  void applyParameters(Alignable* alignable);
79 
81  void resetParameters(void);
82 
84  void resetParameters(Alignable* ali);
85 
87  void cacheTransformations(void);
88 
91 
94  void acquireRelativeParameters(void);
95 
98  const AlignablePositions& newpos, int& ierr );
99 
102  const AlignableShifts& shifts, int& ierr );
103 
105  void attachAlignmentParameters( const align::Alignables& alivec, const Parameters& parvec, int& ierr );
106 
108  void attachAlignmentParameters(const Parameters& parvec, int& ierr);
109 
111  void attachCorrelations( const align::Alignables& alivec, const Correlations& cormap,
112  bool overwrite, int& ierr );
113 
115  void attachCorrelations( const Correlations& cormap, bool overwrite, int& ierr );
116 
118  void attachUserVariables( const align::Alignables& alivec,
119  const std::vector<AlignmentUserVariables*>& uvarvec, int& ierr);
120 
122  void setAlignmentPositionError( const align::Alignables& alivec, double valshift, double valrot );
123 
125  std::pair<int,int> typeAndLayer( const Alignable* ali, const TrackerTopology* tTopo ) const;
126 
128  typedef std::pair<Alignable*, unsigned int> ParameterId;
144  bool hierarchyConstraints(const Alignable *aliMaster, const align::Alignables &aliComps,
145  std::vector<std::vector<ParameterId> > &paramIdsVecOut,
146  std::vector<std::vector<double> > &factorsVecOut,
147  bool all, double epsilon) const;
148 
149 protected:
150 
151  // storage for correlations
153 
154 private:
155  // data members
156 
159 
160 };
161 
162 #endif
void attachUserVariables(const align::Alignables &alivec, const std::vector< AlignmentUserVariables * > &uvarvec, int &ierr)
Attach User Variables to given alignables.
void resetParameters(void)
reset parameters, correlations, user variables
std::map< std::pair< Alignable *, Alignable * >, AlgebraicMatrix > Correlations
std::pair< int, int > typeAndLayer(const Alignable *ali, const TrackerTopology *tTopo) const
Obtain type and layer from Alignable.
std::pair< Alignable *, unsigned int > ParameterId
a single alignable parameter of an Alignable
void setAlignmentPositionError(const align::Alignables &alivec, double valshift, double valrot)
Set Alignment position error.
align::Alignables validAlignables(void) const
get all alignables with valid parameters
void attachCorrelations(const align::Alignables &alivec, const Correlations &cormap, bool overwrite, int &ierr)
Attach correlations to given alignables.
void restoreCachedTransformations(void)
restore the previously cached position, rotation and other parameters
virtual ~AlignmentParameterStore()
destructor
void applyParameters(void)
Obsolete: Use AlignableNavigator::alignableDetFromDetId and alignableFromAlignableDet.
void applyAlignableAbsolutePositions(const align::Alignables &alis, const AlignablePositions &newpos, int &ierr)
apply absolute positions to alignables
void updateParameters(const CompositeAlignmentParameters &aap, bool updateCorrelations=true)
update parameters
std::vector< AlignableRelData > AlignableShifts
Definition: AlignableData.h:52
virtual unsigned int size(void) const
Get number of stored correlations.
vector< ParameterSet > Parameters
std::vector< AlignmentParameters * > Parameters
CLHEP::HepMatrix AlgebraicMatrix
AlignmentParameterStore(const align::Alignables &alis, const edm::ParameterSet &config)
constructor
bool hierarchyConstraints(const Alignable *aliMaster, const align::Alignables &aliComps, std::vector< std::vector< ParameterId > > &paramIdsVecOut, std::vector< std::vector< double > > &factorsVecOut, bool all, double epsilon) const
std::vector< unsigned int > DetIds
void applyAlignableRelativePositions(const align::Alignables &alivec, const AlignableShifts &shifts, int &ierr)
apply relative shifts to alignables
const unsigned int numCorrelations(void) const
get number of correlations between alignables
(Abstract) Base class for alignment algorithm user variables
Alignable * alignableFromAlignableDet(const AlignableDetOrUnitPtr &alignableDet) const
Obsolete: Use AlignableNavigator::alignableDetFromGeomDet and alignableFromAlignableDet.
align::Alignables theAlignables
alignables
int numObjects(void) const
returns number of alignables
CompositeAlignmentParameters selectParameters(const std::vector< AlignableDet * > &alignabledets) const
std::vector< Alignable * > Alignables
Definition: Utilities.h:28
AlignmentCorrelationsStore * theCorrelationsStore
void cacheTransformations(void)
cache the current position, rotation and other parameters
std::vector< AlignableAbsData > AlignablePositions
Definition: AlignableData.h:51
const double epsilon
void attachAlignmentParameters(const align::Alignables &alivec, const Parameters &parvec, int &ierr)
Attach alignment parameters to given alignables.
const align::Alignables & alignables(void) const
get all alignables
AlignmentCorrelationsStore * correlationsStore(void) const
get full correlation map