AlignmentIO

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

/// \class AlignmentIO
///
/// Abstract base class for input/output of Alignment parameters,
/// Correlations, as well as absolute and relative coordinates of
/// Alignables
///
///  $Date: 2006/11/30 09:56:03 $
///  $Revision: 1.3 $
/// (last update by $Author: flucke $)

#include "Alignment/CommonAlignment/interface/Utilities.h"
#include "Alignment/CommonAlignmentAlgorithm/interface/AlignableData.h"

class AlignmentIO {
public:
  virtual ~AlignmentIO() = default;
  /// write AlignmentParameters
  virtual void writeAlignmentParameters(
      const align::Alignables& alivec, const char* filename, int iter, bool validCheck, int& ierr) = 0;

  /// read AlignmentParameters
  virtual align::Parameters readAlignmentParameters(const align::Alignables& alivec,
                                                    const char* filename,
                                                    int iter,
                                                    int& ierr) = 0;

  /// write RigidBodyAlignmentParameters as applied on top of original positions
  virtual void writeOrigRigidBodyAlignmentParameters(
      const align::Alignables& alivec, const char* filename, int iter, bool validCheck, int& ierr) = 0;

  /// write Correlations
  virtual void writeCorrelations(
      const align::Correlations& cormap, const char* filename, int iter, bool validCheck, int& ierr) = 0;

  /// read Correlations
  virtual align::Correlations readCorrelations(const align::Alignables& alivec,
                                               const char* filename,
                                               int iter,
                                               int& ierr) = 0;

  /// write Alignable current absolute positions
  virtual void writeAlignableAbsolutePositions(
      const align::Alignables& alivec, const char* filename, int iter, bool validCheck, int& ierr) = 0;

  /// read Alignable current absolute positions
  virtual AlignablePositions readAlignableAbsolutePositions(const align::Alignables& alivec,
                                                            const char* filename,
                                                            int iter,
                                                            int& ierr) = 0;

  /// write Alignable original (before misalignment) absolute positions
  virtual void writeAlignableOriginalPositions(
      const align::Alignables& alivec, const char* filename, int iter, bool validCheck, int& ierr) = 0;

  /// read Alignable original (before misalignment) absolute positions
  virtual AlignablePositions readAlignableOriginalPositions(const align::Alignables& alivec,
                                                            const char* filename,
                                                            int iter,
                                                            int& ierr) = 0;

  /// write Alignable relative positions (shift,rotation)
  virtual void writeAlignableRelativePositions(
      const align::Alignables& alivec, const char* filename, int iter, bool validCheck, int& ierr) = 0;

  /// read Alignable relative positions (shift,rotation)
  virtual AlignableShifts readAlignableRelativePositions(const align::Alignables& alivec,
                                                         const char* filename,
                                                         int iter,
                                                         int& ierr) = 0;
};

#endif