MFPumpRoutine.cs 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. using Aitex.Core.RT.Routine;
  2. using Aitex.Core.RT.SCCore;
  3. using Venus_RT.Devices;
  4. using MECF.Framework.Common.Routine;
  5. using MECF.Framework.Common.Equipment;
  6. using Venus_Core;
  7. using System.Threading;
  8. namespace Venus_RT.Modules.TM
  9. {
  10. class MFPumpRoutine : ModuleRoutineBase, IRoutine
  11. {
  12. private enum PumpStep
  13. {
  14. kWaitPeerModule,
  15. kSoftPump,
  16. kFastPump,
  17. kClosePumpValves,
  18. kDelayForSwitchPump,
  19. kSwitchLLPump
  20. }
  21. private double _pumpBasePressure;
  22. private double _pumpCrossingPressure;
  23. private int _pumpingTimeout;
  24. private int _switchLLPumpDelay;
  25. private readonly JetTM _JetTM;
  26. public MFPumpRoutine(JetTM jetTM, ModuleName mod) : base(mod)
  27. {
  28. _JetTM = jetTM;
  29. Name = "Pump Down";
  30. }
  31. public RState Start(params object[] objs)
  32. {
  33. if (_JetTM.CheckLidClosed(Module) &&
  34. _JetTM.CheckVentValveClosed(Module) &&
  35. _JetTM.CheckPurgeValveClosed(Module))
  36. {
  37. Reset();
  38. _pumpBasePressure = SC.GetValue<double>($"{Module}.PumpBasePressure");
  39. _pumpCrossingPressure = SC.GetValue<double>($"{Module}.PumpCrossingPressure");
  40. _pumpingTimeout = SC.GetValue<int>($"{Module}.PumpingTimeout") * 1000;
  41. if (Module == ModuleName.LLA || Module == ModuleName.LLB)
  42. _switchLLPumpDelay = SC.GetValue<int>($"{Module}.SwitchLLPumpDelay");
  43. else
  44. _switchLLPumpDelay = 0;
  45. return Runner.Start(Module, Name);
  46. }
  47. return RState.Failed;
  48. }
  49. public RState Monitor()
  50. {
  51. Runner.Wait(PumpStep.kWaitPeerModule, WaitPeerModule, _delay_60s)
  52. .Run(PumpStep.kSoftPump, OpenSoftPump, () => { return _JetTM.GetModulePressure(Module) < _pumpCrossingPressure; }, _pumpingTimeout)
  53. .Run(PumpStep.kFastPump, SwitchFastPump, IsPressureReady, _pumpingTimeout)
  54. .Run(PumpStep.kClosePumpValves, ClosePumpValves, NullFun)
  55. .Delay(PumpStep.kDelayForSwitchPump, _switchLLPumpDelay)
  56. .End(PumpStep.kSwitchLLPump, ReleaseLLPump, NullFun);
  57. return Runner.Status;
  58. }
  59. private bool WaitPeerModule()
  60. {
  61. if (!IsPressureReady() && IsLLModule())
  62. {
  63. return _JetTM.TryGetLLPump(Module);
  64. }
  65. return true;
  66. }
  67. private bool IsLLModule()
  68. {
  69. return Module == ModuleName.LLA || Module == ModuleName.LLB;
  70. }
  71. private bool IsPressureReady()
  72. {
  73. return _JetTM.GetModulePressure(Module) < _pumpBasePressure;
  74. }
  75. private bool OpenSoftPump()
  76. {
  77. if (!IsPressureReady())
  78. {
  79. _JetTM.TurnSoftPumpValve(Module, true);
  80. }
  81. return true;
  82. }
  83. private bool SwitchFastPump()
  84. {
  85. if (_JetTM.GetModulePressure(Module) > (_pumpBasePressure-5))
  86. {
  87. _JetTM.TurnSoftPumpValve(Module, false);
  88. _JetTM.TurnFastPumpValve(Module, true);
  89. }
  90. return true;
  91. }
  92. private bool ClosePumpValves()
  93. {
  94. _JetTM.TurnSoftPumpValve(Module, false);
  95. _JetTM.TurnFastPumpValve(Module, false);
  96. return true;
  97. }
  98. private bool ReleaseLLPump()
  99. {
  100. if (Module == ModuleName.LLA || Module == ModuleName.LLB)
  101. _JetTM.ReleasePump(Module);
  102. return true;
  103. }
  104. public void Abort()
  105. {
  106. ClosePumpValves();
  107. }
  108. }
  109. }