| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284 | using Aitex.Core.Common.DeviceData;using Aitex.Core.RT.Device;using Aitex.Core.RT.Device.Unit;using Aitex.Core.RT.SCCore;using Aitex.Core.RT.Log;using Aitex.Core.Util;using MECF.Framework.Common.Device.Bases;using MECF.Framework.Common.Equipment;using System;using System.Collections.Generic;using Venus_Core;using Venus_RT.Modules;using Venus_RT.Devices.IODevices;using Venus_RT.Devices.EPD;using MECF.Framework.Common.SubstrateTrackings;using IoMfc = Venus_RT.Devices.IODevices.IoMfc;using System.Threading.Tasks;using Aitex.Core.RT.DataCenter;using Aitex.Core.Backend;using Aitex.Core.RT.OperationCenter;using Aitex.Core.RT.Event;using System.Diagnostics;namespace Venus_RT.Devices{    class JetKepler2300PM : JetPMBase    {        private readonly IoLid _Lid;        //private readonly IoLid _LidLoadlock;        private readonly IoCylinder _slitDoor;        private readonly IoCylinder _LiftPin;        private readonly IoCylinder _LoadLockArm;        private readonly IoValve _PVN21Valve;        private readonly IoValve _PVN22Valve;        private readonly IoValve _PV11Valve;        private readonly IoValve _PV12Valve;        private readonly IoValve _PV21Valve;        private readonly IoValve _PV22Valve;        private readonly IoValve _PV31Valve;        private readonly IoValve _PV32Valve;        private readonly IoValve _PV41Valve;        private readonly IoValve _PV42Valve;        private readonly IoValve _N2Valve;        private readonly IoValve _Mfc1Valve;        private readonly IoValve _Mfc2Valve;        private readonly IoValve _Mfc3Valve;        private readonly IoValve _Mfc4Valve;        private readonly IoValve _Mfc5Valve;        private readonly IoValve _Mfc6Valve;        private readonly IoValve _Mfc7Valve;        private readonly IoValve _Mfc8Valve;        private readonly IoValve _PVHe1Valve;        private readonly IoValve _PVHe2Valve;        private readonly IoValve _GasFinalValve;        private readonly IoValve _SoftPumpValve;        private readonly IoValve _FastPumpValve;        private readonly IoValve _TurboPumpPumpingValve;        private readonly IoValve _TurboPumpPurgeValve;        private readonly IoValve _GuageValve;        //private readonly IoValve _LoadlockVentValve;        //private readonly IoValve _LoadlockPumpingValve;        private readonly IoSensor _ATM_sw;        private readonly IoSensor _CDAPressure;        private readonly IoSensor _ATM_Loadlock_sw;        private readonly IoSensor _N2Pressure_sw;        private readonly IoSensor _VAC_sw;        private readonly IoSensor _WLK_sw;        private readonly IoSensor _Water_Flow;        private readonly IoSensor _RFG_Interlock;        //private readonly IoSensor _PM_Lid_Closed;        private readonly IoSensor _Source_RF_Fan;        private readonly IoSensor _PM_SlitDoor_Closed;        private readonly IoSensor _TurboPumpInterlock;        private readonly IoSensor _GasBoxDoor;        private readonly IoSensor _GasBoxPressure;        private readonly PumpBase _MainPump;        private readonly ESC5HighVoltage _ESCHV;        private readonly AdixenTurboPump _TurboPump;        private readonly PendulumValve _pendulumValve;        //private readonly ChillerBase _Chiller;        private readonly ChillerBase _InnerChiller;        private readonly ChillerBase _OuterChiller;        private readonly ChillerBase _TopChiller;        private readonly RfPowerBase _Generator;//srf=>AdTecGenerator        private readonly RfPowerBase _GeneratorBias;//brf=>CometRF        private readonly RfMatchBase _Match;        private readonly RfMatchBase _BiasMatch;        private readonly IoSignalTower _SignalTower;        private readonly IoHeater _ForelineTC;        private readonly IoHeater _WallTC;        private readonly IoPressureControl _pressureController;        private readonly IoGasStick[] _gasLines;        private readonly IoGasStick _gasLineN2;        private readonly IoBacksideHe _backsideHe;        private readonly IoMfc _heMfc;        private readonly double _foreline_interlock_pressure = 750;        private Stopwatch _GasRFStopWatch = new Stopwatch();        //private bool _GasFlag = false;        private float _chillerInnerTemp => GetAiValue($"{Module}.AI_ESC_inner_coolant_outlet_TC_Temp");        private float _chillerOuterTemp => GetAiValue($"{Module}.AI_ESC_outer_coolant_outlet_TC_Temp");        private float _chillerTopTemp => GetAiValue($"{Module}.AI_Top_Plate_coolant_outlet_TC_Temp");        private Stopwatch _pendulumValveStopWatch = new Stopwatch();        // 盖子的状态        public override bool IsLidClosed => _Lid.OFFFeedback;        //public override bool IsLidLoadlockClosed => _LidLoadlock.OFFFeedback;        public override bool IsSlitDoorClosed => _slitDoor.State == CylinderState.Close;        public override bool IsPumpRunning => _MainPump.IsRunning;        public override bool IsTurboPumpRunning => _TurboPump.IsRunning;        public override bool IsTurboPumpAtSpeed => _TurboPump.AtSpeed;        public override float TurboPumpSpeed => _TurboPump.Speed;        public override bool IsISOOpen => _TurboPumpPumpingValve.Status;        public override bool HasPumpError => _MainPump.IsError || !_MainPump.IsRunning;        public override bool HasTurboPumpError => _TurboPump.IsError || !_TurboPump.IsRunning;        public override bool IsCDA_OK => _CDAPressure.Value;        public override bool IsFastPumpOpened => _FastPumpValve.Status;        public override bool IsSoftPumpOpened => _SoftPumpValve.Status;        public override bool IsMfc1ValveOpened => _Mfc1Valve.Status;        public override bool IsMfc2ValveOpened => _Mfc2Valve.Status;        public override bool IsMfc3ValveOpened => _Mfc3Valve.Status;        public override bool IsMfc4ValveOpened => _Mfc4Valve.Status;        public override bool IsMfc5ValveOpened => _Mfc5Valve.Status;        public override bool IsMfc6ValveOpened => _Mfc6Valve.Status;        public override bool IsMfc7ValveOpened => _Mfc7Valve.Status;        public override bool IsMfc8ValveOpened => _Mfc8Valve.Status;        public override bool IsGuageValveOpened => _GuageValve.Status;        // 压力信号        public override bool IsATM => _ATM_sw.Value;        public override bool PVN22ValveIsOpen => _PVN22Valve.Status;        public override bool LiftPinIsDown => _LiftPin.OFFFeedback;        public override bool LiftPinIsUp => _LiftPin.ONFeedback;        //public override bool IsATMLoadlock => _ATM_Loadlock_sw.Value;        //public override bool IsVACLoadLock => LoadlockPressure <= 1000;        public override bool IsVAC => _VAC_sw.Value;        public override bool IsWaterFlowOk => true;        public override bool IsWLK => _WLK_sw.Value;        public override bool IsRFGInterlockOn => _RFG_Interlock.Value;        //public override bool PMLidClosed => _PM_Lid_Closed.Value;        public override bool TurboPumpInterlock => _TurboPumpInterlock.Value;        public override bool SourceRFFanInterlock => _Source_RF_Fan.Value;        public override bool SlitDoorClosed => _PM_SlitDoor_Closed.Value;        //public override double ProcessLowPressure => _pressureController.ProcessLow.Value;        //public override double ProcessHighPressure => _pressureController.ProcessHigh.Value;        public override double CalculationPressure        {            get            {                if (ProcessPressure < 100)                {                    return ProcessPressure;                }                else                {                    return ChamberPressure;                }            }        }        public override double ProcessPressure => _pressureController.ProcessGauge.Value;        public override double ChamberPressure => _pressureController.PressureGauge.Value;        public override double ForelinePressure => _pressureController.ForelineGauge.Value;        public override double TargetPressure => _pressureController.TargetPressure;        //public override double LoadlockPressure => 0;        public override double ESCHePressure => _pressureController.ESCHeGauge.Value;        public override int ESCOutputVoltage => _ESCHV.OutputVoltage;        public override double ESCPositiveOutputCurrent => _ESCHV.PositiveOutputCurrent;        public override double ESCNegativeOutputCurrent => _ESCHV.NegativeOutputCurrent;        public override bool IsHVOn => _ESCHV.IsOn;        public override float CoolantInletTempFB => 0;        public override float CoolantOutletTempFB => 0;        public override bool ChillerIsRunning => false;        public bool innerChillerIsRunning => _InnerChiller.IsRunning;        public bool outerChillerIsRunning => _OuterChiller.IsRunning;        public bool topChillerIsRunning => _TopChiller.IsRunning;        //Loadlock_Arm        public override bool IsLoadlockArmRetract => _LoadLockArm.OFFFeedback;        public override bool IsLoadlockArmExtend => _LoadLockArm.ONFeedback;        //Loadlock_Arm DO        public override bool LoadlockArmRetract => _LoadLockArm.OFFSetPoint;        public override bool LoadlockArmExtend => _LoadLockArm.ONSetPoint;        public override float ReflectPower => _Generator.ReflectPower;        public override float BiasReflectPower => _GeneratorBias.ReflectPower;        public override float ForwardPower => _Generator.ForwardPower;        public override float BiasForwardPower => _GeneratorBias.ForwardPower;        public override bool BackSideHeOutOfRange => _backsideHe.OutOfRange;        public override float RFMatchC1 => _Match != null ? _Match.TunePosition1 : 0;        public override float RFMatchC2 => _Match != null ? _Match.TunePosition2 : 0;        public override float BiasRFMatchC1 => _BiasMatch != null ? _BiasMatch.TunePosition1 : 0;        public override float BiasRFMatchC2 => _BiasMatch != null ? _BiasMatch.TunePosition1 : 0;        public new ModuleName Module { get; }        public override MovementPosition LiftPinPosition        {            get            {                MovementPosition pos = MovementPosition.Unknown;                if (_LiftPin.ONFeedback && !_LiftPin.OFFFeedback)                {                    pos = MovementPosition.Up;                }                else if (!_LiftPin.ONFeedback && _LiftPin.OFFFeedback)                {                    pos = MovementPosition.Down;                }                return pos;            }        }        //public override bool CheckAtm()        //{        //    return _ATM_sw.Value && ChamberPressure > 700000;        //}        public override bool CheckSlitDoorOpen()        {            return _slitDoor.State == CylinderState.Open;        }        public override bool CheckSlitDoorClose()        {            return _slitDoor.State == CylinderState.Close;        }        public override bool CheckLiftUp()        {            return _LiftPin.State == CylinderState.Open;        }        public override bool CheckLiftDown()        {            return _LiftPin.State == CylinderState.Close;        }        public override double TotalGasSetpoint        {            get            {                double sum = 0;                foreach (var gas in _gasLines)                {                    sum += gas.FlowSP;                }                return sum;            }        }        public override bool HasGasOutOfRange        {            get            {                foreach (var gas in _gasLines)                {                    if (!gas.IsOutOfRange)                        return false;                }                return true;            }        }        public override double MFC1FeedBack => DEVICE.GetDevice<IoMfc>($"{Module}.MfcGas1").FeedBack;        public override double MFC2FeedBack => DEVICE.GetDevice<IoMfc>($"{Module}.MfcGas2").FeedBack;        public override double MFC3FeedBack => DEVICE.GetDevice<IoMfc>($"{Module}.MfcGas3").FeedBack;        public override double MFC4FeedBack => DEVICE.GetDevice<IoMfc>($"{Module}.MfcGas4").FeedBack;        public override double MFC5FeedBack => DEVICE.GetDevice<IoMfc>($"{Module}.MfcGas5").FeedBack;        public override double MFC6FeedBack => DEVICE.GetDevice<IoMfc>($"{Module}.MfcGas6").FeedBack;        public override double MFC7FeedBack => DEVICE.GetDevice<IoMfc>($"{Module}.MfcGas7").FeedBack;        public override double MFC8FeedBack => DEVICE.GetDevice<IoMfc>($"{Module}.MfcGas8").FeedBack;        public override float PendulumPressure => _pendulumValve.Pressure;        public override float PendulumPosition => _pendulumValve.Position;        public override bool PendulumValveIsOpen()        {            return _pendulumValve.IsOpen;        }        #region 构造函数        public JetKepler2300PM(ModuleName moduleName) : base(moduleName)        {            Module = moduleName;            _Lid = DEVICE.GetDevice<IoLid>($"{Module}.{VenusDevice.Lid}");            //_LidLoadlock = DEVICE.GetDevice<IoLid>($"{Module}.{VenusDevice.LidLoadlock}");            _slitDoor = DEVICE.GetDevice<IoCylinder>($"{Module}.{VenusDevice.SlitDoor}");            _LiftPin = DEVICE.GetDevice<IoCylinder>($"{Module}.{VenusDevice.LiftPin}");            _LoadLockArm = DEVICE.GetDevice<IoCylinder>($"{Module}.{VenusDevice.LoadLockArm}");            _PVN21Valve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValvePVN21}");            _PVN22Valve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValvePVN22}");            _PV11Valve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValvePV11}");            _PV12Valve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValvePV12}");            _PV21Valve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValvePV21}");            _PV22Valve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValvePV22}");            _PV31Valve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValvePV31}");            _PV32Valve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValvePV32}");            _PV41Valve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValvePV41}");            _PV42Valve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValvePV42}");            _N2Valve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValveN2}");            _Mfc1Valve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValveMfc1}");            _Mfc2Valve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValveMfc2}");            _Mfc3Valve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValveMfc3}");            _Mfc4Valve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValveMfc4}");            _Mfc5Valve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValveMfc5}");            _Mfc6Valve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValveMfc6}");            _Mfc7Valve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValveMfc7}");            _Mfc8Valve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValveMfc8}");            _PVHe1Valve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValvePVHe1}");            _PVHe2Valve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValvePVHe2}");            _GasFinalValve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValveGasFinal}");            _SoftPumpValve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValveSoftPump}");            _FastPumpValve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValveFastPump}");            _TurboPumpPumpingValve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValveTurboPumpPumping}");            _TurboPumpPurgeValve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValveTurboPumpPurge}");            _GuageValve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValveGuage}");            //_LoadlockVentValve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValveLoadlockVent}");            //_LoadlockPumpingValve = DEVICE.GetDevice<IoValve>($"{Module}.{VenusDevice.ValveLoadlockPumping}");            _heMfc = DEVICE.GetDevice<IoMfc>($"{Module}.MfcHe");            _ATM_sw = DEVICE.GetDevice<IoSensor>($"{Module}.SensorATMSwitch");            _ATM_Loadlock_sw = DEVICE.GetDevice<IoSensor>($"{Module}.SensorLoadlockATMSwitch");            _N2Pressure_sw = DEVICE.GetDevice<IoSensor>($"{Module}.N2PressureOk");            _VAC_sw = DEVICE.GetDevice<IoSensor>($"{Module}.SensorVacSwitch");            _Water_Flow = DEVICE.GetDevice<IoSensor>($"{Module}.SensorWaterFlowOk");            _WLK_sw = DEVICE.GetDevice<IoSensor>($"{Module}.SensorWaterLeakOk");            _CDAPressure = DEVICE.GetDevice<IoSensor>($"{Module}.SensorCDAPressureOk");            _RFG_Interlock = DEVICE.GetDevice<IoSensor>($"{Module}.GeneratorInterlock");            //_PM_Lid_Closed = DEVICE.GetDevice<IoSensor>($"{Module}.SensorPMLidClosed");            _Source_RF_Fan = DEVICE.GetDevice<IoSensor>($"{Module}.SensorSourceRFFan");            _PM_SlitDoor_Closed = DEVICE.GetDevice<IoSensor>($"{Module}.SensorSlitDoorClosed");            _TurboPumpInterlock = DEVICE.GetDevice<IoSensor>($"{Module}.TurboPumpInterlock");            _GasBoxDoor = DEVICE.GetDevice<IoSensor>($"{Module}.GasBoxDoorSW");            _GasBoxPressure = DEVICE.GetDevice<IoSensor>($"{Module}.GasBoxPressureSW");            _ForelineTC = DEVICE.GetDevice<IoHeater>($"{Module}.ForelineHeater");            _WallTC = DEVICE.GetDevice<IoHeater>($"{Module}.WallHeater");            _SignalTower = DEVICE.GetDevice<IoSignalTower>($"{Module}.SignalTower");            _CDAPressure = DEVICE.GetDevice<IoSensor>($"{Module}.SensorCDAPressureOk");            _pressureController = DEVICE.GetDevice<IoPressureControl>($"{Module}.{VenusDevice.PressureControl}");            _gasLines = new IoGasStick[8];            for (int index = 0; index < 8; index++)            {                _gasLines[index] = DEVICE.GetDevice<IoGasStick>($"{Module}.GasStick{index + 1}");            }            _gasLineN2 = DEVICE.GetDevice<IoGasStick>($"{Module}.GasStickN2");            _backsideHe = DEVICE.GetDevice<IoBacksideHe>($"{Module}.BacksideHelium");            _MainPump = DEVICE.GetDevice<PumpBase>($"{Module}.{VenusDevice.MainPump}");            // RS232 Dry pump, SKY            if (SC.GetValue<int>($"{Module}.DryPump.CommunicationType") == (int)CommunicationType.RS232)            {                if (SC.GetValue<int>($"{Module}.DryPump.MFG") == (int)DryPumpMFG.SKY)                {                    _MainPump = DEVICE.GetDevice<SkyPump>($"{Module}.{VenusDevice.MainPump}");                }                else if (SC.GetValue<int>($"{Module}.DryPump.MFG") == (int)DryPumpMFG.Edwards)                {                    _MainPump = DEVICE.GetDevice<EdwardsPump>($"{Module}.{VenusDevice.MainPump}");                }            }            _ESCHV = DEVICE.GetDevice<ESC5HighVoltage>($"{Module}.{VenusDevice.ESCHV}");            _TurboPump = DEVICE.GetDevice<AdixenTurboPump>($"{Module}.{VenusDevice.TurboPump}");            _pendulumValve = DEVICE.GetDevice<PendulumValve>($"{Module}.{VenusDevice.PendulumValve}");            //if (SC.GetValue<bool>($"{Module}.Chiller.EnableChiller") &&            //    SC.GetValue<int>($"{Module}.Chiller.CommunicationType") == (int)CommunicationType.RS232)            //{            //    if (SC.GetValue<int>($"{Module}.Chiller.MFG") == (int)ChillerMFG.SMC)            //    {            //        _Chiller = DEVICE.GetDevice<SMCChiller>($"{Module}.{VenusDevice.Chiller}");            //    }            //    else if (SC.GetValue<int>($"{Module}.Chiller.MFG") == (int)ChillerMFG.AIRSYS)            //    {            //        _Chiller = DEVICE.GetDevice<AIRSYSChiller>($"{Module}.{VenusDevice.Chiller}");            //    }            //}            if (SC.GetValue<bool>($"{Module}.InnerChiller.EnableChiller") &&                SC.GetValue<int>($"{Module}.InnerChiller.CommunicationType") == (int)CommunicationType.RS232)            {                if (SC.GetValue<int>($"{Module}.InnerChiller.MFG") == (int)ChillerMFG.SMC)                {                    _InnerChiller = DEVICE.GetDevice<SMCChiller>($"{Module}.{VenusDevice.InnerChiller}");                }                else if (SC.GetValue<int>($"{Module}.InnerChiller.MFG") == (int)ChillerMFG.AIRSYS)                {                    _InnerChiller = DEVICE.GetDevice<AIRSYSChiller>($"{Module}.{VenusDevice.InnerChiller}");                }            }            if (SC.GetValue<bool>($"{Module}.OuterChiller.EnableChiller") &&               SC.GetValue<int>($"{Module}.OuterChiller.CommunicationType") == (int)CommunicationType.RS232)            {                if (SC.GetValue<int>($"{Module}.OuterChiller.MFG") == (int)ChillerMFG.SMC)                {                    _OuterChiller = DEVICE.GetDevice<SMCChiller>($"{Module}.{VenusDevice.OuterChiller}");                }                else if (SC.GetValue<int>($"{Module}.OuterChiller.MFG") == (int)ChillerMFG.AIRSYS)                {                    _OuterChiller = DEVICE.GetDevice<AIRSYSChiller>($"{Module}.{VenusDevice.OuterChiller}");                }            }            if (SC.GetValue<bool>($"{Module}.TopChiller.EnableChiller") &&              SC.GetValue<int>($"{Module}.TopChiller.CommunicationType") == (int)CommunicationType.RS232)            {                if (SC.GetValue<int>($"{Module}.TopChiller.MFG") == (int)ChillerMFG.SMC)                {                    _TopChiller = DEVICE.GetDevice<SMCChiller>($"{Module}.{VenusDevice.TopChiller}");                }                else if (SC.GetValue<int>($"{Module}.TopChiller.MFG") == (int)ChillerMFG.AIRSYS)                {                    _TopChiller = DEVICE.GetDevice<AIRSYSChiller>($"{Module}.{VenusDevice.TopChiller}");                }            }            // RS223 AdTec Generator            if (SC.GetValue<int>($"{Module}.Rf.CommunicationType") == (int)CommunicationType.RS232 &&                SC.GetValue<int>($"{Module}.Rf.MFG") == (int)GeneratorMFG.AdTec)            {                _Generator = DEVICE.GetDevice<AdTecGenerator>($"{Module}.{VenusDevice.Rf}");            }            // Ethernet Comet Generator Bias            if (SC.GetValue<bool>($"{Module}.BiasRf.EnableBiasRF"))            {                if (SC.GetValue<int>($"{Module}.BiasRf.CommunicationType") == (int)CommunicationType.Ethernet &&                    SC.GetValue<int>($"{Module}.BiasRf.MFG") == (int)GeneratorMFG.Comet)                {                    _GeneratorBias = DEVICE.GetDevice<CometRF>($"{Module}.{VenusDevice.BiasRf}");                }                else if (SC.GetValue<int>($"{Module}.BiasRf.MFG") == (int)GeneratorMFG.AdTec)                {                    _GeneratorBias = DEVICE.GetDevice<AdTecGenerator>($"{Module}.{VenusDevice.BiasRf}");                }            }            // RS232 AdTec match            if (SC.GetValue<int>($"{Module}.Match.CommunicationType") == (int)CommunicationType.RS232 &&                SC.GetValue<int>($"{Module}.Match.MFG") == (int)MatchMFG.AdTec)            {                _Match = DEVICE.GetDevice<AdTecMatch>($"{Module}.{VenusDevice.Match}");            }            // Bias Match            if (SC.GetValue<bool>($"{Module}.BiasMatch.EnableBiasMatch") &&                SC.GetValue<int>($"{Module}.BiasMatch.CommunicationType") == (int)CommunicationType.RS232 &&                SC.GetValue<int>($"{Module}.BiasMatch.MFG") == (int)MatchMFG.AdTec)            {                _BiasMatch = DEVICE.GetDevice<AdTecMatch>($"{Module}.{VenusDevice.BiasMatch}");            }            _foreline_interlock_pressure = SC.GetValue<double>($"{Module}.ForelineInterlockPressure");            _GasRFStopWatch.Stop();            DATA.Subscribe($"{Module}.ChillerInnerTemp", () => _chillerInnerTemp);            DATA.Subscribe($"{Module}.ChillerOuterTemp", () => _chillerOuterTemp);            DATA.Subscribe($"{Module}.ChillerTopTemp", () => _chillerTopTemp);            //DATA.Subscribe($"{Module}.InnerChiller.IsRunning", () => innerChillerIsRunning);            //DATA.Subscribe($"{Module}.OuterChiller.IsRunning", () => outerChillerIsRunning);            //DATA.Subscribe($"{Module}.TopChiller.IsRunning",   () => topChillerIsRunning);            //OP.Subscribe($"{Module}.HeatChiller", (cmd, args) => {            //    HeatChiller(ChillerType.InnerChiller, Convert.ToDouble(args[1]), Convert.ToDouble(args[2]));            //    return true;            //});            //OP.Subscribe($"{Module}.OnOffChiller", (cmd, args) => {            //    //HeatChiller(ChillerType.InnerChiller, Convert.ToDouble(args[1]), Convert.ToDouble(args[2]));            //    OnOffChiller(ChillerType.InnerChiller, (bool)(args[1]));            //    return true;            //});            _pendulumValveStopWatch.Start();        }        #endregion        public async override void CloseValves(int? delayTime = null)        {            _PVN21Valve.TurnValve(false, out _);            // _PVN22Valve.TurnValve(false, out _);            _PV11Valve.TurnValve(false, out _);            _PV12Valve.TurnValve(false, out _);            _PV21Valve.TurnValve(false, out _);            _PV22Valve.TurnValve(false, out _);            _PV31Valve.TurnValve(false, out _);            _PV32Valve.TurnValve(false, out _);            _PV41Valve.TurnValve(false, out _);            _PV42Valve.TurnValve(false, out _);            _PVHe1Valve.TurnValve(false, out _);            _PVHe2Valve.TurnValve(false, out _);            _SoftPumpValve.TurnValve(false, out _);            _FastPumpValve.TurnValve(false, out _);            _TurboPumpPumpingValve.TurnValve(false, out _);            _TurboPumpPurgeValve.TurnValve(false, out _);            _GuageValve.TurnValve(false, out _);            _N2Valve.TurnValve(false, out _);            _FastPumpValve.TurnValve(false, out _);            _Mfc1Valve.TurnValve(false, out _);            _Mfc2Valve.TurnValve(false, out _);            _Mfc3Valve.TurnValve(false, out _);            _Mfc4Valve.TurnValve(false, out _);            _Mfc5Valve.TurnValve(false, out _);            _Mfc6Valve.TurnValve(false, out _);            _Mfc7Valve.TurnValve(false, out _);            _Mfc8Valve.TurnValve(false, out _);            foreach (var stick in _gasLines)            {                stick.Stop();            }            if (delayTime != null)            {                await Task.Delay((int)delayTime);            }            _GasFinalValve.TurnValve(false, out _);        }        public override void TurnDryPump(bool on)        {            //_pressureController.StartPump(on);            _MainPump?.SetPumpOnOff(on);        }        public override void TurnTurboPump(bool on)        {            _TurboPump?.SetPumpOnOff(on);        }        public override void OpenValve(ValveType vlvType, bool on)        {            switch (vlvType)            {                case ValveType.PVN21:                    _PVN21Valve.TurnValve(on, out _);                    break;                case ValveType.PVN22:                    _PVN22Valve.TurnValve(on, out _);                    LOG.Write(eEvent.EV_DEVICE_INFO, Module, $"{(on ? "打开" : "关闭")} 阀 {vlvType.ToString()}");                    break;                case ValveType.PV11:                    _PV11Valve.TurnValve(on, out _);                    break;                case ValveType.PV12:                    _PV12Valve.TurnValve(on, out _);                    break;                case ValveType.PV21:                    _PV21Valve.TurnValve(on, out _);                    break;                case ValveType.PV22:                    _PV22Valve.TurnValve(on, out _);                    break;                case ValveType.PV31:                    _PV31Valve.TurnValve(on, out _);                    break;                case ValveType.PV32:                    _PV32Valve.TurnValve(on, out _);                    break;                case ValveType.PV41:                    _PV41Valve.TurnValve(on, out _);                    break;                case ValveType.PV42:                    _PV42Valve.TurnValve(on, out _);                    break;                case ValveType.N2:                    _N2Valve.TurnValve(on, out _);                    break;                case ValveType.PVHe1:                    _PVHe1Valve.TurnValve(on, out _);                    break;                case ValveType.PVHe2:                    _PVHe2Valve.TurnValve(on, out _);                    break;                case ValveType.GasFinal:                    _GasFinalValve.TurnValve(on, out _);                    break;                case ValveType.SoftPump:                    _SoftPumpValve.TurnValve(on, out _);                    break;                case ValveType.FastPump:                    _FastPumpValve.TurnValve(on, out _);                    break;                case ValveType.TurboPumpPumping:                    _TurboPumpPumpingValve.TurnValve(on, out _);                    break;                case ValveType.TurboPumpPurge:                    _TurboPumpPurgeValve.TurnValve(on, out _);                    break;                case ValveType.Guage:                    _GuageValve.TurnValve(on, out _);                    break;                //case ValveType.LoadlockVent:                //    _LoadlockVentValve.TurnValve(on, out _);                //    break;                //case ValveType.LoadlockPumping:                //    _LoadlockPumpingValve.TurnValve(on, out _);                //    break;                case ValveType.Mfc1:                    _Mfc1Valve.TurnValve(on, out _);                    break;                case ValveType.Mfc2:                    _Mfc2Valve.TurnValve(on, out _);                    break;                case ValveType.Mfc3:                    _Mfc3Valve.TurnValve(on, out _);                    break;                case ValveType.Mfc4:                    _Mfc4Valve.TurnValve(on, out _);                    break;                case ValveType.Mfc5:                    _Mfc5Valve.TurnValve(on, out _);                    break;                case ValveType.Mfc6:                    _Mfc6Valve.TurnValve(on, out _);                    break;                case ValveType.Mfc7:                    _Mfc7Valve.TurnValve(on, out _);                    break;                case ValveType.Mfc8:                    _Mfc8Valve.TurnValve(on, out _);                    break;                default:                    throw new ArgumentOutOfRangeException($"Argument error {vlvType}-{on}");            }        }        public override void Monitor()        {            foreach (var gas in _gasLines)            {                gas.Monitor();            }            if (_pendulumValveStopWatch.ElapsedMilliseconds > 1000)            {                CheckPermanentInterlock();                _pendulumValveStopWatch.Restart();            }        }        protected override void CheckPermanentInterlock()        {            if (ProcessPressure >= 99 && _GuageValve.SetPoint)            {                _GuageValve.TurnValve(false, out _);                LOG.Write(eEvent.WARN_DEVICE_INFO, Module, $"Process pressure:{ProcessPressure} exceed 99 mtorr, Guage Valve (DO-31) closed automaticlly.");            }        }        public override void CheckIdleInterlock(int delaytime )        {            if (ForelinePressure > _foreline_interlock_pressure)            {                if (_TurboPumpPumpingValve.SetPoint || _TurboPumpPurgeValve.SetPoint || _pendulumValve.IsOpen)                {                    _pendulumValve.TurnValve(false);                    _TurboPumpPurgeValve.TurnValve(false, out _);                    _TurboPumpPumpingValve.TurnValve(false, out _);                    LOG.Write(eEvent.WARN_DEVICE_INFO, Module, $"Foreline pressure:{ForelinePressure} exceed {_foreline_interlock_pressure} mtorr, Pendulum valve & PV6 & PV7 closed automaticlly.");                }            }        }        public override void BuzzerBlinking(double time)        {            _SignalTower.BuzzerBlinking(time);        }        public override void SwitchOnBuzzerAndRed()        {            _SignalTower.SwitchOnBuzzerAndRed("", null);        }        public override void Home()        {            _pendulumValve.ReConnect();            // 与yp讨论过,PM 初始化不需要            SetLiftPin(MovementPosition.Down, out _);            //if (_slitDoor.State == CylinderState.Open)            //{            //    SetSlitDoor(true, out _);            //}            //else            //{            //    SetSlitDoor(false, out _);            //}            //SetSlitDoor(false, out _);            //2023/03/08添加            OpenValve(ValveType.PVN22, true);            //2023/04/25临时添加            //RetractWafer();        }        public override bool SetLiftPin(MovementPosition dirt, out string reason)        {            reason = string.Empty;            switch (dirt)            {                case MovementPosition.Down:                    return _LiftPin.SetCylinder(false, out reason);                case MovementPosition.Up:                    return _LiftPin.SetCylinder(true, out reason);                case MovementPosition.Left:                case MovementPosition.Right:                case MovementPosition.Middle:                    throw new ArgumentException("Movement argument error");            }            return true;        }        public override bool SetSlitDoor(bool open, out string reason)        {            if (open)            {                if (RouteManager.IsATMMode)                {                    if (!IsATM)                    {                        reason = $"{Module} is not ATM, can not open slit door";                        LOG.Write(eEvent.ERR_DEVICE_INFO, Module, reason);                        return false;                    }                    if (!IsTMATM)                    {                        reason = $"LoadLock is not ATM, can not open slit door";                        LOG.Write(eEvent.ERR_DEVICE_INFO, Module, reason);                        return false;                    }                }                else                {                    double maxPressureDifference = SC.GetValue<double>("System.PMTMMaxPressureDifference");                    if (Math.Abs(TMPressure - ChamberPressure) > maxPressureDifference)                    {                        reason = $"{Module} and TM pressure difference exceeds the max limit {maxPressureDifference}, TMPressure:{TMPressure}, {Module}Pressure:{ChamberPressure}";                        LOG.Write(eEvent.ERR_DEVICE_INFO, Module, reason);                        return false;                    }                }            }            return _slitDoor.SetCylinder(open, out reason);        }        public override bool RetractWafer()        {            return _LoadLockArm.SetCylinder(false, out _);        }        public override bool ExtendWafer()        {            return _LoadLockArm.SetCylinder(true, out _);        }        public override bool FlowGas(int gasNum, double val)        {            if (_gasLines.Length <= gasNum)                return false;            _gasLines[gasNum].Flow(val);            return true;        }        public override bool StopGas(int gasNum)        {            if (_gasLines.Length <= gasNum)                return false;            _gasLines[gasNum].Stop();            return true;        }        public override bool FlowN2(double val)        {            _gasLineN2.Flow(val);            return true;        }        public override bool StopN2()        {            _gasLineN2.Stop();            return true;        }        public override void StopAllGases()        {            foreach (var line in _gasLines)            {                line.Stop();            }        }        public override bool TurnPendulumValve(bool on)        {            return _pendulumValve.TurnValve(on);        }        public override bool SetPVPressure(float pressure)        {            return _pendulumValve.SetPressure(pressure);        }        public override bool SetPVPostion(float position)        {            return _pendulumValve.SetPosition(position);        }        public override float GetPVPosition()        {            return _pendulumValve.Position;        }        public override async void HeatChiller(ChillerType chillerType, double value, double offset)        {            switch (chillerType)            {                //case ChillerType.Chiller:                //    _Chiller?.SetChillerTemp((float)value, (float)offset);                //    await Task.Delay(1000);                //    _Chiller?.SetChillerOnOff(true);                //    break;                case ChillerType.InnerChiller:                    _InnerChiller?.SetChillerTemp((float)value, (float)offset);                    await Task.Delay(1000);                    _InnerChiller?.SetChillerOnOff(true);                    break;                case ChillerType.OuterChiller:                    _OuterChiller?.SetChillerTemp((float)value, (float)offset);                    await Task.Delay(1000);                    _OuterChiller?.SetChillerOnOff(true);                    break;                case ChillerType.TopChiller:                    _TopChiller?.SetChillerTemp((float)value, (float)offset);                    await Task.Delay(1000);                    _TopChiller?.SetChillerOnOff(true);                    break;            }        }        public override void OnOffChiller(ChillerType chillerType, bool onoff)        {            switch (chillerType)            {                //case ChillerType.Chiller:                //    _Chiller?.SetChillerOnOff(onoff);                //    break;                case ChillerType.InnerChiller:                    _InnerChiller?.SetChillerOnOff(onoff);                    break;                case ChillerType.OuterChiller:                    _OuterChiller?.SetChillerOnOff(onoff);                    break;                case ChillerType.TopChiller:                    _TopChiller?.SetChillerOnOff(onoff);                    break;            }        }        //public override bool CheckChillerStatus()        //{        //    return _Chiller != null /*&& _Chiller.IsRunning*/ && !_Chiller.IsError;        //}        public override void SetGeneratorCommunicationMode(int mode)        {            _Generator?.SetCommunicationMode(mode);        }        public override bool GeneratorPowerOn(bool on)        {            if (_Generator == null) return false;            if (on && !IsRFGInterlockOn)            {                LOG.Write(eEvent.ERR_RF, Module, "射频电源 Interlock条件不满足");                return false;            }            return _Generator.SetPowerOnOff(on, out _);        }        public override bool GeneratorSetpower(float val)        {            if (_Generator == null) return false;            if (Math.Abs(val) > 0.01)                _Generator.SetPower((ushort)val);            return true;        }        public override bool GeneratorBiasPowerOn(bool on)        {            if (_GeneratorBias == null) return false;            if (on && !IsRFGInterlockOn)            {                LOG.Write(eEvent.ERR_RF, Module, "Bias射频电源 Interlock条件不满足");                return false;            }            return _GeneratorBias.SetPowerOnOff(on, out _);        }        public override bool GeneratorBiasSetpower(float val)        {            if (_GeneratorBias == null) return false;            if (Math.Abs(val) > 0.01)                _GeneratorBias.SetPower((ushort)val);            return true;        }        public override bool OnOffSetESCHV(bool val)        {            return _ESCHV.SetPowerOnOff(val);        }        public override bool SetWallTCTemperature(float value)        {            return _WallTC.RampTemp(value);        }        public override bool GeneratorBiasSetMatchMode(bool val)        {            if (_GeneratorBias == null) return false;            string reason = string.Empty;            _GeneratorBias.SetMatchingAutoMode(val, out reason);            return true;        }        public override bool SetMatchPosition(float c1, float c2)        {            if (_Match == null) return false;            string reason = string.Empty;            _Match.SetMatchPosition(c1, c2, out reason);            return true;        }        public override bool SetMatchWorkMode(MatchWorkMode matchWorkMode)        {            if (_Match == null) return false;            if (matchWorkMode == MatchWorkMode.Auto)            {                return _Match.SetMatchMode(EnumRfMatchTuneMode.Auto, out _);            }            else if (matchWorkMode == MatchWorkMode.Manual)            {                return _Match.SetMatchMode(EnumRfMatchTuneMode.Manual, out _);            }            return false;        }        public override bool SetBiasMatchPosition(float c1, float c2)        {            if (_BiasMatch == null) return false;            string reason = string.Empty;            _BiasMatch.SetMatchPosition(c1, c2, out reason);            return true;        }        public override bool SetBiasMatchWorkMode(MatchWorkMode matchWorkMode)        {            if (_BiasMatch == null) return false;            if (matchWorkMode == MatchWorkMode.Auto)            {                return _BiasMatch.SetMatchMode(EnumRfMatchTuneMode.Auto, out _);            }            else if (matchWorkMode == MatchWorkMode.Manual)            {                return _BiasMatch.SetMatchMode(EnumRfMatchTuneMode.Manual, out _);            }            return false;        }        public override bool SetBiasPulseMode(bool on)        {            if (_GeneratorBias == null) return false;            _GeneratorBias.SetPulseMode(on);            return true;        }        public override bool SetBiasPulseRateFreq(int nFreq)        {            if (_GeneratorBias == null) return false;            _GeneratorBias.SetPulseRateFreq(nFreq);            return true;        }        public override bool SetDiasPulseDutyCycle(int percentage)        {            if (_GeneratorBias == null) return false;            _GeneratorBias.SetPulseDutyCycle(percentage);            return true;        }        public override bool SetESCClampVoltage(int nVoltage)        {            if (_ESCHV == null) return false;            return _ESCHV.SetOutputVoltage(nVoltage);        }        public override bool CheckGeneratorAndHVInterlock(VenusDevice device)        {            eEvent evt = device == VenusDevice.Rf ? eEvent.ERR_RF : eEvent.ERR_ESC_HV;            if (!IsLidClosed)            {                LOG.Write(evt, Module, $"Cannot Power ON {device} as PM Lid is Open.");                return false;            }            if (!IsVAC)            {                LOG.Write(evt, Module, $"Cannot Power ON {device} as PM is not Vacuum.");                return false;            }            if (!IsWaterFlowOk)            {                LOG.Write(evt, Module, $"Cannot Power ON {device} as Water Flow is OFF.");                return false;            }            if (!IsRFGInterlockOn)            {                LOG.Write(evt, Module, $"Cannot Power ON {device} as Generator Interlock is OFF.");                return false;            }            if (!SourceRFFanInterlock)            {                LOG.Write(evt, Module, $"Cannot Power ON {device} as Source RF Fan is OFF.");                return false;            }            if (!SlitDoorClosed)            {                LOG.Write(evt, Module, $"Cannot Power ON {device} as Slit Door is open.");                return false;            }            if ((device == VenusDevice.ESCHV || device == VenusDevice.BiasRf) && WaferManager.Instance.CheckNoWafer(Module, 0))            {                LOG.Write(evt, Module, $"Cannot Power ON {device} as {Module} has no wafer");                return false;            }            return true;        }        public override void SetBacksideHeFlow(double flow)        {            if (_backsideHe == null) return;            _backsideHe.Flow(flow);        }        public override bool SetBacksideHePressure(float mTorr)        {            if (_backsideHe == null) return false;            return _backsideHe.SetBacksideHelium(mTorr);        }        //public override bool SetBacksideHeThreshold(int nMin, int nMax)        //{        //    if (_backsideHe == null) return false;        //    return _backsideHe.SetFlowThreshold(nMin, nMax);        //}        public override bool StartControlPressure(int pressureSetpoint, int flowSetpoint)        {            OpenValve(ValveType.GasFinal, true);            FlowGas(5, flowSetpoint);            TurnPendulumValve(true);            SetPVPressure(pressureSetpoint);            return true;        }        public async override void AbortControlPressure()        {            FlowGas(5, 0);            //SetPVPressure(0);            SetPVPostion(1000);                await Task.Delay(500);            OpenValve(ValveType.GasFinal, false);            //return true;        }        public override bool PreparePlace()        {            if (!SetSlitDoor(true, out string reason))            {                LOG.Write(eEvent.ERR_PM, Module, $"Set Slit Door Open failed:{reason}");                return false;            }            if (!SetLiftPin(MovementPosition.Down, out reason))            {                LOG.Write(eEvent.ERR_PM, Module, $"Set Lift Pin down failed:{reason}");                return false;            }            return true;        }        public override bool PreparePick()        {            if (!SetSlitDoor(true, out string reason))            {                LOG.Write(eEvent.ERR_PM, Module, $"Set Slit Door Open failed:{reason}");                return false;            }            if (!SetLiftPin(MovementPosition.Up, out reason))            {                LOG.Write(eEvent.ERR_PM, Module, $"Set Lift Pin down failed:{reason}");                return false;            }            return true;        }        public override bool PreparePlaceIsOK()        {            return CheckSlitDoorOpen() && LiftPinIsDown;        }        public override bool PreparePickIsOK()        {            return CheckSlitDoorOpen() && LiftPinIsUp;        }        public override bool EndPlace()        {            if (!SetLiftPin(MovementPosition.Down, out string reason))            {                LOG.Write(eEvent.ERR_PM, Module, $"Set Lift Pin Down failed:{reason}");                return false;            }            if (!SetSlitDoor(false, out reason))            {                LOG.Write(eEvent.ERR_PM, Module, $"Set Slit Door Close failed:{reason}");                return false;            }            return true;        }        public override bool EndPick()        {            if (!SetSlitDoor(false, out string reason))            {                LOG.Write(eEvent.ERR_PM, Module, $"Set Slit Door Close failed:{reason}");                return false;            }            return true;        }        public override bool EndPlaceIsOK()        {            return CheckSlitDoorClose() && LiftPinIsDown;        }        public override bool EndPickIsOK()        {            return CheckSlitDoorClose();        }        public override void RTCloseEvent()        {            if (_Generator.IsPowerOn)            {                GeneratorPowerOn(false);            }            if (_GeneratorBias.IsPowerOn)            {                GeneratorBiasPowerOn(false);            }            if (PendulumValveIsOpen())            {                TurnPendulumValve(false);            }        }        public override bool RFInterlock(VenusDevice device)        {            eEvent evt = eEvent.ERR_RF;            if (!IsWaterFlowOk)            {                LOG.Write(evt, Module, $"Cannot Power ON {device} as Water Flow is OFF.");                return false;            }            if (!IsRFGInterlockOn)            {                LOG.Write(evt, Module, $"Cannot Power ON {device} as Generator Interlock is OFF.");                return false;            }            if (!SourceRFFanInterlock)            {                LOG.Write(evt, Module, $"Cannot Power ON {device} as Source RF Fan is OFF.");                return false;            }            if (GasIsOff())            {                LOG.Write(evt, Module, $"Cannot Power ON {device} as Gas is OFF.");                return false;            }            return true;        }        private bool GasIsOff()        {            if (IsMfc1ValveOpened == false && IsMfc2ValveOpened == false && IsMfc3ValveOpened == false && IsMfc4ValveOpened == false && IsMfc5ValveOpened == false && IsMfc6ValveOpened == false && IsMfc7ValveOpened == false && IsMfc8ValveOpened == false)            {                if (_GasRFStopWatch.IsRunning == false)                {                    _GasRFStopWatch.Start();                }                if (_GasRFStopWatch.ElapsedMilliseconds > 1000)                {                    _GasRFStopWatch.Reset();                    //_GasFlag = true;                    return true;                }            }            else            {                _GasRFStopWatch.Reset();                //_GasFlag = false;            }            return false;        }        public override void PMInError()        {            CloseValves();            GeneratorPowerOn(false);            GeneratorBiasPowerOn(false);            OpenValve(ValveType.TurboPumpPumping, true);            OpenValve(ValveType.TurboPumpPurge, true);        }    }}
 |