SchedulerAligner.cs 5.4 KB

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