CanOpenHomeRoutine.cs 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. using Aitex.Core.RT.Log;
  2. using Aitex.Core.RT.Routine;
  3. using MECF.Framework.Common.CommonData.PUF;
  4. using MECF.Framework.Common.Routine;
  5. using PunkHPX8_Core;
  6. using System;
  7. using System.Collections.Generic;
  8. using System.Linq;
  9. using System.Text;
  10. using System.Threading.Tasks;
  11. namespace PunkHPX8_RT.Devices.AXIS.CANOpen
  12. {
  13. public class CanOpenHomeRoutine : RoutineBase, IRoutine
  14. {
  15. private enum HomeStep
  16. {
  17. WriteControlWord,
  18. HomeModeOfOperation,
  19. WriteHomeControlWord,
  20. HomeDelay,
  21. CheckHome,
  22. NoneModeOfOperation,
  23. EnableOperation,
  24. End
  25. }
  26. #region 内部变量
  27. private JetAxisBase _axis;
  28. private BeckhoffCommonAxis _beckhoffCommonAxis;
  29. private int _timeout = 5000;
  30. private byte _homingMethod = 0;
  31. private bool _isLogError = true;
  32. #endregion
  33. public CanOpenHomeRoutine(string module,JetAxisBase axis,BeckhoffCommonAxis beckhofCommonAxis) : base(module)
  34. {
  35. _axis = axis;
  36. _beckhoffCommonAxis = beckhofCommonAxis;
  37. }
  38. public void Abort()
  39. {
  40. Runner.Stop("Manual Abort");
  41. }
  42. public RState Monitor()
  43. {
  44. Runner.Run(HomeStep.WriteControlWord, () => { return _beckhoffCommonAxis.WriteControlWord(0x0F); }, () => { return CheckControlWord(0x0F); }, 1000)
  45. .Run(HomeStep.HomeModeOfOperation, () => { return _beckhoffCommonAxis.WriteModeOfMode(AxisModeOfOperation.HomingMode); },
  46. ()=> { return CheckModeOfOperation((byte)AxisModeOfOperation.HomingMode); }, 1000)
  47. .Run(HomeStep.WriteHomeControlWord, () => { return _beckhoffCommonAxis.WriteControlWord(0x1F); }, () => { return CheckControlWord(0x1F); },1000)
  48. .Delay(HomeStep.HomeDelay,100)
  49. .WaitWithStopCondition(HomeStep.CheckHome,CheckHome,CheckErrorOrWarning, _timeout, _isLogError)
  50. .Run(HomeStep.NoneModeOfOperation, () => { return _beckhoffCommonAxis.WriteModeOfMode(AxisModeOfOperation.None); },
  51. () => { return CheckModeOfOperation((byte)AxisModeOfOperation.None); },1000)
  52. .Run(HomeStep.EnableOperation, () => { return _beckhoffCommonAxis.WriteControlWord(0x0F); }, () => { return CheckControlWord(0x0F); },1000)
  53. .End(HomeStep.End,NullFun,100);
  54. return Runner.Status;
  55. }
  56. public bool CheckModeOfOperation(byte modeOfOperation)
  57. {
  58. return _axis.ModeOfOperation == modeOfOperation;
  59. }
  60. public bool CheckControlWord(ushort controlWord)
  61. {
  62. return _axis.ControlWord == controlWord;
  63. }
  64. private bool CheckHome()
  65. {
  66. if (CheckHomingMethodNeedHomeSwitched() && !_axis.IsHomeSwitchedTriggered)
  67. {
  68. return false;
  69. }
  70. LOG.WriteLog(eEvent.INFO_AXIS, Module, $"StatusWord is {_axis.MotionData.StatusWord}");
  71. _axis.UpdateStatusWord(_axis.MotionData.StatusWord);
  72. return _axis.IsHomed;
  73. }
  74. /// <summary>
  75. /// 检验Homing Method是否需要检验Home Switch
  76. /// </summary>
  77. /// <returns></returns>
  78. private bool CheckHomingMethodNeedHomeSwitched()
  79. {
  80. if (_homingMethod >= 1 && _homingMethod <= 14)
  81. {
  82. return true;
  83. }
  84. if (_homingMethod == 19)
  85. {
  86. return true;
  87. }
  88. if (_homingMethod == 21)
  89. {
  90. return true;
  91. }
  92. return false;
  93. }
  94. /// 检验是否出错或告警
  95. /// </summary>
  96. /// <returns></returns>
  97. private bool CheckErrorOrWarning()
  98. {
  99. bool result = _axis.MotionData.Status.ToLower().Contains("error") || _axis.MotionData.Status.ToLower().Contains("warning");
  100. if (result)
  101. {
  102. LOG.WriteLog(eEvent.ERR_AXIS, Module, $"axis home occur error or warning");
  103. }
  104. return result;
  105. }
  106. public RState Start(params object[] objs)
  107. {
  108. _timeout = (int)objs[0];
  109. _homingMethod = (byte)objs[1];
  110. if(objs.Length >= 3)
  111. {
  112. _isLogError = (bool)objs[2];
  113. }
  114. return Runner.Start(Module, "Home");
  115. }
  116. }
  117. }