YaskawaStopPositionRoutine.cs 5.2 KB

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