| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255 | using System.Diagnostics;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks;using Aitex.Core.RT.Fsm;using Aitex.Core.RT.Log;using Aitex.Core.Util;using Aitex.Core.RT.SCCore;using Aitex.Sorter.Common;using MECF.Framework.Common.Equipment;using MECF.Framework.Common.Schedulers;using MECF.Framework.Common.SubstrateTrackings;using Venus_RT.Scheduler;namespace Venus_RT.Modules.Schedulers{    class SchedulerItem    {        public TMEntity.MSG MoveType { get;  set; }        public ModuleName target { get;  set; }        public Queue<MoveItem> moveList { get;  set; }    }    class SchedulerTMRobot : SchedulerModule    {        public override bool IsAvailable        {            get { return _entity.IsIdle && /*_entity.IsOnline && */RunSchedulers(); }        }        public override bool IsOnline        {            get { return _entity.IsOnline; }        }        public override bool IsError        {            get { return _entity.IsError; }        }        private TMEntity _entity = null;        private int _entityTaskToken = (int)FSM_MSG.NONE;        private Queue<SchedulerItem> _schedulerList = new Queue<SchedulerItem>();        private SchedulerItem _currentScheduler = null;        public SchedulerTMRobot() : base(ModuleName.TM.ToString())        {            _entity = Singleton<RouteManager>.Instance.TM;        }        private bool CheckTaskDone()        {            bool ret = false;            switch (_entityTaskToken)            {                case (int)TMEntity.MSG.Pick:                case (int)TMEntity.MSG.PMPick:                    ret = WaferManager.Instance.CheckHasWafer(_currentScheduler.moveList.Peek().DestinationModule, _currentScheduler.moveList.Peek().DestinationSlot) &&                        WaferManager.Instance.CheckNoWafer(_currentScheduler.moveList.Peek().SourceModule, _currentScheduler.moveList.Peek().SourceSlot);                    break;                case (int)TMEntity.MSG.Place:                case (int)TMEntity.MSG.PMPlace:                    ret = WaferManager.Instance.CheckHasWafer(_currentScheduler.moveList.Peek().DestinationModule, _currentScheduler.moveList.Peek().DestinationSlot) &&                        WaferManager.Instance.CheckNoWafer(_currentScheduler.moveList.Peek().SourceModule, _currentScheduler.moveList.Peek().SourceSlot);                    break;                case (int)TMEntity.MSG.Swap:                    ret = WaferManager.Instance.CheckHasWafer(_currentScheduler.moveList.Peek().DestinationModule, _currentScheduler.moveList.Peek().DestinationSlot) &&                        WaferManager.Instance.CheckHasWafer(_currentScheduler.moveList.Last().DestinationModule, _currentScheduler.moveList.Last().DestinationSlot);                    break;                case (int)TMEntity.MSG.PMSwap:                    ret = WaferManager.Instance.CheckHasWafer(_currentScheduler.moveList.Peek().DestinationModule, _currentScheduler.moveList.Peek().DestinationSlot) &&                        WaferManager.Instance.CheckHasWafer(_currentScheduler.moveList.Peek().SourceModule, _currentScheduler.moveList.Peek().SourceSlot);                    break;                case (int)FSM_MSG.NONE:                    ret = true;                    break;            }            if(ret && _entityTaskToken != (int)FSM_MSG.NONE)            {                _entityTaskToken = (int)FSM_MSG.NONE;                LOG.Write(eEvent.EV_ROUTER, ModuleName.TM, $"Scheduler, { _currentScheduler.target} Task done: { _currentScheduler.MoveType}");            }            return ret;        }        public bool PostMoveItems(MoveItem[] items)        {            void PackSwapCmds(MoveItem[] swapItems, TMEntity.MSG swapType, int swapIndex)            {                SchedulerItem swap = new SchedulerItem();                swap.MoveType = swapType;                swap.target = swapItems[0].DestinationModule;                swap.moveList = new Queue<MoveItem>();                for (int i = 0; i < swapIndex; i++)                {                    if(!ModuleHelper.IsTM(swapItems[i].SourceModule))                    {                        SchedulerItem item = new SchedulerItem();                        item.MoveType = ModuleHelper.IsLoadLock(swapItems[i].SourceModule) ? TMEntity.MSG.Pick : TMEntity.MSG.PMPick;                        item.target = swapItems[i].SourceModule;                        item.moveList = new Queue<MoveItem>();                        item.moveList.Enqueue(new MoveItem(swapItems[i].SourceModule, swapItems[i].SourceSlot, ModuleName.TM, i, (Hand)i));                        _schedulerList.Enqueue(item);                        swap.moveList.Enqueue(new MoveItem(ModuleName.TM, i, swapItems[i].DestinationModule, swapItems[i].DestinationSlot, (Hand)i));                    }                }                for (int j = swapIndex; j < swapItems.Length; j++)                {                    swap.moveList.Enqueue(new MoveItem(swapItems[j].SourceModule, swapItems[j].SourceSlot, ModuleName.TM, j - swapIndex, (Hand)(j - swapIndex)));                }                _schedulerList.Enqueue(swap);                for (int j = swapIndex; j < swapItems.Length; j++)                {                    if (!ModuleHelper.IsTM(swapItems[j].DestinationModule))                    {                        SchedulerItem item = new SchedulerItem();                        item.MoveType = ModuleHelper.IsLoadLock(swapItems[j].DestinationModule) ?  TMEntity.MSG.Place : TMEntity.MSG.PMPlace;                        item.target = swapItems[j].DestinationModule;                        item.moveList = new Queue<MoveItem>();                        item.moveList.Enqueue(new MoveItem(ModuleName.TM, j - swapIndex, swapItems[j].DestinationModule, swapItems[j].DestinationSlot, (Hand)(j - swapIndex)));                        _schedulerList.Enqueue(item);                    }                }            }            if(WaferManager.Instance.CheckNoWafer(ModuleName.TM, 0) && WaferManager.Instance.CheckNoWafer(ModuleName.TM, 1))            {                if (items.Length == 4)                {                    if (ModuleHelper.IsLoadLock(items[0].DestinationModule) &&                        items[0].DestinationModule == items[1].DestinationModule &&                        items[0].DestinationModule == items[2].SourceModule &&                        items[0].DestinationModule == items[3].SourceModule)                    {                        PackSwapCmds(items,  TMEntity.MSG.Swap, 2);                    }                }                else if (items.Length == 3)                {                    if (ModuleHelper.IsLoadLock(items[0].DestinationModule) &&                        items[0].DestinationModule == items[1].DestinationModule &&                        items[0].DestinationModule == items[2].SourceModule)                    {                        PackSwapCmds(items, TMEntity.MSG.Swap, 2);                    }                    else if (ModuleHelper.IsLoadLock(items[0].DestinationModule) &&                        items[0].DestinationModule == items[1].SourceModule &&                        items[0].DestinationModule == items[2].SourceModule)                    {                        PackSwapCmds(items, TMEntity.MSG.Swap, 1);                    }                }                else if (items.Length == 2)                {                    if (ModuleHelper.IsLoadLock(items[0].DestinationModule) &&                        items[0].DestinationModule == items[1].DestinationModule)                    {                        PackSwapCmds(items, TMEntity.MSG.Swap, 2);                    }                    else if (ModuleHelper.IsLoadLock(items[0].SourceModule) &&                        items[0].SourceModule == items[1].SourceModule)                    {                        PackSwapCmds(items, TMEntity.MSG.Swap, 0);                    }                    else if (ModuleHelper.IsPm(items[0].SourceModule) &&                        items[0].SourceModule == items[1].DestinationModule)                    {                        PackSwapCmds(items,  TMEntity.MSG.PMSwap, 1);                    }                }            }            Hand freeHand = SelectFreeHand();            if(freeHand == Hand.None)            {                LOG.Write(eEvent.WARN_ROUTER, ModuleName.TM, "No Free Arm to transfer wafer");                return false;            }            if(_schedulerList.Count == 0)            {                foreach(var moveItem in items)                {                    if(!ModuleHelper.IsTM(moveItem.SourceModule))                    {                        SchedulerItem item = new SchedulerItem();                        item.MoveType = ModuleHelper.IsLoadLock(moveItem.SourceModule) ?  TMEntity.MSG.Pick : TMEntity.MSG.PMPick;                        item.target = moveItem.SourceModule;                        item.moveList = new Queue<MoveItem>();                        item.moveList.Enqueue(new MoveItem(moveItem.SourceModule, moveItem.SourceSlot, ModuleName.TM, (int)freeHand, freeHand));                        _schedulerList.Enqueue(item);                    }                    if (!ModuleHelper.IsTM(moveItem.DestinationModule))                    {                        SchedulerItem item = new SchedulerItem();                        item.MoveType = ModuleHelper.IsLoadLock(moveItem.DestinationModule) ? TMEntity.MSG.Place : TMEntity.MSG.PMPlace;                        item.target = moveItem.DestinationModule;                        item.moveList = new Queue<MoveItem>();                        item.moveList.Enqueue(new MoveItem(ModuleName.TM, (int)freeHand, moveItem.DestinationModule, moveItem.DestinationSlot,  freeHand));                        _schedulerList.Enqueue(item);                    }                }            }            return true;        }        Hand SelectFreeHand()        {            if (WaferManager.Instance.CheckNoWafer(ModuleName.TM, 0))                return Hand.Blade1;            if (WaferManager.Instance.CheckNoWafer(ModuleName.TM, 1))                return Hand.Blade2;            return Hand.None;        }        bool RunSchedulers()        {            if(_entity.IsIdle && CheckTaskDone())            {                if (_schedulerList.Count == 0)                    return true;                _currentScheduler = _schedulerList.Dequeue();                Queue<MoveItem> moveItems = new Queue<MoveItem>();                foreach(var item in _currentScheduler.moveList)                {                    moveItems.Enqueue(item);                    LOG.Write(eEvent.INFO_TM, ModuleName.TM, $"TM Moving Items: {item.SourceModule} Slot {item.SourceSlot + 1} => {item.DestinationModule} Slot {item.DestinationSlot + 1}");                }                if(_entity.CheckToPostMessage((int)_currentScheduler.MoveType, moveItems))                {                    _entityTaskToken = (int)_currentScheduler.MoveType;                }                else                    _entityTaskToken = (int)FSM_MSG.NONE;            }            return false;        }    }}
 |