using Aitex.Core.RT.DataCenter;
using Aitex.Core.RT.Device;
using Aitex.Core.RT.OperationCenter;
using Aitex.Core.Util;
using MECF.Framework.Common.Equipment;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Venus_Core;
using Venus_RT.Modules;
namespace Venus_RT.Devices
{
///
/// 变量及类型说明
/// bool类型变量 Is开头代表DI 其余代表DO
/// double类型变量 代表AI AO
///
abstract class JetVenusSEPMBase : BaseDevice, IDevice
{
#region DI DO
public abstract bool IsLidClosed { get; }
public abstract bool IsSlitDoorClosed { get; }
public abstract bool IsPumpRunning { get; }
public abstract bool IsTurboPumpRunning { get; }
public abstract bool IsTurboPumpAtSpeed { get; }
public abstract float TurboPumpSpeed { get; }
public abstract bool HasPumpError { get; }
public abstract bool HasTurboPumpError { get; }
public abstract bool IsCDA_OK { get; }
public abstract bool IsFastPumpOpened { get; }
public abstract bool IsSoftPumpOpened { get; }
public abstract bool IsMfc1ValveOpened { get; }
public abstract bool IsMfc2ValveOpened { get; }
public abstract bool IsMfc3ValveOpened { get; }
public abstract bool IsMfc4ValveOpened { get; }
public abstract bool IsMfc5ValveOpened { get; }
public abstract bool IsMfc6ValveOpened { get; }
public abstract bool IsMfc7ValveOpened { get; }
public abstract bool IsMfc8ValveOpened { get; }
public abstract bool IsMfc9ValveOpened { get; }
public abstract bool IsMfc10ValveOpened { get; }
public abstract bool IsMfc11ValveOpened { get; }
public abstract bool IsMfc12ValveOpened { get; }
public abstract bool IsGuageValveOpened { get; }
public abstract bool IsATM { get; }
public abstract bool PVN22ValveIsOpen { get; }
public abstract bool LiftPinIsDown { get; }
public abstract bool LiftPinIsUp { get; }
public abstract bool IsVAC { get; }
public abstract bool IsWaterFlowOk { get; }
public abstract bool IsWLK { get; }
public abstract bool IsRFGInterlockOn { get; }
public abstract bool PMLidClosed { get; }
public abstract bool TurboPumpInterlock { get; }
public abstract bool SourceRFFanInterlock { get; }
public abstract bool SlitDoorClosed { get; } //PM slite door closed
#endregion
#region AI AO
//AI AO
public abstract double ProcessLowPressure { get; }
public abstract double ProcessHighPressure { get; }
public abstract double ProcessPressure { get; }
public abstract double ChamberPressure { get; }
public abstract double ForelinePressure { get; }
public abstract double TargetPressure { get; }
public abstract double ESCHePressure { get; }
public abstract int ESCOutputVoltage { get; }
public abstract double ESCPositiveOutputCurrent { get; }//R+
public abstract double ESCNegativeOutputCurrent { get; }//R-
public abstract bool IsHVOn { get; }
public abstract float CoolantInletTempFB { get; }
public abstract float CoolantOutletTempFB { get; }
public abstract bool ChillerIsRunning { get; }
public abstract float ReflectPower { get; }
public abstract float BiasReflectPower { get; }
#endregion
public abstract bool BackSideHeOutOfRange { get; }
public new ModuleName Module;
public abstract MovementPosition LiftPinPosition { get; }
public abstract bool CheckAtm();
public abstract bool CheckSlitDoorOpen();
public abstract bool CheckSlitDoorClose();
public abstract bool CheckLiftUp();
public abstract bool CheckLiftDown();
public abstract double TotalGasSetpoint { get; }
public abstract bool HasGasOutOfRange { get; }
public abstract bool PendulumValveIsOpen();
public double TMPressure { get { return Singleton.Instance.TM.TMPressure; } }
public bool IsTMATM { get { return Singleton.Instance.TM.IsTMATM; } }
public bool IsTMVAC { get { return Singleton.Instance.TM.IsTMVac; } }
// EndPoint
private readonly JetEPDBase _epdClient;
public List EPDCfgList => _epdClient?.CFGFileList;
public bool EPDCaptured => _epdClient.Captured;
public bool EPDConnected => _epdClient.IsEPDConnected;
public JetVenusSEPMBase(ModuleName module) : base(module.ToString(), module.ToString(), module.ToString(), module.ToString())
{
Module = module;
_epdClient = DEVICE.GetDevice($"{Module}.{VenusDevice.EndPoint}");
DATA.Subscribe($"{Name}.ForelinePressure", () => ForelinePressure);
DATA.Subscribe($"{Name}.ProcessHighPressure", () => ProcessHighPressure);
DATA.Subscribe($"{Name}.ProcessLowPressure", () => ProcessLowPressure);
DATA.Subscribe($"{Name}.ESCHePressure", () => ESCHePressure);
DATA.Subscribe($"{Name}.IsATM", () => IsATM);
DATA.Subscribe($"{Name}.IsVAC", () => IsVAC);
DATA.Subscribe($"{Name}.LiftPinIsUp", () => LiftPinIsUp);
DATA.Subscribe($"{Name}.LiftPinIsDown", () => LiftPinIsDown);
DATA.Subscribe($"{Name}.PumpIsRunning", () => IsPumpRunning);
DATA.Subscribe($"{Name}.TurboPumpIsRunning", () => IsTurboPumpRunning);
DATA.Subscribe($"{Name}.IsSlitDoorClosed", () => IsSlitDoorClosed);
DATA.Subscribe($"{Name}.IsLidClosed", () => IsLidClosed);
DATA.Subscribe($"{Name}.TurboPumpRotationalSpeed", () => TurboPumpSpeed);
DATA.Subscribe($"{Name}.IsWaterFlowOk", () => IsWaterFlowOk);
DATA.Subscribe($"{Name}.IsWLK", () => IsWLK);
DATA.Subscribe($"{Name}.IsCDA_OK", () => IsCDA_OK);
DATA.Subscribe($"{Name}.SourceRFFanInterlock", () => SourceRFFanInterlock);
DATA.Subscribe($"{Name}.IsTurboPumpInterlock", () => TurboPumpInterlock);
DATA.Subscribe($"{Name}.GetPVPosition", () => GetPVPosition());
DATA.Subscribe($"{Name}.ESCHV.Temp", () => CoolantOutletTempFB);
DATA.Subscribe($"{Name}.Chiller.Temp", () => CoolantInletTempFB);
DATA.Subscribe($"{Name}.Chiller.IsOn", () => ChillerIsRunning);
DATA.Subscribe($"{Name}.IsTurboPumpAtSpeed", () => IsTurboPumpAtSpeed);
DATA.Subscribe($"{Name}.EPDCfgList", () => EPDCfgList);
OP.Subscribe($"{Module}.SetLiftPin", (cmd, args) => {
if ((bool)args[0] == true)
{
return SetLiftPin(MovementPosition.Up, out _);
}
else
{
return SetLiftPin(MovementPosition.Down, out _);
}
});
OP.Subscribe($"{Module}.SetSRf", (cmd, args) =>
{
var ison = (bool)args[1];
if (ison == true)
{
GeneratorPowerOn(true);
GeneratorSetpower((float)args[0]);
}
else
{
GeneratorPowerOn(false);
}
return true;
});
OP.Subscribe($"{Module}.SetBRf", (cmd, args) => {
var ison = (bool)args[1];
if (ison == true)
{
GeneratorBiasPowerOn(true);
GeneratorBiasSetpower((float)args[0]);
}
else
{
GeneratorBiasPowerOn(false);
}
return true;
});
OP.Subscribe($"{Module}.SetESCHVIsOn", (cmd, args) => {
OnOffSetESCHV((bool)args[0]);
return true;
});
OP.Subscribe($"{Module}.SetESCHV", (cmd, args) => {
SetESCClampVoltage((int)args[0]);
return true;
});
OP.Subscribe($"{Module}.SetPVPostion", (cmd, args) => {
SetPVPostion((int)args[0]);
return true;
});
OP.Subscribe($"{Module}.SetPVPressure", (cmd, args) => {
SetPVPressure((int)args[0]);
return true;
});
OP.Subscribe($"{Module}.ClosePump", (cmd, args) => {
TurnDryPump(false);
return true;
});
OP.Subscribe($"{Module}.ControlValve", (cmd, args) => {
OpenValve((ValveType)((int)args[0]), (bool)args[1]);
return true;
});
OP.Subscribe($"{Module}.TurnPendulumValve", (cmd, args) => {
TurnPendulumValve((bool)args[0]);
return true;
});
OP.Subscribe($"{Module}.HeatChiller", (cmd, args) => {
var chillerType = (ChillerType)Enum.Parse(typeof(ChillerType), args[0].ToString());
HeatChiller(chillerType, (float)args[1], (float)args[2]);
return true;
});
OP.Subscribe($"{Module}.OnOffChiller", (cmd, args) => {
var chillerType = (ChillerType)Enum.Parse(typeof(ChillerType), args[0].ToString());
OnOffChiller(chillerType, (bool)args[1]);
return true;
});
OP.Subscribe($"{Module}.WallChiller", (cmd, args) => {
float value;
float.TryParse(args[0].ToString(), out value);
SetWallTCTemperature(value);
return true;
});
OP.Subscribe($"{Module}.SetBacksideHeFlow", (cmd, args) => {
double value;
double.TryParse(args[0].ToString(), out value);
SetBacksideHeFlow(value);
return true;
});
OP.Subscribe($"{Module}.SetBacksideHePressure", (cmd, args) =>
{
float value;
float.TryParse(args[0].ToString(), out value);
SetBacksideHePressure(value);
return true;
});
OP.Subscribe($"{Module}.EndPoint.SearchCfg", (cmd, args) =>
{
_epdClient?.QueryConfigList();
return true;
});
}
public virtual void Monitor()
{
}
public virtual bool Initialize()
{
return true;
}
public virtual void Terminate()
{
}
public virtual void Reset()
{
}
public abstract void CloseValves();
public abstract void TurnDryPump(bool on);
public abstract void TurnTurboPump(bool on);
public abstract void OpenValve(ValveType vlvType, bool on);
public abstract bool OnOffSetESCHV(bool on);
public abstract bool SetWallTCTemperature(float value);
protected abstract void CheckPermanentInterlock();
public abstract void CheckIdleInterlock();
public abstract void Home();
public abstract bool SetLiftPin(MovementPosition dirt, out string reason);
public abstract bool FlowGas(int gasNum, double val);
public abstract bool StopGas(int gasNum);
public abstract bool FlowN2(double val);
public abstract bool StopN2();
public abstract void StopAllGases();
public abstract bool TurnPendulumValve(bool on);
public abstract bool SetPVPressure(int pressure);
public abstract bool SetPVPostion(int position);
public abstract int GetPVPosition();
public abstract void HeatChiller(ChillerType chillerType, double value, double offset);
public abstract void OnOffChiller(ChillerType chillerType, bool onoff);
public abstract bool CheckChillerStatus();
public abstract void SetGeneratorCommunicationMode(int mode);
public abstract bool GeneratorPowerOn(bool on);
public abstract bool GeneratorSetpower(float val);
public abstract bool GeneratorBiasPowerOn(bool on);
public abstract bool GeneratorBiasSetpower(float val);
public abstract bool GeneratorBiasSetMatchMode(bool val);
public abstract bool SetMatchPosition(float c1, float c2);
public abstract bool SetBiasMatchPosition(float c1, float c2);
public abstract bool SetBiasPulseMode(bool on);
public abstract bool SetBiasPulseRateFreq(int nFreq);
public abstract bool SetDiasPulseDutyCycle(int percentage);
public abstract bool SetESCClampVoltage(int nVoltage);
public abstract bool CheckGeneratorAndHVInterlock(VenusDevice device);
#region EndPoint
public void EPDRecipeStart(string recipe)
{
_epdClient.RecipeStart(recipe);
}
public void EPDRecipeStop()
{
_epdClient.RecipeStop();
}
public void EPDStepStart(string cfgName, int step)
{
_epdClient.StepStart(cfgName, step);
}
public void EPDStepStop()
{
_epdClient.StepStop();
}
#endregion
public abstract void SetBacksideHeFlow(double flow);
public abstract bool SetBacksideHePressure(float mTorr);
public abstract bool SetBacksideHeThreshold(int nMin, int nMax);
}
}