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
#include "Alignment/TrackerAlignment/interface/AlignableTracker.h"

// Original Author:  ?
//     Last Update:  Max Stark
//            Date:  Mon, 15 Feb 2016 09:32:12 CET

// alignment
#include "Alignment/TrackerAlignment/interface/AlignableTrackerBuilder.h"

#include "CondFormats/Alignment/interface/Alignments.h"
#include "CondFormats/Alignment/interface/AlignmentErrorsExtended.h"

//_____________________________________________________________________________
AlignableTracker ::AlignableTracker(const TrackerGeometry* trackerGeometry, const TrackerTopology* trackerTopology)
    :  // id not yet known, will be set by builder
      AlignableComposite(0, align::Tracker, RotationType()),
      tTopo_(trackerTopology),
      trackerNameSpace_(trackerTopology),
      alignableObjectId_(trackerGeometry, nullptr, nullptr, nullptr) {
  AlignableTrackerBuilder builder(trackerGeometry, trackerTopology);
  builder.buildAlignables(this);
  trackerNameSpace_ = builder.trackerNameSpace();
  alignableObjectId_ = builder.objectIdProvider();
}

//_____________________________________________________________________________
void AlignableTracker::update(const TrackerGeometry* trackerGeometry, const TrackerTopology* trackerTopology) {
  AlignableTrackerBuilder builder(trackerGeometry, trackerTopology);
  builder.buildAlignables(this, /* update = */ true);
}

//_____________________________________________________________________________
align::Alignables AlignableTracker::merge(const Alignables& list1, const Alignables& list2) const {
  Alignables all = list1;

  all.insert(all.end(), list2.begin(), list2.end());

  return all;
}

//_____________________________________________________________________________
Alignments* AlignableTracker::alignments(void) const {
  align::Alignables comp = this->components();
  Alignments* m_alignments = new Alignments();
  // Add components recursively
  for (align::Alignables::iterator i = comp.begin(); i != comp.end(); i++) {
    Alignments* tmpAlignments = (*i)->alignments();
    std::copy(tmpAlignments->m_align.begin(), tmpAlignments->m_align.end(), std::back_inserter(m_alignments->m_align));
    delete tmpAlignments;
  }

  // sort by rawId
  std::sort(m_alignments->m_align.begin(), m_alignments->m_align.end());

  return m_alignments;
}

//_____________________________________________________________________________
AlignmentErrorsExtended* AlignableTracker::alignmentErrors(void) const {
  align::Alignables comp = this->components();
  AlignmentErrorsExtended* m_alignmentErrors = new AlignmentErrorsExtended();

  // Add components recursively
  for (align::Alignables::iterator i = comp.begin(); i != comp.end(); i++) {
    AlignmentErrorsExtended* tmpAlignmentErrorsExtended = (*i)->alignmentErrors();
    std::copy(tmpAlignmentErrorsExtended->m_alignError.begin(),
              tmpAlignmentErrorsExtended->m_alignError.end(),
              std::back_inserter(m_alignmentErrors->m_alignError));
    delete tmpAlignmentErrorsExtended;
  }

  // sort by rawId
  std::sort(m_alignmentErrors->m_alignError.begin(), m_alignmentErrors->m_alignError.end());

  return m_alignmentErrors;
}