CanOpenProfilePositionRoutine.cs 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. using Aitex.Core.RT.Routine;
  2. using MECF.Framework.Common.CommonData.PUF;
  3. using MECF.Framework.Common.Routine;
  4. using MECF.Framework.Common.TwinCat;
  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 CanOpenProfilePositionRoutine : RoutineBase, IRoutine
  14. {
  15. private enum ProfilePositionStep
  16. {
  17. WriteInitControlWord,
  18. ProfileModeOfOperation,
  19. WriteProfileParameter,
  20. WriteProfilePositionControlWord,
  21. Delay,
  22. CheckRun,
  23. NoneModeOfOperation,
  24. EnableOperation,
  25. End
  26. }
  27. #region 常量
  28. private const string PROFILE_VELOCITY = "ProfileVelocity";
  29. private const string PROFILE_ACCEL = "ProfileAccel";
  30. private const string PROFILE_DECEL = "ProfileDecel";
  31. private const string TARGET_POSITION = "TargetPosition";
  32. #endregion
  33. #region 内部变量
  34. private JetAxisBase _axis;
  35. private int _profileVelocity = 0;
  36. private int _profileAcceleration = 0;
  37. private int _profileDeceleration = 0;
  38. private int _targetPosition;
  39. private bool _judgeTorqueLimit = false;
  40. private BeckhoffCommonAxis _beckhoffCommonAxis;
  41. #endregion
  42. public CanOpenProfilePositionRoutine(string module,JetAxisBase axis,BeckhoffCommonAxis beckhoffCommonAxis) : base(module)
  43. {
  44. _axis = axis;
  45. _beckhoffCommonAxis = beckhoffCommonAxis;
  46. }
  47. public void Abort()
  48. {
  49. Runner.Stop("Manual Abort");
  50. }
  51. public RState Monitor()
  52. {
  53. Runner.Run(ProfilePositionStep.WriteInitControlWord, () => { return _beckhoffCommonAxis.WriteControlWord(0x2F); },() => { return CheckControlWord(0x2F); },500)
  54. .Run(ProfilePositionStep.ProfileModeOfOperation, () => { return _beckhoffCommonAxis.WriteModeOfMode(AxisModeOfOperation.ProfilePositionMode); },()=> { return CheckModeOfOperation((byte)AxisModeOfOperation.ProfilePositionMode); }, 1000)
  55. .Run(ProfilePositionStep.WriteProfileParameter, () => { return WriteProfileParameter(); },NullFun,100)
  56. .Run(ProfilePositionStep.WriteProfilePositionControlWord, () => { return _beckhoffCommonAxis.WriteControlWord(0x3F); }, () => { return CheckControlWord(0x3F); },1000)
  57. .Delay(ProfilePositionStep.Delay, 1000)
  58. .WaitWithStopCondition(ProfilePositionStep.CheckRun,CheckRun,CheckRunStop)
  59. .Run(ProfilePositionStep.NoneModeOfOperation, () => { return _beckhoffCommonAxis.WriteModeOfMode(AxisModeOfOperation.None); },() => { return CheckModeOfOperation((byte)AxisModeOfOperation.None); },1000)
  60. .Run(ProfilePositionStep.EnableOperation, () => { return _beckhoffCommonAxis.WriteControlWord(0x0F); }, () => { return CheckControlWord(0x0F); },1000)
  61. .End(ProfilePositionStep.End,NullFun,100);
  62. return Runner.Status;
  63. }
  64. private bool WriteProfileParameter()
  65. {
  66. bool result= _beckhoffCommonAxis.WriteVariable(PROFILE_VELOCITY, _profileVelocity);
  67. if(!result)
  68. {
  69. return false;
  70. }
  71. result=_beckhoffCommonAxis.WriteVariable(PROFILE_ACCEL, _profileAcceleration);
  72. if(!result)
  73. {
  74. return false;
  75. }
  76. result=_beckhoffCommonAxis.WriteVariable(PROFILE_DECEL, _profileDeceleration);
  77. if(!result)
  78. {
  79. return false;
  80. }
  81. result= _beckhoffCommonAxis.WriteVariable(TARGET_POSITION, _targetPosition);
  82. return result;
  83. }
  84. public bool CheckModeOfOperation(byte modeOfOperation)
  85. {
  86. return _axis.ModeOfOperation == modeOfOperation;
  87. }
  88. public bool CheckControlWord(ushort controlWord)
  89. {
  90. return _axis.ControlWord == controlWord;
  91. }
  92. private bool CheckRun()
  93. {
  94. if (_judgeTorqueLimit)
  95. {
  96. return _axis.InTargetPosition && !_axis.IsRun && _axis.JudgeCurrentPositionIsInTargetPosition(_targetPosition);
  97. }
  98. else
  99. {
  100. bool isTorqueOver = TorqueIsOverLimit();
  101. //过载同时掉电
  102. if(isTorqueOver&&!_axis.IsSwitchOn)
  103. {
  104. return true;
  105. }
  106. return false;
  107. }
  108. }
  109. /// <summary>
  110. /// Torque是否过载
  111. /// </summary>
  112. /// <returns></returns>
  113. private bool TorqueIsOverLimit()
  114. {
  115. return !_axis.MotionData.TorqueLimited;
  116. }
  117. private bool CheckRunStop()
  118. {
  119. //没有到达目标同时没有运动
  120. bool isStop = !_axis.IsRun&&!_axis.JudgeCurrentPositionIsInTargetPosition(_targetPosition);
  121. if (isStop)
  122. {
  123. ErrorMsg = "position is stop";
  124. return true;
  125. }
  126. if(_judgeTorqueLimit)
  127. {
  128. if(TorqueIsOverLimit())
  129. {
  130. ErrorMsg = "Torque is over limit";
  131. return true;
  132. }
  133. }
  134. return false;
  135. }
  136. public RState Start(params object[] objs)
  137. {
  138. _targetPosition = (int)objs[0];
  139. _profileVelocity = (int)objs[1];
  140. _profileAcceleration = (int)objs[2];
  141. _profileDeceleration = (int)objs[3];
  142. if (objs.Length >= 5)
  143. {
  144. _judgeTorqueLimit = (bool)objs[4];
  145. }
  146. return Runner.Start(Module, "ProfilePosition");
  147. }
  148. }
  149. }