| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255 | using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks;using Aitex.Core.RT.DataCenter;using Aitex.Core.RT.Device;using Aitex.Core.RT.Event;using Aitex.Core.RT.Log;using Aitex.Core.RT.SCCore;using MECF.Framework.Common.DataCenter;using MECF.Framework.Common.DBCore;using MECF.Framework.Common.Equipment;using MECF.Framework.Common.Schedulers;using MECF.Framework.Common.SubstrateTrackings;using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.TMs;namespace MECF.Framework.RT.EquipmentLibrary.HardwareUnits.PMs{    public class PM : BaseDevice, IDevice, IPM    {        //如果true,robot采用extend, retract指令        //如果false,robot采用pick,place指令        public  bool IsActiveHandoff { get; set; }        //如果true,robot调用收尾PostTransfer        public bool IsNeedPostTransfer { get; set; }        public virtual double ChamberPressure { get; }        public virtual bool IsError { get; }        public virtual bool IsIdle { get; }        public virtual bool IsProcessing { get; }        public virtual bool IsInstalled { get; set; }        public virtual double ForelinePressure { get; set; }         protected readonly string _statNameWaferProcessed;        protected readonly string _statNameWaferProcessedSincePreviousClean;        protected readonly string _statNameWaferProcessedSincePreviousWash;        public PM(string module) : base(module, module, module, module)        {            _statNameWaferProcessed = $"{module}.WaferProcessed";            _statNameWaferProcessedSincePreviousClean = $"{module}.WaferProcessedSincePreviousClean";            _statNameWaferProcessedSincePreviousWash = $"{module}.WaferProcessedSincePreviousWash";        }        public virtual bool Initialize()        {            DATA.Subscribe($"{Name}.IsAtm", () => { return CheckAtm(); });            DATA.Subscribe($"{Name}.IsVacuum", () => { return CheckVacuum(); });            DATA.Subscribe($"{Name}.ChamberPressure", () => ChamberPressure);            IsInstalled = !SC.ContainsItem($"System.{Name}IsInstalled") || SC.GetValue<bool>($"System.{Name}IsInstalled");            StatsDataManager.Instance.Subscribe(_statNameWaferProcessed, $"{Name} Wafer processed", 0);            StatsDataManager.Instance.Subscribe(_statNameWaferProcessedSincePreviousClean, $"{Name} Wafer processed since previous clean", 0);            return true;        }        public virtual bool CheckAtm()        {            return false;        }        public virtual bool CheckVacuum()        {            return false;        }        public virtual bool CheckChuckState()        {            return false;        }        public virtual bool CheckServoTransferPos()        {            return false;        }        public virtual bool CheckChuckPos()        {            return false;        }        public virtual bool CheckHandoff(EnumTransferType type)        {            return false;        }        public virtual bool CheckEnableTransfer(EnumTransferType type, out string reason)        {            reason = string.Empty;            return false;        }        public virtual bool CheckEnableTransfer(EnumTransferType type, int slot, out string reason)        {            reason = string.Empty;            return false;        }        public virtual bool CheckEnablePump(out  string reason)        {            reason = "Undefined";            return false;        }        public virtual void Monitor()        {        }        public virtual void Terminate()        {        }        public virtual void Reset()        {        }        public virtual bool PrepareTransfer(EnumTransferType type, out string reason)        {            reason = string.Empty;            return true;        }        public virtual bool Home()        {            return true;        }        public virtual void PostTransfer(EnumTransferType type)        {        }        public virtual void TransferHandoff(EnumTransferType type)        {        }         public virtual void StartProcess(string recipeName, string recipeContent, bool isClean)        {        }        public virtual bool SetPumpOn(out string reason)        {            throw new NotImplementedException();        }        public virtual void OnProcessStart(string guid, string recipeName, bool isClean)        {            ProcessDataRecorder.Start(guid, recipeName,                 WaferManager.Instance.GetWafer(ModuleHelper.Converter(Module), 0).InnerId.ToString(), Module);            if (!isClean)            {                int value1 = StatsDataManager.Instance.Increase(_statNameWaferProcessed);                int value2 = StatsDataManager.Instance.Increase(_statNameWaferProcessedSincePreviousClean);                LOG.Write($"{_statNameWaferProcessed} counter increase 1 to {value1}");                LOG.Write($"{_statNameWaferProcessedSincePreviousClean} counter increase 1 to {value2}");            }            LOG.Write($"{Module} start run recipe {recipeName}, guid {guid}, clean: {isClean}");        }        public virtual bool CheckPumpIsOn()        {            throw new NotImplementedException();        }        public virtual bool SetPumpOff(out string reason)        {            throw new NotImplementedException();        }        public virtual void OnProcessEnd(string guid, string recipeName, bool isClean, bool isSucceed)        {            if (isClean)            {                int value = StatsDataManager.Instance.Reset(_statNameWaferProcessedSincePreviousClean);                LOG.Write($"{_statNameWaferProcessedSincePreviousClean} counter reset from {value}");            }            LOG.Write($"{Module} end run recipe {recipeName}, guid {guid}, clean: {isClean}, result {isSucceed}");            ProcessDataRecorder.End(guid, isSucceed ? "Complete" : "Failed");        }        public virtual void OnProcessAbort(string guid, string recipeName, bool isClean, bool isSucceed)        {            if (isClean)            {                int value = StatsDataManager.Instance.Reset(_statNameWaferProcessedSincePreviousClean);                LOG.Write($"{_statNameWaferProcessedSincePreviousClean} counter reset from {value}");            }            LOG.Write($"{Module} end run recipe {recipeName}, guid {guid}, clean: {isClean}, result {isSucceed}");            ProcessDataRecorder.End(guid, "Abort" );        }        public virtual bool SetThrottleValvePosition(int slowPumpPosition, out string reason)        {            throw new NotImplementedException();        }        public virtual bool SetThrottleValvePressure(float pressure, out string reason)        {            throw new NotImplementedException();        }        public virtual bool CloseThrottleValve(out string reason)        {            throw new NotImplementedException();        }        public virtual bool SetFastPumpValve(bool isOpen, out string reason)        {            throw new NotImplementedException();        }        public virtual bool SetSlowPumpValve(bool isOpen, out string reason)        {            throw new NotImplementedException();        }        public virtual bool OpenThrottleValve(out string reason)        {            throw new NotImplementedException();        }        public virtual bool SetAllValves(bool isOpen, out string reason)        {            reason = string.Empty;            return true;        }        public virtual bool CheckNoError(out List<string> reason)        {            reason = new List<string>();            return true;        }    }}
 |