DetectorConfiguration.cpp 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. #include "stdafx.h"
  2. #include "DetectorConfiguration.h"
  3. #include "Detector_Model_Def.h"
  4. #include "common_api.h"
  5. DetectorConfiguration::DetectorConfiguration(string ConfigPath)
  6. {
  7. m_strConfigPath = ConfigPath;
  8. }
  9. DetectorConfiguration::~DetectorConfiguration()
  10. {
  11. }
  12. bool DetectorConfiguration::LoadConfigurations(DeviceIndexStruct& DeviceConf, ResDataObject& CalibDoseList, int& nCalibTotalExpNum)
  13. {
  14. if (!m_ConfigAll.loadFile(m_strConfigPath.c_str()))
  15. {
  16. printf("Load configuration file failed!!! \n");
  17. FERROR("load {$} fail!", m_strConfigPath);
  18. return false;
  19. }
  20. try
  21. {
  22. m_Configurations = m_ConfigAll["CONFIGURATION"];
  23. TransferModuleJosnConfig2DriverConfig(m_Configurations);
  24. //FINFO("m_Configurations:{$}", m_Configurations.encode());
  25. DeviceConf.strDeviceName = (string)m_Configurations[DetectorDescription];
  26. DeviceConf.strPanelSerial = (string)m_Configurations[DetectorSerialNumber];
  27. DeviceConf.nNotifyStatusTimePeriod = (int)m_Configurations["NotifyStatusTimePeriod"];
  28. DeviceConf.nReconnectTimePeriod = (int)m_Configurations["ReConnectTimePeriod"];
  29. int nTemp = (int)m_Configurations["SupportDDR"];
  30. if (nTemp == 1)
  31. {
  32. DeviceConf.bSupportDDR = true;
  33. }
  34. else
  35. {
  36. DeviceConf.bSupportDDR = false;
  37. }
  38. //增加温度电量wifi警告和阈值的读取
  39. DeviceConf.fTemperatureErrorMax = (float)m_Configurations["TempMaxLimit"];
  40. DeviceConf.fTemperatureWarnMax = (float)m_Configurations["TempUpperLimit"];
  41. DeviceConf.fTemperatureWarnMin = (float)m_Configurations["TempLowerLimit"];
  42. DeviceConf.fTemperatureErrorMin = (float)m_Configurations["TempMinLimit"];
  43. DeviceConf.nBatteryWarning = (int)m_Configurations["BatLowerLimit"];
  44. DeviceConf.nBatteryLimit = (int)m_Configurations["BatMiniLimit"];
  45. DeviceConf.nWifiWarning = (int)m_Configurations["WifiLowerLimit"];
  46. DeviceConf.nWifiLimit = (int)m_Configurations["WifiMiniLimit"];
  47. DeviceConf.strSupportSyncMode = m_Configurations["SupportSyncMode"].encode();
  48. DeviceConf.nCalibMode = (int)m_Configurations["CalibMode"];
  49. FINFO("DeviceConf.strSupportSyncMode:{$},CalibMode:{$}", DeviceConf.strSupportSyncMode, DeviceConf.nCalibMode);
  50. int maxImageSize = 0;
  51. int nModeCount = (int)m_Configurations["ModeTable"].size();
  52. //FINFO("nModeCount:{$},ModeTable:{$}", nModeCount, m_Configurations["ModeTable"].encode());
  53. for (int i = 0; i < nModeCount; i++)
  54. {
  55. //FINFO("ModeTable[{$}]:{$}", i, m_Configurations["ModeTable"][i].encode());
  56. DeviceConf.nRawWidth = m_Configurations["ModeTable"][i]["RawImgWidth"];
  57. DeviceConf.nRawHeight = m_Configurations["ModeTable"][i]["RawImgHeight"];
  58. if (DeviceConf.nRawWidth * DeviceConf.nRawHeight > maxImageSize)
  59. {
  60. maxImageSize = DeviceConf.nRawWidth * DeviceConf.nRawHeight;
  61. DeviceConf.nMaxImgWidth = DeviceConf.nRawWidth;
  62. DeviceConf.nMaxImgHeight = DeviceConf.nRawHeight;
  63. }
  64. }
  65. FINFO("DeviceConf.nMaxImageWidth:{$},DeviceConf.nMaxImageHeight:{$}", DeviceConf.nMaxImgWidth, DeviceConf.nMaxImgHeight);
  66. int nDoseList = (int)m_Configurations["CalibrationConfig"].size();
  67. for (int i = 0; i < nDoseList; i++)
  68. {
  69. ResDataObject temp;
  70. temp.add("TargetGainEXI", m_Configurations["CalibrationConfig"][i]["TargetGainEXI"]);
  71. temp.add("KV", m_Configurations["CalibrationConfig"][i]["KV"]);
  72. temp.add("MA", m_Configurations["CalibrationConfig"][i]["MA"]);
  73. temp.add("MS", m_Configurations["CalibrationConfig"][i]["MS"]);
  74. temp.add("MAS", m_Configurations["CalibrationConfig"][i]["MAS"]);
  75. temp.add("ExpNum", m_Configurations["CalibrationConfig"][i]["ExpNum"]);
  76. CalibDoseList.add("Dose", temp);
  77. nCalibTotalExpNum += (int)m_Configurations["CalibrationConfig"][i]["ExpNum"];
  78. }
  79. }
  80. catch (ResDataObjectExption &e)
  81. {
  82. printf("Get config error: %s \r\n", e.what());
  83. FERROR("Get config error: {$}", e.what());
  84. return false;
  85. }
  86. return true;
  87. }
  88. bool DetectorConfiguration::SaveConfig()
  89. {
  90. try
  91. {
  92. m_ConfigAll["CONFIGURATION"] = m_Configurations;
  93. }
  94. catch (...)
  95. {
  96. return false;
  97. }
  98. return m_ConfigAll.SaveFile((m_strConfigPath).c_str());
  99. }
  100. bool DetectorConfiguration::LoadCalibrationDose(string& strWorkPath, ResDataObject& CalibDoseList, int& nCalibTotalExpNum)
  101. {
  102. ResDataObject RdoCalibDoseList;
  103. try
  104. {
  105. string strCalibDosePath = strWorkPath + (string)m_Configurations["CalibrationDosePath"] + "\\CalibrationDose_CareRay.xml";
  106. FINFO("start load calibDose file: {$}", strCalibDosePath);
  107. struct stat buffer;
  108. if (stat(strCalibDosePath.c_str(), &buffer) == 0)
  109. {
  110. RdoCalibDoseList.loadFile(strCalibDosePath.c_str());
  111. CalibDoseList = RdoCalibDoseList["List"];
  112. FINFO("CalibDoseList: {$} ", CalibDoseList.encode());
  113. for (int i = 0; i < CalibDoseList.size(); i++)
  114. {
  115. ResDataObject temp = CalibDoseList[i];
  116. int nExpNum = temp["ExpNum"];
  117. nCalibTotalExpNum += nExpNum;
  118. //FINFO("temp: {$} ", temp.encode());
  119. }
  120. }
  121. else
  122. {
  123. FERROR("{$} file not exist!", strCalibDosePath);
  124. return false;
  125. }
  126. }
  127. catch (exception e)
  128. {
  129. FERROR("Get calibDose error: {$}", e.what());
  130. return false;
  131. }
  132. return true;
  133. }