KollmorgenHomeRoutine.cs 4.5 KB

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