MFLeakCheckRoutine.cs 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  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 MECF.Framework.Common.DBCore;
  8. using System;
  9. namespace Venus_RT.Modules.TM
  10. {
  11. class MFLeakCheckRoutine : ModuleRoutineBase, IRoutine
  12. {
  13. private enum LeakCheckStep
  14. {
  15. kCloseValves,
  16. kPumpToCrossing,
  17. kPumpToBasePressure,
  18. kPumpingDelay,
  19. kLeakCheckDelay,
  20. kLeakCheckCalc,
  21. kPumpToCrossing_2,
  22. kPumpToBasePressure_2,
  23. kEnd,
  24. }
  25. public double LeakRate { get; private set; }
  26. private double _basePressure = 100;
  27. private double _CrossingPressure = 2000;
  28. private int _leakcheckPumpTime = 180;
  29. private int _leakcheckWaitTime = 300;
  30. private double _startPressure = 0;
  31. private double _endPressure = 0;
  32. private double _leakRate = 30.0;
  33. private readonly JetTM _JetTM;
  34. //public string CurrentStep;
  35. private string _result;
  36. PressureType _pressureType = PressureType.mTorr;
  37. public MFLeakCheckRoutine(JetTM tm, ModuleName mod) : base(mod)
  38. {
  39. Name = $"{Module} Leakcheck";
  40. _JetTM = tm;
  41. //if (RtInstance.pressureType == PressureType.Pa)
  42. //{
  43. // _pressureType=PressureType.Pa;
  44. //}
  45. }
  46. public RState Start(params object[] objs)
  47. {
  48. if (_JetTM.CheckLidClosed(Module) &&
  49. _JetTM.CheckVentValveClosed(Module) &&
  50. _JetTM.CheckPurgeValveClosed(Module) &&
  51. _JetTM.CheckPumpValveClosed(Module))
  52. {
  53. Reset();
  54. _JetTM.CloseModuleAllValves(Module);
  55. _basePressure = SC.GetValue<double>($"{Module}.PumpBasePressure");
  56. _CrossingPressure = SC.GetValue<double>($"{Module}.PumpCrossingPressure");
  57. _leakcheckPumpTime = SC.GetValue<int>($"{Module}.LeakCheckPumpTime");
  58. _leakcheckWaitTime = SC.GetValue<int>($"{Module}.LeakCheckWaitTime");
  59. _leakRate = SC.GetValue<double>($"{Module}.LeakRate");
  60. _result = "";
  61. return Runner.Start(Module, Name);
  62. }
  63. return RState.Failed;
  64. }
  65. public RState Monitor()
  66. {
  67. Runner.Delay(LeakCheckStep.kCloseValves, _delay_1s)
  68. .Run(LeakCheckStep.kPumpToCrossing, HOFs.WrapAction(_JetTM.TurnSoftPumpValve, Module, true), () => { return _JetTM.GetModulePressure(Module) <= _CrossingPressure; })
  69. .Run(LeakCheckStep.kPumpToBasePressure, SwitchFastPump, () => { return _JetTM.GetModulePressure(Module) <= _basePressure; })
  70. .Delay(LeakCheckStep.kPumpingDelay, _leakcheckPumpTime * 1000)
  71. .Run(LeakCheckStep.kLeakCheckDelay, StartLeakCheck, _leakcheckWaitTime * 1000)
  72. .Run(LeakCheckStep.kLeakCheckCalc, CalcLeakCheckResult, _delay_50ms)
  73. .Run(LeakCheckStep.kPumpToCrossing_2, HOFs.WrapAction(_JetTM.TurnSoftPumpValve, Module, true), () => { return _JetTM.GetModulePressure(Module) <= _CrossingPressure; })
  74. .Run(LeakCheckStep.kPumpToBasePressure_2, SwitchFastPump, () => { return _JetTM.GetModulePressure(Module) <= _basePressure; })
  75. .End(LeakCheckStep.kEnd, LeakCheckEnd, _delay_50ms);
  76. return Runner.Status;
  77. }
  78. public void Abort()
  79. {
  80. _JetTM.CloseModuleAllValves(Module);
  81. }
  82. bool StartLeakCheck()
  83. {
  84. _JetTM.TurnFastPumpValve(Module, false);
  85. _startPressure = _JetTM.GetModulePressure(Module);
  86. Notify($"{Module} 压力开始值 {_startPressure} {_pressureType}");
  87. return true;
  88. }
  89. bool CalcLeakCheckResult()
  90. {
  91. _endPressure = _JetTM.GetModulePressure(Module);
  92. LeakRate = (_endPressure - _startPressure) * 60.0 / _leakcheckWaitTime;
  93. if (LeakRate < _leakRate)
  94. {
  95. Notify($"{Module} Leakcheck完成, 压力结束值: {_startPressure}{_pressureType}, 漏率:{LeakRate} {_pressureType}/min");
  96. _result = "Success";
  97. }
  98. else
  99. {
  100. Stop($"{Module} Leakcheck失败, 腔体漏率 [{LeakRate}] {_pressureType}/min, 高于 [{_leakRate}] {_pressureType}/min");
  101. _result = "Fail";
  102. }
  103. return true;
  104. }
  105. bool LeakCheckEnd()
  106. {
  107. _JetTM.CloseModuleAllValves(Module);
  108. LeakCheckDataRecorder.Add(_leakcheckPumpTime, Math.Round(_startPressure, 1), Math.Round(_endPressure, 1), LeakRate, _result, "", Module.ToString(), "");
  109. return true;
  110. }
  111. private bool SwitchFastPump()
  112. {
  113. _JetTM.TurnSoftPumpValve(Module, false);
  114. _JetTM.TurnFastPumpValve(Module, true);
  115. return true;
  116. }
  117. }
  118. }