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,
- }
- }
|