AlignmentCorrelationsIORoot

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

#include "Alignment/CommonAlignment/interface/StructureType.h"
#include "Alignment/CommonAlignmentAlgorithm/interface/AlignmentIORootBase.h"
#include "Alignment/CommonAlignmentAlgorithm/interface/AlignmentCorrelationsIO.h"

/// Concrete class for ROOT based IO of Correlations

class AlignmentCorrelationsIORoot : public AlignmentIORootBase, public AlignmentCorrelationsIO {
  friend class AlignmentIORoot;

private:
  /// constructor
  AlignmentCorrelationsIORoot();

  /// open IO
  int open(const char* filename, int iteration, bool writemode) override {
    return openRoot(filename, iteration, writemode);
  };

  /// close IO
  int close(void) override { return closeRoot(); };

  /// write correlations
  int write(const align::Correlations& cor, bool validCheck) override;

  /// read correlations
  align::Correlations read(const align::Alignables& alivec, int& ierr) override;

  void createBranches(void) override;
  void setBranchAddresses(void) override;

  // data members

  /// correlation tree
  align::ID Ali1Id, Ali2Id;
  align::StructureType Ali1ObjId, Ali2ObjId;
  int corSize;
  double CorMatrix[nParMax * nParMax];
};

#endif