341 likes | 691 Views
Deterministic Scheduling. Aperiodic Scheduling Earliest Deadline Due, Earliest Deadline First, Latest Deadline First, Spring Algorithm Periodic Scheduling References: Shaw – Chap 6 Buttazo – Chap 3 & 4.
E N D
Deterministic Scheduling Aperiodic Scheduling Earliest Deadline Due, Earliest Deadline First, Latest Deadline First, Spring Algorithm Periodic Scheduling References: Shaw – Chap 6 Buttazo – Chap 3 & 4
Introduction Priority & Round Robin Periodic Scheduling(Feasible Solution) Example 1:
More Round Robin Periodic Scheduling(Non-feasible Solution) Example 2:
APERIODIC TASK SCHEDULING Notation:
Earliest Due Date (EDD) - Jackson’s Rule Set of tasks: Problem: Algorithm:
Earliest Due Date (EDD) – Guaranteed Feasibility Order tasks by increasing deadlines. Then:
Earliest Deadline First (EDF) – Guarantee of Schedualability Assuming all tasks are ordered by increasing deadlines: Dynamic Scheduling: Assume Schedulable Need to Guarantee that Worst case finishing time: For Guaranteed Schedulability:
The scheduling problem for non-preemptive EDF is NP hard EDF - Non-Preemptive Scheduling
Scheduling with Precedence ConstraintsLatest Deadline First (or last?)- Optimizes max Lateness
EDF with Precedence Constraints The problem of scheduling a set of n tasks with precedent constraints and dynamic activations can be solved if the tasks are preemptable. The basic ideas is transform a set of dependent tasks into a set of independent tasks by adequate modification of timing parameters. Then, tasks are scheduled by the Earliest Deadline First (EDF) algorithm, iff is schedulable. Basically, all release times and deadlines are modified so that each task cannot start before its predecessors and cannot preempt their successors.
EDF with Precedence Constraints Modifying the release time:
EDF with Precedence Constraints Modifying the Deadlines:
Jack Stankovic’s Spring Algorithmvery powerful and actually has been applied in Jack’s real-time operating system This does not yield an optimal schedule, but the general problem is NP hard. This does lend itself to artificial intelligence and learning. We are interested here in the concept, rather in any implementation. The objective is to find a feasible schedule when tasks are have different types of constraints, such as precedence relations, resource constraints, arbitrary arrivals, non-preemptive properties, and importance levels. A heuristic function H is used to drive the scheduling toward a plausible path. At each level of the search, function H is applied to each of the remaining tasks. The task with the smallest value determined by the heuristic function H is selected to extend the current schedule. If a schedule is not looking strongly feasible, a minimal amount of backtracking is used.
Jack Stankovic’s Spring Algorithm Precedence constraints can be handled by adding a term E =1 if the task is eligible and E = infinity if it is not.
Homework #3 (due 5/3/07) : Lecture 4/24 1) 2) 3)