00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016 #include "pdscalibdata/CsPad2x2CenterV1.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 CsPad2x2CenterV1::CsPad2x2CenterV1 ()
00044 {
00045 double arr_x[] = {198., 198.};
00046 double arr_y[] = { 95., 308.};
00047
00048 int NPars = NSect;
00049 size_t arr_size = sizeof( double ) * NPars;
00050 memcpy ( &m_center_x[0], arr_x, arr_size);
00051 memcpy ( &m_center_y[0], arr_y, arr_size);
00052 std::fill_n( &m_center_z[0], NPars, double(0));
00053 }
00054
00055
00056
00057 CsPad2x2CenterV1::CsPad2x2CenterV1( const std::vector<double> v_parameters )
00058 {
00059 if (v_parameters.size() != NUMBER_OF_PARAMETERS) {
00060 WithMsgLog("CsPad2x2CenterV1", error, str) {
00061 str << "Expected number of parameters is " << NUMBER_OF_PARAMETERS ;
00062 str << ", read from file " << v_parameters.size() ;
00063 str << ": check the file.\n" ;
00064 }
00065 abort();
00066 }
00067 size_t NPars = NSect;
00068 size_t arr_size = sizeof( double ) * v_parameters.size()/3;
00069 memcpy( &m_center_x, &v_parameters[0], arr_size );
00070 memcpy( &m_center_y, &v_parameters[NPars], arr_size );
00071 memcpy( &m_center_z, &v_parameters[NPars*2], arr_size );
00072
00073 }
00074
00075 void CsPad2x2CenterV1::print()
00076 {
00077 cout << endl << "X:";
00078 for( int sect=0; sect<NSect; ++sect ) { cout << " " << m_center_x[sect]; }
00079 cout << endl;
00080
00081 cout << "Y:";
00082 for( int sect=0; sect<NSect; ++sect ) { cout << " " << m_center_y[sect]; }
00083 cout << endl;
00084
00085 cout << "Z:";
00086 for( int sect=0; sect<NSect; ++sect ) { cout << " " << m_center_z[sect]; }
00087 cout << endl;
00088 }
00089
00090
00091
00092
00093
00094 CsPad2x2CenterV1::~CsPad2x2CenterV1 ()
00095 {
00096 }
00097
00098 }