AlignableExtras

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
#ifndef Alignment_CommonAlignment_AlignableExtras_H
#define Alignment_CommonAlignment_AlignableExtras_H

/** \class AlignableExtras
 *
 * A container for additional/extra alignables
 *
 *  Original author: Andreas Mussgiller, August 2010
 *
 *  $Date: 2009/02/28 21:04:59 $
 *  $Revision: 1.3 $
 *  (last update by $Author: mussgill $)
 */

#include "Alignment/CommonAlignment/interface/Alignable.h"
#include "Alignment/CommonAlignment/interface/AlignableMap.h"
#include "Alignment/CommonAlignment/interface/Utilities.h"

class AlignableExtras {
public:
  typedef align::Alignables Alignables;

  /// Constructor (builds all alignables)
  explicit AlignableExtras();

  /// Return alignables determined by name
  Alignables& subStructures(const std::string& subStructName) { return alignableLists_.find(subStructName); }

  /// Return beam spot alignable as a vector with one element
  Alignables& beamSpot() { return this->subStructures("BeamSpot"); }

  const Alignables& components() const { return components_; }

  /// Return alignments, sorted by DetId
  Alignments* alignments() const;

  /// Return alignment errors, sorted by DetId
  AlignmentErrorsExtended* alignmentErrors() const;

  void dump(void) const;

  /// Initialize the alignable beam spot with the given parameters
  void initializeBeamSpot(double x, double y, double z, double dxdz, double dydz);

  /// Initialize the alignable beam spot with the given parameters
  void resetBeamSpot();

private:
  AlignableMap alignableLists_;  //< kind of map of lists of alignables
  Alignables components_;        //< list of alignables
};

#endif  //AlignableExtras_H