BoatZAxisMoveCycleTest.cs 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236
  1. using Aitex.Core.RT.Device;
  2. using Aitex.Core.RT.Device.Unit;
  3. using Aitex.Core.RT.Event;
  4. using Aitex.Core.RT.Routine;
  5. using Aitex.Core.RT.SCCore;
  6. using Aitex.Core.Util;
  7. using Aitex.Sorter.Common;
  8. using MECF.Framework.Common.Alarms;
  9. using MECF.Framework.Common.Device.Bases;
  10. using MECF.Framework.Common.Equipment;
  11. using MECF.Framework.Common.SubstrateTrackings;
  12. using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.Robot;
  13. using System;
  14. using System.Collections.Generic;
  15. using System.Linq;
  16. using System.Text;
  17. using System.Threading.Tasks;
  18. using FurnaceRT.Equipments.Systems;
  19. using static Aitex.Core.RT.Device.Unit.IoBoat;
  20. using System.Diagnostics;
  21. using FurnaceRT.Devices;
  22. namespace FurnaceRT.Equipments.Boats
  23. {
  24. public class BoatZAxisMoveCycleTest : ModuleRoutine, IRoutine
  25. {
  26. enum RoutineStep
  27. {
  28. SetBoatSpeed,
  29. AutoShutterOpen,
  30. CheckPrepareMove,
  31. MoveToStart,
  32. MoveToEnd,
  33. Loop,
  34. EndLoop,
  35. Delay1,
  36. Delay2,
  37. Delay3,
  38. }
  39. private float _speed;
  40. private float _interval;
  41. private BoatModule _boatModule;
  42. private int _timeout = 0;
  43. private int _shutterTimeout = 0;
  44. private BoatPosition _positionStart;
  45. private BoatPosition _positionEnd;
  46. private int _count;
  47. public BoatZAxisMoveCycleTest(BoatModule boatModule)
  48. {
  49. _boatModule = boatModule;
  50. Module = boatModule.Module;
  51. Name = "ZAxisMoveTest";
  52. }
  53. public void Init(string positionStart = "HomePosition", string positionEnd = "CapPosition")
  54. {
  55. _positionStart = (BoatPosition)Enum.Parse(typeof(BoatPosition), positionStart);
  56. _positionEnd = (BoatPosition)Enum.Parse(typeof(BoatPosition), positionEnd);
  57. }
  58. public Result Start(params object[] objs)
  59. {
  60. Reset();
  61. _timeout = SC.GetValue<int>($"Boat.BoatElevatorServo.MotionTimeout");
  62. _count = SC.GetValue<int>($"Boat.BoatElevatorServo.CycleCount");
  63. _speed = (float)SC.GetValue<double>($"Boat.BoatElevatorServo.MoveSpeed");
  64. _interval = (float)SC.GetValue<double>($"Boat.BoatElevatorServo.IntervalTime");
  65. _shutterTimeout = SC.GetValue<int>($"{Module}.AutoShutter.MotionTimeout");
  66. string reason = string.Empty;
  67. if (!_boatModule.CheckPrepareMove(out reason, false))
  68. {
  69. _boatModule.BoatZAxisMoveFailedForInterlock.Set(reason);
  70. return Result.FAIL;
  71. }
  72. Notify($"Start");
  73. return Result.RUN;
  74. }
  75. public void Abort()
  76. {
  77. _boatModule.ZAxisDevice.ServoStop();
  78. }
  79. public override Result Monitor()
  80. {
  81. try
  82. {
  83. PauseRountine(_boatModule.RAxisDevice.IsPause);
  84. if (_boatModule.RAxisDevice.IsPause)
  85. return Result.RUN;
  86. if (_boatModule.ZAxisDevice.IsError)
  87. return Result.FAIL;
  88. AutoShutterOpen((int)RoutineStep.AutoShutterOpen, true, _shutterTimeout);
  89. Loop((int)RoutineStep.Loop, _count);
  90. CheckPrepareMove((int)RoutineStep.CheckPrepareMove, 2);
  91. SetBoatZAxisMove((int)RoutineStep.MoveToStart, _positionStart, (int)_timeout);
  92. Delay((int)RoutineStep.Delay1, 2);
  93. Delay((int)RoutineStep.Delay2, _interval);
  94. SetBoatZAxisMove((int)RoutineStep.MoveToEnd, _positionEnd, (int)_timeout);
  95. Delay((int)RoutineStep.Delay3, _interval);
  96. EndLoop((int)RoutineStep.EndLoop);
  97. }
  98. catch (RoutineBreakException)
  99. {
  100. return Result.RUN;
  101. }
  102. catch (RoutineFaildException ex)
  103. {
  104. return Result.FAIL;
  105. }
  106. Notify("Finished");
  107. return Result.DONE;
  108. }
  109. private void AutoShutterOpen(int id, bool isOpen, int timeout)
  110. {
  111. Tuple<bool, Result> ret = ExecuteAndWait(id, () =>
  112. {
  113. Notify($"shutter {(isOpen ? "open" : "close")}");
  114. string reason;
  115. if (!_boatModule.ShutterDevice.SetOpen(isOpen, out reason))
  116. {
  117. _boatModule.ShutterDevice.AutoShutterMoveFailedForInterlock.Set();
  118. return false;
  119. }
  120. return true;
  121. }, () =>
  122. {
  123. return isOpen ? _boatModule.ShutterDevice.OpenCloseStatus == DeviceStatus.Open : _boatModule.ShutterDevice.OpenCloseStatus == DeviceStatus.Close;
  124. }, timeout * 1000);
  125. if (ret.Item1)
  126. {
  127. if (ret.Item2 == Result.FAIL)
  128. {
  129. throw (new RoutineFaildException());
  130. }
  131. else if (ret.Item2 == Result.TIMEOUT) //timeout
  132. {
  133. if (isOpen)
  134. {
  135. _boatModule.ShutterDevice.AutoShutterOpenTimeOut.Set($"can not complete in {timeout} seconds");
  136. }
  137. else
  138. {
  139. _boatModule.ShutterDevice.AutoShutterCloseTimeOut.Set($"can not complete in {timeout} seconds");
  140. }
  141. throw (new RoutineFaildException());
  142. }
  143. else
  144. throw (new RoutineBreakException());
  145. }
  146. }
  147. private void CheckPrepareMove(int id, int timeout)
  148. {
  149. var reason = "";
  150. Tuple<bool, Result> ret = ExecuteAndWait(id, () =>
  151. {
  152. Notify($"Check boat move enable");
  153. return true;
  154. }, () =>
  155. {
  156. return _boatModule.CheckPrepareMove(out reason);
  157. }, timeout * 2 * 1000);
  158. if (ret.Item1)
  159. {
  160. if (ret.Item2 == Result.FAIL)
  161. {
  162. throw (new RoutineFaildException());
  163. }
  164. else if (ret.Item2 == Result.TIMEOUT) //timeout
  165. {
  166. _boatModule.BoatZAxisMoveFailedForInterlock.Set($"{reason} is not OK, can not complete in {timeout} seconds");
  167. throw (new RoutineFaildException());
  168. }
  169. else
  170. throw (new RoutineBreakException());
  171. }
  172. }
  173. private void SetBoatZAxisMove(int id, BoatPosition position, int timeout)
  174. {
  175. Tuple<bool, Result> ret = ExecuteAndWait(id, () =>
  176. {
  177. Notify($"Boat ZAxis movet to {position}");
  178. string reason;
  179. if (!_boatModule.ZAxisDevice.SetServoMoveTo(position.ToString(), out reason))
  180. {
  181. //_boatModule.BoatDevice.BoatRAxisMoveFailedForInterlock.Description = reason;
  182. _boatModule.BoatZAxisMoveFailedForInterlock.Set(reason);
  183. }
  184. return true;
  185. }, () =>
  186. {
  187. if (_boatModule.ZAxisDevice.IsError)
  188. return null;
  189. return _boatModule.ZAxisDevice.CheckServoAtPosition(position.ToString());
  190. }, timeout * 2 * 1000);
  191. if (ret.Item1)
  192. {
  193. if (ret.Item2 == Result.FAIL)
  194. {
  195. _boatModule.ZAxisDevice.ServoStop();
  196. throw (new RoutineFaildException());
  197. }
  198. else if (ret.Item2 == Result.TIMEOUT) //timeout
  199. {
  200. _boatModule.ZAxisDevice.ServoStop();
  201. _boatModule.BoatZAxisMoveTimeOut.Set($"can not complete in {timeout} seconds");
  202. throw (new RoutineFaildException());
  203. }
  204. else
  205. throw (new RoutineBreakException());
  206. }
  207. }
  208. }
  209. }