好久没有更新了,今天趁着放假,赶紧来水一期。嗯没错,就是这么直白。
我们做过几个关于生产调度相关的算法,相关的传送门如下:
遗传算法求解混合流水车间调度问题(附C++代码)
作业车间调度JSP与遗传算法GA及其Python/Java/C++实现
Tabu Search求解作业车间调度问题(Job Shop Scheduling)-附Java代码
但是说到生产调度,就不得不提甘特图这东西,可以用它来直观看调度的情况,非常方便。比如下图中:
Python画Gantt图
其实用Python画gantt原理是利用plt.barh()绘制水平方向的条形图,然后加以不同颜色区分表示。就是这么简单的。下面给出一个代码模板:
import matplotlib.pyplot as pltimport numpy as np
ax=plt.gca()
[ax.spines[i].set_visible(False) for i in ["top","right"]]def gatt(m,t):"""甘特图
m机器集
t时间集
"""for j in range(len(m)):#工序j
i=m[j]-1#机器编号iif j==0:
plt.barh(i,t[j])
plt.text(np.sum(t[:j+1])/8,i,'J%s\nT%s'%((j+1),t[j]),color="white",size=8)else:
plt.barh(i,t[j],left=(np.sum(t[:j])))
plt.text(np.sum(t[:j])+t[j]/8,i,'J%s\nT%s'%((j+1),t[j]),color="white",size=8)if __name__=="_