00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016 #include "pdscalibdata/CalibParsOffsetCorrV1.h"
00017
00018
00019
00020
00021 #include <string.h>
00022
00023
00024
00025
00026 #include "MsgLogger/MsgLogger.h"
00027
00028
00029
00030
00031
00032 using namespace std;
00033
00034
00035
00036
00037
00038 namespace pdscalibdata {
00039
00040
00041
00042
00043 CalibParsOffsetCorrV1::CalibParsOffsetCorrV1 ()
00044 {
00045 std::fill_n(&m_offset_corr_x[0], int(NQuad), double(0));
00046 std::fill_n(&m_offset_corr_y[0], int(NQuad), double(0));
00047 std::fill_n(&m_offset_corr_z[0], int(NQuad), double(0));
00048 }
00049
00050
00051 CalibParsOffsetCorrV1::CalibParsOffsetCorrV1( const std::vector<double> v_parameters )
00052 {
00053 if (v_parameters.size() != NUMBER_OF_PARAMETERS) {
00054 WithMsgLog("CalibParsOffsetCorrV1", error, str) {
00055 str << "Expected number of parameters is " << NUMBER_OF_PARAMETERS ;
00056 str << ", read from file " << v_parameters.size() ;
00057 str << ": check the file.\n" ;
00058 }
00059 abort();
00060 }
00061 size_t NPars = NQuad;
00062 size_t arr_size = sizeof( double ) * v_parameters.size()/3;
00063 memcpy( &m_offset_corr_x, &v_parameters[0], arr_size );
00064 memcpy( &m_offset_corr_y, &v_parameters[NPars], arr_size );
00065 memcpy( &m_offset_corr_z, &v_parameters[NPars*2], arr_size );
00066
00067 }
00068
00069 void CalibParsOffsetCorrV1::print()
00070 {
00071 cout << endl;
00072 cout << "Quad offset correction X:"; for( int q=0; q<NQuad; ++q ) {cout << " " << m_offset_corr_x[q];} cout << endl;
00073 cout << "Quad offset correction Y:"; for( int q=0; q<NQuad; ++q ) {cout << " " << m_offset_corr_y[q];} cout << endl;
00074 cout << "Quad offset correction Z:"; for( int q=0; q<NQuad; ++q ) {cout << " " << m_offset_corr_z[q];} cout << endl;
00075 }
00076
00077
00078
00079
00080
00081
00082 CalibParsOffsetCorrV1::~CalibParsOffsetCorrV1 ()
00083 {
00084 }
00085
00086 }