MaxonStopPositionRoutine.cs 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. using Aitex.Core.RT.Log;
  2. using Aitex.Core.RT.Routine;
  3. using CyberX8_Core;
  4. using MECF.Framework.Common.Beckhoff.AxisProvider;
  5. using MECF.Framework.Common.CommonData.PUF;
  6. using MECF.Framework.Common.Routine;
  7. using System;
  8. namespace CyberX8_RT.Devices.AXIS.Maxon
  9. {
  10. public class MaxonStopPositionRoutine : RoutineBase, IRoutine
  11. {
  12. private enum StopPositionStep
  13. {
  14. SetHaltControlWord,
  15. CheckStop,
  16. WriteTargePosition,
  17. ResetHaltControlWord,
  18. CheckRun,
  19. NoneModeOfOperation,
  20. EnableOperation,
  21. End
  22. }
  23. #region 常量
  24. private const string TARGET_POSITION = "TargetPosition";
  25. #endregion
  26. #region 内部变量
  27. private JetAxisBase _axis;
  28. private int _timeout = 5000;
  29. private int _targetPosition;
  30. /// <summary>
  31. /// SRD rotation Provider对象
  32. /// </summary>
  33. private BeckhoffProviderAxis _rotationProviderAxis;
  34. #endregion
  35. public MaxonStopPositionRoutine(string module, JetAxisBase axis) : base(module)
  36. {
  37. _axis = axis;
  38. }
  39. public void Abort()
  40. {
  41. Runner.Stop("Manual Abort");
  42. }
  43. public RState Monitor()
  44. {
  45. Runner.Run(StopPositionStep.SetHaltControlWord, () => { return _axis.WriteControlWord(0X8F); }, () => { return CheckControlWord(0X8F); }, 1000)
  46. .WaitWithStopCondition(StopPositionStep.CheckStop, CheckStop, CheckErrorOrWarning, _timeout)
  47. .Run(StopPositionStep.WriteTargePosition, () => { return WriteTargetPosition(); }, NullFun, 100)
  48. .Run(StopPositionStep.ResetHaltControlWord, () => { return _axis.WriteControlWord(0x3F); }, () => { return CheckControlWord(0x3F); }, 1000)
  49. .WaitWithStopCondition(StopPositionStep.CheckRun, CheckRunEnd, CheckRunStop, 5000)
  50. .Run(StopPositionStep.NoneModeOfOperation, () => { return _axis.WriteModeOfMode(AxisModeOfOperation.None); }, () => { return CheckModeOfOperation((byte)AxisModeOfOperation.None); }, 1000)
  51. .Run(StopPositionStep.EnableOperation, () => { return _axis.EnableOperation(); }, () => { return CheckControlWord(0x0F); }, 1000)
  52. .End(StopPositionStep.End, NullFun, 100);
  53. return Runner.Status;
  54. }
  55. public bool CheckModeOfOperation(byte modeOfOperation)
  56. {
  57. return _axis.ModeOfOperation == modeOfOperation;
  58. }
  59. public bool CheckControlWord(ushort controlWord)
  60. {
  61. return _axis.ControlWord == controlWord;
  62. }
  63. /// <summary>
  64. /// 设置目标位置为当前位置
  65. /// </summary>
  66. /// <param name="targetPosition"></param>
  67. private bool WriteTargetPosition()
  68. {
  69. double scale = _rotationProviderAxis.ScaleFactor;
  70. _targetPosition = (int)Math.Ceiling(_axis.MotionData.MotorPosition * scale);
  71. return _axis.WriteVariable(TARGET_POSITION, _targetPosition);
  72. }
  73. /// <summary>
  74. /// 检查是否运动完成
  75. /// </summary>
  76. /// <returns></returns>
  77. private bool CheckRunEnd()
  78. {
  79. bool result = _axis.InTargetPosition && !_axis.IsRun;
  80. return result;
  81. }
  82. /// <summary>
  83. /// 检查是否运动完成
  84. /// </summary>
  85. /// <returns></returns>
  86. private bool CheckRunStop()
  87. {
  88. //没有到达目标同时没有运动
  89. bool isStop = !_axis.IsRun && !_axis.JudgeCurrentPositionIsInTargetPosition(_targetPosition);
  90. if (isStop)
  91. {
  92. ErrorMsg = "position is stop";
  93. return true;
  94. }
  95. return false;
  96. }
  97. /// <summary>
  98. /// 检查Halt是否停下来
  99. /// </summary>
  100. /// <returns></returns>
  101. private bool CheckStop()
  102. {
  103. return !_axis.IsRun;
  104. }
  105. /// 检验是否出错或告警
  106. /// </summary>
  107. /// <returns></returns>
  108. private bool CheckErrorOrWarning()
  109. {
  110. bool result = _axis.MotionData.Status.ToLower().Contains("error") || _axis.MotionData.Status.ToLower().Contains("warning");
  111. if (result)
  112. {
  113. LOG.WriteLog(eEvent.ERR_AXIS, Module, $"axis stop occur error or warning");
  114. }
  115. return result;
  116. }
  117. public RState Start(params object[] objs)
  118. {
  119. _rotationProviderAxis = BeckhoffAxisProviderManager.Instance.GetAxisProvider($"{Module}");
  120. if (_rotationProviderAxis == null)
  121. {
  122. LOG.WriteLog(eEvent.ERR_AXIS, Module, $"{Module} Axist Provider is not exist");
  123. return RState.Failed;
  124. }
  125. return Runner.Start(Module, "Stop Position");
  126. }
  127. }
  128. }