给定一组任务:
T1(20,100) T2(30,250) T3(100,400) (execution time, deadline=peroid)
现在我想限制最后期限,因为第 i 个任务的新期限在Di = f * Pi
哪里,是第 i 个任务的原始期限,并且是我想弄清楚的因素。使用速率单调调度程序,任务将继续满足其最后期限的最小值是多少?Di
Pi
f
f
给定一组任务:
T1(20,100) T2(30,250) T3(100,400) (execution time, deadline=peroid)
现在我想限制最后期限,因为第 i 个任务的新期限在Di = f * Pi
哪里,是第 i 个任务的原始期限,并且是我想弄清楚的因素。使用速率单调调度程序,任务将继续满足其最后期限的最小值是多少?Di
Pi
f
f
此模式将每 2000 个时间单位重复(同步)一次。在这段时期
总计为每 2000 个时间单位间隔 1140 个时间单位。
f = 1140 / 2000 = 0.57
这假设长时间运行的任务可以被中断和恢复,以允许较短运行的任务在两者之间运行。否则,一旦 T3 开始,T1 将无法按时完成。
更新的截止日期是:
T1(20,57)
T2(30,142.5)
T3(100,228)
这些将每 1851930 个时间单位重复一次,并且需要相同的时间来完成。
一个小的简化:在计算因子时,周期时间抵消了。这意味着您实际上不需要计算周期来获取因子:
Period = 2000
Required time = (Period / 100) * 20 + (Period / 250) * 30 + (Period / 400) * 100
f = Required time / Period = 20 / 100 + 30 / 250 + 100 / 400 = 0.57
f = Sum(Duration[i] / Period[i])
要计算周期,您可以这样做:
Period(T1,T2) = lcm(100, 250) = 500
Period(T1,T2,T3) = lcm(500, 400) = 2000
哪里lcm(x,y)
是最小公倍数。