563 lines
22 KiB
C#
563 lines
22 KiB
C#
using Aitex.Core.RT.Device;
|
||
using Aitex.Core.RT.Device.Devices;
|
||
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.DBCore;
|
||
using MECF.Framework.Common.Equipment;
|
||
using System;
|
||
using System.Collections.Generic;
|
||
using System.Diagnostics;
|
||
|
||
namespace SicPM1.Routines
|
||
{
|
||
public class PMLeakCheckRoutine : PMBaseRoutine
|
||
{
|
||
private enum RoutineStep
|
||
{
|
||
RotationEnable,
|
||
HeatEnable,
|
||
VentPumpClose,
|
||
ArSupply,
|
||
|
||
SetGroupA,
|
||
SetGroupB,
|
||
SetGroupC,
|
||
SetGroupE,
|
||
SetGroupF,
|
||
SetGroupH,
|
||
SetGroupD,
|
||
SetGroupG,
|
||
SetGroupK,
|
||
|
||
SetMFCMode,
|
||
SetPCMode,
|
||
|
||
SetM1to16,
|
||
SetPC,
|
||
SetGroupJ,
|
||
SetM291519to38,
|
||
|
||
SetGasOut,
|
||
SetTv,
|
||
|
||
SetGasIn1, //V68
|
||
OpenFinal1, //V91-96
|
||
SetMfcFinal1, //M32-38
|
||
SetMfc19to26,
|
||
|
||
SetTVCloseMode,
|
||
SetTvPositionToZero,
|
||
|
||
SetGasIn2,
|
||
SetGroupJOpen,
|
||
SetM291519to26,
|
||
|
||
OpenFinal2,
|
||
CloseFinal2,
|
||
SetMfcFinal2,
|
||
|
||
SetEPV1,
|
||
SetEPV2,
|
||
SetTvMode,
|
||
SetTVEnable,
|
||
SetTVPressMode,
|
||
SetTv1,
|
||
WaitTv1,
|
||
SetM2toM40,
|
||
SetTVPositionMode,
|
||
SetTVPositionMode_1,
|
||
SetTVPositionMax,
|
||
SetTVPositionMax_1,
|
||
SetTVPressMode1,
|
||
SetM2TOM40Default,
|
||
SetM2toM40_1,
|
||
|
||
SetTvOpen,
|
||
SetTvModeToPress,
|
||
SetTVtoCurrent,
|
||
RoutinePre,
|
||
|
||
SetPressureUp,
|
||
SetPressureDown,
|
||
WaitPressureDown,
|
||
WaitPressureUp,
|
||
VentPumpOpen,
|
||
|
||
PressureToMax,
|
||
PressureToMin,
|
||
|
||
StartLoop,
|
||
EndLoop,
|
||
|
||
SetMfc28to31,
|
||
SetReactorPress,
|
||
CloseFinanl1,
|
||
CloseFinanl2,
|
||
CloseEPV2,
|
||
SetTVCloseMode2,
|
||
CLoseTvvvv,
|
||
SetEPVVV2,
|
||
CLoseEPV1,
|
||
CheckPM1000,
|
||
WaitPressUpTo1000,
|
||
WaitPressUpTo1020,
|
||
|
||
SetPressUpOrDown1,
|
||
SetPressUpOrDown2,
|
||
SetMfc28to40Special,
|
||
WaitPmPressureUp,
|
||
SetMfc28to40Default,
|
||
|
||
SetV75,
|
||
SetV76,
|
||
SetV751,
|
||
SetV761,
|
||
|
||
SetPC567Close,
|
||
SetPC567Mode,
|
||
SetPC567Default,
|
||
OpenEPV2,
|
||
WaitPressUpTo20,
|
||
SetMfc291519to38,
|
||
WaitPressUpTo0,
|
||
SetMfc291519to38ToDefault,
|
||
WaitPressDownTo20,
|
||
SetPmPressureTo20,
|
||
CloseMfcFinal1,
|
||
CloseMfcFinal2,
|
||
CloseMfc2915,
|
||
CheckFinal1Open,
|
||
DoLeakCheck,
|
||
CalcLeakCheck,
|
||
SetTVClose,
|
||
CloseTV,
|
||
CloseV27,
|
||
CloseV28,
|
||
CloseV69,
|
||
CloseV70,
|
||
SetGroupV25,
|
||
SetV31,
|
||
SetV32,
|
||
SetV35V36,
|
||
|
||
SetV92V93V95,
|
||
SetV94,
|
||
SetV96,
|
||
SetV68,
|
||
SetM32M35M37,
|
||
SetM36,
|
||
SetM38,
|
||
|
||
CloseM32M35M37,
|
||
CloseM36,
|
||
CloseM38,
|
||
CloseGasIn1,
|
||
|
||
|
||
TimeDelay1,
|
||
TimeDelay2,
|
||
TimeDelay3,
|
||
TimeDelay4,
|
||
TimeDelay5,
|
||
TimeDelay6,
|
||
TimeDelay7,
|
||
TimeDelay8,
|
||
TimeDelay9,
|
||
TimeDelay10,
|
||
TimeDelay11,
|
||
TimeDelay12,
|
||
TimeDelay13,
|
||
TimeDelay14,
|
||
TimeDelay15,
|
||
TimeDelay16,
|
||
TimeDelay17,
|
||
}
|
||
|
||
enum LeakCheckType
|
||
{
|
||
ChamberOnly,
|
||
|
||
ChamberAndGasline,
|
||
|
||
ChamberAndGaslineToFacility,
|
||
}
|
||
|
||
private ModuleName moduleName;
|
||
|
||
private IoThrottleValve2 _IoThrottle;
|
||
private IoInterLock _pmIoInterLock;
|
||
|
||
|
||
List<int> _lstPcList = new List<int> { 1, 2, 3, 4, 5, 6, 7 };
|
||
|
||
private int _rotationCheckSpeed = 0; //设置旋转速度为0后检查是否转速低于此数值
|
||
private int _rotationCloseTimeout; //旋转停止超时
|
||
private int _heatTimeOut = 5; //Heat关闭等待Di反馈超时时间
|
||
|
||
private double _pressureMax; //Loop压力上限可设置600-800)
|
||
private double _pressureMin; //Loop压力下限可设置 0-400)
|
||
private int _pressureLoopCount; //Loop次数
|
||
private int _pressureMinDelay;
|
||
private int _pressureMaxDelay;
|
||
private int _pressureMinTimeout;
|
||
private int _pressureMaxTimeout;
|
||
|
||
private int _IoValueOpenCloseTimeout = 10; //开关阀门超时时间
|
||
private double _pmPressureMaxDiff; //蝶阀与目标压力的差值范围(认为调整到位了)
|
||
private int _throttleTimeout; //蝶阀调整到指定压力的超时时间
|
||
|
||
private int _paramContinuePumpTime;
|
||
private int _paramLeakCheckTime ;
|
||
private double _beginPressure;
|
||
private double _beginTime;
|
||
private int _calTimes; //第几次计算LeakCheck的值(每60秒计算一次)
|
||
private double _leakSpec;
|
||
private int _routineTimeOut;
|
||
//private int _EPV2OpenDelayTime = 9;
|
||
|
||
private bool _useSettingValue = false;
|
||
|
||
private Stopwatch _swTimer = new Stopwatch();
|
||
public int ElapsedTime
|
||
{
|
||
get { return _swTimer.IsRunning ? (int)(_swTimer.ElapsedMilliseconds / 1000) : 0; }
|
||
}
|
||
|
||
public PMLeakCheckRoutine(ModuleName module, PM1Module pm1) : base(module, pm1)
|
||
{
|
||
Module = module.ToString();
|
||
Name = "Leak Check";
|
||
|
||
|
||
_IoThrottle = DEVICE.GetDevice<IoThrottleValve2>($"{Module}.TV");
|
||
}
|
||
|
||
internal void Init(int pumpTime, int leakCheckTime)
|
||
{
|
||
_paramContinuePumpTime = pumpTime;
|
||
_paramLeakCheckTime = leakCheckTime;
|
||
_useSettingValue = true;
|
||
}
|
||
|
||
internal void Init()
|
||
{
|
||
_useSettingValue = false;
|
||
}
|
||
|
||
public override Result Start(params object[] objs)
|
||
{
|
||
Reset();
|
||
|
||
_swTimer.Restart();
|
||
|
||
|
||
_rotationCloseTimeout = SC.GetValue<int>($"PM.{Module}.RotationCloseTimeout");
|
||
_pmPressureMaxDiff = SC.GetValue<double>($"PM.{Module}.ThrottlePressureMaxDiff");
|
||
_throttleTimeout = SC.GetValue<int>($"PM.{Module}.ThrottlePressureTimeout");
|
||
_pmIoInterLock = DEVICE.GetDevice<IoInterLock>($"{Module}.PMInterLock");
|
||
_rotationCloseTimeout = SC.GetValue<int>($"PM.{Module}.RotationCloseTimeout");
|
||
|
||
_pressureLoopCount = SC.GetValue<int>($"PM.{Module}.LeakCheck.CyclePurgeCount");
|
||
_pressureMin = SC.GetValue<double>($"PM.{Module}.LeakCheck.PumpBasePressure");
|
||
_pressureMinDelay = SC.GetValue<int>($"PM.{Module}.LeakCheck.PumpDelayTime");
|
||
_pressureMinTimeout = SC.GetValue<int>($"PM.{Module}.LeakCheck.PumpTimeout");
|
||
_pressureMax = SC.GetValue<double>($"PM.{Module}.LeakCheck.VentBasePressure");
|
||
_pressureMaxDelay = SC.GetValue<int>($"PM.{Module}.LeakCheck.VentDelayTime");
|
||
_pressureMaxTimeout = SC.GetValue<int>($"PM.{Module}.LeakCheck.VentTimeout");
|
||
_routineTimeOut = SC.GetValue<int>($"PM.{Module}.LeakCheck.RoutineTimeOut");
|
||
//_EPV2OpenDelayTime = SC.GetValue<int>($"PM.{Module}.TimeDelayAlterEPV2Open");
|
||
|
||
if (!_useSettingValue)
|
||
{
|
||
_paramContinuePumpTime = SC.GetValue<int>($"PM.{Module}.LeakCheck.ContinuePumpTime");
|
||
_paramLeakCheckTime = SC.GetValue<int>($"PM.{Module}.LeakCheck.LeakCheckDelayTime");
|
||
}
|
||
|
||
_leakSpec = SC.GetValue<double>($"PM.{Module}.LeakCheck.LeakSpec");
|
||
|
||
if (!PmDevice.SetIOValueByGroup(IoGroupName.V70, false))
|
||
{
|
||
EV.PostAlarmLog(Module,"Can not close V70-1");
|
||
return Result.FAIL;
|
||
}
|
||
|
||
Notify($"Start LoopCount:{_pressureLoopCount}");
|
||
return Result.RUN;
|
||
}
|
||
|
||
public override Result Monitor()
|
||
{
|
||
try
|
||
{
|
||
CheckRoutineTimeOut();
|
||
|
||
//关闭V76,打开V75
|
||
SetIoValueByGroup((int)RoutineStep.SetV76, IoGroupName.V76, false, _IoValueOpenCloseTimeout);
|
||
SetIoValueByGroup((int)RoutineStep.SetV75, IoGroupName.V75, true, _IoValueOpenCloseTimeout);
|
||
|
||
//旋转停止,加热停止
|
||
SetHeatEnable((int)RoutineStep.HeatEnable, false, _heatTimeOut);
|
||
SetRotationValve((int)RoutineStep.RotationEnable, _rotationCheckSpeed, false, _rotationCloseTimeout);
|
||
|
||
//关闭V72,打开V25
|
||
SetIoValueByGroup((int)RoutineStep.VentPumpClose, IoGroupName.VentPump, false, _IoValueOpenCloseTimeout);
|
||
SetIoValueByGroup((int)RoutineStep.SetGroupV25, IoGroupName.V25, true, _IoValueOpenCloseTimeout);
|
||
|
||
//打开V31,打开V32
|
||
SetIoValueByGroup((int)RoutineStep.SetV31, IoGroupName.V31, true, _IoValueOpenCloseTimeout);
|
||
SetIoValueByGroup((int)RoutineStep.SetV32, IoGroupName.V32, true, _IoValueOpenCloseTimeout);
|
||
|
||
//打开V35,打开V36
|
||
SetIoValueByGroup((int)RoutineStep.SetV35V36, IoGroupName.V35V36, true, _IoValueOpenCloseTimeout);
|
||
|
||
//关闭B/C/E/F/H/K 阀门
|
||
SetIoValueByGroup((int)RoutineStep.SetGroupB, IoGroupName.B, false, _IoValueOpenCloseTimeout);
|
||
SetIoValueByGroup((int)RoutineStep.SetGroupC, IoGroupName.C, false, _IoValueOpenCloseTimeout);
|
||
SetIoValueByGroup((int)RoutineStep.SetGroupE, IoGroupName.E, false, _IoValueOpenCloseTimeout);
|
||
SetIoValueByGroup((int)RoutineStep.SetGroupF, IoGroupName.F, false, _IoValueOpenCloseTimeout);
|
||
SetIoValueByGroup((int)RoutineStep.SetGroupH, IoGroupName.H, false, _IoValueOpenCloseTimeout);
|
||
SetIoValueByGroup((int)RoutineStep.SetGroupK, IoGroupName.K, false, _IoValueOpenCloseTimeout);
|
||
|
||
//打开D/G 阀门
|
||
SetIoValueByGroup((int)RoutineStep.SetGroupD, IoGroupName.D, true, _IoValueOpenCloseTimeout);
|
||
SetIoValueByGroup((int)RoutineStep.SetGroupG, IoGroupName.G, true, _IoValueOpenCloseTimeout);
|
||
|
||
//设置MFC和PC的模式
|
||
SetMfcModeToNormalByGroup((int)RoutineStep.SetMFCMode, MfcGroupName.All);
|
||
SetPcModeToNormal((int)RoutineStep.SetPCMode, _lstPcList);
|
||
|
||
//M1-M16设定为default值(M2、M9、M15除外)
|
||
SetMfcToDefaultByGroup((int)RoutineStep.SetM1to16, MfcGroupName.M1to16, 0);
|
||
|
||
//设置所有PC到默认值
|
||
SetPcToDefault((int)RoutineStep.SetPC, _lstPcList);
|
||
|
||
//设置M2,M9,M15,M19-M26 3s ramp 到default 值
|
||
SetMfcToDefaultByGroup((int)RoutineStep.SetM291519to26, MfcGroupName.M2toM26, 3);
|
||
|
||
//打开V68
|
||
SetIoValueByGroup((int)RoutineStep.SetV68, IoGroupName.GasIn1, true, _IoValueOpenCloseTimeout);
|
||
|
||
//打开J阀门
|
||
SetIoValueByGroup((int)RoutineStep.SetGroupJ, IoGroupName.J, true, _IoValueOpenCloseTimeout);
|
||
|
||
//打开EPV2
|
||
SetIoValueByGroup((int)RoutineStep.SetEPV2, IoGroupName.EPV2, true, _IoValueOpenCloseTimeout);
|
||
TimeDelay((int)RoutineStep.TimeDelay1, 3);
|
||
|
||
//设置蝶阀Enable
|
||
SetThrottleEnableAndWait((int)RoutineStep.SetTVEnable, _IoThrottle, 5);
|
||
|
||
//设置蝶阀为压力模式
|
||
SetThrottleToPressModeAndWait((int)RoutineStep.SetTVPressMode, _IoThrottle, 5);
|
||
|
||
//伺服压力设定值到0mbar
|
||
SetThrottlePressureAndWaitSetPoint((int)RoutineStep.SetTv1, _IoThrottle, _pressureMin, _pmPressureMaxDiff, _throttleTimeout);
|
||
|
||
//M2、M9、M15、M19-M40 MFC 3s ramp到0
|
||
SetMfcByGroup((int)RoutineStep.SetM2toM40, MfcGroupName.M2toM40, 0, 3);
|
||
|
||
//等待腔体压力Pump到设定值
|
||
WaitChamberPressDownTo((int)RoutineStep.WaitTv1, _pressureMin, _pmPressureMaxDiff, _throttleTimeout);
|
||
|
||
TimeDelay((int)RoutineStep.TimeDelay8, 3);
|
||
|
||
//蝶阀设置为位置模式,开度设置为最大
|
||
SetThrottleToPositionMode((int)RoutineStep.SetTVPositionMode, _IoThrottle, _throttleTimeout);
|
||
SetThrottleSetPosition((int)RoutineStep.SetTVPositionMax, _IoThrottle, 100, _throttleTimeout);
|
||
|
||
TimeDelay((int)RoutineStep.TimeDelay9,3);
|
||
|
||
//循环开始
|
||
Loop((int)RoutineStep.StartLoop, _pressureLoopCount);
|
||
|
||
//M2、M9、M15、M19-M40 MFC 3s ramp 到 default 值
|
||
SetMfcToDefaultByGroup((int)RoutineStep.SetM2TOM40Default, MfcGroupName.M2toM40, 3);
|
||
|
||
//设置蝶阀为压力模式
|
||
SetThrottleToPressModeAndWait((int)RoutineStep.SetTVPressMode1, _IoThrottle, 5);
|
||
|
||
//使用动态流量伺服到300mbar
|
||
SetPressureUpOrDown((int)RoutineStep.SetPressUpOrDown1, PressureUpOrDown.Uping);
|
||
SetThrottleToTargetAndNoWait((int)RoutineStep.SetPressureUp, _IoThrottle, _pressureMax);
|
||
WaitThrottleToPressureAndSetMfcSpecial((int)RoutineStep.WaitPressureUp, _IoThrottle, _pressureMax, _pmPressureMaxDiff, _pressureMaxTimeout);
|
||
TimeDelay((int)RoutineStep.TimeDelay10, _pressureMaxDelay);
|
||
|
||
//M2、M9、M15、M19-M40 MFC 3s ramp 0
|
||
SetMfcByGroup((int)RoutineStep.SetM2toM40_1, MfcGroupName.M2toM40, 0, 3);
|
||
|
||
//伺服到0mbar
|
||
SetThrottlePressureAndWait((int)RoutineStep.SetPressureDown, _IoThrottle, _pressureMin, _pmPressureMaxDiff, _throttleTimeout);
|
||
|
||
TimeDelay((int)RoutineStep.TimeDelay11,3);
|
||
|
||
//蝶阀设置为位置模式,开度设置为最大
|
||
SetThrottleToPositionMode((int)RoutineStep.SetTVPositionMode_1, _IoThrottle, _throttleTimeout);
|
||
SetThrottleSetPositionNoWait((int)RoutineStep.SetTVPositionMax_1, _IoThrottle, 100, _throttleTimeout);
|
||
|
||
TimeDelay((int)RoutineStep.TimeDelay12, _pressureMinDelay);
|
||
|
||
EndLoop((int)RoutineStep.EndLoop);
|
||
|
||
//依次关闭Final1
|
||
SetIoValueByGroup((int)RoutineStep.CloseGasIn1, IoGroupName.GasIn1, false, _IoValueOpenCloseTimeout);
|
||
Delay((int)RoutineStep.TimeDelay13, 5);
|
||
|
||
//关闭M32,M35,M36,M37,M38
|
||
SetMfcByGroup((int)RoutineStep.CloseM32M35M37, MfcGroupName.M32M35M37, 0, 5);
|
||
SetMfcByGroup((int)RoutineStep.CloseM36, MfcGroupName.M36, 0, 5);
|
||
SetMfcByGroup((int)RoutineStep.CloseM38, MfcGroupName.M38, 0, 5);
|
||
|
||
Delay((int)RoutineStep.TimeDelay14, 5);
|
||
|
||
//关闭Final1阀
|
||
SetIoValueByGroup((int)RoutineStep.CloseFinanl1, IoGroupName.Final1, false, _IoValueOpenCloseTimeout);
|
||
|
||
//关闭Final2
|
||
SetIoValueByGroup((int)RoutineStep.CloseFinal2, IoGroupName.Final2, false, _IoValueOpenCloseTimeout);
|
||
|
||
//延时
|
||
TimeDelay((int)RoutineStep.TimeDelay15, _paramContinuePumpTime);
|
||
|
||
//先关蝶阀,再关闭EPV2
|
||
SetThrottleToCloseMode((int)RoutineStep.SetTVCloseMode2, _IoThrottle, 8);
|
||
SetThrottleDisable((int)RoutineStep.CLoseTvvvv, _IoThrottle, 8);
|
||
TimeDelay((int)RoutineStep.TimeDelay16, 1);
|
||
SetIoValueByGroup((int)RoutineStep.SetEPVVV2, IoGroupName.EPV2, false, _IoValueOpenCloseTimeout);
|
||
|
||
//计算漏率
|
||
DoLeakCheck((int)RoutineStep.DoLeakCheck, _paramLeakCheckTime);
|
||
TimeDelay((int)RoutineStep.TimeDelay17, _paramLeakCheckTime);
|
||
CalcLeakCheck((int)RoutineStep.CalcLeakCheck, _paramLeakCheckTime);
|
||
//CalcLeackCheckPerMinute(_paramLeakCheckTime);
|
||
}
|
||
catch (RoutineBreakException)
|
||
{
|
||
return Result.RUN;
|
||
}
|
||
catch (RoutineFaildException)
|
||
{
|
||
return Result.FAIL;
|
||
}
|
||
|
||
_swTimer.Stop();
|
||
return Result.DONE;
|
||
}
|
||
|
||
public override void Abort()
|
||
{
|
||
Stop($"{Module} leak check aborted");
|
||
_swTimer.Stop();
|
||
PmDevice._ioThrottleValve.StopRamp();
|
||
PmDevice.SetMfcStopRamp(PmDevice.GetMfcListByGroupName(MfcGroupName.All));
|
||
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());
|
||
}
|
||
}
|
||
}
|
||
|
||
public void DoLeakCheck(int id, double time)
|
||
{
|
||
Tuple<bool, Result> ret = Execute(id, () =>
|
||
{
|
||
Notify($"Keep pressure for {time} seconds");
|
||
|
||
_beginTime = _swTimer.ElapsedMilliseconds;
|
||
_beginPressure = PmDevice.ChamberPressure;
|
||
_calTimes = 1;
|
||
return true;
|
||
});
|
||
if (ret.Item1)
|
||
{
|
||
if (ret.Item2 == Result.FAIL)
|
||
{
|
||
throw (new RoutineFaildException());
|
||
}
|
||
else
|
||
throw (new RoutineBreakException());
|
||
}
|
||
}
|
||
|
||
public void CalcLeackCheckPerMinute(int time)
|
||
{
|
||
//大于LeakCheck时间,
|
||
if ((int)((_swTimer.ElapsedMilliseconds - _beginTime) / 1000) >= time)
|
||
{
|
||
int leakSecond = (int)((_swTimer.ElapsedMilliseconds - _beginTime) / 1000);
|
||
double endPressure = PmDevice.ChamberPressure;
|
||
double leakSpan = endPressure - _beginPressure;
|
||
double leakRate = (endPressure - _beginPressure) / (leakSecond / 60.0);
|
||
if (leakRate > _leakSpec)
|
||
{
|
||
LeakCheckDataRecorder.Add(time, (int)_beginPressure, (int)endPressure, leakRate, Result.FAIL.ToString(), "", Module);
|
||
EV.PostInfoLog(Module, $"Leak check result: end at {DateTime.Now.ToString("HH:mm:ss")}, start: {_beginPressure:F2}mbar, end: {endPressure:F2}mbar, using {time} seconds, leak rate: {leakRate:F2}");
|
||
|
||
}
|
||
else
|
||
{
|
||
LeakCheckDataRecorder.Add(time, (int)_beginPressure, (int)endPressure, leakRate, Result.Succeed.ToString(), "", Module);
|
||
EV.PostInfoLog(Module, $"Leak check result: end at {DateTime.Now.ToString("HH:mm:ss")}, start: {_beginPressure:F2}mbar, end: {endPressure:F2}mbar, using {time} seconds, leak rate: {leakRate:F2}");
|
||
|
||
}
|
||
}
|
||
else
|
||
{
|
||
if ((int)((_swTimer.ElapsedMilliseconds - _beginTime) / 1000) >= 60 * _calTimes)
|
||
{
|
||
_calTimes++;
|
||
int leakSecond = (int)((_swTimer.ElapsedMilliseconds - _beginTime) / 1000);
|
||
double endPressure = PmDevice.ChamberPressure;
|
||
double leakSpan = endPressure - _beginPressure;
|
||
double leakRate = (endPressure - _beginPressure) / (leakSecond / 60.0);
|
||
if (leakRate > _leakSpec)
|
||
{
|
||
EV.PostInfoLog(Module, $"Leak check Failed Count {_calTimes - 1}: using {leakSecond} seconds, leak rate: {leakRate:F2} ,Rate over {_leakSpec}");
|
||
|
||
throw (new RoutineFaildException());
|
||
}
|
||
EV.PostInfoLog(Module, $"Leak check Count {_calTimes - 1}: using {leakSecond} seconds, leak rate: {leakRate:F2}");
|
||
}
|
||
throw (new RoutineBreakException());
|
||
}
|
||
}
|
||
|
||
|
||
public void CalcLeakCheck(int id, int time)
|
||
{
|
||
Tuple<bool, Result> ret = Execute(id, () =>
|
||
{
|
||
double endPressure = PmDevice.ChamberPressure;
|
||
double leakSpan = endPressure - _beginPressure;
|
||
double leakRate = (endPressure - _beginPressure) / (time / 60.0);
|
||
if (leakRate > _leakSpec)
|
||
{
|
||
LeakCheckDataRecorder.Add(time, (int)_beginPressure, (int)endPressure, leakRate, Result.FAIL.ToString(), "", Module);
|
||
|
||
EV.PostInfoLog(Module,$"Leak check result: end at {DateTime.Now.ToString("HH:mm:ss")}, start: {_beginPressure:F2}mbar, end: {endPressure:F2}mbar, using {time} seconds, leak rate: {leakRate:F2}");
|
||
return false;
|
||
}
|
||
else
|
||
{
|
||
LeakCheckDataRecorder.Add(time, (int)_beginPressure, (int)endPressure, leakRate, Result.Succeed.ToString(), "", Module);
|
||
|
||
EV.PostInfoLog(Module,$"Leak check result: end at {DateTime.Now.ToString("HH:mm:ss")}, start: {_beginPressure:F2}mbar, end: {endPressure:F2}mbar, using {time} seconds, leak rate: {leakRate:F2}");
|
||
return true;
|
||
}
|
||
});
|
||
}
|
||
}
|
||
}
|