CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Classes | Public Types | Public Member Functions | Static Public Attributes | Protected Member Functions | Protected Attributes | Private Attributes
PedeLabelerBase Class Referenceabstract

#include <PedeLabelerBase.h>

Inheritance diagram for PedeLabelerBase:
MomentumDependentPedeLabeler PedeLabeler RunRangeDependentPedeLabeler

Classes

class  TopLevelAlignables
 

Public Types

typedef
AlignmentAlgorithmBase::RunNumber 
RunNumber
 
typedef
AlignmentAlgorithmBase::RunRange 
RunRange
 
typedef std::vector< RunRangeRunRanges
 

Public Member Functions

virtual void addCalibrations (const std::vector< IntegratedCalibrationBase * > &iCals)
 tell labeler to treat also integrated calibrations More...
 
virtual AlignablealignableFromLabel (unsigned int label) const =0
 
virtual unsigned int alignableLabel (Alignable *alignable) const =0
 
virtual unsigned int alignableLabelFromLabel (unsigned int label) const =0
 alignable label from parameter label (works also for alignable label...) More...
 
virtual unsigned int alignableLabelFromParamAndInstance (Alignable *alignable, unsigned int param, unsigned int instance) const =0
 
virtual unsigned int calibrationLabel (const IntegratedCalibrationBase *calib, unsigned int paramNum) const
 label for parameter 'paramNum' (counted from 0) of an integrated calibration More...
 
virtual std::pair
< IntegratedCalibrationBase
*, unsigned int > 
calibrationParamFromLabel (unsigned int label) const
 
virtual unsigned int firstFreeLabel () const
 
virtual bool hasSplitParameters (Alignable *alignable) const =0
 returns true if the alignable has parameters that are split into various bins More...
 
virtual unsigned int lasBeamIdFromLabel (unsigned int label) const =0
 
virtual unsigned int lasBeamLabel (unsigned int lasBeamId) const =0
 
virtual unsigned int maxNumberOfParameterInstances () const =0
 returns the maximum number of instances for any parameter of an Alignable* More...
 
virtual unsigned int numberOfParameterInstances (Alignable *alignable, int param=-1) const =0
 returns the number of instances for a given parameter More...
 
unsigned int parameterInstanceOffset () const
 offset in labels between consecutive parameter instances of Alignable*s More...
 
virtual unsigned int parameterLabel (unsigned int aliLabel, unsigned int parNum) const =0
 returns the label for a given alignable parameter number combination More...
 
virtual unsigned int parameterLabel (Alignable *alignable, unsigned int parNum, const AlignmentAlgorithmBase::EventInfo &eventInfo, const TrajectoryStateOnSurface &tsos) const =0
 
virtual unsigned int paramNumFromLabel (unsigned int paramLabel) const =0
 parameter number, 0 <= .. < theMaxNumParam, belonging to unique parameter label More...
 
 PedeLabelerBase (const TopLevelAlignables &alignables, const edm::ParameterSet &config)
 constructor from three Alignables (null pointers allowed ) More...
 
virtual const RunRangerunRangeFromLabel (unsigned int label) const
 
virtual ~PedeLabelerBase ()
 

Static Public Attributes

static const unsigned int theMaxNumParam = RigidBodyAlignmentParameters::N_PARAM + 14
 
static const unsigned int theMinLabel = 1
 
static const unsigned int theParamInstanceOffset = 700000
 

Protected Member Functions

virtual unsigned int firstNonAlignableLabel () const
 

Protected Attributes

const RunRange theOpenRunRange
 

Private Attributes

std::vector< std::pair
< IntegratedCalibrationBase
*, unsigned int > > 
theCalibrationLabels
 pairs of calibrations and their first label More...
 

Detailed Description

Baseclass for pede labelers

Original author: Andreas Mussgiller, January 2011

Date:
2011/02/18 17:08:13
Revision:
1.2

(last update by

Author:
mussgill

)

Definition at line 32 of file PedeLabelerBase.h.

Member Typedef Documentation

Definition at line 36 of file PedeLabelerBase.h.

Definition at line 37 of file PedeLabelerBase.h.

typedef std::vector<RunRange> PedeLabelerBase::RunRanges

Definition at line 38 of file PedeLabelerBase.h.

Constructor & Destructor Documentation

PedeLabelerBase::PedeLabelerBase ( const TopLevelAlignables alignables,
const edm::ParameterSet config 
)

constructor from three Alignables (null pointers allowed )

Definition at line 25 of file PedeLabelerBase.cc.

27  :theOpenRunRange(std::make_pair<RunNumber,RunNumber>( RunNumber( cond::timeTypeSpecs[cond::runnumber].beginValue) , // since we know we have a runnumber here, we can
28  RunNumber( cond::timeTypeSpecs[cond::runnumber].endValue ) )) // simply convert the Time_t to make the compiler happy
29 {
30 
31 }
const TimeTypeSpecs timeTypeSpecs[]
Definition: Time.cc:22
AlignmentAlgorithmBase::RunNumber RunNumber
const RunRange theOpenRunRange
virtual PedeLabelerBase::~PedeLabelerBase ( )
inlinevirtual

Definition at line 55 of file PedeLabelerBase.h.

55 {}

Member Function Documentation

void PedeLabelerBase::addCalibrations ( const std::vector< IntegratedCalibrationBase * > &  iCals)
virtual

tell labeler to treat also integrated calibrations

Definition at line 106 of file PedeLabelerBase.cc.

References firstFreeLabel(), and theCalibrationLabels.

Referenced by MillePedeAlignmentAlgorithm::addCalibrations().

107 {
108  unsigned int nextId = this->firstFreeLabel(); // so far next free label
109 
110  // Now foresee labels for new calibrations:
111  for (auto iCal = iCals.begin(); iCal != iCals.end(); ++iCal) {
112  if (*iCal) {
113  theCalibrationLabels.push_back(std::make_pair(*iCal, nextId));
114  nextId += (*iCal)->numParameters();
115  } else {
116  edm::LogError("LogicError")
117  << "@SUB=PedeLabelerBase::addCalibrations" << "Ignoring nullPtr.";
118  }
119  }
120 }
std::vector< std::pair< IntegratedCalibrationBase *, unsigned int > > theCalibrationLabels
pairs of calibrations and their first label
virtual unsigned int firstFreeLabel() const
virtual Alignable* PedeLabelerBase::alignableFromLabel ( unsigned int  label) const
pure virtual

Alignable from alignable or parameter label, null if no alignable (but error only if not las beam, either!)

Implemented in RunRangeDependentPedeLabeler, MomentumDependentPedeLabeler, and PedeLabeler.

Referenced by PedeReader::setParameter().

virtual unsigned int PedeLabelerBase::alignableLabel ( Alignable alignable) const
pure virtual

uniqueId of Alignable, 0 if alignable not known between this ID and the next there is enough 'space' to add parameter numbers 0...nPar-1 to make unique IDs for the labels of active parameters

Implemented in RunRangeDependentPedeLabeler, MomentumDependentPedeLabeler, and PedeLabeler.

Referenced by MillePedeAlignmentAlgorithm::addPxbSurvey(), MillePedeAlignmentAlgorithm::buildUserVariables(), PedeReader::checkAliParams(), PedeSteerer::hierarchyConstraint(), PedeSteerer::presigmasFile(), and PedeReader::setParameter().

virtual unsigned int PedeLabelerBase::alignableLabelFromLabel ( unsigned int  label) const
pure virtual

alignable label from parameter label (works also for alignable label...)

Implemented in RunRangeDependentPedeLabeler, MomentumDependentPedeLabeler, and PedeLabeler.

virtual unsigned int PedeLabelerBase::alignableLabelFromParamAndInstance ( Alignable alignable,
unsigned int  param,
unsigned int  instance 
) const
pure virtual

uniqueId of Alignable for a given parameter index and instance, 0 if alignable not known between this ID and the next there is enough 'space' to add parameter numbers 0...nPar-1 to make unique IDs for the labels of active parameters

Implemented in RunRangeDependentPedeLabeler, MomentumDependentPedeLabeler, and PedeLabeler.

Referenced by PedeSteererWeakModeConstraints::constructConstraints(), and PedeSteerer::fixParameter().

unsigned int PedeLabelerBase::calibrationLabel ( const IntegratedCalibrationBase calib,
unsigned int  paramNum 
) const
virtual

label for parameter 'paramNum' (counted from 0) of an integrated calibration

Definition at line 76 of file PedeLabelerBase.cc.

References Exception, plotBeamSpotDB::first, IntegratedCalibrationBase::name(), and theCalibrationLabels.

Referenced by MillePedeAlignmentAlgorithm::addGlobalData(), and MillePedeAlignmentAlgorithm::globalDerivativesCalibration().

78 {
79  if (!calib) {
80  throw cms::Exception("LogicError") << "PedeLabelerBase::calibrationLabel: "
81  << "nullPtr passed!\n";
82  }
83 
84  // loop on all known IntegratedCalibration's
85  for (auto iCal = theCalibrationLabels.begin(); iCal != theCalibrationLabels.end(); ++iCal) {
86  if (iCal->first == calib) { // found IntegratedCalibrationBase
87  if (paramNum < iCal->first->numParameters()) {
88  return iCal->second + paramNum;
89  } else { // paramNum out of range!
90  edm::LogError("LogicError")
91  << "@SUB=PedeLabelerBase::calibrationLabel" << "IntegratedCalibration "
92  << calib->name() << " has only " << iCal->first->numParameters()
93  << " parameters, but " << paramNum << "requested!";
94  }
95  }
96  }
97 
98  edm::LogError("LogicError")
99  << "@SUB=PedeLabelerBase::calibrationLabel" << "IntegratedCalibration "
100  << calib->name() << " not known or too few parameters.";
101 
102  return 0;
103 }
std::vector< std::pair< IntegratedCalibrationBase *, unsigned int > > theCalibrationLabels
pairs of calibrations and their first label
const std::string & name() const
name of this calibration
std::pair< IntegratedCalibrationBase *, unsigned int > PedeLabelerBase::calibrationParamFromLabel ( unsigned int  label) const
virtual

calibration and its parameter number from label, if label does not belong to any calibration return nullptr as pair.first

Definition at line 35 of file PedeLabelerBase.cc.

References edm::second(), and theCalibrationLabels.

Referenced by PedeReader::read().

36 {
37  // Quick check whether label is in range of calibration labels:
38  if (!theCalibrationLabels.empty() && label >= theCalibrationLabels.front().second) {
39  // Loop on all known IntegratedCalibration's:
40  for (auto iCal = theCalibrationLabels.begin(); iCal != theCalibrationLabels.end(); ++iCal) {
41  if (label >= iCal->second && label < iCal->second + iCal->first->numParameters()) {
42  // Label fits in range for this calibration, so return calibration
43  // and subtract first label of this calibration from label.
44  return std::make_pair(iCal->first, label - iCal->second);
45  }
46  }
47  edm::LogError("LogicError") << "@SUB=PedeLabelerBase::calibrationParamFromLabel"
48  << "Label " << label << "larger than first calibration's label, "
49  << "but no calibration fits!";
50  }
51 
52  // Return that nothing fits:
53  return std::pair<IntegratedCalibrationBase*, unsigned int>(0,0);
54 }
std::vector< std::pair< IntegratedCalibrationBase *, unsigned int > > theCalibrationLabels
pairs of calibrations and their first label
U second(std::pair< T, U > const &p)
unsigned int PedeLabelerBase::firstFreeLabel ( ) const
virtual

first free label not yet used (for hacks within millepede...) valid only after last call to addCalibrations(..)

Definition at line 57 of file PedeLabelerBase.cc.

References firstNonAlignableLabel(), and theCalibrationLabels.

Referenced by addCalibrations().

58 {
59  unsigned int nextId = this->firstNonAlignableLabel();
60 
61  for (auto iCal = theCalibrationLabels.begin(); iCal != theCalibrationLabels.end(); ++iCal) {
62  nextId += iCal->first->numParameters();
63  }
64 
65  return nextId;
66 }
std::vector< std::pair< IntegratedCalibrationBase *, unsigned int > > theCalibrationLabels
pairs of calibrations and their first label
virtual unsigned int firstNonAlignableLabel() const
unsigned int PedeLabelerBase::firstNonAlignableLabel ( ) const
protectedvirtual

first free label after everything about Alignables and LAS beams (to be used for calibrations)

Definition at line 69 of file PedeLabelerBase.cc.

References maxNumberOfParameterInstances(), and parameterInstanceOffset().

Referenced by firstFreeLabel().

70 {
71 
72  return this->parameterInstanceOffset() * this->maxNumberOfParameterInstances() + 1;
73 }
unsigned int parameterInstanceOffset() const
offset in labels between consecutive parameter instances of Alignable*s
virtual unsigned int maxNumberOfParameterInstances() const =0
returns the maximum number of instances for any parameter of an Alignable*
virtual bool PedeLabelerBase::hasSplitParameters ( Alignable alignable) const
pure virtual

returns true if the alignable has parameters that are split into various bins

Implemented in RunRangeDependentPedeLabeler, MomentumDependentPedeLabeler, and PedeLabeler.

virtual unsigned int PedeLabelerBase::lasBeamIdFromLabel ( unsigned int  label) const
pure virtual

las beam id from las beam or parameter label zero and error if not a valid las beam label

Implemented in RunRangeDependentPedeLabeler, MomentumDependentPedeLabeler, and PedeLabeler.

Referenced by PedeReader::setParameter().

virtual unsigned int PedeLabelerBase::lasBeamLabel ( unsigned int  lasBeamId) const
pure virtual
virtual unsigned int PedeLabelerBase::maxNumberOfParameterInstances ( ) const
pure virtual

returns the maximum number of instances for any parameter of an Alignable*

Implemented in RunRangeDependentPedeLabeler, MomentumDependentPedeLabeler, and PedeLabeler.

Referenced by firstNonAlignableLabel(), and PedeSteererWeakModeConstraints::PedeSteererWeakModeConstraints().

virtual unsigned int PedeLabelerBase::numberOfParameterInstances ( Alignable alignable,
int  param = -1 
) const
pure virtual

returns the number of instances for a given parameter

Implemented in RunRangeDependentPedeLabeler, MomentumDependentPedeLabeler, and PedeLabeler.

Referenced by PedeSteerer::fixParameters().

unsigned int PedeLabelerBase::parameterInstanceOffset ( ) const
inline

offset in labels between consecutive parameter instances of Alignable*s

Definition at line 86 of file PedeLabelerBase.h.

References theParamInstanceOffset.

Referenced by firstNonAlignableLabel().

86 { return theParamInstanceOffset; }
static const unsigned int theParamInstanceOffset
virtual unsigned int PedeLabelerBase::parameterLabel ( unsigned int  aliLabel,
unsigned int  parNum 
) const
pure virtual
virtual unsigned int PedeLabelerBase::parameterLabel ( Alignable alignable,
unsigned int  parNum,
const AlignmentAlgorithmBase::EventInfo eventInfo,
const TrajectoryStateOnSurface tsos 
) const
pure virtual

returns the label for a given alignable parameter number combination in case the parameters are split into various instances

Implemented in RunRangeDependentPedeLabeler, MomentumDependentPedeLabeler, and PedeLabeler.

virtual unsigned int PedeLabelerBase::paramNumFromLabel ( unsigned int  paramLabel) const
pure virtual

parameter number, 0 <= .. < theMaxNumParam, belonging to unique parameter label

Implemented in RunRangeDependentPedeLabeler, MomentumDependentPedeLabeler, and PedeLabeler.

Referenced by PedeReader::setParameter().

virtual const RunRange& PedeLabelerBase::runRangeFromLabel ( unsigned int  label) const
inlinevirtual

Reimplemented in RunRangeDependentPedeLabeler.

Definition at line 103 of file PedeLabelerBase.h.

References theOpenRunRange.

Referenced by PedeReader::read().

103  {
104  return theOpenRunRange;
105  }
const RunRange theOpenRunRange

Member Data Documentation

std::vector<std::pair<IntegratedCalibrationBase*, unsigned int> > PedeLabelerBase::theCalibrationLabels
private

pairs of calibrations and their first label

Definition at line 127 of file PedeLabelerBase.h.

Referenced by addCalibrations(), calibrationLabel(), calibrationParamFromLabel(), and firstFreeLabel().

const unsigned int PedeLabelerBase::theMaxNumParam = RigidBodyAlignmentParameters::N_PARAM + 14
static
const unsigned int PedeLabelerBase::theMinLabel = 1
static
const RunRange PedeLabelerBase::theOpenRunRange
protected
const unsigned int PedeLabelerBase::theParamInstanceOffset = 700000
static