CarmImplPositionManager.cpp 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351
  1. #include "stdafx.h"
  2. #include "CarmImplPositionManager.h"
  3. #include "Converter.h"
  4. #include "IMachineryManager.h"
  5. #include "ISensorEncoderController.h"
  6. #include "PacketAnalizer.h"
  7. #include "CArmComponentNameDef.h"
  8. #include "ConfigurerMotion.h"
  9. #include "DIOS.Dev.Machinery.Driver.ECOM.h"
  10. using namespace DIOS::Dev::Detail::MachineryECOM;
  11. CarmImplPositionManager::CarmImplPositionManager()
  12. :m_isSystemReady(FALSE),
  13. m_isSystemReadySwing(FALSE),
  14. m_isSystemReadyCircular(FALSE),
  15. m_notifyLogicDriver(nullptr),
  16. m_machineryManager(nullptr),
  17. m_encoderCircular(nullptr),
  18. m_encoderSwing(nullptr)
  19. {
  20. }
  21. CarmImplPositionManager::~CarmImplPositionManager()
  22. {
  23. }
  24. void CarmImplPositionManager::Initialize(IMachineryManager *machmanager)
  25. {
  26. m_machineryManager = machmanager;
  27. m_encoderCircular = (ISensorEncoderController*)(m_machineryManager->Resove(CONTROLLER_CARM_TUBE_CIRCULAR_ENCODER));
  28. m_encoderSwing = (ISensorEncoderController*)(m_machineryManager->Resove(CONTROLLER_CARM_TUBE_SWING_ENCODER));
  29. }
  30. float CarmImplPositionManager::GetLandmarkPosition(DOF_MECH dof, LANDMARK_TYPE landmarkType)
  31. {
  32. if(gbusinessLog) gbusinessLog->Error("[GetLandmarkPosition] [DOF [{$:d}] Not implemented]", dof);
  33. return 0.0f;
  34. }
  35. float CarmImplPositionManager::GetCurrentAbsolutePhysical(DOF_MECH dof)
  36. {
  37. if(gbusinessLog) gbusinessLog->Error("[GetCurrentAbsolutePhysical] [DOF [{$:d}] Not implemented]", dof);
  38. return 0.0f;
  39. }
  40. float CarmImplPositionManager::GetPhysicalPerMotorPulse(DOF_MECH dof)
  41. {
  42. float ret = 0.0f;
  43. switch (dof)
  44. {
  45. case CARM_TUBE_SWING:
  46. {
  47. float angleinonecircle = ConfigurerMotion::GetDistanceInOneCircleOfTubeAngleMotor();
  48. DWORD pulseinonecircle = ConfigurerMotion::GetPulseInOneCircleOfTubeAngleMotor();
  49. if (pulseinonecircle == 0)
  50. {
  51. ret = 0.0f;
  52. }
  53. ret = (angleinonecircle / pulseinonecircle);
  54. }
  55. break;
  56. case CARM_TUBE_CIRCULAR:
  57. {
  58. float angleinonecircle = ConfigurerMotion::GetDistanceInOneCircleOfTubeHeightMotor();
  59. DWORD pulseinonecircle = ConfigurerMotion::GetPulseInOneCircleOfTubeHeightMotor();
  60. if (pulseinonecircle == 0)
  61. {
  62. ret = 0.0f;
  63. }
  64. ret = (angleinonecircle / pulseinonecircle);
  65. }
  66. break;
  67. default:
  68. if(gbusinessLog) gbusinessLog->Error("[GetPhysicalPerMotorPulse] [DOF [{$:d}] Not implemented]", dof);
  69. break;
  70. }
  71. return ret;
  72. }
  73. float CarmImplPositionManager::GetCurrentPhysical(DOF_MECH dof)
  74. {
  75. float ret = 0.0f;
  76. switch (dof)
  77. {
  78. case CARM_TUBE_SWING:
  79. {
  80. auto sensorvalue = m_encoderSwing->GetCurrentEncoderValue();
  81. float angleinonecircle = ConfigurerMotion::GetDistanceInOneCircleOfTubeAngleMotor();
  82. auto encodervalueinonecircle = ConfigurerMotion::GetEncoderValueInOneCircleOfTubeAngleMotor();
  83. auto absolutevalueAtorigin = ConfigurerMotion::GetAbsoluteValueAtTubeAngleOrigin();
  84. ret = Converter::ConvertEncoder(sensorvalue, angleinonecircle, encodervalueinonecircle, absolutevalueAtorigin);
  85. if (gmotionLog) gmotionLog->Info("[CarmImplPositionManager][GetCurrentPhysical]->[CARM_TUBE_SWING][Sensor:{$:d} DIS:{$:f3} ENC:{$:f3} ORI:{$:f3} Ret:{$:f3}]",
  86. sensorvalue, angleinonecircle, encodervalueinonecircle, absolutevalueAtorigin, ret);
  87. }
  88. break;
  89. case CARM_TUBE_CIRCULAR:
  90. {
  91. auto sensorvalue = m_encoderCircular->GetCurrentEncoderValue();
  92. float distanceinonecircle = ConfigurerMotion::GetDistanceInOneCircleOfTubeHeightMotor();
  93. auto encodervalueinonecircle = ConfigurerMotion::GetEncoderValueInOneCircleOfTubeHeightMotor();
  94. auto absolutevalueAtorigin = ConfigurerMotion::GetAbsoluteValueAtTubeHeightOrigin();
  95. ret = Converter::ConvertEncoder(sensorvalue, distanceinonecircle, encodervalueinonecircle, absolutevalueAtorigin);
  96. if (gmotionLog) gmotionLog->Info("[CarmImplPositionManager][GetCurrentPhysical]->[CIRCULAR][Sensor:{$:d} DIS:{$:f3} ENC:{$:f3} ORI:{$:f3} Ret:{$:f3}]",
  97. sensorvalue, distanceinonecircle, encodervalueinonecircle, absolutevalueAtorigin, ret);
  98. }
  99. break;
  100. default:
  101. if(gbusinessLog) gbusinessLog->Error("[GetCurrentPhysical] [DOF [{$:d}] Not implemented]", dof);
  102. break;
  103. }
  104. return ret;
  105. }
  106. int CarmImplPositionManager::GetCurrentSensorValue(DOF_MECH dof)
  107. {
  108. int ret = 0;
  109. switch (dof)
  110. {
  111. case CARM_TUBE_SWING:
  112. ret = m_encoderSwing->GetCurrentEncoderValue();
  113. break;
  114. case CARM_TUBE_CIRCULAR:
  115. ret = m_encoderCircular->GetCurrentEncoderValue();
  116. break;
  117. default:
  118. if(gbusinessLog) gbusinessLog->Error("[GetCurrentSensorValue] [DOF [{$:d}] Not implemented]", dof);
  119. break;
  120. }
  121. return ret;
  122. }
  123. float CarmImplPositionManager::ConvertSensorValue(const std::string &componentName, int sensorValue)
  124. {
  125. float ret = 0.0f;
  126. if (componentName == CONTROLLER_CARM_TUBE_SWING_ENCODER)
  127. {
  128. //auto sensorvalue = m_encoderSwing->GetCurrentEncoderValue();
  129. float angleinonecircle = ConfigurerMotion::GetDistanceInOneCircleOfTubeAngleMotor();
  130. auto encodervalueinonecircle = ConfigurerMotion::GetEncoderValueInOneCircleOfTubeAngleMotor();
  131. auto absolutevalueAtorigin = ConfigurerMotion::GetAbsoluteValueAtTubeAngleOrigin();
  132. ret = Converter::ConvertEncoder(sensorValue, angleinonecircle, encodervalueinonecircle, absolutevalueAtorigin);
  133. }
  134. else if (componentName == CONTROLLER_CARM_TUBE_CIRCULAR_ENCODER)
  135. {
  136. //auto sensorvalue = m_encoderCircular->GetCurrentEncoderValue();
  137. float distanceinonecircle = ConfigurerMotion::GetDistanceInOneCircleOfTubeHeightMotor();
  138. auto encodervalueinonecircle = ConfigurerMotion::GetEncoderValueInOneCircleOfTubeHeightMotor();
  139. auto absolutevalueAtorigin = ConfigurerMotion::GetAbsoluteValueAtTubeHeightOrigin();
  140. ret = Converter::ConvertEncoder(sensorValue, distanceinonecircle, encodervalueinonecircle, absolutevalueAtorigin);
  141. }
  142. if (gmotionLog) gmotionLog->Info("[CarmImplPositionManager][ConvertSensorValue]->[{$}][{$:d04}][{$:f6}]", componentName.c_str(), sensorValue, ret);
  143. return ret;
  144. }
  145. int CarmImplPositionManager::ConvertPhysicsValue(const std::string &componentName, float physicsValue)
  146. {
  147. DWORD ret = 0;
  148. if (componentName == CONTROLLER_CARM_TUBE_SWING_ENCODER)
  149. {
  150. float angleinonecircle = ConfigurerMotion::GetDistanceInOneCircleOfTubeAngleMotor();
  151. auto encodervalueinonecircle = ConfigurerMotion::GetEncoderValueInOneCircleOfTubeAngleMotor();
  152. auto absolutevalueAtorigin = ConfigurerMotion::GetAbsoluteValueAtTubeAngleOrigin();
  153. ret = Converter::ConvertPhysicsToEncoder(physicsValue, angleinonecircle, encodervalueinonecircle, absolutevalueAtorigin);
  154. }
  155. else if (componentName == CONTROLLER_CARM_TUBE_CIRCULAR_ENCODER)
  156. {
  157. float distanceinonecircle = ConfigurerMotion::GetDistanceInOneCircleOfTubeHeightMotor();
  158. auto encodervalueinonecircle = ConfigurerMotion::GetEncoderValueInOneCircleOfTubeHeightMotor();
  159. auto absolutevalueAtorigin = ConfigurerMotion::GetAbsoluteValueAtTubeHeightOrigin();
  160. ret = Converter::ConvertPhysicsToEncoder(physicsValue, distanceinonecircle, encodervalueinonecircle, absolutevalueAtorigin);
  161. }
  162. if (gmotionLog) gmotionLog->Info("[CarmImplPositionManager][ConvertPhysicsValue]->[{$}][{$:f6}][{$:d04}]", componentName.c_str(), physicsValue, ret);
  163. return ret;
  164. }
  165. DWORD CarmImplPositionManager::ConvertMotorStepValue(const std::string &componentName, float physicsOffset)
  166. {
  167. DWORD ret = 0;
  168. if (componentName == CONTROLLER_CARM_TUBE_SWING)
  169. {
  170. float angleinonecircle = ConfigurerMotion::GetDistanceInOneCircleOfTubeAngleMotor();
  171. DWORD pulseinonecircle = ConfigurerMotion::GetPulseInOneCircleOfTubeAngleMotor();
  172. ret = Converter::ConvertMotorPulse(physicsOffset, angleinonecircle, pulseinonecircle);
  173. }
  174. else if (componentName == CONTROLLER_CARM_TUBE_CIRCULAR)
  175. {
  176. float heightinonecircle = ConfigurerMotion::GetDistanceInOneCircleOfTubeHeightMotor();
  177. DWORD pulseinonecircle = ConfigurerMotion::GetPulseInOneCircleOfTubeHeightMotor();
  178. ret = Converter::ConvertMotorPulse(physicsOffset, heightinonecircle, pulseinonecircle);
  179. }
  180. if (gmotionLog) gmotionLog->Info("[CarmImplPositionManager][ConvertMotorStepValue]->[{$}][{$:f6}][{$:d04}]", componentName.c_str(), physicsOffset, ret);
  181. return ret;
  182. }
  183. DWORD CarmImplPositionManager::ConvertMotorSpeed(const std::string &componentName, float speed)
  184. {
  185. DWORD ret = 0;
  186. if (componentName == CONTROLLER_CARM_TUBE_SWING)
  187. {
  188. float angleinonecircle = ConfigurerMotion::GetDistanceInOneCircleOfTubeAngleMotor();
  189. DWORD pulseinonecircle = ConfigurerMotion::GetPulseInOneCircleOfTubeAngleMotor();
  190. ret = Converter::ConvertSpeed(speed, angleinonecircle, pulseinonecircle);
  191. }
  192. else if (componentName == CONTROLLER_CARM_TUBE_CIRCULAR)
  193. {
  194. float heightinonecircle = ConfigurerMotion::GetDistanceInOneCircleOfTubeHeightMotor();
  195. DWORD pulseinonecircle = ConfigurerMotion::GetPulseInOneCircleOfTubeHeightMotor();
  196. ret = Converter::ConvertSpeed(speed, heightinonecircle, pulseinonecircle);
  197. }
  198. if (gmotionLog) gmotionLog->Info("[ImplPositionManager][ConvertMotorSpeed]->[{$}][{$:f6}][{$:d04}]", componentName.c_str(), speed, ret);
  199. return ret;
  200. }
  201. void CarmImplPositionManager::ResetSystem()
  202. {
  203. m_isSystemReady = FALSE;
  204. }
  205. BOOL CarmImplPositionManager::IsSystemReady()
  206. {
  207. return m_isSystemReady;
  208. }
  209. int CarmImplPositionManager::IsTomoMotionLimitationStatus()
  210. {
  211. return TRUE;
  212. }
  213. BOOL CarmImplPositionManager::IsNeedCenterAdjust()
  214. {
  215. return FALSE;
  216. }
  217. void CarmImplPositionManager::SetNotifyLogicDevice(MachineryECOMDriver* logicdriver)
  218. {
  219. m_notifyLogicDriver = logicdriver;
  220. }
  221. void CarmImplPositionManager::NotifyAlignStatus(BOOL isAligned)
  222. {
  223. if (m_notifyLogicDriver)
  224. {
  225. ResDataObject NotifyData;
  226. ResDataObject tmp;
  227. tmp.add("Alignstatus", (bool)isAligned);
  228. PacketAnalizer::MakeNotify(NotifyData, PACKET_CMD_UPDATE, NOTIFY_KEY_ALIGNSTATUS.c_str(), (const char *)tmp["Alignstatus"]);
  229. m_notifyLogicDriver->FireNotify("Alignstatus", std::to_string(isAligned));
  230. }
  231. }
  232. void CarmImplPositionManager::NotifySystemIsReady()
  233. {
  234. m_isSystemReady = TRUE;
  235. if (m_notifyLogicDriver)
  236. {
  237. ResDataObject NotifyData;
  238. ResDataObject tmp;
  239. tmp.add("Systemready", (bool)m_isSystemReady);
  240. PacketAnalizer::MakeNotify(NotifyData, PACKET_CMD_UPDATE, NOTIFY_KEY_SYSTEM_READY.c_str(), (const char *)tmp["Systemready"]);
  241. m_notifyLogicDriver->FireNotify("Systemready", std::to_string(m_isSystemReady));
  242. }
  243. }
  244. void CarmImplPositionManager::NotifySystemIsTomoMotionLimitation(int nLimitaionStatus)
  245. {
  246. }
  247. void CarmImplPositionManager::ResetSystem(const std::string &componentName)
  248. {
  249. if (componentName == CONTROLLER_CARM_TUBE_SWING)
  250. {
  251. m_isSystemReadySwing = FALSE;
  252. }
  253. else if (componentName == CONTROLLER_CARM_TUBE_CIRCULAR)
  254. {
  255. m_isSystemReadyCircular = FALSE;
  256. }
  257. }
  258. BOOL CarmImplPositionManager::IsSystemReady(const std::string &componentName)
  259. {
  260. BOOL bSysReady = FALSE;
  261. if (componentName == CONTROLLER_CARM_TUBE_SWING)
  262. {
  263. bSysReady = m_isSystemReadySwing;
  264. }
  265. else if (componentName == CONTROLLER_CARM_TUBE_CIRCULAR)
  266. {
  267. bSysReady = m_isSystemReadyCircular;
  268. }
  269. return bSysReady;
  270. }
  271. void CarmImplPositionManager::NotifySystemIsReady(const std::string &componentName)
  272. {
  273. BOOL bSysReady = FALSE;
  274. if (componentName == CONTROLLER_CARM_TUBE_SWING)
  275. {
  276. m_isSystemReadySwing = TRUE;
  277. bSysReady = m_isSystemReadySwing;
  278. }
  279. else if (componentName == CONTROLLER_CARM_TUBE_CIRCULAR)
  280. {
  281. m_isSystemReadyCircular = TRUE;
  282. bSysReady = m_isSystemReadyCircular;
  283. }
  284. if (m_notifyLogicDriver)
  285. {
  286. ResDataObject NotifyData;
  287. ResDataObject tmp;
  288. tmp.add("Systemready", (bool)bSysReady);
  289. PacketAnalizer::MakeNotify(NotifyData, PACKET_CMD_UPDATE, NOTIFY_KEY_SYSTEM_READY.c_str(), (const char *)tmp["Systemready"]);
  290. m_notifyLogicDriver->FireNotify("Systemready", std::to_string(bSysReady));
  291. }
  292. }