DryerBlowerHighRoutine.cs 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  1. using Aitex.Core.RT.Device;
  2. using Aitex.Core.RT.Log;
  3. using Aitex.Core.RT.Routine;
  4. using Aitex.Core.RT.SCCore;
  5. using MECF.Framework.Common.Routine;
  6. using CyberX8_Core;
  7. using CyberX8_RT.Devices.Facilities;
  8. using System;
  9. using System.Collections.Generic;
  10. using System.Linq;
  11. using System.Text;
  12. using System.Threading.Tasks;
  13. namespace CyberX8_RT.Devices.Dryer
  14. {
  15. public class DryerBlowerHighRoutine : RoutineBase, IRoutine
  16. {
  17. /// <summary>
  18. /// step
  19. /// </summary>
  20. private enum DryerBlowerHighStep
  21. {
  22. HighOn,
  23. Delay,
  24. CheckExhaustPressure,
  25. ReturnLow,
  26. End
  27. }
  28. #region 内部变量
  29. private bool _bypass = false;
  30. private double _minimumPressure = 0;
  31. private int _delayTime = 1000;
  32. private DryerDevice _device;
  33. private SystemFacilities _facilities;
  34. private bool _backLow = false;
  35. #endregion
  36. /// <summary>
  37. /// 构造函数
  38. /// </summary>
  39. /// <param name="module"></param>
  40. public DryerBlowerHighRoutine(string module,DryerDevice device) : base(module)
  41. {
  42. _device = device;
  43. }
  44. /// <summary>
  45. /// 中止
  46. /// </summary>
  47. public void Abort()
  48. {
  49. Runner.Stop("Manual Abort");
  50. }
  51. /// <summary>
  52. /// 监控
  53. /// </summary>
  54. /// <returns></returns>
  55. public RState Monitor()
  56. {
  57. Runner.Run(DryerBlowerHighStep.HighOn, _device.BlowerHighOn, () => { return _device.CommonData.BlowerHigh; }, _delay_1s)
  58. .Delay(DryerBlowerHighStep.Delay, _delayTime)
  59. .Run(DryerBlowerHighStep.CheckExhaustPressure, CheckExhaustPressure, _delay_1ms)
  60. .Run(DryerBlowerHighStep.ReturnLow, ReturnLow, _delay_1ms)
  61. .End(DryerBlowerHighStep.End, NullFun, _delay_1ms);
  62. return Runner.Status;
  63. }
  64. /// <summary>
  65. /// 检验Pressure
  66. /// </summary>
  67. /// <returns></returns>
  68. private bool CheckExhaustPressure()
  69. {
  70. if (_bypass)
  71. {
  72. return true;
  73. }
  74. else
  75. {
  76. if(_device.CommonData.ExhaustPressure>_minimumPressure)
  77. {
  78. _backLow = true;
  79. LOG.WriteLog(eEvent.ERR_DRYER, Module, $"Current ExhaustPressure{_device.CommonData.ExhaustPressure} is large than {_minimumPressure}");
  80. }
  81. else
  82. {
  83. _backLow = false;
  84. }
  85. return true;
  86. }
  87. }
  88. /// <summary>
  89. /// Return Low
  90. /// </summary>
  91. /// <returns></returns>
  92. private bool ReturnLow()
  93. {
  94. if (_bypass)
  95. {
  96. return true;
  97. }
  98. else
  99. {
  100. if(_backLow)
  101. {
  102. _device.BlowerLowOn();
  103. }
  104. return true;
  105. }
  106. }
  107. /// <summary>
  108. /// 启动
  109. /// </summary>
  110. /// <param name="objs"></param>
  111. /// <returns></returns>
  112. public RState Start(params object[] objs)
  113. {
  114. _bypass=(bool)objs[0];
  115. if(_bypass)
  116. {
  117. _delayTime = 1;
  118. }
  119. _facilities = DEVICE.GetDevice<SystemFacilities>("System.Facilities");
  120. if(!CheckPreCondition())
  121. {
  122. return RState.End;
  123. }
  124. _backLow = false;
  125. _minimumPressure = SC.GetValue<double>("Dryer.MinimumPressure");
  126. return Runner.Start(Module, "Start Dryer Blower Hight");
  127. }
  128. /// <summary>
  129. /// 检验前置条件
  130. /// </summary>
  131. /// <returns></returns>
  132. private bool CheckPreCondition()
  133. {
  134. if(!_device.CommonData.PowerControl)
  135. {
  136. LOG.WriteLog(eEvent.ERR_DRYER, Module, "Power Control is off");
  137. return false;
  138. }
  139. var result = _facilities.CheckExhaustResult();
  140. if(!result.result)
  141. {
  142. LOG.WriteLog(eEvent.ERR_DRYER, Module, result.reason);
  143. return false;
  144. }
  145. if(_device.FacilityCommonLimitData.IsWarning || _device.FacilityCommonLimitData.IsError)
  146. {
  147. LOG.WriteLog(eEvent.ERR_DRYER, Module, "Exhuast Pressure is Abnormal");
  148. return false;
  149. }
  150. return true;
  151. }
  152. }
  153. }