pdscalibdata/src/CsPad2x2CenterV1.cpp

Go to the documentation of this file.
00001 //--------------------------------------------------------------------------
00002 // File and Version Information:
00003 //      $Id$
00004 //
00005 // Description:
00006 //      Class CsPad2x2CenterV1...
00007 //
00008 // Author List:
00009 //      Mikhail S. Dubrovin
00010 //
00011 //------------------------------------------------------------------------
00012 
00013 //-----------------------
00014 // This Class's Header --
00015 //-----------------------
00016 #include "pdscalibdata/CsPad2x2CenterV1.h"
00017 
00018 //-----------------
00019 // C/C++ Headers --
00020 //-----------------
00021 #include <string.h>
00022 
00023 //-------------------------------
00024 // Collaborating Class Headers --
00025 //-------------------------------
00026 #include "MsgLogger/MsgLogger.h"
00027 
00028 //-----------------------------------------------------------------------
00029 // Local Macros, Typedefs, Structures, Unions and Forward Declarations --
00030 //-----------------------------------------------------------------------
00031 
00032 using namespace std;
00033 
00034 //              ----------------------------------------
00035 //              -- Public Function Member Definitions --
00036 //              ----------------------------------------
00037 
00038 namespace pdscalibdata {
00039 
00040 //----------------
00041 // Constructors --
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     //this->print();
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 // Destructor --
00093 //--------------
00094 CsPad2x2CenterV1::~CsPad2x2CenterV1 ()
00095 {
00096 }
00097 
00098 } // namespace pdscalibdata

Generated on 19 Dec 2016 for PSANAmodules by  doxygen 1.4.7