PrewetKeepWetStateMachine.cs 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  1. using Aitex.Core.RT.Device;
  2. using Aitex.Core.RT.Fsm;
  3. using Aitex.Core.RT.Log;
  4. using Aitex.Core.Utilities;
  5. using CyberX8_Core;
  6. using CyberX8_RT.Devices.LinMot;
  7. using CyberX8_RT.Devices.Prewet;
  8. using System;
  9. using System.Collections.Generic;
  10. using System.Linq;
  11. using System.Text;
  12. using System.Threading.Tasks;
  13. using System.Windows.Markup;
  14. namespace CyberX8_RT.Modules.Prewet
  15. {
  16. public class PrewetKeepWetStateMachine : Entity, IEntity
  17. {
  18. #region 内部变量
  19. /// <summary>
  20. /// 模块名称
  21. /// </summary>
  22. private string _module;
  23. /// <summary>
  24. /// prewet设备
  25. /// </summary>
  26. private PrewetDevice _prewetDevice;
  27. /// <summary>
  28. /// linmot axis
  29. /// </summary>
  30. private LinMotAxis _linMotAxis;
  31. #endregion
  32. #region 属性
  33. /// <summary>
  34. /// 状态
  35. /// </summary>
  36. public string State { get { return ((PrewetKeepWetState)fsm.State).ToString(); } }
  37. #endregion
  38. /// <summary>
  39. /// 构造函数
  40. /// </summary>
  41. /// <param name="module"></param>
  42. public PrewetKeepWetStateMachine(string module,LinMotAxis linMotAxis)
  43. {
  44. _module = module;
  45. _prewetDevice = DEVICE.GetDevice<PrewetDevice>(module);
  46. _linMotAxis = linMotAxis;
  47. fsm = new StateMachine($"{_module}_KeepWetStateMachine", (int)PrewetKeepWetState.Idle, 20);
  48. fsm.EnableRepeatedMsg(true);
  49. AnyStateTransition(PrewetKeepWetMsg.ReturnIdle, NullFunc, PrewetKeepWetState.Idle);
  50. AnyStateTransition(PrewetKeepWetMsg.Error, EnterError, PrewetKeepWetState.Error);
  51. Transition(PrewetKeepWetState.Error, PrewetKeepWetMsg.KeepWetStart, NullFunc, PrewetKeepWetState.Idle_KeepwetPrepare);
  52. Transition(PrewetKeepWetState.Idle, PrewetKeepWetMsg.KeepWetStart, NullFunc, PrewetKeepWetState.Idle_KeepwetPrepare);
  53. Transition(PrewetKeepWetState.Idle_KeepwetPrepare, FSM_MSG.TIMER, ResetLinmot, CheckResetLinmot, PrewetKeepWetState.Idle_KeepWetStart);
  54. Transition(PrewetKeepWetState.Idle_KeepWetStart, FSM_MSG.TIMER, ExecuteWetScan, WaitExecuteWetScan, PrewetKeepWetState.Idle_KeepWetScan);
  55. Transition(PrewetKeepWetState.Idle_KeepWetScan, FSM_MSG.TIMER, KeepWetComplete, PrewetKeepWetState.Idle_KeepWetPause);
  56. Transition(PrewetKeepWetState.Idle_KeepWetPause, FSM_MSG.TIMER, NullFunc, PrewetKeepWetState.Idle);
  57. EnumLoop<PrewetKeepWetState>.ForEach((item) => { fsm.MapState((int)item, item.ToString()); });
  58. EnumLoop<PrewetKeepWetMsg>.ForEach((item) => { fsm.MapMessage((int)item, item.ToString()); });
  59. }
  60. /// <summary>
  61. /// 初始化
  62. /// </summary>
  63. protected override bool Init()
  64. {
  65. fsm.Init((int)PrewetKeepWetState.Idle, 20);
  66. return true;
  67. }
  68. /// <summary>
  69. /// 进入Error状态
  70. /// </summary>
  71. /// <param name="param"></param>
  72. /// <returns></returns>
  73. private bool EnterError(object param)
  74. {
  75. if(_linMotAxis.Status==RState.Running)
  76. {
  77. _linMotAxis.AbortCurrentRoutine();
  78. }
  79. if(_prewetDevice.Status==RState.Running)
  80. {
  81. _prewetDevice.AbortCurrentRoutine();
  82. }
  83. return true;
  84. }
  85. #region process
  86. /// <summary>
  87. /// Reset Linmot
  88. /// </summary>
  89. /// <param name="param"></param>
  90. /// <returns></returns>
  91. private bool ResetLinmot(object param)
  92. {
  93. bool result = _linMotAxis.ResetOperation("", false);
  94. if (!result)
  95. {
  96. PostMsg(PrewetKeepWetMsg.Error);
  97. return false;
  98. }
  99. return true;
  100. }
  101. /// <summary>
  102. /// 检验Reset Linmot状态
  103. /// </summary>
  104. /// <param name="param"></param>
  105. /// <returns></returns>
  106. private bool CheckResetLinmot(object param)
  107. {
  108. if (_linMotAxis.Status == RState.End)
  109. {
  110. return true;
  111. }
  112. else if(_linMotAxis.Status==RState.Failed)
  113. {
  114. PostMsg(PrewetKeepWetMsg.Error);
  115. return false;
  116. }
  117. return false;
  118. }
  119. /// <summary>
  120. /// execute Keep Wet Scan
  121. /// </summary>
  122. /// <param name="param"></param>
  123. /// <returns></returns>
  124. private bool ExecuteWetScan(object param)
  125. {
  126. bool pumpValveResult = _prewetDevice.PumpValveOpen();
  127. if (!pumpValveResult)
  128. {
  129. LOG.WriteLog(eEvent.ERR_PREWET, _module, "pump valve open error");
  130. PostMsg(PrewetKeepWetMsg.Error);
  131. return false;
  132. }
  133. //bool pumpEnableResult = _prewetDevice.PumpEnableOperation("", null);
  134. bool pumpEnableResult = _prewetDevice.PumpEnable();
  135. if (!pumpEnableResult)
  136. {
  137. LOG.WriteLog(eEvent.ERR_PREWET, _module, "pump enable error");
  138. PostMsg(PrewetKeepWetMsg.Error);
  139. return false;
  140. }
  141. bool result = _linMotAxis.StartPosition("", new object[] { 1 });
  142. if (!result)
  143. {
  144. PostMsg(PrewetKeepWetMsg.Error);
  145. return false;
  146. }
  147. return true;
  148. }
  149. /// <summary>
  150. /// Wait execute WetScan
  151. /// </summary>
  152. /// <param name="param"></param>
  153. /// <returns></returns>
  154. private bool WaitExecuteWetScan(object param)
  155. {
  156. if (_prewetDevice.PrewetPumpData.PumpFlowData.IsWarning)
  157. {
  158. LOG.WriteLog(eEvent.WARN_PREWET, _module, "pump flow status is in warning");
  159. }
  160. if (_prewetDevice.PrewetPumpData.PumpFlowData.IsError)
  161. {
  162. LOG.WriteLog(eEvent.ERR_PREWET, _module, "pump flow status is in error");
  163. PostMsg(PrewetKeepWetMsg.Error);
  164. return false;
  165. }
  166. if (_prewetDevice.PrewetPumpData.PumpPressureData.IsWarning)
  167. {
  168. LOG.WriteLog(eEvent.WARN_PREWET, _module, "pump pressure status is in warning");
  169. }
  170. if (_prewetDevice.PrewetPumpData.PumpPressureData.IsError)
  171. {
  172. LOG.WriteLog(eEvent.ERR_PREWET, _module, "pump pressure status is in error");
  173. PostMsg(PrewetKeepWetMsg.Error);
  174. return false;
  175. }
  176. //linmot完成一次scan
  177. if ( _linMotAxis.Status == RState.End)
  178. {
  179. return true;
  180. }
  181. return false;
  182. }
  183. /// <summary>
  184. /// Keep wet scan完成
  185. /// </summary>
  186. /// <param name="param"></param>
  187. /// <returns></returns>
  188. private bool KeepWetComplete(object param)
  189. {
  190. bool result = _prewetDevice.PumpDisableOperation("pump disable",null);
  191. if (!result)
  192. {
  193. LOG.WriteLog(eEvent.ERR_PREWET, _module, "pump disable error");
  194. PostMsg(PrewetKeepWetMsg.Error);
  195. return false;
  196. }
  197. result = _linMotAxis.SwitchOff();
  198. if (!result)
  199. {
  200. LOG.WriteLog(eEvent.ERR_PREWET, _module, "linmot disable error");
  201. PostMsg(PrewetKeepWetMsg.Error);
  202. return false;
  203. }
  204. return true;
  205. }
  206. #endregion
  207. public bool Check(int msg, out string reason, params object[] args)
  208. {
  209. reason = "";
  210. return true;
  211. }
  212. public enum PrewetKeepWetState
  213. {
  214. Error,
  215. Idle,
  216. Idle_KeepwetPrepare,
  217. Idle_KeepWetStart,
  218. Idle_KeepWetScan,
  219. Idle_KeepWetPause
  220. }
  221. public enum PrewetKeepWetMsg
  222. {
  223. Error,
  224. KeepWetStart,
  225. ReturnIdle
  226. }
  227. }
  228. }