363 lines
12 KiB
C#
363 lines
12 KiB
C#
using Aitex.Core.RT.Device;
|
||
using Aitex.Core.RT.Device.Unit;
|
||
using Aitex.Core.RT.Event;
|
||
using Aitex.Core.RT.Routine;
|
||
using Aitex.Core.RT.SCCore;
|
||
using MECF.Framework.Common.Equipment;
|
||
using SicPM.Devices;
|
||
using System;
|
||
using System.Collections.Generic;
|
||
using System.Diagnostics;
|
||
|
||
namespace SicPM.Routines
|
||
{
|
||
public class PMExchangeMoRoutine : PMBaseRoutine
|
||
{
|
||
private enum RoutineStep
|
||
{
|
||
SetGroupE,
|
||
SetGroupK,
|
||
|
||
SetM7,
|
||
SetM8,
|
||
SetM11,
|
||
SetPc2,
|
||
|
||
OpenV73,
|
||
CloseV73,
|
||
SetGroup1,
|
||
SetGroup11,
|
||
SetGroup2,
|
||
SetGroup3,
|
||
SetGroup4,
|
||
SetGroup5,
|
||
SetGroup6,
|
||
|
||
StartLoop,
|
||
EndLoop,
|
||
|
||
SetM7Default,
|
||
SetM8Default,
|
||
SetPc2Default,
|
||
SetM11Default,
|
||
SetGroupV25,
|
||
|
||
|
||
TimeDelay1,
|
||
TimeDelay2,
|
||
TimeDelay3,
|
||
TimeDelay4,
|
||
TimeDelay5,
|
||
TimeDelay6,
|
||
TimeDelay7,
|
||
TimeDelay8,
|
||
TimeDelay9,
|
||
TimeDelay10,
|
||
TimeDelay11,
|
||
}
|
||
|
||
private bool _isTCS = false; //标记是TMA换源还是TCS换源
|
||
private PMModule _pmModule;
|
||
private ModuleName moduleName;
|
||
private IoInterLock _pmIoInterLock;
|
||
|
||
private int _IoValueOpenCloseTimeout = 10; //开关超时时间
|
||
private int _loopCount;
|
||
private double _OpenTime = 10;
|
||
private double _CLoseTime = 10;
|
||
private int _routineTimeOut;
|
||
|
||
//默认为TMA换源参数
|
||
private int mfc7Or10 = 7;
|
||
private int mfc8Or12 = 8;
|
||
private int mfc11 = 11;
|
||
private int pc2Or3 = 2;
|
||
private List<string> _lstGroupV73 = new List<string>() { "V73" };
|
||
private List<string> _lstGroupV50 = new List<string>() { "V50" };
|
||
private List<string> _lstGroupV48 = new List<string>() { "V48" };
|
||
private List<string> _lstGroupV49 = new List<string>() { "V49" };
|
||
|
||
private List<string> _lstGroup1 = new List<string>() { "V46","V46s","V73" };
|
||
private List<string> _lstGroup2 = new List<string>() { "V46", "V46s" };
|
||
private List<string> _lstGroup3 = new List<string>() { "V43", "V43s", "V45" };
|
||
|
||
private Stopwatch _swTimer = new Stopwatch();
|
||
public PMExchangeMoRoutine(ModuleName module, PMModule pm) : base(module, pm)
|
||
{
|
||
moduleName = module;
|
||
_pmModule = pm;
|
||
Name = "MoExchange";
|
||
_pmIoInterLock = DEVICE.GetDevice<IoInterLock>($"{Module}.PMInterLock");
|
||
}
|
||
|
||
public void Init(string moName)
|
||
{
|
||
if (moName.ToUpper().Contains("TCS"))
|
||
{
|
||
_isTCS = true;
|
||
}
|
||
else
|
||
{
|
||
_isTCS = false;
|
||
}
|
||
}
|
||
|
||
public override Result Start(params object[] objs)
|
||
{
|
||
Reset();
|
||
|
||
if (_pmModule.V69.Status)
|
||
{
|
||
EV.PostAlarmLog(Module, $"can not Exchange Mo,V69 should be Closed");
|
||
return Result.FAIL;
|
||
}
|
||
if (_pmModule.V72.Status)
|
||
{
|
||
EV.PostAlarmLog(Module, $"can not Exchange Mo,V72 should be Closed");
|
||
return Result.FAIL;
|
||
}
|
||
if (_pmModule.V74.Status)
|
||
{
|
||
EV.PostAlarmLog(Module, $"can not Exchange Mo,V74 should be Closed");
|
||
return Result.FAIL;
|
||
}
|
||
if (_pmModule.EPV2.Status)
|
||
{
|
||
EV.PostAlarmLog(Module, $"can not Exchange Mo,EPV2 should be Closed");
|
||
return Result.FAIL;
|
||
}
|
||
|
||
_loopCount = SC.GetValue<int>($"PM.{Module}.MoExchange.CycleCount");
|
||
_OpenTime= SC.GetValue<int>($"PM.{Module}.MoExchange.PumpTime");
|
||
_CLoseTime = SC.GetValue<int>($"PM.{Module}.MoExchange.VentTime");
|
||
_routineTimeOut = SC.GetValue<int>($"PM.{Module}.MoExchange.RoutineTimeOut");
|
||
|
||
|
||
//设置TCS换源参数
|
||
if (_isTCS)
|
||
{
|
||
mfc7Or10 = 10;
|
||
mfc8Or12 = 12;
|
||
pc2Or3 = 3;
|
||
|
||
_lstGroup1 = new List<string>() { "V50"};
|
||
_lstGroup2 = new List<string>() { "V48" };
|
||
_lstGroup3 = new List<string>() { "V49" };
|
||
}
|
||
else
|
||
{
|
||
mfc7Or10 = 7;
|
||
mfc8Or12 = 8;
|
||
pc2Or3 = 2;
|
||
|
||
_lstGroup1 = new List<string>() { "V46" };
|
||
_lstGroup2 = new List<string>() { "V43" };
|
||
_lstGroup3 = new List<string>() { "V45" };
|
||
}
|
||
|
||
if (!_pmIoInterLock.SetPMExchangeMoRoutineRunning(true, out string reason))
|
||
{
|
||
EV.PostAlarmLog(Module, $"can not Exchange Mo,{reason}");
|
||
return Result.FAIL;
|
||
}
|
||
_swTimer.Restart();
|
||
Notify("Start");
|
||
return Result.RUN;
|
||
}
|
||
|
||
|
||
public override Result Monitor()
|
||
{
|
||
try
|
||
{
|
||
if (SC.GetValue<bool>("System.IsATMMode"))
|
||
{
|
||
return Result.DONE;
|
||
}
|
||
|
||
CheckRoutineTimeOut();
|
||
|
||
// 关闭E组和K组的阀门
|
||
SetIoValueByGroup((int)RoutineStep.SetGroupE, IoGroupName.E, false, _IoValueOpenCloseTimeout);
|
||
SetIoValueByGroup((int)RoutineStep.SetGroupK, IoGroupName.K, false, _IoValueOpenCloseTimeout);
|
||
SetIoValueByGroup((int)RoutineStep.SetGroupV25, IoGroupName.V25, true, _IoValueOpenCloseTimeout);
|
||
|
||
|
||
//设定M7,M8 80%,PC2设定Max
|
||
SetMfcValueByPercent((int)RoutineStep.SetM7, mfc7Or10, 80);
|
||
SetMfcValueByPercent((int)RoutineStep.SetM8, mfc8Or12, 80);
|
||
if (_isTCS)
|
||
{
|
||
SetMfcValueByPercent((int)RoutineStep.SetM11, mfc11, 80);
|
||
}
|
||
SetPCValueByPercent((int)RoutineStep.SetPc2, pc2Or3, 100);
|
||
|
||
//打开V73,V46,V46s,保持30s
|
||
SetIoValueByList((int)RoutineStep.OpenV73, _lstGroupV73, true, _IoValueOpenCloseTimeout);
|
||
SetIoValueByList((int)RoutineStep.SetGroup11, _lstGroup1, true, _IoValueOpenCloseTimeout);
|
||
TimeDelay((int)RoutineStep.TimeDelay1, 30);
|
||
|
||
//Loop
|
||
Loop((int)RoutineStep.StartLoop, _loopCount);
|
||
SetIoValueByList((int)RoutineStep.SetGroup1, _lstGroup1, false, _IoValueOpenCloseTimeout);
|
||
SetIoValueByList((int)RoutineStep.SetGroup2, _lstGroup2, true, _IoValueOpenCloseTimeout);
|
||
SetIoValueByList((int)RoutineStep.SetGroup3, _lstGroup3, true, _IoValueOpenCloseTimeout);
|
||
TimeDelay((int)RoutineStep.TimeDelay2, _OpenTime);
|
||
|
||
//SetIoValueByList((int)RoutineStep.SetGroup4, _lstGroup3, false, _IoValueOpenCloseTimeout);
|
||
SetIoValueByList((int)RoutineStep.SetGroup5, _lstGroup2, false, _IoValueOpenCloseTimeout);
|
||
SetIoValueByList((int)RoutineStep.SetGroup6, _lstGroup1, true, _IoValueOpenCloseTimeout);
|
||
TimeDelay((int)RoutineStep.TimeDelay3, _CLoseTime);
|
||
|
||
EndLoop((int)RoutineStep.EndLoop);
|
||
|
||
//关闭V73,V46,V46s
|
||
SetIoValueByList((int)RoutineStep.SetGroup6, _lstGroup1, false, _IoValueOpenCloseTimeout);
|
||
SetIoValueByList((int)RoutineStep.CloseV73, _lstGroupV73, false, _IoValueOpenCloseTimeout);
|
||
|
||
SetMfcValueToDefaultByID((int)RoutineStep.SetM7Default, mfc7Or10);
|
||
SetMfcValueToDefaultByID((int)RoutineStep.SetM8Default, mfc8Or12);
|
||
if (_isTCS)
|
||
{
|
||
SetMfcValueToDefaultByID((int)RoutineStep.SetM11Default, mfc11);
|
||
}
|
||
SetPcToDefault((int)RoutineStep.SetPc2Default, new List<int> { pc2Or3 });
|
||
|
||
}
|
||
catch (RoutineBreakException)
|
||
{
|
||
return Result.RUN;
|
||
}
|
||
catch (RoutineFaildException)
|
||
{
|
||
return Result.FAIL;
|
||
}
|
||
|
||
Notify($"Finished ! Elapsed time: {(int)(_swTimer.ElapsedMilliseconds / 1000)} s");
|
||
_swTimer.Stop();
|
||
SetRoutineRuningDo();
|
||
return Result.DONE;
|
||
}
|
||
|
||
private void SetRoutineRuningDo()
|
||
{
|
||
_pmIoInterLock.DoExchangeMoRoutineRunning = false;
|
||
}
|
||
|
||
public override void Abort()
|
||
{
|
||
SetRoutineRuningDo();
|
||
|
||
PMDevice.SetIoValue(_lstGroup1,false);
|
||
PMDevice.SetIoValue(_lstGroup2, false);
|
||
PMDevice.SetMfcValueToDefault(new List<int> { mfc7Or10 });
|
||
PMDevice.SetMfcValueToDefault(new List<int> { mfc8Or12 });
|
||
PMDevice.SetMfcValueToDefault(new List<int> { mfc11 });
|
||
PMDevice.SetPCValueToDefault(new List<int> { pc2Or3 });
|
||
PMDevice.SetRotationServo(0, 0);
|
||
|
||
base.Abort();
|
||
}
|
||
private void CheckRoutineTimeOut()
|
||
{
|
||
if (_routineTimeOut > 10)
|
||
{
|
||
if ((int)(_swTimer.ElapsedMilliseconds / 1000) > _routineTimeOut)
|
||
{
|
||
EV.PostAlarmLog(Module, $"Routine TimeOut! over {_routineTimeOut} s");
|
||
throw (new RoutineFaildException());
|
||
}
|
||
}
|
||
}
|
||
|
||
private void SetIoValueByList(int id, List<string> lstIo, bool close, int timeout)
|
||
{
|
||
Tuple<bool, Result> ret = ExecuteAndWait(id, () =>
|
||
{
|
||
_pmModule.SetIoValue(lstIo, close);
|
||
return true;
|
||
}, () =>
|
||
{
|
||
return _pmModule.CheckIoValue(lstIo, close);
|
||
},
|
||
timeout * 1000);
|
||
|
||
if (ret.Item1)
|
||
{
|
||
if (ret.Item2 == Result.FAIL)
|
||
{
|
||
throw (new RoutineFaildException());
|
||
}
|
||
else if (ret.Item2 == Result.TIMEOUT)
|
||
{
|
||
throw (new RoutineFaildException());
|
||
}
|
||
else
|
||
throw (new RoutineBreakException());
|
||
}
|
||
}
|
||
|
||
private void SetMfcValueToDefaultByID(int id, int mfcID)
|
||
{
|
||
Tuple<bool, Result> ret = Execute(id, () =>
|
||
{
|
||
List<int> lst = new List<int> { mfcID };
|
||
_pmModule.SetMfcModelToNormal(lst);
|
||
_pmModule.SetMfcValueToDefault(lst);
|
||
return true;
|
||
});
|
||
|
||
if (ret.Item1)
|
||
{
|
||
if (ret.Item2 == Result.FAIL)
|
||
{
|
||
throw (new RoutineFaildException());
|
||
}
|
||
else
|
||
throw (new RoutineBreakException());
|
||
}
|
||
}
|
||
|
||
|
||
private void SetMfcValueByPercent(int id,int mfcID, double percent)
|
||
{
|
||
Tuple<bool, Result> ret = Execute(id, () =>
|
||
{
|
||
_pmModule.SetMfcModelToNormal(new List<int> { mfcID });
|
||
_pmModule.SetMfcValueByPercent(mfcID, percent);
|
||
return true;
|
||
});
|
||
|
||
if (ret.Item1)
|
||
{
|
||
if (ret.Item2 == Result.FAIL)
|
||
{
|
||
throw (new RoutineFaildException());
|
||
}
|
||
else
|
||
throw (new RoutineBreakException());
|
||
}
|
||
}
|
||
|
||
private void SetPCValueByPercent(int id,int pcID,double percent)
|
||
{
|
||
Tuple<bool, Result> ret = Execute(id, () =>
|
||
{
|
||
_pmModule.SetPcModelToNormal(new List<int> { pcID });
|
||
_pmModule.SetPCValueByPercent(pcID, percent);
|
||
return true;
|
||
});
|
||
|
||
if (ret.Item1)
|
||
{
|
||
if (ret.Item2 == Result.FAIL)
|
||
{
|
||
throw (new RoutineFaildException());
|
||
}
|
||
else
|
||
throw (new RoutineBreakException());
|
||
}
|
||
}
|
||
}
|
||
}
|