RFPowerSwitchRoutine.cs 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  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 Venus_Core;
  6. using Aitex.Core.Common.DeviceData;
  7. using System;
  8. namespace Venus_RT.Modules.PMs
  9. {
  10. class RFPowerSwitchRoutine : PMRoutineBase, IRoutine
  11. {
  12. enum RFPowerStep
  13. {
  14. kSetPower,
  15. kEnd,
  16. }
  17. private bool _bOn = true;
  18. private bool _enableBias;
  19. private double _rfPower;
  20. private double _rfPowerBias;
  21. private BiasRfMatchMode _matchMode;
  22. private double _matchC1;
  23. private double _matchC2;
  24. private int _rfPowerOnTime;
  25. public RFPowerSwitchRoutine(JetPM chamber, bool bOn) : base(chamber)
  26. {
  27. Name = "RF Power Switch";
  28. _bOn = bOn;
  29. }
  30. public RState Start(params object[] objs)
  31. {
  32. if (!_chamber.IsFastPumpOpened)
  33. {
  34. Stop("Pump 阀没有打开");
  35. return RState.Failed;
  36. }
  37. _enableBias = SC.GetValue<bool>($"{_chamber.Module}.BiasRf.EnableBiasRF");
  38. if (_bOn)
  39. {
  40. if (objs == null || objs.Length < 3)
  41. {
  42. Stop("RF routine argument error");
  43. return RState.Failed;
  44. }
  45. _rfPower = Convert.ToDouble(objs[0]);
  46. _rfPowerBias = Convert.ToDouble(objs[1]);
  47. _rfPowerOnTime = (int)Convert.ToDouble(objs[2]) * 1000;
  48. _matchMode = Convert.ToInt32(objs[3]) == 1 ? BiasRfMatchMode.Preset : BiasRfMatchMode.Hold;
  49. _matchC1 = Convert.ToDouble(objs[4]);
  50. _matchC2 = Convert.ToDouble(objs[5]);
  51. }
  52. else
  53. {
  54. _rfPower = 0.0;
  55. _rfPowerBias = 0.0;
  56. _matchMode = BiasRfMatchMode.Preset;
  57. _matchC1 = 0.0;
  58. _matchC2 = 0.0;
  59. _rfPowerOnTime = 2000;
  60. }
  61. return Runner.Start(Module, Name);
  62. }
  63. public RState Monitor()
  64. {
  65. Runner.Run((int)RFPowerStep.kSetPower, SetRFPower, _rfPowerOnTime)
  66. .End((int)RFPowerStep.kEnd, RFPowerFinished, _delay_1s);
  67. return Runner.Status;
  68. }
  69. private bool SetRFPower()
  70. {
  71. if(_bOn)
  72. {
  73. if (_enableBias)
  74. Notify($"放电开始, 源射频设定值 {_rfPower}, 偏压射频设定值 {_rfPowerBias}");
  75. else
  76. Notify($"放电开始, 源射频设定值 {_rfPower}");
  77. if (Math.Abs(_rfPower) > 0.01 && Math.Abs(_rfPowerBias) > 0.01)
  78. {
  79. _chamber.GeneratorSetpower((float)_rfPower);
  80. _chamber.GeneratorBiasSetpower((float)_rfPowerBias);
  81. if (_matchMode == BiasRfMatchMode.Preset)
  82. {
  83. _chamber.GeneratorBiasSetMatchMode(true);
  84. Notify($"Bias RF Match C1设定值 {_matchC1}, Bias RF Match C2设定值 {_matchC2}");
  85. _chamber.SetBiasMatchPosition((float)_matchC1, (float)_matchC2);
  86. }
  87. else if (_matchMode == BiasRfMatchMode.Hold)
  88. {
  89. _chamber.GeneratorBiasSetMatchMode(false);
  90. }
  91. return _chamber.GeneratorPowerOn(true) && _chamber.GeneratorBiasPowerOn(true);
  92. }
  93. else if (Math.Abs(_rfPower) < 0.01 && Math.Abs(_rfPowerBias) > 0.01)
  94. {
  95. if (_matchMode == BiasRfMatchMode.Preset)
  96. {
  97. _chamber.GeneratorBiasSetMatchMode(true);
  98. Notify($"Bias RF Match C1设定值 {_matchC1}, Bias RF Match C2设定值 {_matchC2}");
  99. _chamber.SetBiasMatchPosition((float)_matchC1, (float)_matchC2);
  100. }
  101. else if (_matchMode == BiasRfMatchMode.Hold)
  102. {
  103. _chamber.GeneratorBiasSetMatchMode(false);
  104. }
  105. _chamber.GeneratorBiasSetpower((float)_rfPowerBias);
  106. return _chamber.GeneratorBiasPowerOn(true);
  107. }
  108. else if (Math.Abs(_rfPower) > 0.01 && Math.Abs(_rfPowerBias) < 0.01)
  109. {
  110. _chamber.GeneratorSetpower((float)_rfPower);
  111. return _chamber.GeneratorPowerOn(true);
  112. }
  113. else
  114. {
  115. Notify("放电结束");
  116. return false;
  117. }
  118. }
  119. else
  120. {
  121. Notify("放电停止");
  122. if (!_enableBias)
  123. return _chamber.GeneratorPowerOn(false);
  124. return _chamber.GeneratorPowerOn(false) && _chamber.GeneratorBiasPowerOn(false);
  125. }
  126. }
  127. private bool RFPowerFinished()
  128. {
  129. if(_bOn)
  130. {
  131. Notify("放电结束");
  132. _chamber.StopAllGases();
  133. _chamber.OpenValve(ValveType.GasFinal, false);
  134. _chamber.GeneratorPowerOn(false);
  135. _chamber.GeneratorBiasPowerOn(false);
  136. }
  137. return true;
  138. }
  139. public void Abort()
  140. {
  141. _chamber.GeneratorSetpower(0);
  142. _chamber.GeneratorBiasSetpower(0);
  143. _chamber.GeneratorPowerOn(false);
  144. _chamber.GeneratorBiasPowerOn(false);
  145. }
  146. }
  147. }