00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016 #include "pdscalibdata/CsPadRotationGlobalV1.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 CsPadRotationGlobalV1::CsPadRotationGlobalV1 ()
00044 {
00045 double arr[] = { 0, 0, 270, 270, 180, 180, 270, 270,
00046 90, 90, 0, 0, 270, 270, 0, 0,
00047 180, 180, 90, 90, 0, 0, 90, 90,
00048 270, 270, 180, 180, 90, 90, 180, 180 };
00049 memcpy( &m_rotation, &arr[0], sizeof( double ) * NQuad * NSect );
00050 }
00051
00052
00053
00054 CsPadRotationGlobalV1::CsPadRotationGlobalV1( const std::vector<double> v_parameters )
00055 {
00056 if (v_parameters.size() != NUMBER_OF_PARAMETERS) {
00057 WithMsgLog("CsPadRotationGlobalV1", error, str) {
00058 str << "Expected number of parameters is " << NUMBER_OF_PARAMETERS ;
00059 str << ", read from file " << v_parameters.size() ;
00060 str << ": check the file.\n" ;
00061 }
00062 abort();
00063 }
00064 size_t arr_size = sizeof( double ) * v_parameters.size();
00065 memcpy( &m_rotation, &v_parameters[0], arr_size );
00066
00067 }
00068
00069 void CsPadRotationGlobalV1::print()
00070 {
00071 cout << endl << "Rotation global:" << endl;
00072 for( int quad=0; quad<NQuad; ++quad ) {
00073 for( int sect=0; sect<NSect; ++sect ) { cout << " " << m_rotation[quad][sect]; }
00074 cout << endl;
00075 }
00076 }
00077
00078
00079
00080
00081
00082 CsPadRotationGlobalV1::~CsPadRotationGlobalV1 ()
00083 {
00084 }
00085
00086 }