DetectorConfiguration.cpp 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. #include "stdafx.h"
  2. #include "DetectorConfiguration.h"
  3. #include "Detector_Model_Def.h"
  4. DetectorConfiguration::DetectorConfiguration(string ConfigPath)
  5. {
  6. m_strConfigPath = ConfigPath;
  7. }
  8. DetectorConfiguration::~DetectorConfiguration()
  9. {
  10. }
  11. bool DetectorConfiguration::LoadConfigurations(DeviceIndexStruct & DeviceConf, ResDataObject & ACQMODElist)
  12. {
  13. if (!m_ConfigAll.loadFile(m_strConfigPath.c_str()))
  14. {
  15. printf( "Load configuration file failed!!! \n");
  16. Error("load {$} fail!", m_strConfigPath);
  17. return false;
  18. }
  19. try
  20. {
  21. m_Configurations = m_ConfigAll["CONFIGURATION"];
  22. DeviceConf.strDeviceName = (string)m_Configurations[DetectorDescription];
  23. int maxImageSize = 0;
  24. int nModeCount = (int)m_Configurations["ModeTable"].GetKeyCount("DetectorMode");
  25. for (int i = 0; i < nModeCount; i++)
  26. {
  27. DeviceConf.nRawWidth = m_Configurations["ModeTable"][i]["RawImgWidth"];
  28. DeviceConf.nRawHeight = m_Configurations["ModeTable"][i]["RawImgHeight"];
  29. DeviceConf.nFullImageWidth = m_Configurations["ModeTable"][i]["ImageWidth"];
  30. DeviceConf.nFullImageHeight = m_Configurations["ModeTable"][i]["ImageHeight"];
  31. DeviceConf.fPixelSpace = m_Configurations["ModeTable"][i]["PixelPitch"];
  32. DeviceConf.nImageBits = (int)m_Configurations["ModeTable"][i]["PhySizeInfoBit"];
  33. DeviceConf.nDoseOfEXI = (int)m_Configurations["ModeTable"][i]["Sensitivity"];
  34. DeviceConf.nSyncMode = (int)m_Configurations["ModeTable"][i]["SyncType"];
  35. if (DeviceConf.nRawWidth * DeviceConf.nRawHeight > maxImageSize)
  36. {
  37. maxImageSize = DeviceConf.nRawWidth * DeviceConf.nRawHeight;
  38. DeviceConf.nMaxImageWidth = DeviceConf.nRawWidth;
  39. DeviceConf.nMaxImageHeight = DeviceConf.nRawHeight;
  40. }
  41. }
  42. Info("DeviceConf.nMaxImageWidth:{$},DeviceConf.nMaxImageHeight:{$}", DeviceConf.nMaxImageWidth, DeviceConf.nMaxImageHeight);
  43. }
  44. catch (ResDataObjectExption &e)
  45. {
  46. printf("Get config error: %s \r\n", e.what());
  47. Error("Get config error: {$}", e.what());
  48. return false;
  49. }
  50. return true;
  51. }
  52. bool DetectorConfiguration::SaveConfig()
  53. {
  54. try
  55. {
  56. m_ConfigAll["CONFIGURATION"] = m_Configurations;
  57. }
  58. catch (...)
  59. {
  60. return false;
  61. }
  62. return m_ConfigAll.SaveFile((m_strConfigPath).c_str());
  63. }
  64. bool DetectorConfiguration::LoadCalibrationDose(string& strWorkPath, ResDataObject& CalibDoseList, int& nCalibTotalExpNum)
  65. {
  66. ResDataObject RdoCalibDoseList;
  67. try
  68. {
  69. string strCalibDosePath = strWorkPath + (string)m_Configurations["CalibrationDosePath"] + "\\CalibrationDose_CareRay.xml";
  70. Info("start load calibDose file: {$}", strCalibDosePath);
  71. struct stat buffer;
  72. if (stat(strCalibDosePath.c_str(), &buffer) == 0)
  73. {
  74. RdoCalibDoseList.loadFile(strCalibDosePath.c_str());
  75. CalibDoseList = RdoCalibDoseList["List"];
  76. Info("CalibDoseList: {$} ", CalibDoseList.encode());
  77. for (int i = 0; i < CalibDoseList.size(); i++)
  78. {
  79. ResDataObject temp = CalibDoseList[i];
  80. int nExpNum = temp["ExpNum"];
  81. nCalibTotalExpNum += nExpNum;
  82. //Info("temp: {$} ", temp.encode());
  83. }
  84. }
  85. else
  86. {
  87. Error("{$} file not exist!", strCalibDosePath);
  88. return false;
  89. }
  90. }
  91. catch (exception e)
  92. {
  93. Error("Get calibDose error: {$}", e.what());
  94. return false;
  95. }
  96. return true;
  97. }