using Aitex.Core.RT.Log; using Aitex.Core.RT.Routine; using CyberX8_Core; using MECF.Framework.Common.Beckhoff.AxisProvider; using MECF.Framework.Common.CommonData.PUF; using MECF.Framework.Common.Routine; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace CyberX8_RT.Devices.AXIS.Yaskawa { public class YaskawaStopPositionRoutine : RoutineBase, IRoutine { private enum StopPositionStep { SetHaltControlWord, CheckStop, WriteTargePosition, ResetHaltControlWord, CheckRun, NoneModeOfOperation, EnableOperation, End } #region 常量 private const string TARGET_POSITION = "TargetPosition"; #endregion #region 内部变量 private JetAxisBase _axis; private int _timeout = 5000; private int _targetPosition; /// /// SRD rotation Provider对象 /// private BeckhoffProviderAxis _rotationProviderAxis; #endregion public YaskawaStopPositionRoutine(string module, JetAxisBase axis) : base(module) { _axis = axis; } public void Abort() { Runner.Stop("Manual Abort"); } public RState Monitor() { Runner.Run(StopPositionStep.SetHaltControlWord, () => { return _axis.WriteControlWord(0X8F); }, () => { return CheckControlWord(0X8F); }, 1000) .WaitWithStopCondition(StopPositionStep.CheckStop, CheckStop, CheckErrorOrWarning, _timeout) .Run(StopPositionStep.WriteTargePosition, () => { return WriteTargetPosition(); }, NullFun, 100) .Run(StopPositionStep.ResetHaltControlWord, () => { return _axis.WriteControlWord(0x3F); }, () => { return CheckControlWord(0x3F); }, 1000) .WaitWithStopCondition(StopPositionStep.CheckRun, CheckRunEnd, CheckRunStop, 5000) .Run(StopPositionStep.NoneModeOfOperation, () => { return _axis.WriteModeOfMode(AxisModeOfOperation.None); }, () => { return CheckModeOfOperation((byte)AxisModeOfOperation.None); }, 1000) .Run(StopPositionStep.EnableOperation, () => { return _axis.EnableOperation(); }, () => { return CheckControlWord(0x0F); }, 1000) .End(StopPositionStep.End, NullFun, 100); return Runner.Status; } public bool CheckModeOfOperation(byte modeOfOperation) { return _axis.ModeOfOperation == modeOfOperation; } public bool CheckControlWord(ushort controlWord) { return _axis.ControlWord == controlWord; } /// /// 设置目标位置为当前位置 /// /// private bool WriteTargetPosition() { double scale = _rotationProviderAxis.ScaleFactor; _targetPosition = (int)Math.Ceiling(_axis.MotionData.MotorPosition * scale); return _axis.WriteVariable(TARGET_POSITION, _targetPosition); } /// /// 检查是否运动完成 /// /// private bool CheckRunEnd() { bool result = _axis.InTargetPosition && !_axis.IsRun; return result; } /// /// 检查是否运动完成 /// /// private bool CheckRunStop() { //没有到达目标同时没有运动 bool isStop = !_axis.IsRun && !_axis.JudgeCurrentPositionIsInTargetPosition(_targetPosition); if (isStop) { ErrorMsg = "position is stop"; return true; } return false; } /// /// 检查Halt是否停下来 /// /// private bool CheckStop() { return !_axis.IsRun; } /// 检验是否出错或告警 /// /// private bool CheckErrorOrWarning() { bool result = _axis.MotionData.Status.ToLower().Contains("error") || _axis.MotionData.Status.ToLower().Contains("warning"); if (result) { LOG.WriteLog(eEvent.ERR_AXIS, Module, $"axis stop occur error or warning"); } return result; } public RState Start(params object[] objs) { _rotationProviderAxis = BeckhoffAxisProviderManager.Instance.GetAxisProvider($"{Module}"); if (_rotationProviderAxis == null) { LOG.WriteLog(eEvent.ERR_AXIS, Module, $"{Module} Axist Provider is not exist"); return RState.Failed; } return Runner.Start(Module, "Stop Position"); } } }