| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265 | using Aitex.Core.RT.DataCenter;using Aitex.Core.RT.Device;using Aitex.Core.RT.Fsm;using Aitex.Core.RT.Log;using Aitex.Core.RT.OperationCenter;using Aitex.Core.RT.Routine;using Aitex.Core.Utilities;using MECF.Framework.Common.Equipment;using MECF.Framework.Common.SubstrateTrackings;using MECF.Framework.Common.Utilities;using CyberX8_Core;using CyberX8_RT.Devices.AXIS;using CyberX8_RT.Devices.PUF;using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks;using System.Windows.Interop;using MECF.Framework.Common.CommonData;using MECF.Framework.Common.Alarm;using Aitex.Core.Util;using MECF.Framework.Common.WaferHolder;namespace CyberX8_RT.Modules.PUF{    public class PUFEntity : Entity, IEntity, IModuleEntity    {        #region 常量        #endregion        #region 属性        public bool IsInRobotStation        {            get { return CheckPufRotationInRobot(); }        }        public ModuleName Module { get; private set; }        public bool IsInit        {            get { return fsm.State == (int)PUFSTATE.Init; }        }        public bool IsIdle        {            get            {                return  fsm.State == (int)PUFSTATE.Idle;            }        }        public bool IsError        {            get { return fsm.State == (int)PUFSTATE.Error; }        }        public bool IsBusy        {            get { return !IsInit && !IsError && !IsIdle; }        }        public bool IsAuto { get; } = true;        /// <summary>        /// 是否为工程模式        /// </summary>        public bool IsEngineering { get; } = false;        /// <summary>        /// 是否为产品模式        /// </summary>        public bool IsProduction { get; } = true;        /// <summary>        /// SideA Wafer情况         /// </summary>        public bool SideAWaferPresent        {            get { return _pufVacuum.ChuckAWaferPresent; }        }        /// <summary>        /// SideB Wafer情况         /// </summary>        public bool SideBWaferPresent        {            get { return _pufVacuum.ChuckBWaferPresent; }        }        public bool IsHomed        {            get { return _isHomed; }        }        /// <summary>        /// 是否禁用        /// </summary>        public bool IsDisable { get; internal set; }        /// <summary>        /// Rotation是否SwitchOn        /// </summary>        public bool IsRotationSwitchOn        {            get { return _rotationAxis.IsSwitchOn; }        }        /// <summary>        /// Flip是否SwitchOn        /// </summary>        public bool IsFlipSwitchOn        {            get { return _flipAxis.IsSwitchOn; }        }        /// <summary>        /// 当前状态机状态        /// </summary>        public int State { get { return fsm.State; } }        /// <summary>        /// 是否回到安全位置        /// </summary>        public bool IsBackToParkStation        {            get            {                double flipPosition = _flipAxis.MotionData.MotorPosition;                double rotationPosition = _rotationAxis.MotionData.MotorPosition;                return  (_flipAxis.CheckPositionIsInStation(flipPosition, "SideA")||Module==ModuleName.PUF2)                    && _rotationAxis.CheckPositionIsInStation(rotationPosition, "Home") &&                    _pufVacuum.CheckChuckIn();            }        }        /// <summary>        /// 是否Flip到达sideA        /// </summary>        public bool IsFlipSideA        {            get { return _flipAxis.CheckPositionIsInStation(_flipAxis.MotionData.MotorPosition, "SideA"); }        }        /// <summary>        /// Vacuum状态        /// </summary>        public PufVacuum PufVacuum { get { return _pufVacuum; } }        #endregion        #region 内部变量        private bool _isHomed;        private JetAxisBase _flipAxis;        private JetAxisBase _rotationAxis;        private PufVacuum _pufVacuum;        private IRoutine _currentRoutine;        #endregion        #region routine        private PufHomeAllRoutine _homeAllRoutine;        private PufSwitchOnRoutine _switchOnRoutine;        private PufSwitchOffRoutine _switchOffRoutine;        private PufCalibrateRoutine _calibrateRoutine;        private PufPickFromLoaderRoutine _pickFromLoaderRoutine;        private PufPlaceToLoaderRoutine _placeToLoaderRoutine;        private PufGotoRobotForPlaceRoutine _gotoRobotForPlaceRoutine;        private PufGotoRobotForPickRoutine _gotoRobotForPickRoutine;        private PufReadyForRobotPlaceRoutine _readyForRobotPlaceRoutine;        private PufReadyForSwapRoutine _readyForSwapRoutine;        private PufSwapRoutine _swapRoutine;        private PufReadyForRobotPickRoutine _readyForRobotPickRoutine;        private PufBackToParkRoutine _backToParkRoutine;        #endregion        /// <summary>        /// 构造函数        /// </summary>        /// <param name="module"></param>        public PUFEntity(ModuleName module)        {            this.Module = module;            _flipAxis = DEVICE.GetDevice<JetAxisBase>($"{module}.Flip");            _rotationAxis=DEVICE.GetDevice<JetAxisBase>($"{module}.Rotation");            _pufVacuum = DEVICE.GetDevice<PufVacuum>($"{module}.Vacuum");            _pufVacuum.OnVacuumLeak += PufVacuum_OnVacuumLeak;            WaferManager.Instance.SubscribeLocation(Module, 2);            InitialFsm();            InitializeRoutine();        }        /// <summary>        /// Vacuum Leak 异常        /// </summary>        /// <param name="sender"></param>        /// <param name="e"></param>        private void PufVacuum_OnVacuumLeak(object sender, string e)        {            PostMsg((int)PUFMSG.Error);        }        protected override bool Init()        {            InitialOperation();            InitialDATA();            return true;        }        private void InitialDATA()        {            DATA.Subscribe($"{Module}.FsmState", () => ((PUFSTATE)fsm.State).ToString(), SubscriptionAttribute.FLAG.IgnoreSaveDB);            DATA.Subscribe($"{Module}.IsHomed", () => _isHomed,SubscriptionAttribute.FLAG.IgnoreSaveDB);             DATA.Subscribe($"{Module}.IsError", () => IsError, SubscriptionAttribute.FLAG.IgnoreSaveDB);            DATA.Subscribe($"{Module}.IsInRobotStation", () => IsInRobotStation, SubscriptionAttribute.FLAG.IgnoreSaveDB);             DATA.Subscribe($"{Module}.State", () => ((PUFSTATE)fsm.State).ToString(), SubscriptionAttribute.FLAG.IgnoreSaveDB);        }        /// <summary>        /// 初始化操作        /// </summary>        private void InitialOperation()        {            OP.Subscribe($"{Module}.Abort", (cmd, args) => { return CheckToPostMessage<PUFSTATE, PUFMSG>(eEvent.ERR_PUF, Module.ToString(), (int)PUFMSG.Abort); });            OP.Subscribe($"{Module}.ClearError", (cmd, args) => { return CheckToPostMessage<PUFSTATE, PUFMSG>(eEvent.ERR_PUF, Module.ToString(), (int)PUFMSG.ResumeError); });            OP.Subscribe($"{Module}.{MotionOperation.HomeAll}", (cmd, args) => { return CheckToPostMessage<PUFSTATE,PUFMSG>(eEvent.ERR_PUF,Module.ToString(),(int)PUFMSG.HomeAll);});            OP.Subscribe($"{Module}.{MotionOperation.SwitchOff}", (cmd, args) => { return CheckToPostMessage<PUFSTATE,PUFMSG>(eEvent.ERR_PUF,Module.ToString(),(int)PUFMSG.SwitchOff); });            OP.Subscribe($"{Module}.{MotionOperation.SwitchOn}", (cmd, args) => { return CheckToPostMessage<PUFSTATE,PUFMSG>(eEvent.ERR_PUF,Module.ToString(),(int)PUFMSG.SwitchOn); });            OP.Subscribe($"{Module}.{MotionOperation.Calibrate}", (cmd, args) => { return CheckToPostMessage<PUFSTATE,PUFMSG>(eEvent.ERR_PUF,Module.ToString(),(int)PUFMSG.Calibrate, args);});            OP.Subscribe($"{Module}.{MotionOperation.Pick}", (cmd, args) => { return CheckToPostMessage<PUFSTATE,PUFMSG>(eEvent.ERR_PUF,Module.ToString(),(int)PUFMSG.PickFromLoader, args); });            OP.Subscribe($"{Module}.{MotionOperation.Place}", (cmd, args) => { return CheckToPostMessage<PUFSTATE,PUFMSG>(eEvent.ERR_PUF,Module.ToString(),(int)PUFMSG.PlaceToLoader, args); });            OP.Subscribe($"{Module}.GotoRobotPositionForPlace", (cmd, args) => { return CheckToPostMessage<PUFSTATE, PUFMSG>(eEvent.ERR_PUF, Module.ToString(), (int)PUFMSG.GotoRobotPositionForPlace,  args); });             OP.Subscribe($"{Module}.GotoRobotPositionForPick", (cmd, args) => { return CheckToPostMessage<PUFSTATE, PUFMSG>(eEvent.ERR_PUF, Module.ToString(), (int)PUFMSG.GotoRobotPositionForPick, args); });        }        /// <summary>        /// 初始化Routine        /// </summary>        private void InitializeRoutine()        {            _homeAllRoutine = new PufHomeAllRoutine(Module,this);            _switchOnRoutine = new PufSwitchOnRoutine(Module);            _switchOffRoutine= new PufSwitchOffRoutine(Module);            _calibrateRoutine = new PufCalibrateRoutine(Module);            _pickFromLoaderRoutine = new PufPickFromLoaderRoutine(Module.ToString());            _placeToLoaderRoutine=new PufPlaceToLoaderRoutine(Module.ToString());            _gotoRobotForPlaceRoutine = new PufGotoRobotForPlaceRoutine(Module.ToString());            _gotoRobotForPickRoutine=new PufGotoRobotForPickRoutine(Module.ToString());            _readyForRobotPlaceRoutine=new PufReadyForRobotPlaceRoutine(Module.ToString());            _readyForSwapRoutine=new PufReadyForSwapRoutine(Module.ToString());            _swapRoutine=new PufSwapRoutine(Module.ToString());            _readyForRobotPickRoutine=new PufReadyForRobotPickRoutine(Module.ToString());            _backToParkRoutine=new PufBackToParkRoutine(Module.ToString());        }        /// <summary>        /// 初始化状态机        /// </summary>        private void InitialFsm()        {            fsm = new StateMachine<PUFEntity>(Module.ToString(), (int)PUFSTATE.Init, 20);            fsm.EnableRepeatedMsg(true);            AnyStateTransition(PUFMSG.Error, EnterError, PUFSTATE.Error);            AnyStateTransition(PUFMSG.ReturnIdle, (param) => { return true; }, PUFSTATE.Idle);            AnyStateTransition(PUFMSG.Abort, Abort, PUFSTATE.Init);            AnyStateTransition(PUFMSG.HomeAll, HomeAll, PUFSTATE.Homing);            Transition(PUFSTATE.Error, PUFMSG.ResumeError, ResumeError, PUFSTATE.Init);            //SwitchOn            Transition(PUFSTATE.Init, PUFMSG.SwitchOn, SwitchOnAll, PUFSTATE.SwitchOning);            Transition(PUFSTATE.Idle, PUFMSG.SwitchOn, SwitchOnAll, PUFSTATE.SwitchOning);            Transition(PUFSTATE.Error, PUFMSG.SwitchOn, SwitchOnAll, PUFSTATE.SwitchOning);            Transition(PUFSTATE.SwitchOning, FSM_MSG.TIMER, SwitchOnTimeout, PUFSTATE.Init);            //SwitchOff            Transition(PUFSTATE.Init, PUFMSG.SwitchOff, SwitchOffAll, PUFSTATE.SwitchOffing);            Transition(PUFSTATE.Idle, PUFMSG.SwitchOff, SwitchOffAll, PUFSTATE.SwitchOffing);            Transition(PUFSTATE.Error, PUFMSG.SwitchOff, SwitchOffAll, PUFSTATE.SwitchOffing);            Transition(PUFSTATE.SwitchOffing, FSM_MSG.TIMER, SwitchOffTimeout, PUFSTATE.Init);            // Home            Transition(PUFSTATE.Homing, FSM_MSG.TIMER, HomingTimeout, PUFSTATE.Idle);            //Calibrate            Transition(PUFSTATE.Idle, PUFMSG.Calibrate, Calibrate, PUFSTATE.Calibrating);            Transition(PUFSTATE.Calibrating, FSM_MSG.TIMER, CalibrateTimeout, PUFSTATE.Idle);            //PickFromLoader            Transition(PUFSTATE.Idle, PUFMSG.PickFromLoader, PickFromLoader, PUFSTATE.Picking);            Transition(PUFSTATE.Picking, FSM_MSG.TIMER, PickTimeout, PUFSTATE.Idle);            //PlaceToLoader            Transition(PUFSTATE.Idle, PUFMSG.PlaceToLoader, PlaceToLoader, PUFSTATE.Placing);            Transition(PUFSTATE.Placing, FSM_MSG.TIMER, PlaceToLoaderMonitor, PUFSTATE.Idle);            //GotoRobotPositionForPlace            Transition(PUFSTATE.Idle, PUFMSG.GotoRobotPositionForPlace, GotoRobotPositionForPlace, PUFSTATE.GotoRobotPositionForPlace);            Transition(PUFSTATE.GotoRobotPositionForPlace, FSM_MSG.TIMER, GotoRobotPositionForPlaceMonitor, PUFSTATE.Idle);            //GotoRobotPositionForPick            Transition(PUFSTATE.Idle, PUFMSG.GotoRobotPositionForPick, GotoRobotPositionForPick, PUFSTATE.GotoRobotPositionForPick);            Transition(PUFSTATE.GotoRobotPositionForPick, FSM_MSG.TIMER, GotoRobotPositionForPickMonitor, PUFSTATE.Idle);            //ready for robot place            Transition(PUFSTATE.Idle, PUFMSG.ReadyForRobotPlace, ReadyForRobotPlace, PUFSTATE.WaitForRobotPlacing);            Transition(PUFSTATE.WaitForRobotPlacing, FSM_MSG.TIMER, ReadyForRobotPlaceMonitor, PUFSTATE.WaitForRobotPlace);            Transition(PUFSTATE.WaitForRobotPlace, PUFMSG.ReadyForSwap, ReadyForSwap, PUFSTATE.WaitForSwaping);            Transition(PUFSTATE.WaitForSwaping, FSM_MSG.TIMER, ReadyForSwapMonitor, PUFSTATE.WaitForSwap);            Transition(PUFSTATE.WaitForSwap, PUFMSG.Swap, Swap, PUFSTATE.Swaping);            Transition(PUFSTATE.Swaping, FSM_MSG.TIMER, SwapMonitor, PUFSTATE.AferSwapParkStation);            Transition(PUFSTATE.AferSwapParkStation, PUFMSG.ReadyForRobotPick, ReadyForRobotPick, PUFSTATE.WaitForRobotPicking);            Transition(PUFSTATE.WaitForRobotPicking, FSM_MSG.TIMER, ReadyForRobotPickMonitor, PUFSTATE.WaitForRobotPick);            Transition(PUFSTATE.WaitForRobotPick, PUFMSG.RobotPickComplete, BackToParkStation, PUFSTATE.BackToPackStationing);            Transition(PUFSTATE.BackToPackStationing, FSM_MSG.TIMER, BackToParkStationMonitor, PUFSTATE.Idle);            Transition(PUFSTATE.Idle, PUFMSG.FlipSideA, FlipSideA, PUFSTATE.Fliping);            Transition(PUFSTATE.Fliping,FSM_MSG.TIMER,FlipSideAMonitor,PUFSTATE.Idle);            //Retry            Transition(PUFSTATE.Error, PUFMSG.Retry, NullFunc, PUFSTATE.Retrying);            Transition(PUFSTATE.Retrying, FSM_MSG.TIMER, PufRetry,PUFSTATE.Retrying);            Transition(PUFSTATE.Retrying, PUFMSG.ReadyForRobotPlace, RetryReadyForRobotPlace, PUFSTATE.WaitForRobotPlacing);            Transition(PUFSTATE.Retrying, PUFMSG.ReadyForSwap, RetryReadyForSwap, PUFSTATE.WaitForSwaping);            Transition(PUFSTATE.Retrying, PUFMSG.Swap, RetrySwap, PUFSTATE.Swaping);            Transition(PUFSTATE.Retrying, PUFMSG.ReadyForRobotPick, RetryReadyForRobotPick, PUFSTATE.WaitForRobotPicking);            Transition(PUFSTATE.Retrying, PUFMSG.RobotPickComplete, RetryBackToParkStation, PUFSTATE.BackToPackStationing);            //ConfirmComplete            Transition(PUFSTATE.Error, PUFMSG.ConfirmComplete, NullFunc, PUFSTATE.ConfirmCompleting);            Transition(PUFSTATE.Init, PUFMSG.ConfirmComplete, ClearModuleAlarm, PUFSTATE.Init);            Transition(PUFSTATE.Idle, PUFMSG.ConfirmComplete, ClearModuleAlarm, PUFSTATE.Idle);            Transition(PUFSTATE.ConfirmCompleting, FSM_MSG.TIMER, ConfirmComplete, PUFSTATE.ConfirmCompleting);            Transition(PUFSTATE.ConfirmCompleting, PUFMSG.ReadyForRobotPlace, ConfirmReadyForRobotPlace, PUFSTATE.WaitForRobotPlace);            Transition(PUFSTATE.ConfirmCompleting, PUFMSG.ReadyForSwap, ConfirmReadyForSwap, PUFSTATE.WaitForSwap);            Transition(PUFSTATE.ConfirmCompleting, PUFMSG.Swap, ConfirmSwap, PUFSTATE.Swaping);            Transition(PUFSTATE.ConfirmCompleting, PUFMSG.ReadyForRobotPick, ConfirmReadyForRobotPick, PUFSTATE.WaitForRobotPick);            Transition(PUFSTATE.ConfirmCompleting, PUFMSG.RobotPickComplete, ConfirmBackToParkStation, PUFSTATE.Idle);            EnumLoop<PUFSTATE>.ForEach((item) => { fsm.MapState((int)item, item.ToString()); });            EnumLoop<PUFMSG>.ForEach((item) => { fsm.MapMessage((int)item, item.ToString()); });        }        private bool EnterError(object[] param)        {            return true;        }        /// <summary>        /// 恢复错误        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool ResumeError(object[] param)        {            if (_isHomed)            {                PostMsg(PUFMSG.ReturnIdle);                return false;            }            return true;        }        #region Abort        private bool Abort(object parameter)        {            bool preHomed = IsHomed;            if(_flipAxis != null) _flipAxis.StopPositionOperation();            if(_rotationAxis != null) _rotationAxis.StopPositionOperation();            if(_currentRoutine!=null)            {                _currentRoutine.Abort();                _currentRoutine = null;            }            if (preHomed)            {                PostMsg(PUFMSG.ReturnIdle);                return false;            }            return true;        }        #endregion        #region Switch On        /// <summary>        /// SwitchAll        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool SwitchOnAll(object[] param)        {            return _switchOnRoutine.Start() == RState.Running;        }        private bool SwitchOnTimeout(object[] param)        {            RState ret = _switchOnRoutine.Monitor();            if (ret == RState.Failed || ret == RState.Timeout)            {                PostMsg(PUFMSG.Error);                return false;            }            bool result= ret == RState.End;            if(result)            {                _isHomed = false;            }            return result;        }        #endregion        #region Switch Off        /// <summary>        /// SwitchAll        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool SwitchOffAll(object[] param)        {            return _switchOffRoutine.Start() == RState.Running;        }        private bool SwitchOffTimeout(object[] param)        {            RState ret = _switchOffRoutine.Monitor();            if (ret == RState.Failed || ret == RState.Timeout)            {                PostMsg(PUFMSG.Error);                return false;            }            bool result= ret == RState.End;            if(result)            {                _isHomed= false;            }            return result;        }        #endregion        #region Home        /// <summary>        /// HomeAll        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool HomeAll(object[] param)        {            _isHomed = false;            bool result= _homeAllRoutine.Start() == RState.Running;            if(result)            {                _currentRoutine = _homeAllRoutine;            }            return result;        }        /// <summary>        /// Home超时        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool HomingTimeout(object[] param)        {            RState ret = _homeAllRoutine.Monitor();            if (ret == RState.Failed || ret == RState.Timeout)            {                _currentRoutine = null;                PostMsg(PUFMSG.Error);                _isHomed = false;                return false;            }            bool result = ret == RState.End;            if (result)            {                _currentRoutine = null;                _isHomed = true;            }            return result;        }        #endregion        #region Calibrate        private bool Calibrate(object[] param)        {            _calibrateRoutine.Start(param);            return true;        }        private bool CalibrateTimeout(object[] param)        {            RState ret = _calibrateRoutine.Monitor();            if (ret == RState.Failed || ret == RState.Timeout)            {                return true;            }            return ret == RState.End;        }        #endregion        #region Pick        private bool PickFromLoader(object[] param)        {            bool result= _pickFromLoaderRoutine.Start(param)==RState.Running;            if(result)            {                _currentRoutine = _pickFromLoaderRoutine;            }            return result;        }        private bool PickTimeout(object[] param)        {            //RState ret = _pufNoWaferPickRoutine.Monitor();            RState ret = _pickFromLoaderRoutine.Monitor();            if (ret == RState.Failed || ret == RState.Timeout)            {                PostMsg(PUFMSG.Error);                return false;            }            bool result = ret == RState.End;            if(result)            {                _currentRoutine = null;            }            return result;        }        #endregion        #region Place        /// <summary>        /// 放片至Loader        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool PlaceToLoader(object[] param)        {            bool result = _placeToLoaderRoutine.Start(param) == RState.Running;            if(result)            {                _currentRoutine = _placeToLoaderRoutine;            }            return result;        }        /// <summary>        /// 监控放片至Loader        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool PlaceToLoaderMonitor(object[] param)        {            //RState ret = _pufNoWaferPickRoutine.Monitor();            RState ret = _placeToLoaderRoutine.Monitor();            if (ret == RState.Failed || ret == RState.Timeout)            {                _currentRoutine = null;                PostMsg(PUFMSG.Error);                return false;            }            bool result = ret == RState.End;            if(result)            {                _currentRoutine = null;            }            return result;        }        #endregion                #region GotoRobotPositionForPlace        /// <summary>        /// Goto Robot Position For Place        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool GotoRobotPositionForPlace(object[] param)         {            bool result= _gotoRobotForPlaceRoutine.Start(param)==RState.Running;            if(result)            {                _currentRoutine = _gotoRobotForPlaceRoutine;            }            return result;        }        /// <summary>        /// Goto Robot Position For Place监控        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool GotoRobotPositionForPlaceMonitor(object[] param)        {            RState ret = _gotoRobotForPlaceRoutine.Monitor();            if (ret == RState.Failed || ret == RState.Timeout)            {                _currentRoutine = null;                PostMsg(PUFMSG.Error);                return false;            }            bool result= ret == RState.End;            if(result)            {                _currentRoutine = null;            }            return result;        }        #endregion        #region GotoRobotPositionForPick        /// <summary>        /// Goto Robot Position For Pick        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool GotoRobotPositionForPick(object[] param)        {            bool result= _gotoRobotForPickRoutine.Start(param) == RState.Running;            if(result)            {                _currentRoutine = _gotoRobotForPickRoutine;            }            return result;        }        /// <summary>        /// Goto Robot Position For Pick监控        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool GotoRobotPositionForPickMonitor(object[] param)        {            RState ret = _gotoRobotForPickRoutine.Monitor();            if (ret == RState.Failed || ret == RState.Timeout)            {                _currentRoutine = null;                PostMsg(PUFMSG.Error);                return false;            }            bool result = ret == RState.End;            if(result)            {                _currentRoutine = null;            }            return result;        }        #endregion        #region ReadyForRobotPlace        /// <summary>        /// Ready For Robot Place        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool ReadyForRobotPlace(object[] param)        {            bool result = _readyForRobotPlaceRoutine.Start(param)==RState.Running;            if(result)            {                _currentRoutine = _readyForRobotPlaceRoutine;            }            return result;        }        /// <summary>        /// Ready For Robot Place        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool RetryReadyForRobotPlace(object[] param)        {            int stepIndex = (int)param[0];            bool result = _readyForRobotPlaceRoutine.Retry(stepIndex) == RState.Running;            if (result)            {                _currentRoutine = _readyForRobotPlaceRoutine;            }            return result;        }        /// <summary>        /// ReadyForRobotPlace监控        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool ReadyForRobotPlaceMonitor(object[] param)        {            RState ret = _readyForRobotPlaceRoutine.Monitor();            if (ret == RState.Failed || ret == RState.Timeout)            {                _currentRoutine = null;                if (Singleton<RouteManager>.Instance.IsAutoRunning)                {                    AlarmList alarmList = new AlarmList(Module.ToString(), ((PUFSTATE)fsm.State).ToString(), (int)PUFMSG.ReadyForRobotPlace, _readyForRobotPlaceRoutine.ErrorMsg, _readyForRobotPlaceRoutine.ErrorStep, (int)AlarmType.Error);                    AlarmListManager.Instance.AddAlarm(alarmList);                }                PostMsg(PUFMSG.Error);                return false;            }            bool result= ret == RState.End;            if(result)            {                AlarmListManager.Instance.CheckModuleAlamAndRemove(Module.ToString(), PUFSTATE.WaitForRobotPlacing.ToString());                _currentRoutine = null;            }            return result;        }        /// <summary>        /// 确认ReadyForRobotPlace        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool ConfirmReadyForRobotPlace(object[] param)        {            bool result = _readyForRobotPlaceRoutine.CheckCompleteCondition();            if (!result)            {                if (Singleton<RouteManager>.Instance.IsAutoRunning)                {                    AlarmList alarmList = new AlarmList(Module.ToString(), ((PUFSTATE)fsm.State).ToString(), (int)PUFMSG.ReadyForRobotPlace,                    _readyForRobotPlaceRoutine.ErrorMsg, _readyForRobotPlaceRoutine.ErrorStep, (int)AlarmType.Error);                    AlarmListManager.Instance.AddAlarm(alarmList);                }                PostMsg(PUFMSG.Error);            }            else            {                if (Singleton<RouteManager>.Instance.IsAutoRunning)                {                    AlarmListManager.Instance.CheckModuleAlamAndRemove(Module.ToString(), PUFSTATE.WaitForRobotPlacing.ToString());                }            }            return result;        }        #endregion        #region Ready for Swap        /// <summary>        /// Ready For Swap        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool ReadyForSwap(object[] param)        {            bool result= _readyForSwapRoutine.Start(param)==RState.Running;            if(result)            {                _currentRoutine = _readyForSwapRoutine;            }            return result;        }        /// <summary>        /// Retry Ready For Swap        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool RetryReadyForSwap(object[] param)        {            int stepIndex = (int)param[0];            bool result = _readyForSwapRoutine.Retry(stepIndex) == RState.Running;            if (result)            {                _currentRoutine = _readyForSwapRoutine;            }            return result;        }        /// <summary>        /// Ready For Swap 监控        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool ReadyForSwapMonitor(object[] param)        {            RState ret = _readyForSwapRoutine.Monitor();            if (ret == RState.Failed || ret == RState.Timeout)            {                _currentRoutine = null;                if (Singleton<RouteManager>.Instance.IsAutoRunning)                {                    AlarmList alarmList = new AlarmList(Module.ToString(), ((PUFSTATE)fsm.State).ToString(), (int)PUFMSG.ReadyForSwap,                    _readyForSwapRoutine.ErrorMsg, _readyForSwapRoutine.ErrorStep, (int)AlarmType.Error);                    AlarmListManager.Instance.AddAlarm(alarmList);                }                PostMsg(PUFMSG.Error);                return false;            }            bool result= ret == RState.End;            if(result)            {                AlarmListManager.Instance.CheckModuleAlamAndRemove(Module.ToString(), PUFSTATE.WaitForSwaping.ToString());                _currentRoutine = null;            }            return result;        }        /// <summary>        /// 确认Ready For Swap        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool ConfirmReadyForSwap(object[] param)        {            bool result = _readyForSwapRoutine.CheckCompleteCondition();            if (!result)            {                if (Singleton<RouteManager>.Instance.IsAutoRunning)                {                    AlarmList alarmList = new AlarmList(Module.ToString(), ((PUFSTATE)fsm.State).ToString(), (int)PUFMSG.ReadyForSwap,                    _readyForSwapRoutine.ErrorMsg, _readyForSwapRoutine.ErrorStep, (int)AlarmType.Error);                    AlarmListManager.Instance.AddAlarm(alarmList);                }                PostMsg(PUFMSG.Error);            }            else            {                if (Singleton<RouteManager>.Instance.IsAutoRunning)                {                    AlarmListManager.Instance.CheckModuleAlamAndRemove(Module.ToString(), PUFSTATE.WaitForSwaping.ToString());                }            }            return result;        }        #endregion        #region Swap        /// <summary>        /// Swap        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool Swap(object[] param)        {            bool result= _swapRoutine.Start(param)==RState.Running;            if(result)            {                _currentRoutine = _swapRoutine;            }            return result;        }        /// <summary>        /// Retry Swap        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool RetrySwap(object[] param)        {            int stepIndex = (int)param[0];            bool result = _swapRoutine.Retry(stepIndex) == RState.Running;            if (result)            {                _currentRoutine = _swapRoutine;            }            return result;        }        /// <summary>        /// Swap监控        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool SwapMonitor(object[] param)        {            RState ret = _swapRoutine.Monitor();            if (ret == RState.Failed || ret == RState.Timeout)            {                _currentRoutine = null;                if (Singleton<RouteManager>.Instance.IsAutoRunning)                {                    AlarmList alarmList = new AlarmList(Module.ToString(), ((PUFSTATE)fsm.State).ToString(), (int)PUFMSG.Swap,                    _swapRoutine.ErrorMsg, _swapRoutine.ErrorStep, (int)AlarmType.Error);                    AlarmListManager.Instance.AddAlarm(alarmList);                }                PostMsg(PUFMSG.Error);                return false;            }            bool result = ret == RState.End;            if(result)            {                AlarmListManager.Instance.CheckModuleAlamAndRemove(Module.ToString(), PUFSTATE.Swaping.ToString());                _currentRoutine = null;            }            return result;        }        /// <summary>        /// 确认ReadyForRobotPick        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool ConfirmSwap(object[] param)        {            bool result = _swapRoutine.CheckCompleteCondition();            if (!result)            {                if (Singleton<RouteManager>.Instance.IsAutoRunning)                {                    AlarmList alarmList = new AlarmList(Module.ToString(), ((PUFSTATE)fsm.State).ToString(), (int)PUFMSG.Swap,                    _readyForRobotPickRoutine.ErrorMsg, _readyForRobotPickRoutine.ErrorStep, (int)AlarmType.Error);                    AlarmListManager.Instance.AddAlarm(alarmList);                }                PostMsg(PUFMSG.Error);            }            else            {                if (Singleton<RouteManager>.Instance.IsAutoRunning)                {                    AlarmListManager.Instance.CheckModuleAlamAndRemove(Module.ToString(), PUFSTATE.Swaping.ToString());                }            }            return result;        }        #endregion        #region ReadyForRobotPIck        /// <summary>        /// Ready For Robot Pick        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool ReadyForRobotPick(object[] param)        {            bool result= _readyForRobotPickRoutine.Start(param) == RState.Running;            if(result)            {                _currentRoutine = _readyForRobotPickRoutine;            }            return result;        }        /// <summary>        /// retry Ready For Robot Pick        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool RetryReadyForRobotPick(object[] param)        {            int stepIndex = (int)param[0];            bool result = _readyForRobotPickRoutine.Retry(stepIndex) == RState.Running;            if (result)            {                _currentRoutine = _readyForRobotPickRoutine;            }            return result;        }        /// <summary>        /// ReadyForRobotPick监控        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool ReadyForRobotPickMonitor(object[] param)        {            RState ret = _readyForRobotPickRoutine.Monitor();            if (ret == RState.Failed || ret == RState.Timeout)            {                if (Singleton<RouteManager>.Instance.IsAutoRunning)                {                    AlarmList alarmList = new AlarmList(Module.ToString(), ((PUFSTATE)fsm.State).ToString(), (int)PUFMSG.ReadyForRobotPick,                    _readyForRobotPickRoutine.ErrorMsg, _readyForRobotPickRoutine.ErrorStep, (int)AlarmType.Error);                    AlarmListManager.Instance.AddAlarm(alarmList);                }                PostMsg(PUFMSG.Error);                _currentRoutine = _readyForRobotPickRoutine;                return false;            }            bool result= ret == RState.End;            if(result)            {                AlarmListManager.Instance.CheckModuleAlamAndRemove(Module.ToString(), PUFSTATE.WaitForRobotPicking.ToString());                _currentRoutine = null;            }            return result;          }        /// <summary>        /// 确认ReadyForRobotPick        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool ConfirmReadyForRobotPick(object[] param)        {            bool result = _readyForRobotPickRoutine.CheckCompleteCondition();            if (!result)            {                if (Singleton<RouteManager>.Instance.IsAutoRunning)                {                    AlarmList alarmList = new AlarmList(Module.ToString(), ((PUFSTATE)fsm.State).ToString(), (int)PUFMSG.ReadyForRobotPick,                    _readyForRobotPickRoutine.ErrorMsg, _readyForRobotPickRoutine.ErrorStep, (int)AlarmType.Error);                    AlarmListManager.Instance.AddAlarm(alarmList);                }                PostMsg(PUFMSG.Error);            }            else            {                if (Singleton<RouteManager>.Instance.IsAutoRunning)                {                    AlarmListManager.Instance.CheckModuleAlamAndRemove(Module.ToString(), PUFSTATE.ConfirmCompleting.ToString());                }            }            return result;        }        #endregion        #region BackToParkStation        /// <summary>        /// Back to park station        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool BackToParkStation(object[] param)        {            bool result= _backToParkRoutine.Start(param) == RState.Running;            if(result)            {                _currentRoutine = _backToParkRoutine;            }            return true;        }        /// <summary>        /// Retry Back to park station        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool RetryBackToParkStation(object[] param)        {            int stepIdex = (int)param[0];            bool result = _backToParkRoutine.Retry(stepIdex) == RState.Running;            if (result)            {                _currentRoutine = _backToParkRoutine;            }            return true;        }        /// <summary>        /// BackToParkStation监控        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool BackToParkStationMonitor(object[] param)        {            RState ret = _backToParkRoutine.Monitor();            if (ret == RState.Failed || ret == RState.Timeout)            {                if (Singleton<RouteManager>.Instance.IsAutoRunning)                {                    AlarmList alarmList = new AlarmList(Module.ToString(), ((PUFSTATE)fsm.State).ToString(), (int)PUFMSG.RobotPickComplete,                    _backToParkRoutine.ErrorMsg, _backToParkRoutine.ErrorStep, (int)AlarmType.Error);                    AlarmListManager.Instance.AddAlarm(alarmList);                }                PostMsg(PUFMSG.Error);                _currentRoutine = null;                return false;            }            bool result= ret == RState.End;            if(result)            {                AlarmListManager.Instance.CheckModuleAlamAndRemove(Module.ToString(), PUFSTATE.BackToPackStationing.ToString());                _currentRoutine = null;            }            return result;        }        /// <summary>        /// 确认BackToParkStation        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool ConfirmBackToParkStation(object[] param)        {            bool result = _backToParkRoutine.CheckCompleteCondition();            if (!result)            {                if (Singleton<RouteManager>.Instance.IsAutoRunning)                {                    AlarmList alarmList = new AlarmList(Module.ToString(), ((PUFSTATE)fsm.State).ToString(), (int)PUFMSG.RobotPickComplete,                    _backToParkRoutine.ErrorMsg, _backToParkRoutine.ErrorStep, (int)AlarmType.Error);                    AlarmListManager.Instance.AddAlarm(alarmList);                }                PostMsg(PUFMSG.Error);            }            else            {                if (Singleton<RouteManager>.Instance.IsAutoRunning)                {                    AlarmListManager.Instance.CheckModuleAlamAndRemove(Module.ToString(), PUFSTATE.BackToPackStationing.ToString());                }            }            return result;        }        #endregion        #region Retry        /// <summary>        /// Retry        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool PufRetry(object[] param)        {            AlarmList alarmList = AlarmListManager.Instance.GetAlarmListByModule(Module.ToString());            if (alarmList != null)            {                CheckToPostMessage<PUFSTATE, PUFMSG>(eEvent.ERR_PUF, Module.ToString(), alarmList.ModuleCmd,                    alarmList.ModuleStep);            }            return false;        }        #endregion        #region ConfirmComplete        /// <summary>        /// 确认是否完成        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool ConfirmComplete(object[] param)        {            AlarmList alarmList = AlarmListManager.Instance.GetAlarmListByModule(Module.ToString());            if (alarmList != null)            {                if (alarmList.ModuleState == PUFSTATE.WaitForRobotPlacing.ToString())                {                    CheckToPostMessage<PUFSTATE, PUFMSG>(eEvent.ERR_PUF, Module.ToString(), (int)PUFMSG.ReadyForRobotPlace);                }                else if (alarmList.ModuleState == PUFSTATE.WaitForSwaping.ToString())                {                    CheckToPostMessage<PUFSTATE, PUFMSG>(eEvent.ERR_PUF, Module.ToString(), (int)PUFMSG.ReadyForSwap);                }                else if (alarmList.ModuleState == PUFSTATE.WaitForRobotPicking.ToString())                {                    CheckToPostMessage<PUFSTATE, PUFMSG>(eEvent.ERR_PUF, Module.ToString(), (int)PUFMSG.ReadyForRobotPick);                }                else if (alarmList.ModuleState == PUFSTATE.BackToPackStationing.ToString())                {                    CheckToPostMessage<PUFSTATE, PUFMSG>(eEvent.ERR_PUF, Module.ToString(), (int)PUFMSG.RobotPickComplete);                }                else if (alarmList.ModuleState == PUFSTATE.Swaping.ToString())                {                    CheckToPostMessage<PUFSTATE, PUFMSG>(eEvent.ERR_PUF, Module.ToString(), (int)PUFMSG.Swap);                }                else                {                    PostMsg(PUFMSG.Error);                    LOG.WriteLog(eEvent.ERR_PUF, Module.ToString(), $"error state {alarmList.ModuleState},cannot ConfirmComplete");                }            }            return false;        }        /// <summary>        /// 清除报警        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool ClearModuleAlarm(object[] param)        {            AlarmList alarmList = AlarmListManager.Instance.GetAlarmListByModule(Module.ToString());            if (alarmList != null)            {                AlarmListManager.Instance.CheckModuleAlamAndRemove(Module.ToString(), "");            }            return true;        }        #endregion        #region FlipSideA        /// <summary>        /// Flip SideA        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool FlipSideA(object[] param)         {            return _flipAxis.PositionStation("SideA");        }        /// <summary>        /// Flip SideA监控        /// </summary>        /// <param name="param"></param>        /// <returns></returns>        private bool FlipSideAMonitor(object[] param)        {            RState ret = _flipAxis.Status;            if (ret == RState.End)            {                return true;            }            else if (ret == RState.Failed || ret == RState.Timeout)            {                PostMsg(PUFMSG.Error);            }            return false;        }        #endregion        /// <summary>        /// 校验Puf Rotation是否到达Robot位置        /// </summary>        /// <returns></returns>        public bool CheckPufRotationInRobot()        {            if (!_pufVacuum.CheckChuckIn())            {                return false;            }            if (!_rotationAxis.CheckPositionIsInStation(_rotationAxis.MotionData.MotorPosition, "Robot"))            {                return false;            }            return true;        }        public bool Check(int msg, out string reason, params object[] args)        {            reason = "";            return false;        }        public bool CheckAcked(int msg)        {            return false;        }        public int Invoke(string function, params object[] args)        {            switch(function)            {                case "HomeAll":                    if(IsIdle)                    {                        return (int)FSM_MSG.NONE;                    }                    if (CheckToPostMessage<PUFSTATE, PUFMSG>(eEvent.ERR_PUF, Module.ToString(), (int)PUFMSG.HomeAll))                    {                        return (int)FSM_MSG.NONE;                    }                    else                    {                        return (int)FSM_MSG.ALARM;                    }                case "Abort":                    CheckToPostMessage<PUFSTATE, PUFMSG>(eEvent.ERR_PUF, Module.ToString(), (int)PUFMSG.Abort);                    return (int)FSM_MSG.NONE;                case "Retry":                    if (CheckToPostMessage<PUFSTATE, PUFMSG>(eEvent.ERR_PUF, Module.ToString(), (int)PUFMSG.Retry, args))                    {                        return (int)PUFMSG.Retry;                    }                    else                    {                        return (int)FSM_MSG.NONE;                    }                case "ConfirmComplete":                    if (CheckToPostMessage<PUFSTATE, PUFMSG>(eEvent.ERR_PUF, Module.ToString(), (int)PUFMSG.ConfirmComplete, args))                    {                        return (int)PUFMSG.ConfirmComplete;                    }                    else                    {                        return (int)FSM_MSG.NONE;                    }                default:                    return (int)FSM_MSG.NONE;            }        }    }    public enum PUFMSG    {        HomeAll,            // 0        SwitchOn,        SwitchOff,        Calibrate,        Error,        ResumeError,        Abort,        PickFromLoader,        PlaceToLoader,        GoToSavedPosition,        GotoRobotPositionForPlace,        GotoRobotPositionForPick,        ReturnIdle,        ReturnInit,        ReadyForRobotPlace,        ReadyForSwap,        Swap,        ReadyForRobotPick,        RobotPickComplete,        Retry,        ConfirmComplete,        FlipSideA    }}
 |