AlignmentParameterBuilder

Macros

Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99
#ifndef Alignment_CommonAlignmentAlgorithm_AlignmentParameterBuilder_h
#define Alignment_CommonAlignmentAlgorithm_AlignmentParameterBuilder_h

/** \class AlignmentParameterBuilder
 *
 *  Build Alignment Parameter Structure 
 *
 *  $Date: 2010/10/26 20:01:51 $
 *  $Revision: 1.11 $
 *  (last update by $Author: flucke $)
 */

#include "Alignment/CommonAlignment/interface/Utilities.h"
#include "Alignment/CommonAlignmentParametrization/interface/AlignmentParametersFactory.h"

namespace edm {
  class ParameterSet;
}
class AlignableExtras;
class AlignableTracker;
class AlignableMuon;
class AlignmentParameters;
class TrackerTopology;

class AlignmentParameterBuilder {
public:
  /// Constructor from tracker only
  explicit AlignmentParameterBuilder(AlignableTracker *alignableTracker, AlignableExtras *alignableExtras);

  /// Constructor from tracker and muon
  AlignmentParameterBuilder(AlignableTracker *alignableTracker,
                            AlignableMuon *alignableMuon,
                            AlignableExtras *alignableExtras);

  /// Constructor adding selections by passing the ParameterSet named 'AlignmentParameterSelector'
  /// (expected in pSet) to addSelections(..)
  AlignmentParameterBuilder(AlignableTracker *alignableTracker,
                            AlignableExtras *alignableExtras,
                            const edm::ParameterSet &pSet);

  /// Constructor from tracker and muon, plus selection
  AlignmentParameterBuilder(AlignableTracker *alignableTracker,
                            AlignableMuon *alignableMuon,
                            AlignableExtras *alignableExtras,
                            const edm::ParameterSet &pSet);

  /// destructor
  virtual ~AlignmentParameterBuilder() {}
  /// master initialisation method, PSet must have form as constructor wants it
  void addAllSelections(const edm::ParameterSet &pSet);

  /// Add selections of Alignables, using AlignmenParameterSelector::addSelections.
  /// For each Alignable, AlignmentParameters of type parType will be attached
  /// using the selection of active parameters done in AlignmenParameterSelector,
  /// e.g. for RigidBody a selection string '11100' selects the degrees of freedom in
  /// (x,y,z), but not (alpha,beta,gamma).
  /// Returns number of added selections
  unsigned int addSelections(const edm::ParameterSet &pset, AlignmentParametersFactory::ParametersType parType);

  /// Add arbitrary selection of Alignables, return number of higher level Alignables
  unsigned int add(const align::Alignables &alignables,
                   AlignmentParametersFactory::ParametersType parType,
                   const std::vector<bool> &sel);
  /// Add a single Alignable, true if it is higher level, false if it is an AlignableDet
  bool add(Alignable *alignable, AlignmentParametersFactory::ParametersType parType, const std::vector<bool> &sel);

  /// Get list of alignables for which AlignmentParameters are built
  const align::Alignables &alignables() const { return theAlignables; };

  /// Remove n Alignables from list
  void fixAlignables(int n);

  /// Alignable tracker
  const AlignableTracker *alignableTracker() const;

private:
  /// First remove all spaces (' ') from char selection 'paramSelChar' (coming
  /// from ParameterSelector) and then convert the selection to bool (for AlignmentParameters).
  /// True if (after removal of spaces) anything else than 0 and 1 is found in vector<char>.
  bool decodeParamSel(std::vector<char> &paramSelChar, std::vector<bool> &result) const;
  /// add SelectionUserVariables corresponding to fullSel
  bool addFullParamSel(AlignmentParameters *aliPar, const std::vector<char> &fullSel) const;

  // data members

  /// Vector of alignables
  align::Alignables theAlignables;

  /// Alignable tracker
  AlignableTracker *theAlignableTracker;

  /// Alignable muon
  AlignableMuon *theAlignableMuon;

  /// extra Alignables
  AlignableExtras *theAlignableExtras;
};

#endif