| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478 | using Aitex.Core.Common;using Aitex.Core.RT.DataCenter;using Aitex.Core.RT.Device;using Aitex.Core.RT.Event;using Aitex.Core.RT.Fsm;using Aitex.Core.RT.OperationCenter;using Aitex.Sorter.Common;using MECF.Framework.Common.DBCore;using MECF.Framework.Common.Equipment;using MECF.Framework.Common.Event;using MECF.Framework.Common.SubstrateTrackings;using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks;namespace MECF.Framework.RT.EquipmentLibrary.HardwareUnits.OcrReaders{    public abstract class OCRReaderBaseDevice : Entity, IDevice, IEntity    {        public OCRReaderBaseDevice(string module,string name):base()        {            Module = module;            Name = name;            InitializeOCRReader();        }               public ModuleName InstalledModule { get; set; }        public event Action<bool> ActionDone;        public event Action<string, AlarmEventItem> OnDeviceAlarmStateChanged;        public bool IsBusy = false;        public OCRReaderStateEnum DeviceState => (OCRReaderStateEnum)fsm.State;        public string CurrentJobName { get; set; }        public bool IsReadLaserMark1 { get; set; }        public string LaserMark1 { get; set; } = "";        public string LaserMark1Score { get; set; } = "";        public string LaserMark1ReadTime { get; set; } = string.Empty;        public string LaserMark2 { get; set; } = "";        public string LaserMark2Score { get; set; } = "";        public string LaserMark2ReadTime { get; set; } = string.Empty;        public string CurrentLaserMark { get; set; } = "";        public string CurrentLaserMarkOnWafer         {            get             {                if (WaferManager.Instance.CheckHasWafer(ModuleName.Aligner, 0))                    return CurrentLaserMark;                return "";             }        }        public virtual string CurrentImageFileName        {            get; set;        } = "";        public DateTime StartReadTime { get; private set; }        public int TimeLimitForRead { get; set; } = 300;        public List<string> JobFileList { get; set; }        public bool ReadOK { get; set; }        public string AlarmWIDReadTimeout { get => Name.ToString() + "WIDReadTimeout"; }        public string AlarmWIDLostCommunication { get => Name.ToString() + "WIDLostCommunication"; }        public string AlarmWIDLoadJobFail { get => Name.ToString() + "WIDLoadJobFail"; }        public string LaserMark1ReadResult { get; set; }        public string LaserMark2ReadResult { get; set; }        public virtual bool IsReady()        {            if (DeviceState != OCRReaderStateEnum.Idle)                return false;            if (IsBusy)                return false;            return true;        }               private void InitializeOCRReader()        {            BuildTransitionTable();            SubscribeDataVariable();            SubscribeOperation();            SubscribeDeviceOperation();            Running = true;        }        private void SubscribeDeviceOperation()        {            DEVICE.Register(string.Format("{0}.{1}", Name, "ReadWaferID"),//DeviceOperationName.ReadWaferID),                (out string reason, int time, object[] param) =>                {                    var bLaser = bool.Parse((string)param[0]);                    var jobName = (string)param[1];                    var ret = ReadWaferID(jobName, bLaser?0:1);                    if (ret)                    {                        reason = string.Format("{0}", Name, "Read Laser Mark.");                        return true;                    }                    else                        reason = string.Format("{0}", Name, "Can't read Laser Mark.");                    return false;                });            DEVICE.Register(string.Format("{0}.{1}", Name, "ReadLM1"),//DeviceOperationName.ReadWaferID),                (out string reason, int time, object[] param) =>                {                                       var jobName = (string)param[0];                    var ret = ReadWaferID(jobName, 0);                    if (ret)                    {                        reason = string.Format("{0}", Name, "Read Laser Mark.");                        return true;                    }                    else                        reason = string.Format("{0}", Name, "Can't read Laser Mark.");                    return false;                });            DEVICE.Register(string.Format("{0}.{1}", Name, "ReadLM2"),//DeviceOperationName.ReadWaferID),                (out string reason, int time, object[] param) =>                {                    reason = "";                    var jobName = (string)param[0];                    var ret = ReadWaferID(jobName,1);                    if (ret)                    {                        reason = string.Format("{0}", Name, "Read Laser Mark.");                        return true;                    }                    else                        reason = string.Format("{0}", Name, "Can't read Laser Mark.");                    return false;                });            DEVICE.Register($"{Name}.RefreshJobList", (out string reason, int time, object[] param) =>            {                reason = "";                return CheckToPostMessage((int)OCRReaderMsg.ReadParameter, new object[] { "JobList" });                            });            DEVICE.Register($"{Name}.Reset", (out string reason, int time, object[] param) =>            {                reason = "";                return CheckToPostMessage((int)OCRReaderMsg.Reset, new object[] { "Reset" });            });            DEVICE.Register($"{Name}.ManualSetLaserMark", (out string reason, int time, object[] param) =>            {                reason = "";                CurrentLaserMark = param[0].ToString();                var wafer = WaferManager.Instance.GetWafer(InstalledModule, 0);                if (!wafer.IsEmpty)                {                    wafer.LaserMarker = CurrentLaserMark;                    Guid guid = Guid.NewGuid();                    OCRDataRecorder.OcrReadComplete(guid.ToString(), wafer.WaferID, wafer.OriginStation.ToString(),                               wafer.OriginCarrierID ?? "", wafer.OriginSlot.ToString(), "0", "0", true, CurrentLaserMark,                              "0", "0");                }                return true;            });        }        private void SubscribeOperation()        {            OP.Subscribe($"{Name}.ReadWaferID", (string cmd, object[] param) =>            {                var bLaser = bool.Parse(param[0].ToString());                var jobName = (string)param[1];                var ret = ReadWaferID(jobName, bLaser ? 0 : 1);                if (!ret)                {                    EV.PostWarningLog(Module, $"{Name} can not read laser mark.");                    return false;                }                EV.PostInfoLog(Module, $"{Name} start read laser mark");                return true;            });            OP.Subscribe($"{Name}.ReadLM1", (string cmd, object[] param) =>            {                var jobName = (string)param[0];                var ret = ReadWaferID(jobName, 0);                if (ret)                {                                        return true;                }                               return false;            });            OP.Subscribe($"{Name}.RefreshJobList", (string cmd, object[] param) =>            {                               return CheckToPostMessage((int)OCRReaderMsg.ReadParameter, new object[] { "JobList" });            });            OP.Subscribe($"{Name}.Reset", (out string reason, int time, object[] param) =>            {                reason = "";                return CheckToPostMessage((int)OCRReaderMsg.Reset, new object[] { "Reset" });            });        }        private void SubscribeDataVariable()        {            DATA.Subscribe(Name, "WIDReaderState", () => DeviceState.ToString());            DATA.Subscribe(Name, "WIDReaderBusy", () => (DeviceState != OCRReaderStateEnum.Idle && DeviceState != OCRReaderStateEnum.Init));            DATA.Subscribe(Name, "WRIDReaderState", () => DeviceState.ToString());            DATA.Subscribe(Name, "WRIDReaderBusy", () => (DeviceState != OCRReaderStateEnum.Idle && DeviceState != OCRReaderStateEnum.Init));            DATA.Subscribe(Name, "LaserMaker1", () => LaserMark1);            DATA.Subscribe(Name, "LaserMaker2", () => LaserMark2);            DATA.Subscribe(Name, "LaserMark1Result", () => LaserMark1ReadResult);            DATA.Subscribe(Name, "LaserMark2Result", () => LaserMark2ReadResult);            DATA.Subscribe(Name, "JobFileList", () => JobFileList);            DATA.Subscribe(Name, "CurrentLaserMark", () => CurrentLaserMarkOnWafer);            DATA.Subscribe(Name, "CurrentImageFileName", () => CurrentImageFileName);            DATA.Subscribe(Name, "CurrentWaferID", () => WaferManager.Instance.GetWafer(InstalledModule, 0).WaferID);            EV.Subscribe(new EventItem("Alarm", AlarmWIDLoadJobFail, $"{Name} WID Reader load job failed.", EventLevel.Alarm, EventType.EventUI_Notify));            EV.Subscribe(new EventItem("Alarm", AlarmWIDLostCommunication, $"{Name} WID Reader lost communication.", EventLevel.Alarm, EventType.EventUI_Notify));            EV.Subscribe(new EventItem("Alarm", AlarmWIDReadTimeout, $"{Name} WID Reader read laser mark timeout.", EventLevel.Alarm, EventType.EventUI_Notify));        }        private void BuildTransitionTable()        {            fsm = new StateMachine<OCRReaderBaseDevice>(Module + Name + ".OCRReaderReaderStateMachine", (int)OCRReaderStateEnum.Init, 50);            AnyStateTransition(OCRReaderMsg.Error, fError, OCRReaderStateEnum.Error);            AnyStateTransition(OCRReaderMsg.Reset, fStartReset, OCRReaderStateEnum.Resetting);            Transition(OCRReaderStateEnum.Resetting, OCRReaderMsg.ActionDone, fResetComplete, OCRReaderStateEnum.Idle);            Transition(OCRReaderStateEnum.Resetting, OCRReaderMsg.ResetComplete, fResetComplete, OCRReaderStateEnum.Idle);            Transition(OCRReaderStateEnum.Resetting, FSM_MSG.TIMER, fMonitorReset, OCRReaderStateEnum.Idle);            Transition(OCRReaderStateEnum.Init, OCRReaderMsg.StartInit, fStartInit, OCRReaderStateEnum.Initializing);            Transition(OCRReaderStateEnum.Initializing, OCRReaderMsg.InitComplete, fInitComplete, OCRReaderStateEnum.Initializing);            Transition(OCRReaderStateEnum.Initializing, OCRReaderMsg.ActionDone, fInitComplete, OCRReaderStateEnum.Idle);            Transition(OCRReaderStateEnum.Initializing, FSM_MSG.TIMER, fMonitorInit, OCRReaderStateEnum.Idle);            Transition(OCRReaderStateEnum.Error, OCRReaderMsg.Clear, fStartClear, OCRReaderStateEnum.Idle);                        Transition(OCRReaderStateEnum.Idle, OCRReaderMsg.SetParameter, fStartSetParameter, OCRReaderStateEnum.SetParameter);            Transition(OCRReaderStateEnum.SetParameter, OCRReaderMsg.SetComplete, fSetParameterComplete, OCRReaderStateEnum.SetParameter);            Transition(OCRReaderStateEnum.SetParameter, OCRReaderMsg.ActionDone, fSetParameterComplete, OCRReaderStateEnum.SetParameter);            Transition(OCRReaderStateEnum.Idle, OCRReaderMsg.ReadParameter, fStartReadParameter, OCRReaderStateEnum.ReadParameter);            Transition(OCRReaderStateEnum.ReadParameter, OCRReaderMsg.ReadParaComplete, fReadParameterComplete, OCRReaderStateEnum.Idle);            Transition(OCRReaderStateEnum.ReadParameter, OCRReaderMsg.ActionDone, fReadParameterComplete, OCRReaderStateEnum.Idle);            Transition(OCRReaderStateEnum.ReadParameter, FSM_MSG.TIMER, fMonitorReadParameter, OCRReaderStateEnum.Idle);            Transition(OCRReaderStateEnum.Idle, OCRReaderMsg.ReadWaferID, fStartReadWaferID, OCRReaderStateEnum.ReadWaferID);            Transition(OCRReaderStateEnum.ReadWaferID, OCRReaderMsg.ReadCarrierIDComplete, fReadWaferIDComplete, OCRReaderStateEnum.Idle);            Transition(OCRReaderStateEnum.ReadWaferID, OCRReaderMsg.ActionDone, fReadWaferIDComplete, OCRReaderStateEnum.Idle);            Transition(OCRReaderStateEnum.ReadWaferID, FSM_MSG.TIMER, fMonitorReading, OCRReaderStateEnum.Idle);            Transition(OCRReaderStateEnum.Idle, OCRReaderMsg.SavePicture, fStartSavePicture, OCRReaderStateEnum.SavingPicture);            Transition(OCRReaderStateEnum.SavingPicture, OCRReaderMsg.SavePictureComplete, fSavePictureComplete, OCRReaderStateEnum.Idle);            Transition(OCRReaderStateEnum.SavingPicture, OCRReaderMsg.ActionDone, fSavePictureComplete, OCRReaderStateEnum.Idle);            Transition(OCRReaderStateEnum.SavingPicture, FSM_MSG.TIMER, fMonitorSavingPicture, OCRReaderStateEnum.Idle);        }        protected virtual void OnWaferIDRead(string wid, string score, string readtime)        {            EV.PostInfoLog(Name, $"{Name} read laser mark successfully,ID:{wid},score:{score},read time:{readtime}.");            CheckToPostMessage((int)OCRReaderMsg.ReadCarrierIDComplete, null);        }        protected virtual bool fMonitorSavingPicture(object[] param)        {            return false;        }        protected virtual bool fMonitorReading(object[] param)        {            if (DateTime.Now - StartReadTime > TimeSpan.FromSeconds((double)TimeLimitForRead))            {                OnError(AlarmWIDReadTimeout);            }            return false;        }        protected virtual bool fMonitorReadParameter(object[] param)        {            return false;        }        protected virtual bool fSavePictureComplete(object[] param)        {            return true; ;        }        protected abstract bool fStartSavePicture(object[] param);                protected virtual bool fError(object[] param)        {            return true;        }        protected abstract bool fStartReset(object[] param);        protected virtual bool fResetComplete(object[] param)        {            return true;        }        protected virtual bool fMonitorReset(object[] param)        {            return true;        }        protected abstract bool fStartInit(object[] param);        protected virtual bool fInitComplete(object[] param)        {            return true;        }        protected virtual bool fMonitorInit(object[] param)        {            return true;        }        protected virtual bool fStartClear(object[] param)        {            return true;        }        protected abstract bool fStartSetParameter(object[] param);        protected virtual bool fSetParameterComplete(object[] param)        {            return true;        }        protected abstract bool fStartReadParameter(object[] param);        protected virtual bool fReadParameterComplete(object[] param)        {            return true;        }        protected abstract bool fStartReadWaferID(object[] param);        protected virtual bool fReadWaferIDComplete(object[] param)        {            return true;        }        public virtual bool ReadWaferID(string jobname,int lasermarkindex=0)        {            StartReadTime = DateTime.Now;            CurrentJobName = jobname;            return CheckToPostMessage((int)OCRReaderMsg.ReadWaferID, new object[] { jobname, lasermarkindex });        }            public abstract string[] GetJobFileList();        public bool SavePicture(string path = "",string filename = "")        {            return CheckToPostMessage((int)OCRReaderMsg.SavePicture, new object[] { "SavePicture", path, filename });        }        protected override bool Init()        {            return base.Init();        }        public virtual void Monitor()        {            return;        }        public virtual void Reset()        {                    }        public virtual bool OnActionDone(object[] param)        {            IsBusy = false;            CheckToPostMessage((int)OCRReaderMsg.ActionDone, new object[] { "ActionDone" });            if (ActionDone != null)                ActionDone(true);            return true;        }        public void OnActionDone(bool result)        {            if (ActionDone != null)                ActionDone(result);        }        public virtual bool OnError(string errorMsg)        {            EV.PostAlarmLog(Module, $"{Name} occured error:{errorMsg}");            return CheckToPostMessage((int)OCRReaderMsg.Error, null);        }        public bool CheckToPostMessage(int msg, params object[] args)        {            if (!fsm.FindTransition(fsm.State, msg))            {                EV.PostWarningLog(Name, $"{Name} is in { (OCRReaderStateEnum)fsm.State} state,can not do {(OCRReaderMsg)msg}");                return false;            }            if ((OCRReaderMsg)msg == OCRReaderMsg.Reset || (OCRReaderMsg)msg == OCRReaderMsg.ReadParameter ||                (OCRReaderMsg)msg == OCRReaderMsg.ReadWaferID || (OCRReaderMsg)msg == OCRReaderMsg.SavePicture ||                (OCRReaderMsg)msg == OCRReaderMsg.SetParameter || (OCRReaderMsg)msg == OCRReaderMsg.StartInit)                IsBusy = true;            else                IsBusy = false;            fsm.PostMsg(msg, args);            return true;        }        public bool Check(int msg, out string reason, params object[] args)        {            if (!fsm.FindTransition(fsm.State, msg))            {                reason = String.Format("{0} is in {1} state,can not do {2}", Name, (OCRReaderStateEnum)fsm.State, (OCRReaderMsg)msg);                return false;            }            reason = "";            return true;        }                public virtual bool Error        {            get;        }        public string Module { get ; set ; }        public string Name { get; set ; }        public bool HasAlarm { get; set; }    }    public enum OCRReaderStateEnum    {        Undefined = 0,        Init,        Initializing,        Idle,        SetParameter,        ReadParameter,        ReadWaferID,         SavingPicture,        Error,        Resetting,    }    public enum OCRReaderMsg    {        Reset,        ResetComplete,        Clear,        StartInit,        InitComplete,        SetParameter,        SetComplete,        ReadParameter,        ReadParaComplete,        ReadWaferID,        ReadCarrierIDComplete,        SavePicture,        SavePictureComplete,        ActionDone,        Error,    }}
 |