| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187 | 
							- using System;
 
- 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.Sorter.Common;
 
- using MECF.Framework.Common.Schedulers;
 
- using MECF.Framework.Common.Equipment;
 
- using MECF.Framework.Common.SubstrateTrackings;
 
- using Venus_RT.Modules;
 
- using Venus_Core;
 
- namespace Venus_RT.Scheduler
 
- {
 
-     class SchedulerItem
 
-     {
 
-         public EfemEntity.MSG MoveType { get; set; }
 
-         public ModuleName target { get; set; }
 
-         public Queue<MoveItem> moveList { get; set; }
 
-         public RState Status { get; set; }
 
-     }
 
-     public class SchedulerEfemRobot : SchedulerModule
 
-     {
 
-         public override bool IsAvailable
 
-         {
 
-             get { return _entity.IsIdle && /*_entity.IsOnline && */CheckTaskDone() && RunSchedulers(); }
 
-         }
 
-         public override bool IsOnline
 
-         {
 
-             get { return _entity.IsOnline; }
 
-         }
 
-         public override bool IsError
 
-         {
 
-             get { return _entity.IsError; }
 
-         }
 
-         private EfemEntity _entity = null;
 
-         private SchedulerItem _currentScheduler = null;
 
-         private int _entityTaskToken = (int)TaskType.None;
 
-         public ModuleName PreviousTarget { get; set; }
 
-         public SchedulerEfemRobot() : base(ModuleName.EfemRobot.ToString())
 
-         {
 
-             _entity = Singleton<RouteManager>.Instance.EFEM;
 
-             PreviousTarget = ModuleName.System;
 
-         }
 
-         public bool Goto(ModuleName target, int slot )
 
-         {
 
-             _entityTaskToken = _entity.InvokeGoto(target, slot );
 
-             PreviousTarget = target;
 
-             LogTaskStart(_task, $"Robot goto {target}.{slot + 1}");
 
-             return true;
 
-         }
 
-         public bool Map(ModuleName destination )
 
-         {
 
-             _entityTaskToken = _entity.InvokeMap(destination.ToString());
 
-             LogTaskStart(_task, $"{Module} mapping");
 
-             PreviousTarget = destination;
 
-             return true;
 
-         }
 
-         public bool Monitor()
 
-         {
 
-             return true;
 
-         }
 
-         public bool CheckTaskDone()
 
-         {
 
-             bool ret = false;
 
-             switch (_entityTaskToken)
 
-             {
 
-                 case (int)TaskType.None:
 
-                     ret = true;
 
-                     break;
 
-                 case (int)EfemEntity.MSG.Pick:
 
-                 case (int)EfemEntity.MSG.Place:
 
-                 case (int)EfemEntity.MSG.Swap:
 
-                     ret = IsAllWafersArrived();
 
-                     break;
 
-                 case (int)EfemEntity.MSG.Map:
 
-                     ret = _entity.CheckAcked(_entityTaskToken) && _entity.IsIdle;
 
-                     break;
 
-                 case (int)EfemEntity.MSG.Goto:
 
-                     ret = _entity.CheckAcked(_entityTaskToken) && _entity.IsIdle;
 
-                     break;
 
-                 
 
-             }
 
-             if (ret && _task != TaskType.None)
 
-             {
 
-                 LogTaskDone(_task, "");
 
-                 _task = TaskType.None;
 
-             }
 
-             return ret;
 
-         }
 
-         public bool PostMoveItems(MoveItem[] items)
 
-         {
 
-             foreach (var item in items)
 
-             {
 
-                 LOG.Write(eEvent.EV_ROUTER, ModuleName.EfemRobot, $"Post Moving Item: {item.SourceModule} Slot {item.SourceSlot + 1} => {item.DestinationModule} Slot {item.DestinationSlot + 1}");
 
-             }
 
-             if (ModuleHelper.IsLoadLock(items.First().Module))
 
-             {
 
-                 _currentScheduler = new SchedulerItem();
 
-                 _currentScheduler.MoveType = EfemEntity.MSG.Swap;
 
-                 _currentScheduler.target = items.First().Module;
 
-                 _currentScheduler.Status = RState.Init;
 
-                 _currentScheduler.moveList = new Queue<MoveItem>(items);
 
-                 
 
-             }
 
-             else
 
-             {
 
-                 _currentScheduler = new SchedulerItem();
 
-                 _currentScheduler.MoveType = items.First().TransferType == EnumMoveType.Pick ? EfemEntity.MSG.Pick : EfemEntity.MSG.Place;
 
-                 _currentScheduler.target = items.First().Module;
 
-                 _currentScheduler.Status = RState.Init;
 
-                 _currentScheduler.moveList = new Queue<MoveItem>(items);
 
-             }
 
-             RunSchedulers();
 
-             return true;
 
-         }
 
-         bool RunSchedulers()
 
-         {
 
-             if (_currentScheduler == null)
 
-                 return true;
 
-             if (_entity.IsIdle)
 
-             {
 
-                 if(_currentScheduler.Status == RState.Init)
 
-                 {
 
-                     foreach (var item in _currentScheduler.moveList)
 
-                     {
 
-                         LOG.Write(eEvent.EV_EFEM_ROBOT, ModuleName.EfemRobot, $"EFEM Robot Moving Items: {item.SourceModule} Slot {item.SourceSlot + 1} => {item.DestinationModule} Slot {item.DestinationSlot + 1}");
 
-                     }
 
-                     if (_entity.CheckToPostMessage((int)_currentScheduler.MoveType, _currentScheduler.moveList))
 
-                     {
 
-                         _currentScheduler.Status = RState.Running;
 
-                         _entityTaskToken = (int)_currentScheduler.MoveType;
 
-                     }
 
-                     else
 
-                         _entityTaskToken = (int)FSM_MSG.NONE;
 
-                 }
 
-                 else if(_currentScheduler.Status == RState.Running)
 
-                 {
 
-                     if (IsAllWafersArrived())
 
-                         _currentScheduler.Status = RState.End;
 
-                 }
 
-             }
 
-             return _currentScheduler.Status == RState.End;
 
-         }
 
-         private bool IsAllWafersArrived()
 
-         {
 
-             foreach(var item in _currentScheduler.moveList)
 
-             {
 
-                 if (WaferManager.Instance.CheckNoWafer(item.DestinationModule, item.DestinationSlot))
 
-                     return false;
 
-             }
 
-             return true;
 
-         }
 
-     }
 
- }
 
 
  |