SchedulerAligner.cs 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Diagnostics;
  4. using System.Linq;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. using Aitex.Core.RT.Fsm;
  8. using Aitex.Core.RT.SCCore;
  9. using Aitex.Core.Util;
  10. using Aitex.Sorter.Common;
  11. using MECF.Framework.Common.Equipment;
  12. using MECF.Framework.Common.Schedulers;
  13. using MECF.Framework.Common.SubstrateTrackings;
  14. using VirgoRT.Scheduler;
  15. namespace VirgoRT.Modules.Schedulers
  16. {
  17. public class SchedulerAligner : SchedulerModule
  18. {
  19. public override bool IsAvailable
  20. {
  21. get { return /*_entity.IsIdle &&*//* _entity.IsOnline && */CheckTaskDone(); }
  22. }
  23. public override bool IsOnline
  24. {
  25. get { return _efemEntity.IsOnline; }
  26. }
  27. public override bool IsError
  28. {
  29. get { return _efemEntity.IsError; }
  30. }
  31. private EfemEntity _efemEntity = null;
  32. private bool _isCooling;
  33. private DeviceTimer _timerCooling = new DeviceTimer();
  34. private float _paramCoolingTime = 0;
  35. //private int _token;
  36. private int _coolingDelayTime;
  37. private Stopwatch _timerDelay = new Stopwatch();
  38. private DeviceTimer _timerAligning = new DeviceTimer();
  39. private float _paramAligningTime = 0;
  40. public SchedulerAligner(ModuleName chamber) : base(chamber.ToString())
  41. {
  42. _efemEntity = Singleton<RouteManager>.Instance.EFEM;
  43. _isCooling = chamber == ModuleName.Cooling1 || chamber == ModuleName.Cooling2;
  44. }
  45. public override bool IsReadyForPick(ModuleName robot, int slot, Hand blade)
  46. {
  47. return WaferManager.Instance.CheckHasWafer(ModuleHelper.Converter(_module), slot);
  48. }
  49. public override bool IsReadyForPlace(ModuleName robot, int slot, Hand blade)
  50. {
  51. return WaferManager.Instance.CheckNoWafer(ModuleHelper.Converter(_module), slot);
  52. }
  53. public override bool Cooling(int time)
  54. {
  55. _task = TaskType.Cooling;
  56. LogTaskStart(_task, $"Cooling {time} seconds" );
  57. _coolingDelayTime = SC.GetValue<int>("EFEM.DelayTimeBeforeLiftDown");
  58. _paramCoolingTime = time ;
  59. _timerDelay.Restart();
  60. //_token = _efemEntity.InvokeCooling(Module.ToString(), time);
  61. return true;//_token != (int)FSM_MSG.NONE;
  62. }
  63. public bool Monitor()
  64. {
  65. return true;
  66. }
  67. public bool Align(float time)
  68. {
  69. _task = TaskType.Align;
  70. LogTaskStart(_task, "Aligning");
  71. _paramAligningTime = time;
  72. _timerAligning.Start(_paramAligningTime * 1000);
  73. _timerDelay.Restart();
  74. Singleton<RouteManager>.Instance.EFEM.EfemDevice.SetPinDown(Module);
  75. //token = _entity.InvokeAlign(Module.ToString(), time);
  76. return true;// _token != (int)FSM_MSG.NONE;
  77. }
  78. public override bool PostTransfer(ModuleName robot, EnumTransferType type, int slot)
  79. {
  80. StopWaitTransfer(robot);
  81. if (type == EnumTransferType.Place)
  82. {
  83. _task = TaskType.Align;
  84. LogTaskStart(_task, $"Waiting {_paramAligningTime} seconds");
  85. _timerAligning.Start(_paramAligningTime * 1000);
  86. }
  87. return true;
  88. }
  89. public override bool PostTransfer(ModuleName robot)
  90. {
  91. StopWaitTransfer(robot);
  92. return true;
  93. }
  94. public bool CheckTaskDone()
  95. {
  96. bool ret = false;
  97. switch (_task)
  98. {
  99. case TaskType.None:
  100. ret = true;
  101. break;
  102. case TaskType.Align:
  103. if (_timerDelay.IsRunning && _timerDelay.ElapsedMilliseconds > 1 * 1000)
  104. {
  105. _timerDelay.Stop();
  106. }
  107. ret = !_timerDelay.IsRunning && _timerAligning.IsTimeout() && /* _entity.CheckAcked(_token) &&*/ _efemEntity.IsIdle && !_efemEntity.EfemDevice.IsBufferPinUp[Module];
  108. break;
  109. case TaskType.Cooling:
  110. if (_timerDelay.IsRunning && _timerDelay.ElapsedMilliseconds > _coolingDelayTime*1000)
  111. {
  112. _timerDelay.Stop();
  113. //_efemEntity.InvokeLiftDown(Module.ToString());
  114. Singleton<RouteManager>.Instance.EFEM.SetLiftDown(Module);
  115. //lift pin down time = 2seconds
  116. _timerCooling.Start(_paramCoolingTime * 1000 + 2*1000);
  117. break;
  118. }
  119. ret = !_timerDelay.IsRunning && _timerCooling.IsTimeout() && _efemEntity.IsIdle;
  120. break;
  121. }
  122. if (ret && _task != TaskType.None)
  123. {
  124. LogTaskDone(_task, "");
  125. _task = TaskType.None;
  126. }
  127. return ret;
  128. }
  129. }
  130. }