VpwCellDevice.cs 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536
  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.Beckhoff.ModuleIO;
  7. using MECF.Framework.Common.CommonData.Prewet;
  8. using MECF.Framework.Common.CommonData.Vpw;
  9. using MECF.Framework.Common.IOCore;
  10. using MECF.Framework.Common.Persistent.SRD;
  11. using MECF.Framework.Common.Persistent.Temperature;
  12. using MECF.Framework.Common.Persistent.VpwCell;
  13. using MECF.Framework.Common.Persistent.VpwMain;
  14. using MECF.Framework.Common.Utilities;
  15. using PunkHPX8_RT.Devices.AXIS;
  16. using PunkHPX8_RT.Modules;
  17. using PunkHPX8_RT.Modules.VpwMain;
  18. using System;
  19. using System.Collections.Generic;
  20. using System.Linq;
  21. using System.Reflection;
  22. using System.Text;
  23. using System.Threading.Tasks;
  24. namespace PunkHPX8_RT.Devices.VpwCell
  25. {
  26. public class VpwCellDevice : BaseDevice, IDevice
  27. {
  28. #region 常量
  29. private const string COMMON_DATA = "CommonData";
  30. private const string DIW_FLOW = "DiwFlow";
  31. private const string VACUUM_PRESSURE = "VacuumPressure";
  32. private const string FLOW_DRIP = "FlowDrip";
  33. private const string FLOW_SMALL = "FlowSmall";
  34. private const string FLOW_LARGE = "FlowLarge";
  35. private const string VACUUM_VALVE = "VacuumValve";
  36. private const string VENT_VALVE = "VentValve";
  37. private const string DRAIN_VALVE = "DrainValve";
  38. private const string PERSISTENT_VALUE = "PersistentValue";
  39. #endregion
  40. #region 内部变量
  41. /// <summary>
  42. /// 变量是否初始化字典
  43. /// </summary>
  44. private Dictionary<string, bool> _variableInitializeDic = new Dictionary<string, bool>();
  45. /// <summary>
  46. /// 数据
  47. /// </summary>
  48. private VpwCellCommonData _commonData=new VpwCellCommonData();
  49. /// <summary>
  50. /// 持久性数值
  51. /// </summary>
  52. private VpwCellPersistentValue _vpwCellPersistentValue;
  53. /// <summary>
  54. /// 水平电机
  55. /// </summary>
  56. private JetAxisBase _rotationAxis;
  57. #endregion
  58. #region 属性
  59. /// <summary>
  60. /// 数据
  61. /// </summary>
  62. public VpwCellCommonData CommonData { get { return _commonData; } }
  63. /// <summary>
  64. /// 操作模式
  65. /// </summary>
  66. public string OperationMode { get { return _vpwCellPersistentValue.OperatingMode; } }
  67. /// <summary>
  68. /// 工程模式
  69. /// </summary>
  70. public string EngineerMode { get { return _vpwCellPersistentValue.RecipeOperatingMode; } }
  71. #endregion
  72. /// <summary>
  73. /// 构造函数
  74. /// </summary>
  75. /// <param name="moduleName"></param>
  76. public VpwCellDevice(string moduleName) : base(moduleName, moduleName, moduleName, moduleName)
  77. {
  78. }
  79. #region 初始化
  80. /// <summary>
  81. /// 初始化
  82. /// </summary>
  83. /// <returns></returns>
  84. public bool Initialize()
  85. {
  86. InitializeParameter();
  87. InitializeRoutine();
  88. SubscribeData();
  89. SubscribeValueAction();
  90. InitializeOperation();
  91. return true;
  92. }
  93. /// <summary>
  94. /// 初始化参数
  95. /// </summary>
  96. private void InitializeParameter()
  97. {
  98. _rotationAxis = DEVICE.GetDevice<JetAxisBase>($"{Module}.Rotation");
  99. _vpwCellPersistentValue = VpwCellPersistentManager.Instance.GetPersistentValue(Module);
  100. }
  101. /// <summary>
  102. /// 初始化Routine
  103. /// </summary>
  104. private void InitializeRoutine()
  105. {
  106. }
  107. /// <summary>
  108. /// 订阅
  109. /// </summary>
  110. private void SubscribeData()
  111. {
  112. DATA.Subscribe($"{Module}.{COMMON_DATA}", () => CommonData, SubscriptionAttribute.FLAG.IgnoreSaveDB);
  113. DATA.Subscribe($"{Module}.{PERSISTENT_VALUE}", () => _vpwCellPersistentValue, SubscriptionAttribute.FLAG.IgnoreSaveDB);
  114. DATA.Subscribe($"{Module}.DiwCellFlow", () => CommonData.DiwFlow, SubscriptionAttribute.FLAG.IgnoreSaveDB);
  115. }
  116. /// <summary>
  117. /// 订阅数据
  118. /// </summary>
  119. private void SubscribeValueAction()
  120. {
  121. IoSubscribeUpdateVariable(DIW_FLOW);
  122. IoSubscribeUpdateVariable(DRAIN_VALVE);
  123. IoSubscribeUpdateVariable(VACUUM_PRESSURE);
  124. IoSubscribeUpdateVariable(VACUUM_VALVE);
  125. IoSubscribeUpdateVariable(VENT_VALVE);
  126. IoSubscribeUpdateVariable(FLOW_DRIP);
  127. IoSubscribeUpdateVariable(FLOW_LARGE);
  128. IoSubscribeUpdateVariable(FLOW_SMALL);
  129. }
  130. /// <summary>
  131. /// 初始化变量
  132. /// </summary>
  133. /// <param name="variable"></param>
  134. private void IoSubscribeUpdateVariable(string variable)
  135. {
  136. _variableInitializeDic[variable] = false;
  137. IOModuleManager.Instance.SubscribeModuleVariable(Module, variable, UpdateVariableValue);
  138. }
  139. /// <summary>
  140. /// 更新变量数值
  141. /// </summary>
  142. /// <param name="variable"></param>
  143. /// <param name="value"></param>
  144. private void UpdateVariableValue(string variable, object value)
  145. {
  146. PropertyInfo property = _commonData.GetType().GetProperty(variable);
  147. if (property != null)
  148. {
  149. property.SetValue(_commonData, value);
  150. }
  151. if (_variableInitializeDic.ContainsKey(variable) && !_variableInitializeDic[variable])
  152. {
  153. _variableInitializeDic[variable] = true;
  154. }
  155. }
  156. /// <summary>
  157. /// 初始化OP
  158. /// </summary>
  159. private void InitializeOperation()
  160. {
  161. OP.Subscribe($"{Module}.FlowDripOn", (cmd,para)=> { return FlowDripOn(); });
  162. OP.Subscribe($"{Module}.FlowDripOff", (cmd, para) => { return FlowDripOff(); });
  163. OP.Subscribe($"{Module}.FlowSmallOn", (cmd, para) => { return FlowSmallOn(); });
  164. OP.Subscribe($"{Module}.FlowSmallOff", (cmd, para) => { return FlowSmallOff(); });
  165. OP.Subscribe($"{Module}.FlowLargeOn", (cmd, para) => { return FlowLargeOn(); });
  166. OP.Subscribe($"{Module}.FlowLargeOff", (cmd, para) => { return FlowLargeOff(); });
  167. OP.Subscribe($"{Module}.VentValveOn", (cmd, para) => { return VentValveOn(); });
  168. OP.Subscribe($"{Module}.VentValveOff", (cmd, para) => { return VentValveOff(); });
  169. OP.Subscribe($"{Module}.DrainValveOn", (cmd, para) => { return DrainValveOn(); });
  170. OP.Subscribe($"{Module}.DrainValveOff", (cmd, para) => { return DrainValveOff(); });
  171. OP.Subscribe($"{Module}.VacuumValveOn", (cmd, para) => { return VacuumValveOn(); });
  172. OP.Subscribe($"{Module}.VacuumValveOff", (cmd, para) => { return VacuumValveOff(); });
  173. OP.Subscribe($"{Module}.DisabledAction", DisabledOperation);
  174. OP.Subscribe($"{Module}.ManualAction", ManualOperation);
  175. OP.Subscribe($"{Module}.AutoAction", AutoOperation);
  176. OP.Subscribe($"{Module}.EngineeringModeAction", EngineeringModeOperation);
  177. OP.Subscribe($"{Module}.ProductionModeAction", ProductionModeOperation);
  178. }
  179. #endregion
  180. #region Action
  181. #region Flow
  182. /// <summary>
  183. /// Flow Drip on
  184. /// </summary>
  185. /// <returns></returns>
  186. public bool FlowDripOn()
  187. {
  188. return WriteVariableValue(FLOW_DRIP, true);
  189. }
  190. /// <summary>
  191. /// Flow Drip Off
  192. /// </summary>
  193. /// <returns></returns>
  194. public bool FlowDripOff()
  195. {
  196. return WriteVariableValue(FLOW_DRIP, false);
  197. }
  198. /// <summary>
  199. /// Flow Small On
  200. /// </summary>
  201. /// <returns></returns>
  202. public bool FlowSmallOn()
  203. {
  204. return WriteVariableValue(FLOW_SMALL, true);
  205. }
  206. /// <summary>
  207. /// Flow Small Off
  208. /// </summary>
  209. /// <returns></returns>
  210. public bool FlowSmallOff()
  211. {
  212. return WriteVariableValue(FLOW_SMALL, false);
  213. }
  214. /// <summary>
  215. /// Flow Large On
  216. /// </summary>
  217. /// <returns></returns>
  218. public bool FlowLargeOn()
  219. {
  220. return WriteVariableValue(FLOW_LARGE, true);
  221. }
  222. /// <summary>
  223. /// Flow Large Off
  224. /// </summary>
  225. /// <returns></returns>
  226. public bool FlowLargeOff()
  227. {
  228. return WriteVariableValue(FLOW_LARGE, false);
  229. }
  230. #endregion
  231. #region Mode Switch
  232. /// <summary>
  233. /// DisabledAction
  234. /// </summary>
  235. /// <param name="cmd"></param>
  236. /// <param name="param"></param>
  237. /// <returns></returns>
  238. private bool DisabledOperation(string cmd, object[] args)
  239. {
  240. string currentOperation = "Disabled";
  241. VpwCellEntity vpwCellEntity = Singleton<RouteManager>.Instance.GetModule<VpwCellEntity>(Module);
  242. if (vpwCellEntity != null && _vpwCellPersistentValue != null && _vpwCellPersistentValue.OperatingMode != currentOperation)
  243. {
  244. string preOperation = _vpwCellPersistentValue.OperatingMode;
  245. if (vpwCellEntity.IsBusy)
  246. {
  247. LOG.WriteLog(eEvent.ERR_VPWMAIN, Module, $"{Module} is Busy, can't switch to Disabled mode");
  248. return false;
  249. }
  250. vpwCellEntity.EnterInit();
  251. _vpwCellPersistentValue.OperatingMode = currentOperation;
  252. LOG.WriteLog(eEvent.INFO_VPWMAIN, Module, $"Operating mode is switched from {preOperation} to {currentOperation}");
  253. }
  254. VpwCellPersistentManager.Instance.UpdatePersistentValue(Module);
  255. return true;
  256. }
  257. /// <summary>
  258. /// ManualAction
  259. /// </summary>
  260. /// <param name="cmd"></param>
  261. /// <param name="param"></param>
  262. /// <returns></returns>
  263. private bool ManualOperation(string cmd, object[] args)
  264. {
  265. string currentOperation = "Manual";
  266. VpwCellEntity vpwCellEntity = Singleton<RouteManager>.Instance.GetModule<VpwCellEntity>(Module);
  267. if (vpwCellEntity != null && _vpwCellPersistentValue != null && _vpwCellPersistentValue.OperatingMode != currentOperation)
  268. {
  269. string preOperation = _vpwCellPersistentValue.OperatingMode;
  270. if (vpwCellEntity.IsBusy)
  271. {
  272. LOG.WriteLog(eEvent.ERR_VPWMAIN, Module, $"{Module} is Busy, can't switch to Manual mode");
  273. return false;
  274. }
  275. vpwCellEntity.EnterInit();
  276. _vpwCellPersistentValue.OperatingMode = currentOperation;
  277. LOG.WriteLog(eEvent.INFO_VPWMAIN, Module, $"Operating mode is switched from {preOperation} to {currentOperation}");
  278. }
  279. VpwCellPersistentManager.Instance.UpdatePersistentValue(Module);
  280. return true;
  281. }
  282. /// <summary>
  283. /// AutoAction
  284. /// </summary>
  285. /// <param name="cmd"></param>
  286. /// <param name="param"></param>
  287. /// <returns></returns>
  288. private bool AutoOperation(string cmd, object[] args)
  289. {
  290. string currentOperation = "Auto";
  291. VpwCellEntity vpwCellEntity = Singleton<RouteManager>.Instance.GetModule<VpwCellEntity>(Module);
  292. if (vpwCellEntity != null && _vpwCellPersistentValue != null && _vpwCellPersistentValue.OperatingMode != currentOperation)
  293. {
  294. string preOperation = _vpwCellPersistentValue.OperatingMode;
  295. if (vpwCellEntity.IsBusy)
  296. {
  297. LOG.WriteLog(eEvent.ERR_VPWMAIN, Module, $"{Module} is Busy, can't switch to Auto mode");
  298. return false;
  299. }
  300. vpwCellEntity.EnterInit();
  301. _vpwCellPersistentValue.OperatingMode = currentOperation;
  302. LOG.WriteLog(eEvent.INFO_VPWMAIN, Module, $"Operating mode is switched from {preOperation} to {currentOperation}");
  303. }
  304. VpwCellPersistentManager.Instance.UpdatePersistentValue(Module);
  305. return true;
  306. }
  307. /// <summary>
  308. /// EngineeringModeAction
  309. /// </summary>
  310. /// <param name="cmd"></param>
  311. /// <param name="param"></param>
  312. /// <returns></returns>
  313. private bool EngineeringModeOperation(string cmd, object[] args)
  314. {
  315. string currentRecipeOperation = "Engineering";
  316. if (_vpwCellPersistentValue != null)
  317. {
  318. _vpwCellPersistentValue.RecipeOperatingMode = currentRecipeOperation;
  319. }
  320. VpwCellPersistentManager.Instance.UpdatePersistentValue(Module);
  321. return true;
  322. }
  323. /// <summary>
  324. /// ProductionAction
  325. /// </summary>
  326. /// <param name="cmd"></param>
  327. /// <param name="param"></param>
  328. /// <returns></returns>
  329. private bool ProductionModeOperation(string cmd, object[] args)
  330. {
  331. string currentRecipeOperation = "Production";
  332. if (_vpwCellPersistentValue != null)
  333. {
  334. _vpwCellPersistentValue.RecipeOperatingMode = currentRecipeOperation;
  335. }
  336. VpwCellPersistentManager.Instance.UpdatePersistentValue(Module);
  337. return true;
  338. }
  339. #endregion
  340. #region Vent Valve
  341. /// <summary>
  342. /// Vent Valve On
  343. /// </summary>
  344. /// <returns></returns>
  345. public bool VentValveOn()
  346. {
  347. return WriteVariableValue(VENT_VALVE, true);
  348. }
  349. /// <summary>
  350. /// Vent Valve Off
  351. /// </summary>
  352. /// <returns></returns>
  353. public bool VentValveOff()
  354. {
  355. return WriteVariableValue(VENT_VALVE, false);
  356. }
  357. #endregion
  358. #region Drain Valve
  359. /// <summary>
  360. /// Drain Valve On
  361. /// </summary>
  362. /// <returns></returns>
  363. public bool DrainValveOn()
  364. {
  365. return WriteVariableValue(DRAIN_VALVE, true);
  366. }
  367. /// <summary>
  368. /// Drain Valve Off
  369. /// </summary>
  370. /// <returns></returns>
  371. public bool DrainValveOff()
  372. {
  373. return WriteVariableValue(DRAIN_VALVE, false);
  374. }
  375. #endregion
  376. #region Vacuum
  377. /// <summary>
  378. /// Vacuum valve on
  379. /// </summary>
  380. /// <returns></returns>
  381. public bool VacuumValveOn()
  382. {
  383. return WriteVariableValue(VACUUM_VALVE, true);
  384. }
  385. /// <summary>
  386. /// Vacuum valve off
  387. /// </summary>
  388. /// <returns></returns>
  389. public bool VacuumValveOff()
  390. {
  391. return WriteVariableValue(VACUUM_VALVE, false);
  392. }
  393. #endregion
  394. /// <summary>
  395. /// 写变量
  396. /// </summary>
  397. /// <param name="variable"></param>
  398. /// <param name="value"></param>
  399. /// <returns></returns>
  400. private bool WriteVariableValue(string variable, object value)
  401. {
  402. string ioName = BeckhoffModuleIOManager.Instance.GetIoNameByInnerModuleName($"{Module}.{variable}");
  403. return IOModuleManager.Instance.WriteIoValue(ioName, value);
  404. }
  405. #endregion
  406. #region Axis
  407. /// <summary>
  408. /// 电机是否上电
  409. /// </summary>
  410. /// <returns></returns>
  411. public bool CheckRotationSwitchOn()
  412. {
  413. return _rotationAxis.IsSwitchOn;
  414. }
  415. /// <summary>
  416. /// Home rotation
  417. /// </summary>
  418. /// <returns></returns>
  419. public bool HomeRotation()
  420. {
  421. return _rotationAxis.Home();
  422. }
  423. /// <summary>
  424. /// 检验Rotation Home结果
  425. /// </summary>
  426. /// <returns></returns>
  427. public bool CheckHomeEndStatus()
  428. {
  429. return CheckRotationEndStatus() && _rotationAxis.IsHomed;
  430. }
  431. /// <summary>
  432. /// 检验Rotation结束状态
  433. /// </summary>
  434. /// <returns></returns>
  435. public bool CheckRotationEndStatus()
  436. {
  437. return _rotationAxis.Status == PunkHPX8_Core.RState.End;
  438. }
  439. /// <summary>
  440. /// 检验Rotation失败状态
  441. /// </summary>
  442. /// <returns></returns>
  443. public bool CheckRotationStopStatus()
  444. {
  445. return _rotationAxis.Status == PunkHPX8_Core.RState.Failed;
  446. }
  447. /// <summary>
  448. /// 设置速度
  449. /// </summary>
  450. /// <param name="speed"></param>
  451. /// <returns></returns>
  452. public bool SetRotationSpeed(int speed)
  453. {
  454. _rotationAxis.SetProfileSpeed(speed);
  455. return true;
  456. }
  457. /// <summary>
  458. /// 电机运动
  459. /// </summary>
  460. /// <param name="position"></param>
  461. /// <returns></returns>
  462. public bool RotationProfilePosition(double position)
  463. {
  464. return _rotationAxis.ProfilePositionOperation(position);
  465. }
  466. /// <summary>
  467. /// 停止运动
  468. /// </summary>
  469. /// <returns></returns>
  470. public bool StopProfilePosition()
  471. {
  472. return _rotationAxis.StopPositionOperation();
  473. }
  474. /// <summary>
  475. /// 是否Rotation运动
  476. /// </summary>
  477. /// <returns></returns>
  478. public bool CheckRotationRunning()
  479. {
  480. return _rotationAxis.IsRun;
  481. }
  482. #endregion
  483. /// <summary>
  484. /// 定时器
  485. /// </summary>
  486. /// <returns></returns>
  487. public bool OnTimer()
  488. {
  489. if (_rotationAxis != null)
  490. {
  491. _rotationAxis.OnTimer();
  492. }
  493. return true;
  494. }
  495. /// <summary>
  496. /// 监控
  497. /// </summary>
  498. public void Monitor()
  499. {
  500. }
  501. public void Reset()
  502. {
  503. }
  504. public void Terminate()
  505. {
  506. }
  507. }
  508. }