00001 #ifndef PDSCALIBDATA_CALIBPARSCENTERCORRV1_H
00002 #define PDSCALIBDATA_CALIBPARSCENTERCORRV1_H
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016 #include <vector>
00017
00018
00019
00020
00021
00022
00023
00024
00025 #include "psddl_psana/cspad.ddl.h"
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035 namespace pdscalibdata {
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046
00047
00048
00049
00050
00051 class CalibParsCenterCorrV1 {
00052 public:
00053
00054 enum { NQuad = Psana::CsPad::MaxQuadsPerSensor};
00055 enum { NSect = Psana::CsPad::SectorsPerQuad};
00056 enum { NUMBER_OF_PARAMETERS = 96 };
00057
00058 CalibParsCenterCorrV1( const std::vector<double> v_parameters );
00059 double getCenterCorrX(size_t quad, size_t sect){ return m_center_corr_x[quad][sect]; };
00060 double getCenterCorrY(size_t quad, size_t sect){ return m_center_corr_y[quad][sect]; };
00061 double getCenterCorrZ(size_t quad, size_t sect){ return m_center_corr_z[quad][sect]; };
00062 void print();
00063
00064
00065 CalibParsCenterCorrV1 () ;
00066
00067
00068 virtual ~CalibParsCenterCorrV1 () ;
00069
00070 protected:
00071
00072 private:
00073
00074
00075
00076 double m_center_corr_x[NQuad][NSect];
00077 double m_center_corr_y[NQuad][NSect];
00078 double m_center_corr_z[NQuad][NSect];
00079
00080
00081 CalibParsCenterCorrV1 ( const CalibParsCenterCorrV1& ) ;
00082 CalibParsCenterCorrV1& operator = ( const CalibParsCenterCorrV1& ) ;
00083 };
00084
00085 }
00086
00087 #endif // PDSCALIBDATA_CALIBPARSCENTERCORRV1_H