using Aitex.Core.RT.Device;
using Aitex.Core.RT.Routine;
using MECF.Framework.Common.Routine;
using CyberX8_Core;
using CyberX8_RT.Devices.AXIS;
using CyberX8_RT.Devices.PUF;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Aitex.Core.RT.Log;
using MECF.Framework.Common.Utilities;
namespace CyberX8_RT.Modules.PUF
{
public class PufReadyForSwapRoutine : RoutineBase, IRoutine
{
private enum ReadyForSwapStep
{
VacuumOn,
RotationPark,
RotationParkWait,
VerticalPark,
VerticalParkWait,
End
}
#region 常量
private const string WAFER_PRESENT = "WaferPresent";
#endregion
#region 内部变量
private JetAxisBase _rotationAxis;
private JetAxisBase _verticalAxis;
private PufVacuum _vacuum;
#endregion
///
/// 构造函数
///
///
public PufReadyForSwapRoutine(string module) : base(module)
{
}
///
/// 中止
///
public void Abort()
{
Runner.Stop("Manual Abort");
}
///
/// 监控
///
///
public RState Monitor()
{
Runner.Run(ReadyForSwapStep.VacuumOn, VacuumBOn, CheckWaferPresence, _delay_5s)
.Run(ReadyForSwapStep.RotationPark, RotationGotoPark, _delay_1ms)
.WaitWithStopCondition(ReadyForSwapStep.RotationParkWait, () => _rotationAxis.Status == RState.End, CheckRotationStopStatus)
.Run(ReadyForSwapStep.VerticalPark, VerticalGotoPark, _delay_1ms)
.WaitWithStopCondition(ReadyForSwapStep.VerticalParkWait, () => _verticalAxis.Status == RState.End, CheckVerticalStopStatus)
.End(ReadyForSwapStep.End, NullFun, _delay_1ms);
return Runner.Status;
}
///
/// Vacuum B On
///
///
private bool VacuumBOn()
{
bool result = _vacuum.VacuumBOn();
if(!result)
{
NotifyError(eEvent.ERR_PUF, "side B Vacuum on failed", 0);
}
return result;
}
///
/// 检验是否存在Wafer
///
///
private bool CheckWaferPresence()
{
return _vacuum.ChuckBVacuumStatus == WAFER_PRESENT;
}
///
/// Rotation Goto Park
///
///
private bool RotationGotoPark()
{
bool result = _rotationAxis.PositionStation("Park");
if (!result)
{
NotifyError(eEvent.ERR_PUF, "rotation goto park failed", 0);
}
return result;
}
///
/// 检验Rotation异常状态
///
///
private bool CheckRotationStopStatus()
{
bool result = _rotationAxis.Status == RState.Failed || _rotationAxis.Status == RState.Timeout;
if (result)
{
NotifyError(eEvent.ERR_PUF, "rotaion motion failed", 0);
}
return result;
}
///
/// Vertical Goto Park
///
///
private bool VerticalGotoPark()
{
bool result = _verticalAxis.PositionStation("Park");
if (!result)
{
NotifyError(eEvent.ERR_PUF, "vertical goto park failed", 0);
}
return result;
}
///
/// 检验Vertical异常状态
///
///
private bool CheckVerticalStopStatus()
{
bool result = _verticalAxis.Status == RState.Failed || _verticalAxis.Status == RState.Timeout;
if (result)
{
NotifyError(eEvent.ERR_PUF, "vertical motion failed", 0);
}
return result;
}
///
/// 启动
///
///
///
public RState Start(params object[] objs)
{
InitializeParameters();
return Runner.Start(Module, "Start Go to Park For Swap");
}
///
/// 初始化参数
///
private void InitializeParameters()
{
_rotationAxis = DEVICE.GetDevice($"{Module}.Rotation");
_verticalAxis = DEVICE.GetDevice($"{Module}.Vertical");
_vacuum = DEVICE.GetDevice($"{Module}.Vacuum");
}
///
/// 重试
///
///
public RState Retry(int step)
{
InitializeParameters();
List preStepIds = new List();
return Runner.Retry(ReadyForSwapStep.VacuumOn, preStepIds, Module, "ReadyForSwap Retry");
}
///
/// 检验完成情况
///
///
public bool CheckCompleteCondition()
{
double rotationPosition = _rotationAxis.MotionData.MotorPosition;
if (!_rotationAxis.CheckPositionIsInStation(rotationPosition, "Park"))
{
NotifyError(eEvent.ERR_PUF, $"rotation {rotationPosition} not in Park", 0);
return false;
}
double verticalPosition = _verticalAxis.MotionData.MotorPosition;
if (!_verticalAxis.CheckPositionIsInStation(verticalPosition, "Park"))
{
NotifyError(eEvent.ERR_PUF, $"vertical {verticalPosition} not in Park", 0);
return false;
}
return true;
}
}
}