ReservoirDevice.cs 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311
  1. using Aitex.Core.RT.DataCenter;
  2. using Aitex.Core.RT.Device;
  3. using Aitex.Core.RT.Log;
  4. using Aitex.Core.RT.OperationCenter;
  5. using Aitex.Core.Util;
  6. using MECF.Framework.Common.CommonData.Reservoir;
  7. using MECF.Framework.Common.IOCore;
  8. using MECF.Framework.Common.Persistent.Reservoirs;
  9. using MECF.Framework.Common.TwinCat;
  10. using MECF.Framework.Common.Utilities;
  11. using PunkHPX8_RT.Modules;
  12. using System;
  13. using System.Collections.Generic;
  14. using System.Linq;
  15. using System.Reflection;
  16. using System.Text;
  17. using System.Threading.Tasks;
  18. namespace PunkHPX8_RT.Devices.Reservoir
  19. {
  20. public class ReservoirDevice : BaseDevice, IDevice
  21. {
  22. #region 常量
  23. protected const string AUTO = "Auto";
  24. protected const string MANUAL = "Manual";
  25. protected const string DISABLE = "Disable";
  26. protected const string CA_PUMP_RUNNING="CaPumpRunning";
  27. protected const string AN_TOWER_HIGH="AnTowerHigh";
  28. protected const string AN_TOWER_LOW="AnTowerLow";
  29. protected const string CA_LEVEL="CaLevel";
  30. protected const string CA_WATER_LEVEL="CaWaterLevel";
  31. protected const string AN_FLOW="AnFlow";
  32. protected const string AN_PUMP_ENABLE="AnPumpEnable";
  33. protected const string AN_PUMP_SPEED="AnPumpSpeed";
  34. protected const string CA_FLOW="CaFlow";
  35. protected const string CA_PUMP_ENABLE="CaPumpEnable";
  36. protected const string CA_PUMP_SPEED="CaPumpSpeed";
  37. protected const string RETURN_VALVE_OPENING="ReturnValveOpening";
  38. protected const string RETURN_VALVE="ReturnValve";
  39. protected const string RETURN_VALVE_PERCENT="ReturnValvePercent";
  40. protected const string CA_DI_REPLEN="CaDiReplen";
  41. protected const string AN_DI_REPLEN="AnDiReplen";
  42. protected const string SAMPLE_OUT="SampleOut";
  43. protected const string DEGAS_ENABLE="DegasEnable";
  44. protected const string HED_FLOW="HedFlow";
  45. protected const string HED_FLOW_ENABLE="HedFlowEnable";
  46. protected const string PH_FLOW_VALVE="PhFlowValve";
  47. protected const string PH_VALUE="PhValue";
  48. #endregion
  49. #region 内部变量
  50. /// <summary>
  51. /// Prewet 持久性数值对象
  52. /// </summary>
  53. private ReservoirsPersistentValue _persistentValue;
  54. /// <summary>
  55. /// 变量是否初始化字典
  56. /// </summary>
  57. private Dictionary<string, bool> _variableInitializeDic = new Dictionary<string, bool>();
  58. /// <summary>
  59. /// 数据
  60. /// </summary>
  61. private ReservoirData _reservoirData = new ReservoirData();
  62. /// <summary>
  63. /// 定时器
  64. /// </summary>
  65. private PeriodicJob _periodicJob;
  66. #endregion
  67. #region 属性
  68. /// <summary>
  69. /// 操作模式
  70. /// </summary>
  71. public string OperationMode { get { return _persistentValue.OperatingMode; } }
  72. /// <summary>
  73. /// 工程模式
  74. /// </summary>
  75. public string EngineerMode { get { return _persistentValue.RecipeOperatingMode; } }
  76. /// <summary>
  77. /// 是否自动
  78. /// </summary>
  79. public bool IsAuto { get { return _persistentValue.OperatingMode == AUTO; } }
  80. /// <summary>
  81. /// 数据
  82. /// </summary>
  83. public ReservoirData ReservoirData { get { return _reservoirData; } }
  84. #endregion
  85. /// <summary>
  86. /// 构造函数
  87. /// </summary>
  88. /// <param name="moduleName"></param>
  89. /// <param name="name"></param>
  90. public ReservoirDevice(string moduleName) : base(moduleName, moduleName, moduleName, moduleName)
  91. {
  92. }
  93. /// <summary>
  94. /// 初始化
  95. /// </summary>
  96. /// <returns></returns>
  97. public bool Initialize()
  98. {
  99. InitializeParameter();
  100. InitializeRoutine();
  101. SubscribeData();
  102. InitializeOperation();
  103. SubscribeValueAction();
  104. _periodicJob = new PeriodicJob(200, OnTimer, $"{Module}.Timer", true, true);
  105. return true;
  106. }
  107. /// <summary>
  108. /// 初始化参数
  109. /// </summary>
  110. private void InitializeParameter()
  111. {
  112. _persistentValue = ReservoirsPersistentManager.Instance.GetReservoirsPersistentValue(Module.ToString());
  113. if (_persistentValue == null)
  114. {
  115. LOG.WriteLog(eEvent.ERR_RESERVOIR, Module.ToString(), "Persistent Value Object is not exist");
  116. }
  117. }
  118. /// <summary>
  119. /// 初始化Routine
  120. /// </summary>
  121. private void InitializeRoutine()
  122. {
  123. }
  124. /// <summary>
  125. /// 订阅数据
  126. /// </summary>
  127. private void SubscribeData()
  128. {
  129. DATA.Subscribe($"{Module}.ReservoirData", () => _reservoirData, SubscriptionAttribute.FLAG.IgnoreSaveDB);
  130. }
  131. /// <summary>
  132. /// 初始化Operation
  133. /// </summary>
  134. private void InitializeOperation()
  135. {
  136. OP.Subscribe($"{Module}.DisabledAction", DisabledOperation);
  137. OP.Subscribe($"{Module}.ManualAction", ManualOperation);
  138. OP.Subscribe($"{Module}.AutoAction", AutoOperation);
  139. OP.Subscribe($"{Module}.EngineeringModeAction", EngineeringModeOperation);
  140. OP.Subscribe($"{Module}.ProductionModeAction", ProductionModeOperation);
  141. }
  142. /// <summary>
  143. /// 订阅变量数值发生变化
  144. /// </summary>
  145. protected virtual void SubscribeValueAction()
  146. {
  147. IoSubscribeUpdateVariable(CA_PUMP_RUNNING);
  148. IoSubscribeUpdateVariable(AN_TOWER_HIGH);
  149. IoSubscribeUpdateVariable(AN_TOWER_LOW);
  150. IoSubscribeUpdateVariable(CA_LEVEL);
  151. IoSubscribeUpdateVariable(CA_WATER_LEVEL);
  152. IoSubscribeUpdateVariable(CA_PUMP_ENABLE);
  153. IoSubscribeUpdateVariable(CA_PUMP_SPEED);
  154. IoSubscribeUpdateVariable(CA_DI_REPLEN);
  155. IoSubscribeUpdateVariable(RETURN_VALVE);
  156. IoSubscribeUpdateVariable(RETURN_VALVE_OPENING);
  157. IoSubscribeUpdateVariable(RETURN_VALVE_PERCENT);
  158. IoSubscribeUpdateVariable(SAMPLE_OUT);
  159. }
  160. /// <summary>
  161. /// 订阅IO变量
  162. /// </summary>
  163. /// <param name="variable"></param>
  164. protected void IoSubscribeUpdateVariable(string variable)
  165. {
  166. _variableInitializeDic[variable] = false;
  167. IOModuleManager.Instance.SubscribeModuleVariable(Module, variable, UpdateVariableValue);
  168. }
  169. /// <summary>
  170. /// 更新变量数值
  171. /// </summary>
  172. /// <param name="variable"></param>
  173. /// <param name="value"></param>
  174. private void UpdateVariableValue(string variable, object value)
  175. {
  176. if (!_reservoirData.IsDataInitialized)
  177. {
  178. _reservoirData.IsDataInitialized = true;
  179. }
  180. PropertyInfo property = _reservoirData.GetType().GetProperty(variable);
  181. if (property != null)
  182. {
  183. property.SetValue(_reservoirData, value);
  184. }
  185. if (_variableInitializeDic.ContainsKey(variable) && !_variableInitializeDic[variable])
  186. {
  187. _variableInitializeDic[variable] = true;
  188. }
  189. }
  190. /// <summary>
  191. /// 定时器
  192. /// </summary>
  193. /// <returns></returns>
  194. protected virtual bool OnTimer()
  195. {
  196. return true;
  197. }
  198. #region Mode switch
  199. /// <summary>
  200. /// DisabledAction
  201. /// </summary>
  202. /// <param name="cmd"></param>
  203. /// <param name="param"></param>
  204. /// <returns></returns>
  205. private bool DisabledOperation(string cmd, object[] args)
  206. {
  207. string currentOperation = "Disabled";
  208. string preOperation = _persistentValue.OperatingMode;
  209. _persistentValue.OperatingMode = currentOperation;
  210. LOG.WriteLog(eEvent.INFO_RESERVOIR, Module, $"Operating mode is switched from {preOperation} to {currentOperation}");
  211. ReservoirsPersistentManager.Instance.UpdatePersistentValue(Module);
  212. return true;
  213. }
  214. /// <summary>
  215. /// ManualAction
  216. /// </summary>
  217. /// <param name="cmd"></param>
  218. /// <param name="param"></param>
  219. /// <returns></returns>
  220. private bool ManualOperation(string cmd, object[] args)
  221. {
  222. string currentOperation = "Manual";
  223. string preOperation = _persistentValue.OperatingMode;
  224. _persistentValue.OperatingMode = currentOperation;
  225. LOG.WriteLog(eEvent.INFO_RESERVOIR, Module, $"Operating mode is switched from {preOperation} to {currentOperation}");
  226. ReservoirsPersistentManager.Instance.UpdatePersistentValue(Module);
  227. return true;
  228. }
  229. /// <summary>
  230. /// AutoAction
  231. /// </summary>
  232. /// <param name="cmd"></param>
  233. /// <param name="param"></param>
  234. /// <returns></returns>
  235. private bool AutoOperation(string cmd, object[] args)
  236. {
  237. string currentOperation = "Auto";
  238. string preOperation = _persistentValue.OperatingMode;
  239. _persistentValue.OperatingMode = currentOperation;
  240. LOG.WriteLog(eEvent.INFO_RESERVOIR, Module, $"Operating mode is switched from {preOperation} to {currentOperation}");
  241. ReservoirsPersistentManager.Instance.UpdatePersistentValue(Module);
  242. return true;
  243. }
  244. /// <summary>
  245. /// EngineeringModeAction
  246. /// </summary>
  247. /// <param name="cmd"></param>
  248. /// <param name="param"></param>
  249. /// <returns></returns>
  250. private bool EngineeringModeOperation(string cmd, object[] args)
  251. {
  252. string currentRecipeOperation = "Engineering";
  253. if (_persistentValue != null)
  254. {
  255. _persistentValue.RecipeOperatingMode = currentRecipeOperation;
  256. }
  257. ReservoirsPersistentManager.Instance.UpdatePersistentValue(Module);
  258. return true;
  259. }
  260. /// <summary>
  261. /// ProductionAction
  262. /// </summary>
  263. /// <param name="cmd"></param>
  264. /// <param name="param"></param>
  265. /// <returns></returns>
  266. private bool ProductionModeOperation(string cmd, object[] args)
  267. {
  268. string currentRecipeOperation = "Production";
  269. if (_persistentValue != null)
  270. {
  271. _persistentValue.RecipeOperatingMode = currentRecipeOperation;
  272. }
  273. ReservoirsPersistentManager.Instance.UpdatePersistentValue(Module);
  274. return true;
  275. }
  276. #endregion
  277. /// <summary>
  278. /// 监控
  279. /// </summary>
  280. public void Monitor()
  281. {
  282. }
  283. public void Reset()
  284. {
  285. }
  286. public void Terminate()
  287. {
  288. }
  289. }
  290. }