WaferHolderTaskDispatcher.cs 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396
  1.  using Aitex.Core.RT.Log;
  2. using Aitex.Core.RT.SCCore;
  3. using Aitex.Core.Util;
  4. using CyberX8_Core;
  5. using CyberX8_RT.Modules;
  6. using CyberX8_RT.Modules.Dryer;
  7. using CyberX8_RT.Modules.Metal;
  8. using CyberX8_RT.Modules.Prewet;
  9. using CyberX8_RT.Modules.Transporter;
  10. using CyberX8_RT.Schedulers;
  11. using MECF.Framework.Common.CommonData;
  12. using MECF.Framework.Common.Equipment;
  13. using MECF.Framework.Common.ToolLayout;
  14. using MECF.Framework.Common.WaferHolder;
  15. using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.TMs;
  16. using SecsGem.Core.ItemModel;
  17. using System;
  18. using System.Collections.Generic;
  19. using System.Linq;
  20. using System.Text;
  21. using System.Threading.Tasks;
  22. namespace CyberX8_RT.Dispatch
  23. {
  24. public class WaferHolderTaskDispatcher : Singleton<WaferHolderTaskDispatcher>
  25. {
  26. /// <summary>
  27. /// 分析
  28. /// </summary>
  29. public void Analyse()
  30. {
  31. List <WaferHolderTask> waferHolderTasks = WaferHolderTaskManager.Instance.LoaderWaferHolderTaskList().ToList();
  32. bool exsitTransport2FromBuffer = false;
  33. List<WaferHolderTask> canceledWaferHolderTask = new List<WaferHolderTask>();
  34. foreach (var item in waferHolderTasks)
  35. {
  36. SchedulerSequence currentSequence = item.GetCurrentSchedulerSequence();
  37. if (currentSequence == null)
  38. {
  39. item.Run();
  40. continue;
  41. }
  42. //处理ProcessTransporter逻辑
  43. if (currentSequence.ModuleName == ModuleName.Transporter1)
  44. {
  45. DealProcessTransporterScheduler(currentSequence, item, waferHolderTasks);
  46. }
  47. //处理LoaderTransporter逻辑
  48. else if(currentSequence.ModuleName==ModuleName.Transporter2)
  49. {
  50. DealLoaderTransporterScheduler(currentSequence, item, waferHolderTasks,canceledWaferHolderTask,ref exsitTransport2FromBuffer);
  51. }
  52. else
  53. {
  54. item.Run();
  55. }
  56. }
  57. RemoveCanceledTask(canceledWaferHolderTask);
  58. }
  59. /// <summary>
  60. /// 处理ProcessTransporter
  61. /// </summary>
  62. /// <param name="sequence"></param>
  63. private void DealProcessTransporterScheduler(SchedulerSequence currentSequence,WaferHolderTask item,List<WaferHolderTask> waferHolderTasks)
  64. {
  65. int transporterTransferSeconds = SC.GetValue<int>("Transporter.TransporterTransferSeconds");
  66. if (currentSequence.State == RState.End)
  67. {
  68. item.Run();
  69. return;
  70. }
  71. if (currentSequence.State == RState.Running)
  72. {
  73. item.Run();
  74. return;
  75. }
  76. if (CheckOtherTransporterIsRunning(waferHolderTasks, item,ModuleName.Transporter1))
  77. {
  78. return;
  79. }
  80. //存在其他任务当前source为prewet同时prewet状态为WaitForPick
  81. if (CheckPrewetIsWaitForPick(waferHolderTasks, item) && currentSequence.State == RState.Init)
  82. {
  83. return;
  84. }
  85. if (currentSequence.State == RState.Init)
  86. {
  87. AnalyseProcessTransporterSchedulerSequence(currentSequence, item, transporterTransferSeconds);
  88. }
  89. }
  90. /// <summary>
  91. /// 处理LoaderTransPorter
  92. /// </summary>
  93. /// <param name="currentSequence"></param>
  94. /// <param name="item"></param>
  95. /// <param name="waferHolderTasks"></param>
  96. private void DealLoaderTransporterScheduler(SchedulerSequence currentSequence,WaferHolderTask item, List<WaferHolderTask> waferHolderTasks,
  97. List<WaferHolderTask> canceledWaferHolderTask, ref bool exsitTransport2FromBuffer)
  98. {
  99. if (currentSequence.State == RState.End)
  100. {
  101. item.Run();
  102. return;
  103. }
  104. if (currentSequence.State == RState.Running)
  105. {
  106. item.Run();
  107. return;
  108. }
  109. if (CheckOtherTransporterIsRunning(waferHolderTasks, item, ModuleName.Transporter2))
  110. {
  111. return;
  112. }
  113. if (!(currentSequence.Parameters is WaferHolderMoveItem))
  114. {
  115. return;
  116. }
  117. WaferHolderMoveItem waferHolderMoveItem = currentSequence.Parameters as WaferHolderMoveItem;
  118. if (waferHolderMoveItem.SourceModuleType == ModuleType.Buffer && waferHolderMoveItem.DestModuleType == ModuleType.Prewet)
  119. {
  120. if (item.State == WaferHolderTaskState.Canceled)
  121. {
  122. canceledWaferHolderTask.Add(item);
  123. return;
  124. }
  125. if (!exsitTransport2FromBuffer)
  126. {
  127. exsitTransport2FromBuffer = true;
  128. item.Run();
  129. }
  130. }
  131. else if (waferHolderMoveItem.SourceModuleType == ModuleType.Dryer)
  132. {
  133. if (waferHolderMoveItem.DestModuleType == ModuleType.Buffer)
  134. {
  135. if (WaferHolderManager.Instance.HasWaferHolder("Loader"))
  136. {
  137. item.Run();
  138. return;
  139. }
  140. if (CheckExistWaferHolderTaskIsCreateState(waferHolderTasks, item))
  141. {
  142. item.Run();
  143. return;
  144. }
  145. if (CheckDryerWaferHolderIdle(waferHolderTasks, item))
  146. {
  147. item.Run();
  148. return;
  149. }
  150. else
  151. {
  152. item.UpdateDryerLastSchedulerComplete();
  153. }
  154. }
  155. else
  156. {
  157. item.Run();
  158. }
  159. }
  160. else
  161. {
  162. item.Run();
  163. }
  164. }
  165. /// <summary>
  166. /// 是否存在未启动的WaferHolderTask
  167. /// </summary>
  168. /// <param name="waferHolderTasks"></param>
  169. /// <param name="waferHolderTask"></param>
  170. /// <returns></returns>
  171. private bool CheckExistWaferHolderTaskIsCreateState(List<WaferHolderTask> waferHolderTasks, WaferHolderTask waferHolderTask)
  172. {
  173. foreach(WaferHolderTask item in waferHolderTasks)
  174. {
  175. if (item.ID == waferHolderTask.ID)
  176. {
  177. continue;
  178. }
  179. if (item.State == WaferHolderTaskState.Created)
  180. {
  181. return true;
  182. }
  183. }
  184. return false;
  185. }
  186. /// <summary>
  187. /// 检验是否存在Dryer WaferHolder空闲(WaferHolder不存在WaferHolderTask中)
  188. /// </summary>
  189. /// <param name="waferHolderTasks"></param>
  190. /// <param name="module"></param>
  191. /// <returns></returns>
  192. private bool CheckDryerWaferHolderIdle(List<WaferHolderTask> waferHolderTasks,WaferHolderTask waferHolderTask)
  193. {
  194. List<string> dryerModules = DryerItemManager.Instance.InstalledModules;
  195. foreach (string item in dryerModules)
  196. {
  197. if (WaferHolderManager.Instance.HasWaferHolder(item))
  198. {
  199. DryerEntity dryerEntity = Singleton<RouteManager>.Instance.GetModule<DryerEntity>(item);
  200. if (dryerEntity == null)
  201. {
  202. continue;
  203. }
  204. if (!dryerEntity.IsIdle)
  205. {
  206. continue;
  207. }
  208. WaferHolderInfo waferHolderInfo=WaferHolderManager.Instance.GetWaferHolder(item);
  209. if(waferHolderInfo == null)
  210. {
  211. continue;
  212. }
  213. if (waferHolderInfo.Id == waferHolderTask.WaferHolderInfo.Id)
  214. {
  215. continue;
  216. }
  217. int index = waferHolderTasks.FindIndex(O => O.WaferHolderInfo.Id == waferHolderInfo.Id);
  218. if (index == -1)
  219. {
  220. return true;
  221. }
  222. else
  223. {
  224. WaferHolderTask task = waferHolderTasks[index];
  225. if (task.State == WaferHolderTaskState.Created)
  226. {
  227. return true;
  228. }
  229. }
  230. }
  231. }
  232. return false;
  233. }
  234. /// <summary>
  235. /// 移除状态为取消的WaferHolderTask
  236. /// </summary>
  237. /// <param name="waferHolderTasks"></param>
  238. private void RemoveCanceledTask(List<WaferHolderTask> waferHolderTasks)
  239. {
  240. foreach(WaferHolderTask item in waferHolderTasks)
  241. {
  242. WaferHolderTaskManager.Instance.RemoveById(item.ID);
  243. LOG.WriteLog(eEvent.EV_SCHEDULER, "System", $"remove wafer shuttle {item.WaferHolderInfo.Id} task");
  244. //List<string> mathedWaferIds = WaferTaskManager.Instance.GetWaferHolderMathWaferId(item.WaferHolderInfo.Id);
  245. //foreach(string waferId in mathedWaferIds)
  246. //{
  247. // WaferTaskManager.Instance.RemoveWaferTask(waferId);
  248. // WaferTaskManager.Instance.RemoveWaferIdMatchWaferHolderTaskDic(waferId);
  249. //}
  250. }
  251. }
  252. /// <summary>
  253. /// 检验其他任务是否也是Transporter并且正在执行
  254. /// </summary>
  255. /// <param name="waferHolderTasks"></param>
  256. /// <param name="waferHolderTask"></param>
  257. /// <returns></returns>
  258. private bool CheckOtherTransporterIsRunning(List<WaferHolderTask> waferHolderTasks,WaferHolderTask waferHolderTask,ModuleName moduleName)
  259. {
  260. foreach(WaferHolderTask item in waferHolderTasks)
  261. {
  262. if (item.ID == waferHolderTask.ID)
  263. {
  264. continue;
  265. }
  266. SchedulerSequence schedulerSequence = item.GetCurrentSchedulerSequence();
  267. if (schedulerSequence == null)
  268. {
  269. continue;
  270. }
  271. if (schedulerSequence.ModuleName == moduleName)
  272. {
  273. if(schedulerSequence.State==RState.Running)
  274. {
  275. return true;
  276. }
  277. }
  278. }
  279. return false;
  280. }
  281. /// <summary>
  282. /// 检验其他任务是否也是Transporter1并且正在执行
  283. /// </summary>
  284. /// <param name="waferHolderTasks"></param>
  285. /// <param name="waferHolderTask"></param>
  286. /// <returns></returns>
  287. private bool CheckPrewetIsWaitForPick(List<WaferHolderTask> waferHolderTasks, WaferHolderTask waferHolderTask)
  288. {
  289. foreach (WaferHolderTask item in waferHolderTasks)
  290. {
  291. if (item.ID == waferHolderTask.ID)
  292. {
  293. continue;
  294. }
  295. SchedulerSequence schedulerSequence = item.GetCurrentSchedulerSequence();
  296. if (schedulerSequence == null)
  297. {
  298. continue;
  299. }
  300. if (schedulerSequence.ModuleName == ModuleName.Transporter1)
  301. {
  302. WaferHolderMoveItem waferHolderMoveItem = schedulerSequence.Parameters as WaferHolderMoveItem;
  303. if (waferHolderMoveItem != null && waferHolderMoveItem.SourceModule == ModuleName.Prewet1)
  304. {
  305. PrewetEntity prewetEntity = Singleton<RouteManager>.Instance.GetModule<PrewetEntity>(ModuleName.Prewet1.ToString());
  306. if(prewetEntity != null &&(prewetEntity.State==(int)PrewetState.PreparingToPick||
  307. prewetEntity.State==(int)PrewetState.WaitForPick))
  308. {
  309. return true;
  310. }
  311. }
  312. }
  313. }
  314. return false;
  315. }
  316. /// <summary>
  317. /// 解析Transporter1调度逻辑
  318. /// </summary>
  319. /// <param name="sequence"></param>
  320. private void AnalyseProcessTransporterSchedulerSequence(SchedulerSequence sequence,WaferHolderTask waferHolderTask,int transporterTransferSeconds)
  321. {
  322. SchedulerSequence preSequence = waferHolderTask.GetPreSchedulerSequence();
  323. if (preSequence == null)
  324. {
  325. waferHolderTask.Run();
  326. return;
  327. }
  328. if (preSequence.ModuleType == ModuleType.Metal)
  329. {
  330. //Metal处于Error
  331. if (preSequence.SchedulerModule.IsError)
  332. {
  333. waferHolderTask.Run();
  334. return;
  335. }
  336. }
  337. if(CheckExistMetalRemainTime(transporterTransferSeconds))
  338. {
  339. return;
  340. }
  341. else
  342. {
  343. waferHolderTask.Run();
  344. }
  345. }
  346. /// <summary>
  347. /// 是否存在当前阶段为Metal,剩余时间比Transporter搬运时间更小时
  348. /// </summary>
  349. /// <param name="transporterTransferSeconds"></param>
  350. /// <returns></returns>
  351. private bool CheckExistMetalRemainTime(int transporterTransferSeconds)
  352. {
  353. List<WaferHolderTask> waferHolderTasks = WaferHolderTaskManager.Instance.LoaderWaferHolderTaskList().ToList();
  354. foreach (var item in waferHolderTasks)
  355. {
  356. SchedulerSequence currentSequence = item.GetCurrentSchedulerSequence();
  357. if (currentSequence == null)
  358. {
  359. continue;
  360. }
  361. if(currentSequence.ModuleType==ModuleType.Metal&&ModuleHelper.IsMetal(currentSequence.ModuleName))
  362. {
  363. MetalEntity metalEntity = Singleton<RouteManager>.Instance.GetModule<MetalEntity>(currentSequence.ModuleName.ToString());
  364. if (metalEntity == null)
  365. {
  366. continue;
  367. }
  368. if (metalEntity.IsIdle && metalEntity.WaferHolderInfo != null)
  369. {
  370. return true;
  371. }
  372. if(metalEntity.TimeToReady<=transporterTransferSeconds&&metalEntity.IsBusy)
  373. {
  374. return true;
  375. }
  376. }
  377. if (currentSequence.ModuleName == ModuleName.Transporter1)
  378. {
  379. SchedulerSequence preSequence = item.GetPreSchedulerSequence();
  380. if (preSequence.ModuleType==ModuleType.Metal&&WaferHolderManager.Instance.HasWaferHolder(preSequence.ModuleName.ToString()))
  381. {
  382. WaferHolderInfo waferHolderInfo = WaferHolderManager.Instance.GetWaferHolder(preSequence.ModuleName.ToString());
  383. if (DateTime.Now.Subtract(waferHolderInfo.LastMetalRecipeCompleteTime).TotalMilliseconds <= 1000)
  384. {
  385. return true;
  386. }
  387. }
  388. }
  389. }
  390. return false;
  391. }
  392. }
  393. }