Joshua Mack, Samet E. Arda, Umit Y. Ogras, Ali Akoglu

**Abstract**—Performance-, power-, and energy-aware scheduling techniques play an essential role in optimally utilizing processing elements (PEs) of heterogeneous systems. List schedulers, a class of low-complexity static schedulers, have commonly been used in static execution scenarios. However, list schedulers are not suitable for runtime decision making, particularly when multiple concurrent applications are interleaved dynamically. For such cases, the static task execution times and expectation of idle PEs assumed by list schedulers lead to inefficient system utilization and poor performance. To address this problem, we present techniques for optimizing execution of list scheduling algorithms in dynamic runtime scenarios via a family of algorithms inspired by the well-known heterogeneous earliest finish time (HEFT) list scheduler. Through dynamically arriving, realistic workload scenarios that are simulated in an open-source discrete event heterogeneous SoC simulator, we exhaustively evaluate each of the proposed algorithms across two SoCs modeled after the Xilinx Zynq Ultrascale+ ZCU102 and O-Droid XU3 development boards. Altogether, depending on the chosen variant in this family of algorithms, we are able to achieve an up to 39% execution time improvement, up to 7.24x algorithmic speedup, or up to 30% energy consumption improvement compared to the baseline HEFT implementation.

Index Terms—Scheduling and task partitioning, heterogeneous (hybrid) systems, energy-aware systems, hardware simulation, HEFT

# 1 INTRODUCTION

**T** HEN designed with the right mix of accelerators and general-purpose processors, heterogeneous processors offer performance and energy-efficiency not attainable with homogeneous processing systems [1], [2]. Battery capacity and power budget are at a premium in both homogeneous and heterogeneous platforms with strict size, weight, and power (SWaP) requirements. The ability to make scheduling decisions that extend the lifetime between charges is as valuable in these devices, if not more-so, than meeting execution deadline requirements alone. As such, portable heterogeneous platforms can utilize their full capabilities only if they carefully balance power, energy, and execution time requirements by utilizing task scheduling that is aware of all three. However, schedulers for heterogeneous systems, which are required to realize this potential, face significant challenges that are not present in homogeneous counterparts. First, task performance and power consumption are not uniform across all processing elements (PEs), even in a static context. Consequently, the inability to exploit symmetries in the scheduling problem increases the computational complexity of converging to a high-quality scheduling decision. Furthermore, the already NP-Complete [3] scheduling problem becomes even harder when the scheduling problem expands to a runtime scope where applications may interleave at arbitrary times.

Previous studies showed that list-scheduling algorithms effectively balance the complexity of the scheduler and qual-

ity of schedules they generate [4]. Among the large body of list-scheduling algorithms, heterogeneous earliest finish time (HEFT) [5] is a well-known heuristic that generates competitive static schedules that minimize the total application execution time [6]. List-scheduling algorithms, such as HEFT, are typically used as purely static schedulers as they operate on entire directed acyclic graphs (DAGs) with known task dependencies and application structures. However, many runtime systems, including the Linux OS, employ a ready-queue-based framework that focuses on only the tasks ready to execute. Hence, by definition, there are no dependencies among the tasks waiting for scheduling. Furthermore, new applications and tasks can be launched before previous ones finish. Existing list schedulers cannot work in these scenarios since they would have to process DAGs of new applications and partial DAGs of existing ones. Consequently, utilization of list schedulers is challenging in runtime environments, where the scheduler only has visibility into ready tasks with minimal or no insight into future interleaved workloads.

This paper addresses the limitations of list schedulers to work in dynamic runtime environments. Overcoming this limitation makes a large body of list-schedulers [7], [8], [9], [10], [11] practical and opens up the opportunity to use them in operating systems and other runtime environments. Motivated by HEFT's ability to balance runtime complexity and quality of generated schedules, we use HEFT as our baseline scheduler and use it in dynamic runtime scenarios. Furthermore, we develop new dynamic schedulers that can optimize not only for performance but also for energy, which in turn enable balancing the tradeoff between performance and energy consumption. Finally, static scheduling algorithms have typically been evaluated on individual DAG instances against an optimal schedule length ratio. However, in runtime systems, multiple applications can run concurrently. Hence, to properly evaluate

J. Mack and A. Akoglu are with the Electrical and Computer Engineering Dept., University of Arizona, Tucson, AZ 85719 USA. E-mail: {jmack2545, akoglu}@email.arizona.edu.

S. E. Arda is with the School of Electrical, Computer and Energy Engineering, Arizona State University, Tempe, AZ 85287 USA. E-mail: sarda1@asu.edu

U. Y. Ogras is with the Electrical and Computer Engineering Dept., University of Wisconsin-Madison, Madison, WI 53706 USA. E-mail: uogras@wisc.edu

static scheduling algorithms in dynamic environments, we must consider scenarios with multiple concurrent DAGs and arbitrary application interleaving. To address this need, we evaluate the proposed schedulers against the optimal achievable solutions found by dynamically solving Constraint Programming (CP) formulations of each scheduling problem. With this insight, list scheduling algorithms, like HEFT, can truly be evaluated against the best achievable runtime rather than overly optimistic bounds that assume no communication and maximum parallelism. To that end, this paper makes the following contributions:

Taking the original HEFT as a baseline (referred to as HEFT<sub>Base</sub>), we incrementally develop a family of heuristics that we call  $\text{HEFT}_{\text{Dyn}}$ ,  $\text{HEFT}_{\text{RT}}$ ,  $\text{HEFT}_{\text{EDP}}$ , and  $\text{HEFT}_{\text{EDP-LB}}$ . Each scheduler builds off of the one listed before it. In that sense, HEFT<sub>Dyn</sub> optimizes HEFT<sub>Base</sub> for dynamic workload scenarios through a combination of DAG merging, running task constraints, and dynamic dependencies. Through this process, we observe that there is room for algorithmic simplification and propose a runtime variant,  $\text{HEFT}_{\text{RT}}$ . We show that  $HEFT_{Dyn}$  and  $HEFT_{RT}$  improve average frame execution time over  $\text{HEFT}_{\text{Base}}$  by up to 34% and 45% respectively. Additionally, we find that HEFT<sub>RT</sub> is algorithmically more efficient than HEFT<sub>Dyn</sub> with a 7.24x average algorithmic speedup. By reformulating HEFT<sub>RT</sub> to optimize for energy-delay product (EDP) rather than only execution time, we present  $\text{HEFT}_{\text{EDP}}$  and show that it reduces energy consumption by an average of 30.4% and 20.6% compared to HEFT<sub>RT</sub> on the Odroid-XU3 and ZCU102 platforms, respectively. Finally, to better balance energy consumption and execution time, we introduce a load balanced-variant, HEFT<sub>EDP-LB</sub>, which effectively reduces energy consumption without drastically sacrificing workload execution time performance relative to  $\text{HEFT}_{\text{RT}}$ .

In summary, this family of heuristics enables the use of HEFT in richly interleaving workload scenarios with the ability to optimize for energy, delay, or both. We believe that these strategies remove previous limitations that prevented effective deployment of list scheduling algorithms like HEFT in System on Chip (SoC)-scale resource management. As technical contributions, this paper:

- Presents the first evaluation of the original HEFT algorithm (HEFT<sub>Base</sub>) under dynamically interleaving workload scenarios, exposes the drawbacks of deploying an unmodified list scheduler to a dynamic runtime, and develops an execution-focused heuristic (HEFT<sub>RT</sub>) to address these drawbacks.
- Adjusts HEFT<sub>RT</sub> to be energy-aware by developing HEFT<sub>EDP</sub> and HEFT<sub>EDP-LB</sub>, enabling system designers to target various points in the trade space of energy consumption and execution time.
- Presents an exhaustive evaluation of the proposed policies with respect to HEFT<sub>Base</sub> along with Minimum Execution Time, Constraint Programming, and Predict Earliest Finish Time [8] schedulers using dynamically interleaving workload mixtures across simulated SoCs that are validated against Odroid-XU3 [12] and Xilinx Zynq ZCU102 [13] platforms.

The rest of the paper is organized as follows: Section 2 begins with preliminaries on HEFT. Section 3 describes the



Fig. 1: Illustration of the HEFT list scheduling process.

simulation environment used to develop each of the presented algorithms. Section 4 presents an in depth look at barriers to scaling HEFT in interleaving workload scenarios and introduces  $\text{HEFT}_{\text{Dyn}}$ ,  $\text{HEFT}_{\text{RT}}$ ,  $\text{HEFT}_{\text{EDP}}$ , and  $\text{HEFT}_{\text{EDP-LB}}$ . Section 5 presents exhaustive performance analysis across a large variety of workload scenarios. Section 6 presents a brief evaluation of the generalizability of the proposed techniques. Section 7 explores related work in the area of task scheduling with emphasis on dynamic task scheduling. Finally, Section 8 concludes and provides avenues for future work.

# 2 BACKGROUND

Directed Acyclic Graphs (DAGs) are a standard method of representing applications where each node represents a task along with its computation cost, and each edge represents the communication cost between data-dependent tasks. HEFT works by performing a single pass over the DAG to rank nodes by relative importance, sorting them in non-increasing order, and scheduling them in this priority order. In HEFT, for E edges and P PEs, the NP-complete scheduling problem is reduced to polynomial time  $(E \times P)$ by considering the average computation cost for each node over the available PEs and the average communication cost for each edge as a function of the amount of data transfer between two nodes and average link speed between the PEs. Despite this tremendous complexity reduction, HEFT still manages to provide competitive scheduling decisions [6]. This is due to a combination of a good choice of rank metric and the insertion-based scheduling.

The basic flow of HEFT is shown in Fig. 1. Other list schedulers perform a similar process with differences in the rank calculation and schedule heuristic. Given an input DAG, each node in the DAG is assigned a metric of importance. In standard HEFT, that metric is upward rank, which classifies the weight of a node based on its placement in the critical execution path of the DAG. Once this process is complete, the list of nodes in the DAG is sorted by this metric in non-increasing order, and the resource allocation phase begins. In this phase, a node is popped and allocated to one of the system resources. This process repeats until all the nodes are scheduled. In HEFT, the allocation process is performed by an insertion-based earliest finish time (EFT) scheduler. HEFT estimates the earliest possible finish time of a given node on each PE by considering both the delay of transferring data from parent tasks to that PE as well as the compute cost of that node on the PE under consideration.



Fig. 2: Canonical DAG in [5]. Each task is supported on three PEs (P0, P1, P2). Table shows execution time for each task on each PE. Gantt chart shows output schedule generated via the DS3 simulation environment [14]. In this scenario, all link speeds between distinct PEs are assumed to be 1 in accordance with [5], and the edge weights in the DAG represent the total volume of data that must be transferred over those links.



Fig. 3: Basic operation of the DS3 [14] simulation framework.

After that, it assigns the task to the PE that minimizes its earliest finish time. At the end of this process, a static schedule is generated, with the canonical input/output pair as illustrated with Fig. 2. The schedule shown in the figure is the output from our simulation environment and serves as the basis for functional verification of our implementation. Further details are presented in Section 3.

# **3** EXPERIMENTAL METHODOLOGY AND SETUP

### 3.1 Simulation Framework

We conduct our evaluations in the open-source DS3 environment [14] that allows the designer to simulate the behavior of a heterogeneous platform under a variety of realistic SoC workload scenarios, resource management strategies, and hardware configurations.

DS3 enables simulations of benchmark applications, modeled as DAGs, considering a target heterogeneous SoC platform under different scheduling algorithms. The list of PEs in the SoC along with the expected computation cost and power consumption of the tasks in the application(s) are stored in the *Resource Database* (see Fig. 3). The *Job Generator* injects frames (i.e. instances of applications) into the

| Application            | Max<br>Width | Depth | Number of<br>Nodes | Supported<br>Accelerators |
|------------------------|--------------|-------|--------------------|---------------------------|
| WiFi TX                | 5            | 7     | 27                 | IFFT                      |
| WiFi RX                | 5            | 10    | 34                 | FFT,<br>Viterbi Decoder   |
| Radar<br>Correlator    | 2            | 6     | 7                  | FFT, IFFT                 |
| Temporal<br>Mitigation | 2            | 6     | 10                 | Matrix Multiply           |
| Single<br>Carrier TX   | 1            | 8     | 8                  | -                         |
| Single<br>Carrier RX   | 1            | 8     | 8                  | Viterbi Decoder           |

TABLE 1: Parallelism, complexity, and accelerator characteristics of each application evaluated in this study.

simulation with an average inter-arrival time determined by a user-defined distribution. We refer to this rate of frame injection as the "frame rate" for the remainder of this study.

In addition, the DS3 enables a loosely defined plug-andplay interface to run a wide range of built-in and custom scheduling algorithms. The interaction between a particular scheduling algorithm and the framework is depicted in Fig. 3. The simulator invokes the scheduler at every scheduling epoch with the list of tasks ready for execution (tasks in *Ready Queue*). Then, it maps ready tasks to PE by utilizing the data in the Resource Database. Finally, the tasks are simulated and placed into the *Completed Queue* upon completion.

For our evaluations, we implement the two hypothetical SoC configurations discussed previously as well as our proposed scheduling algorithms. Then, we perform trend-based analysis on execution time, throughput, and energy consumption metrics across both SoCs for different workloads composed of a mixture of six WiFi and Radar applications.

## 3.2 Benchmark Applications and SoC Configurations

In this study, we utilize six different applications from wireless communications and radar domains: WiFitransmitter (WiFi-TX), WiFi-receiver (WiFi-RX), range detection (RangeDet), temporal mitigation (TempMit), singlecarrier transmitter (SC-TX), and single-carrier receiver (SC-RX) applications. As shown in Table 1, these applications exhibit different workload characteristics due to variations in DAG structure and support for accelerators. For example, WiFi RX exhibits a large degree of parallelism while the Single Carrier TX consists of a linear chain of DAG nodes. Execution time and energy profiles of these real-world applications are available in DS3 for two commercially available SoC platforms: the Xilinx Zynq ZCU102 FPGA board [13] and the Odroid-XU3 [12]. The ZCU102 FPGA has 4 ARM Cortex-A53 cores coupled with programmable fabric, and the Odroid-XU3 has a Samsung Exynos 5422 SoC with 4 ARM Cortex-A7 and 4 ARM Cortex-A15 cores. We integrated power consumption and execution time profiling data collected from these boards with state-of-theart accelerator execution and power measurements from the literature [15], [16]. Using this data, DS3 allows us to model two SoC configurations consisting of (1) a big cluster of 4 ARM A53 cores along with two FFT, two Viterbi decoder, and two matrix multiplication accelerators to replicate the ZCU102 with a set of accelerators and (2) the same big.LITTLE cluster of four ARM A15 and four ARM A7 cores to replicate the Odroid. DS3 is validated against the aforementioned ZCU102 and Odroid-XU3 target platformss with results that are within 3%, on average, of the reference measurements [14]. Taken together, while we acknowledge that our test applications do not cover the full spectrum of possible workloads, we believe that we cover a reasonable set of the kinds of radar and communications dataflowbased applications that are likely to be deployed on low power heterogeneous SoCs, with Single Carrier RX/TX giving rudimentary communications workflows, WiFi TX/RX giving more advanced communications workflows, Radar Correlator giving a radar-focused workflow, and Temporal Mitigation giving a mixed radar & comms workflow.

# 3.3 Workload Generation

We generate workloads by running the benchmark applications at different frame rates. Initial evaluations are conducted with an upload intensive wireless communication workload composed of 80% WiFi-TX and 20% WiFi-RX as each WiFi-RX frame requires nearly  $4 \times$  longer to execute. Later, we expand our analysis to all six applications to demonstrate the generalizability of our conclusions. Each simulation is run for 100ms of simulation time with the chosen scheduler and a fixed average frame rate. Each simulation is executed ten times and the results are averaged with the exception of those that utilize the constraint programming scheduler. Due to their computational complexity, simulations utilizing the constraint programming scheduler are instead only averaged across three iterations. We evaluate the performance of each scheduler in this study by stressing the scheduler's ability to cope with the volume of incoming jobs. We establish this by setting a fixed "target" frame rate that defines the expected inter-frame arrival time. Then, we monitor if the scheduler can complete jobs at that same rate or if system performance begins to suffer. We refer to the empirical frame rate observed as the "achieved" frame rate. Ideally, if a given scheduler is able to cope with the rate of job arrival, the achieved frame rate matches the target frame rate. However, each scheduler eventually reaches a saturation point where the achieved frame rate diverges from the target frame rate. Unable to keep up with the target frame rate, each scheduler saturates at some lower point and simultaneously experiences a sharp

## 3.4 Built-in Schedulers

The *Minimum Execution Time* (*MET*) scheduler assigns a ready task to a PE that achieves the minimum expected execution time following a FIFO policy [17].

The Constraint Programming (CP) scheduler is based on concepts from IBM ILOG CPOptimizer [18]. An *interval variable* x, in constraint programming terminology, is a decision variable, which can represent an activity, operation or a task, as in this study. The domain of an interval variable x is a subset of  $\{\bot\} \cup \{[s, e)|s, e \in \mathbb{Z}, s \leq e\}$ , where s and e are the start and end of the interval, respectively. By default interval variables are supposed to be present in the solution of a problem, but they can be specified as being optional. In this case,  $\bot$  is part of the domain of the variable, and thus, the solver determines whether the interval will be present or absent in the solution. If an interval variable is present: x = [s, e), (s - e) represents the *size* of the interval variable and it is a lower bound on the *length*. We will apply the following constraints on interval variables:

- $\operatorname{span}(x, \{x_1, ..., x_n\})$  states that if x is present, it starts together with the first present interval in  $\{x_1, ..., x_n\}$  and ends together with the last one. Interval x is absent if and only if all the  $x_i$  are absent.
- alternative  $(x, \{x_1, ..., x_n\})$  models an exclusive alternative between  $\{x_1, ..., x_n\}$ : if interval x is present then exactly one of intervals  $\{x_1, ..., x_n\}$  is present and x starts and ends together with this chosen one. Interval x is absent if and only if all the  $x_i$  are absent.
- no\_overlap({x<sub>1</sub>,...,x<sub>n</sub>}) states that permutation {x<sub>1</sub>,...,x<sub>n</sub>} defines a chain of non-overlapping intervals, any interval in the chain being constrained to end before the start of the next interval in the permutation.
- start\_of(x, av) returns the start of x when x is present and returns a value av if x is absent (by default if argument av is omitted it assumes av = 0).
- end\_of(x, av) returns the end of x when x is present and returns a value av if x is absent.
- length\_of(x, av) returns the length (end start) of x when x is present and returns a value av if x is absent.
- end\_before\_start( $x_i, x_j, delay$ ) constrains at least the given delay to elapse between the end of  $x_i$  and the start of  $x_j$ . It imposes the inequality end\_of( $x_i$ ) +  $delay \leq$  start\_of( $x_j$ ).

Our CP model for dynamic task scheduling minimizes the execution of DAGs in a workload for a given architecture with heterogeneous processing elements. Consider a set of DAGs  $D = \{d_1, d_2, ..., d_n\}$  under consideration for scheduling. Then,  $d_i$  is an interval variable – a variable that represents an interval of time via a start and end – that



Fig. 4: Gantt chart showing optimal schedule for a single instance of the canonical DAG from [5].

defines the  $i^{th}$  DAG in the system where  $i \in n$ . Let T denote the set of tasks  $T_i = \{t_{i,1}, t_{i,2}, ..., t_{i,m}\}$  in a DAG  $d_i$ . Then,  $t_{i,j}$  is an interval variable for a task in the DAG  $d_i$  where  $i \in n, j \in m$ , with n the number of DAGs and m the number of tasks in DAG  $d_i$ . Finally,  $P = \{p_1, p_2, ..., p_z\}$  represents the number of PEs in an architecture. Then,  $t_{i,j,k}$  is an optional interval variable for task  $t_{i,j}$  if it can be executed on PE  $p_k$  where  $i \in n, j \in m, k \in z$ . The constraints of the model are listed below:

$$\forall i \in n \quad \text{span}(d_i, T_i) \tag{1}$$

alternative
$$(t_{i,j}, \{t_{i,j,1}, t_{i,j,2}, ..., t_{i,j,z}\})$$
  
 $\forall i \in n, j \in m$  (2)

$$\forall i \in n \quad \text{no\_overlap}(T_i)$$
 (3)

end\_before\_start(
$$t_{i,j}$$
,  $succ(t_{i,j})$ ,  $comm\_cost$ )  
 $\forall i \in n, j \in m$  (4)

Constraint (1) ensures that the interval variable  $d_i$  encompasses all tasks  $T_i$  and it is bounded by the start of the first task and the end of the last task in the DAG. In addition, constraint (2) ensures that the solution only includes one of the optional internal variables  $\{t_{i,j,1}, t_{i,j,2}, ..., t_{i,j,z}\}$  to represent task variable  $t_{i,j}$ . In other words, task  $t_{i,j}$  is mapped *only* to one of the PEs in the system. Furthermore, constraint (3) ensures that tasks assigned on each PE are not scheduled in overlapping time windows. Finally, constraint (4) accounts for the overhead associated with the data transfer (*comm\_cost*) between the tasks and ensures that task  $t_{i,j}$  finishes before any of the successor tasks  $succ(t_{i,j})$  start their execution.

The objective function to minimize the execution time of DAGs is stated as:

minimize 
$$\left( \operatorname{sum}(\operatorname{length}_of(\{d_1, d_2, ..., d_n\})) \right)$$
 (5)

If we apply this formulation to a single instance of the Canonical DAG in Fig. 2, D will contain only one DAG,  $D = d_1$ , while  $T_i$  will consist of ten task interval variables  $T_i = \{t_{1,0}, t_{1,1}, t_{1,2}, t_{1,3}, t_{1,4}, t_{1,5}, t_{1,6}, t_{1,7}, t_{1,8}, t_{1,9}\}$ . Then, the formulation will include, for example, three optional interval variables  $\{t_{1,0,0}, t_{1,0,1}, t_{1,0,2}\}$  with a size of 14, 16, and 9, respectively, for the task interval variable  $t_{1,0}$ . The simulation framework dynamically calls the CP solver at the injection of each frame to find an optimal schedule, whenever the problem size allows, as a function of the current system state. Then, the obtained schedule is stored

in a lookup table, and tasks are assigned to the PEs accordingly as the simulation proceeds. For the single instance Canonical DAG example above, the CP solver finds the optimal solution as given in Fig. 4. Since the CP solver takes hours for large inputs (100 tasks), we employed a time limit of ten minutes per scheduling decision. If the model fails to find an optimal schedule within the time limit, we use the best solution found.

With our experimental setup in place, in Section 4, we begin by introducing key challenges related to applying list scheduling heuristics in dynamic runtime environments. We then derive a number of empirically-motivated algorithmic changes and optimizations to address these challenges until we stabilize to a promising suite of modified algorithms. In Section 5, we proceed to exhaustively evaluate each of these algorithms across a wide variety of workload scenarios and quantify their relative performance against a number of baseline scheduling techniques.

## 4 ALGORITHMIC CONTRIBUTIONS

#### 4.1 Static Scheduling: Challenges & Solutions

As HEFT is a static list scheduling algorithm, we begin here by first exposing the drawbacks that come with deploying baseline HEFT [5] – referred to as  $\text{HEFT}_{\text{Base}}$  – in a dynamic runtime environment with interleaving applications through discussion of three key challenges. Interleaved with those discussions, we also incrementally address each of these three challenges and demonstrate the performance benefits via execution time analysis with a workload consisting of four frames of WiFi-RX data. The incremental results of addressing each of these challenges is captured in Fig. 5.

*First*, in a runtime system, frames (full application DAGs) can arrive at any point in the simulation regardless of whether or not existing tasks are still being processed. This presents a challenge to static scheduling as it disallows statically scheduling and executing each DAG serially. Previous scheduling decisions that have yet to be fulfilled need to be considered when scheduling subsequent DAGs. A simple approach to handle this is to consider all previous scheduling assignments that have been generated as fixed and use them as constraints on the scheduling of the incoming frame. However, this choice can easily lead to suboptimal assignment of resources. As there are potentially a large number of previously scheduled tasks that have not had their execution dependencies satisfied yet, they can clearly be reassigned.

Instead, the proposed approach maintains a DAG representing the current system state, excluding tasks that are currently executing, and uses the Common Entry and Common Exit method proposed by Zhao et al. [19] to merge the newly arrived DAG with the current system state. Rankingbased composition was also tested, but it was not found to be beneficial relative to its increased complexity. This enables the scheduler to balance the needs of the incoming DAG with the needs of the outstanding task nodes in the system. Without DAG merging, HEFT is only provided a local/application-level view for each DAG in the system. As HEFT is a stateless algorithm, this then means that 4 instances of a single application back-to-back all produce identical schedules and identical executions as shown in



Fig. 5: Evolution of a single workload consisting of four sequentially arriving, color-coded WiFi RX frames on SoC configuration (1) (ZCU102) from Section 3 across all proposed mitigation strategies. (a) provides a baseline implementation, (b) builds on (a) and enables merging existing DAGs with the incoming job, (c) builds on (b) and enables fixing currently running tasks as constraints, and (d) builds on (c) and enables dynamic dependencies. Processing Elements 0-3 are ARM A53 CPUs, 4-5 are Matrix Multiply accelerators, 6-7 are FFT accelerators, and 8-9 are Viterbi decoders.

Fig. 5a. With DAG merging, HEFT is then provided a global view of all applications currently being processed by the system, and it can make more informed decisions based on interleaving the execution of independent applications more intelligently to better utilize the system resources. This leads in a reduction in the achieved makespan from 995 to 791, a 20.5% improvement compared to Fig. 5a.

Second, many static scheduling approaches like HEFT assume that the underlying platform they are scheduling on is idle, and as such, all time slots are available for scheduling. In runtime systems, however, this is not necessarily the case. Hence, we need to ensure that currently running tasks are represented as constraints on the scheduling problem so that the algorithm doesn't attempt to schedule in an occupied time slot. As it turns out, HEFT in particular is quite amenable to the integration of running task constraints. They can simply be excluded from the " $rank_u$ " list prioritization phase and treated as tasks that have already been assigned to resources in the main "pop and schedule" loop from Fig. 1. With these constraints in place, the remaining standard processor assignment algorithm can be invoked. Taken together, these first two issues solve two complementary problems with regards to representing the current system state: solving the first issue allows the scheduler to have a global view of all the unscheduled tasks in the system while solving the second issue allows the scheduler to also have a global view of all currently executing tasks in the system. In total, by addressing these two issues, a stateless

list scheduler can be provided with all the context needed to have a holistic view of the system state when performing scheduling decisions.

Compared to Fig. 5b, as shown in Fig. 5c, running task constraints allow for earlier execution of the FFTs on the FFT accelerators (PEs 6 and 7) near timestep 300. This allows the remainder of the instance 3 and instance 4 nodes to be completed earlier to reduce the overall makespan. As a result we observe a drop in the achieved makespan from 791 to 722, an 8.7% reduction over Fig. 5b and 27.4% overall compared to Fig. 5a.

*Third*, our last key challenge in applying static scheduling policies in a runtime environment centers around ensuring, after scheduling is complete, that the generated schedule is executed faithfully by the runtime framework. The output of a static schedule is traditionally thought of as a lookup table mapping tasks in the runtime to their associated processing elements. As each task has its dependencies satisfied, the runtime then checks this table and dispatches based on its guidance. However, as these schedulers are scheduling before tasks become ready, they do not know exactly when two independent tasks, for example A and B, will have their predecessors completed. Despite this, the scheduler may want to enforce a particular execution order of those two tasks on the same PE to, i.e., prioritize the DAG's critical execution path. Meanwhile, at runtime, variation in the completion of dependencies of these tasks could cause the runtime to dispatch differently from the

requested order due to i.e. discrepancies in estimating task execution time. Supposing that B has its predecessors met slightly before A, the runtime could attempt to launch B before A despite the scheduler requesting that A runs first and is followed by B. If B is a particularly long running task and A has many dependent nodes, this can cause massive divergences between the static schedule execution and observed execution. To address this, static schedulers must produce, along with their resource allocation decisions, a set of dynamic dependencies that the runtime can use to ensure that the desired execution order is maintained. These dynamic dependencies are then verified in the same fashion as any other dependencies by the runtime with the exception that they may be modified after any Job Generation event (shown in Fig. 3), so special care must be taken to ensure that no old data from previous scheduling epochs causes cyclic dependencies and subsequently system deadlock.

We observe the result of enabling dynamic dependencies in Fig. 5d. Compared to Fig. 5c, this further compresses the node executions together, filling nearly all the gaps present in the Gantt chart. It does this by increasing the amount of application interleaving performed, with nodes from all 4 DAG instances spread across the entire execution. Notably, this change leads to a large delay in the execution of instance 1. However, the overall execution of all four DAGs together is still able to finish sooner than it was able to previously despite this delay. This leads to a reduction in the achieved makespan from 722 to 676, a 6.3% reduction over previous and a 32.1% reduction overall compared to the baseline. We refer to this implementation as HEFT<sub>Dyn</sub>.

## 4.2 Algorithmic Optimizations of HEFT<sub>Dyn</sub>

*Finally*, as an optimization on top of HEFT<sub>Dyn</sub>, we integrated it directly with the Scheduler interface of Fig. 3. This is distinct from HEFT<sub>Dyn</sub> and HEFT<sub>Base</sub> as they have all been integrated through the Job Generation interface where the full application DAG is available. Scheduling decisions for these previous schedulers were then written to a lookup table for later reference by the Scheduler component. When integrated with the Scheduler component directly, HEFT<sub>Dyn</sub> is only provided the ready queue of tasks at each scheduling epoch. This lowers the work per scheduling decision as it introduces a number of opportunities to simplify the HEFT algorithm. By the nature of the ready queue, all tasks are independent, so " $rank_{\mu}$ " calculation reduces to prioritizing based on the mean computation time. Consequently, operations that depend on graph traversal in HEFT – like the upward ranking calculation or ready time availability during processor assignment – can be simplified down to a single set of independent tasks. Because this implementation only utilizes information available at runtime rather than information about the full DAG to make its scheduling decisions, we refer to this *runtime* implementation as HEFT<sub>RT</sub>.

#### 4.3 Scheduler Overhead and Throughput Analysis

Next, we extend our analysis of  $\text{HEFT}_{\text{Base}}$  against  $\text{HEFT}_{\text{Dyn}}$ and  $\text{HEFT}_{\text{RT}}$  using a more demanding workload scenario. We contextualize the results with DS3's built-in MET and CP schedulers in Fig. 6. The CP scheduler sets an effective lower bound on frame execution time with the understanding that



Fig. 6: Comparison of schedulers on SoC Configuration (1) (ZCU102) from Section 3. (a) Target frame rate versus achieved frame rate per scheduler – i.e., at a target frame rate of 20 frames/ms, HEFT<sub>Dyn</sub> achieved 15 frames/ms. (b) Achieved frame rate versus average frame execution time.

lower times are potentially possible if CP were given longer to search the solution space. We generated a sample workload consisting of an 80%/20% mixture of WiFi-TX/WiFi-RX flow graphs and evaluated the average execution time for each frame in the system as a function of the frame rate. As our SoC configuration, we modeled configuration (1) (ZCU102) from Section 3. In Fig. 6a, we observe the ability of each scheduler to cope with the target frame rate as described in Section 3. The x-axis presents the target frame rate set in DS3 and the y-axis presents the achieved frame rate for each of the schedulers. We see that, up to 10 frames/ms, each scheduler is able to handle the incoming workload effectively and therefore the plot of the achieved frame rate is linear. Above 10 frames/ms, though, each scheduler begins to be unable to cope with the rate of frame arrival, and the achieved frame rate experiences a drop for each scheduler. For instance, the CP scheduler achieves a frame rate of 17.5 frames/ms at a target frame rate of 20 frames/ms. We see in these plots that HEFT<sub>Base</sub> performs nearly identically to the greedy MET scheduler, saturating near 13.5 frames/ms. After resolving each of the challenges discussed above, HEFT<sub>Dyn</sub> saturates at 16.1 frames/ms, a 22% higher throughput than HEFT<sub>Base</sub>. Also, we see that  $\text{HEFT}_{\text{RT}}$  extends the saturation to 17.5 frames/ms, a 32% higher throughput than  $\text{HEFT}_{\text{Base}}$ .

Additionally, Fig. 6b illustrates the average frame execution time observed at each of the achieved frame rates. In this plot, the x-axis presents the achieved frame rate (the



Fig. 7: Empirical runtime CDFs for  $\text{HEFT}_{\text{Dyn}}$  versus  $\text{HEFT}_{\text{RT}}$  across an even mixture of all 6 DS3 applications with a total of 2338 executed application instances.

y-axis from Fig. 6a) against the average frame execution time for frames executed by each particular scheduler. As expected based on the previous saturation plot,  $\text{HEFT}_{\text{Base}}$  consistently performs worse than  $\text{HEFT}_{\text{Dyn}}$  and  $\text{HEFT}_{\text{RT}}$ . However, the performance suffers not only in level of throughput achieved but also in the quality of the schedule per application frame. We observe that, at saturation, the average frame scheduled by  $\text{HEFT}_{\text{Base}}$  takes nearly 750 microseconds while  $\text{HEFT}_{\text{Dyn}}$  takes 680 and  $\text{HEFT}_{\text{RT}}$  640 – 10% and 15% reductions respectively. As such, we find that these algorithms improve not only application throughput, but they do so by improving the quality of the generated schedules.

Upon initial observation, it is somewhat surprising that  $\text{HEFT}_{\text{RT}}$  outperforms  $\text{HEFT}_{\text{Dyn}}$ , particularly at high frame rates, given that the primary design goal of  $HEFT_{RT}$  was to optimize algorithmic efficiency. While one might assume that HEFT<sub>Dvn</sub> would take advantage of having the full application DAG to make less greedy decisions that consider impacts to successor nodes when scheduling a particular node, HEFT by itself does not perform these kinds of calculations. These "lookahead"-style modifications are the subject of other works [7], [8]. As such, neither HEFT nor  $HEFT_{RT}$ take advantage of any lookahead-style considerations, and HEFT<sub>RT</sub>, by nature of being called at the moment of scheduling, is always provided the most up to date information with regards to system execution state when it performs scheduling. Finally, by nature of each individual scheduling problem being smaller, HEFT<sub>RT</sub> schedules in a much smaller combinatorial space.

With this analysis in mind, it is worth exploring whether  $\text{HEFT}_{\text{RT}}$  achieved its primary design goal: optimizing algorithmic efficiency and reducing scheduling overhead. To explore this, we profiled the execution times of each implementation inside the DS3 simulation environment. We generated a workload consisting of an even mixture of all 6 applications available in the DS3 environment in order to ensure variety, and we swept the target frame rate from 0.1 to 10 frames/ms. Across this full sweep, we executed a total of 2338 instances of each of these application DAGs, profiling the scheduling calls made by  $\text{HEFT}_{\text{Dyn}}$  and  $\text{HEFT}_{\text{RT}}$  during execution. As the host system can affect this performance, in this instance, DS3 was executed on

Ubuntu 18.04LTS with an Intel Core i7 8700. Fig. 7 displays the empirical cumulative distribution function (CDF) of the runtimes observed. We observe that the average HEFT<sub>Dvn</sub> call requires 18.59 ms while the average HEFT<sub>RT</sub> call requires only 0.216 ms, and 95% of HEFT<sub>Dyn</sub> calls fall below 33.36ms while 95% of  $\text{HEFT}_{\text{RT}}$  calls fall below 0.347ms. Taken together, we find that, on average,  $HEFT_{RT}$  observes an 86x speedup. This does not take into account differences in call frequency, however: HEFT<sub>Dyn</sub> is called once for each application DAG while HEFT<sub>RT</sub> is called every time the ready queue requires scheduling. We find that HEFT<sub>Dyn</sub> is called 2338 times while  $\text{HEFT}_{\text{RT}}$  is called 27780 times. When this is multiplied by the average execution to estimate total time spent scheduling, we observe that HEFT<sub>Dvn</sub> spent 43.46 seconds scheduling while HEFT<sub>RT</sub> spent 6.00 seconds, still yielding a total overall speedup of 7.24x for an equivalent workload. Together with Fig. 6, we see that  $HEFT_{RT}$  provides better scheduling performance with lower scheduling overhead. Therefore, we will use this algorithm as the foundation for development of energy aware scheduling policies.

### 4.4 Energy Aware Scheduling

To develop an energy-aware variant of HEFT, we start by redesigning the ranking method. Specifically, we take HEFT<sub>RT</sub> as a baseline – given its excellent execution-time performance – and modify the original upward rank calculation from Section 2 to incorporate a  $v \times q$  power cost matrix Pto complement HEFT's  $v \times q$  computation cost matrix W, where v is the number of tasks and q is the number of PEs. To enable this, we utilized power consumption measurements on hardware as explained in Section 3. If analytical power models are available, estimates from those can be tabulated into a power cost matrix similarly. In this context, let the average power cost of a task  $n_i$  be  $\bar{p}_i = \sum_{j=1}^{q} \frac{P_{i,j}}{q}$ , where  $P_{i,j}$  is the power consumption of task  $n_i$  on PE j. Using this power matrix, we define a new rank metric as:

$$rank_{u}^{edp}(n_{i}) = \bar{w_{i}}^{2}\bar{p_{i}} + \max_{n_{j} \in succ(n_{i})}(\bar{c_{ij}} + rank_{u}^{edp}(n_{j}))$$
(6)

where  $\bar{w}_i$  is the average computation cost for task  $n_i$ ,  $\bar{p}_i$  is the average power cost for task  $n_i$ ,  $\bar{w}_i{}^2\bar{p}_i$  is the average EDP consumption of task  $n_i$ ,  $succ(n_i)$  is the set of immediate successors of task  $n_i$ , and  $\bar{c}_{ij}$  is the average communication cost of edge (i, j). During the task prioritization phase of HEFT, this metric enables ranking of tasks based on their impact on DAG EDP. In practice, we apply this new upward rank formulation to HEFT<sub>RT</sub>. It is then worth noting that, because HEFT<sub>RT</sub> only schedules one ready queue worth of tasks per execution, its DAG effectively consists of disconnected, independent tasks that have no successors. Consequently, the  $\max_{n_j \in succ(n_i)}$  term in Eq. 6 does not influence the computation's result.

With a new rank metric in place, we adjust the resource allocation phase similarly to assign tasks to PEs that minimize application EDP. The first approach taken in this work is to perform resource assignment to the processor that minimizes task EDP, regardless of how much later an execution slot is chosen. We refer to this implementation as  $HEFT_{EDP}$  as shown in Algorithm 1. Based on the simulation and workload setup described in Section 3, we test this

#### Algorithm 1: HEFT<sub>EDP</sub> 1 initialize task list with $rank_u^{edp}$ -based ranking; 2 while there are unscheduled tasks in the task list do pop task $n_i$ from list for scheduling; 3 minEDP = inf;4 for each processor $p_k$ do 5 $sched = EFT(n_i, p_k);$ 6 $edp = (sched.end - sched.start)^2 * P[n_i, p_k];$ 7 if edp < minEDP then 8 minEDP = edp; minSched = sched;9 end 10 else if edp == minEDP &&11 sched.end < minSched.end then minSched = sched;12 13 end end 14 15 assign $n_i$ according to minSched; 16 end

algorithm and illustrate the findings in Fig. 8. In addition to average execution time, shown in Fig. 8a, we plot total energy versus frame rate in Fig. 8b, where the total energy is obtained by accumulating static and dynamic energy consumption at each target injection rate. Like Fig. 6, the workload is a mixture of 80% WiFi TX, 20% WiFi RX, but we expand our evaluation to SoC configuration (2) (Odroid XU3) from Section 3 that is composed of 4 ARM A7 LITTLE cores and 4 ARM A15 big cores. Many trends observed in Fig. 6b continue to hold for this configuration, with the key difference being the saturation point. Compared to Fig. 6b, saturation occurs sooner because the SoC configuration is now composed of 4 big and 4 LITTLE CPU cores, and without accelerators, each individual frame takes longer on average. It is worthwhile to consider this SoC configuration because, as explained in Section 3, we are able to extract accurate power estimates for this SoC by using an equivalent Odroid-XU3 development board. As such, this SoC configuration is more suitable for development of energy aware scheduling. Despite the drop in saturation point,  $\text{HEFT}_{\text{RT}}$  performs quite well and is both far from MET and near CP throughout the full range of achieved frame rates. We find that the gap between CP and  $\text{HEFT}_{\text{RT}}$  is narrower in this instance, and this could be caused by two possibilities. First, it could be that there aren't any better solutions available. Second, it could be that, on this SoC configuration, finding a schedule with constraint programming is actually more difficult. By their nature, accelerators are restricted in the tasks they can execute, so swapping accelerators for CPU cores actually produces more valid solutions in the combinatorial search space and increases the likelihood that CP will timeout before finding a true optimum.

Looking at HEFT<sub>EDP</sub>, we observe that while it performs similarly to MET in frame execution, it does provide the most energy efficient scheduling decisions, with a maximum energy reduction relative to  $\text{HEFT}_{\text{RT}}$  of 58.0% and an average reduction of 46.2% across all frame rates.  $\text{HEFT}_{\text{EDP}}$ prioritizes the PE that contributes to EDP reduction most. Therefore, it is not sensitive to execution time-driven task to PE mapping decisions. Due to the increased average execution time per frame compared to  $\text{HEFT}_{\text{RT}}$ , fewer frames get completed as the number of frames increases. This results in achieved throughput for  $\text{HEFT}_{\text{EDP}}$  saturating earlier near 2.8 frames/ms compared to  $\text{HEFT}_{\text{RT}}$  as shown in Fig. 8b. Next,



Fig. 8: (a) average frame makespan and (b) total energy versus achieved frame rate in a workload composed of 80% WiFi TX, 20% WiFi RX on configuration (2) (Odroid XU3) from Section 3.



Fig. 9: Illustration of the processor assignment heuristics for both EDP-aware methods. The red task is being considered for placement on three different processors. In the first case, P1 is chosen despite over subscription, but in the second case, P2 is chosen as a compromise between P1 and P3.

we illustrate the cause of this limitation of  $\text{HEFT}_{\text{EDP}}$  with an example and introduce our solution.

The poor scaling of  $\text{HEFT}_{\text{EDP}}$  can be explained through Fig. 9a. Assume there are three processing elements operating at 1 Watt, 2 Watts, and 3 Watts respectively. Suppose the assigned workload for each PE is given by the solid grey boxes, and the goal is to decide on which PE to assign the new task highlighted in red. On each PE, the estimated makespan is the same:  $100\mu s$ . In standard EFTbased scheduling, P<sub>2</sub> and P<sub>3</sub> finish at an earlier time of  $t = 200\mu s$ , so the heuristic would choose one of them. HEFT<sub>EDP</sub> observes that, in a local sense, the EDP of this task can be minimized by assignment to P1 regardless of how much later the frame executes. This has the effect of elongating the runtime for the full application's DAG. As the heuristic disregards the absolute end time of each node and only considers the relative makespan in combination with power usage of the PE, queues for the most EDPefficient PEs in the system grow unbounded while PEs that are less optimal remain idle, leading to an unbalanced workload distribution.

To solve this issue by incentivizing load balancing, we propose a second heuristic, referred to as HEFT<sub>EDP-LB</sub>, as shown in Algorithm 2. This heuristic measures the delay used in EDP calculation relative to the earliest possible starting time of the new task across all processors. This is illustrated through the loop on lines 4-11 in Algorithm 2 that define the minStart. Then, this minStart term replaces the sched.start value from Algorithm 1 on line 7. Looking back at Fig. 9b, with this modification in place, the processor that minimizes the selection metric is P2, which strikes a balance between the short-sighted tasklevel minimization of P1 and the unquestionably worse decision of P3. This helps balancing the tasks across all PEs rather than continuously assigning them to the most power efficient processor with no regard to load balancing. Fig. 8a shows that HEFT<sub>EDP-LB</sub> improves the runtime significantly compared to  $\text{HEFT}_{\text{EDP}}$ , scaling in a fashion nearly equivalent to HEFT<sub>RT</sub>. Meanwhile, in Fig. 8b, we see that energy is still reduced by a maximum of 20.2% with an average reduction of 4.6% across all injection rates relative to  $\text{HEFT}_{\text{RT}}$ . As the target injection rate increases,  $\text{HEFT}_{\text{EDP-LB}}$ and HEFT<sub>RT</sub> converge to similar energy consumption values because the system has a high enough workload that it must utilize all available PEs regardless of energy impact. Because HEFT<sub>EDP-LB</sub> only adjusts energy usage by choice of PE and not through dynamic voltage and frequency scaling (DVFS)-based measures, when all PEs are in use, the energy usage is equivalent to that of  $\text{HEFT}_{\text{RT}}$ . Taken together, across these results, we find that, if execution time is the largest priority, HEFT<sub>RT</sub> provides the most effective scheduling. Meanwhile, if energy consumption is the largest priority, HEFT<sub>EDP</sub> provides the most effective scheduling, particularly at low workload rates. Finally, if a balance of

Algorithm 2: HEFT<sub>EDP-LB</sub> 1 initialize task list with  $rank_u^{edp}$ -based ranking; while there are unscheduled tasks in the task list do 2 pop task  $n_i$  from list for scheduling; 3 minStart = minEDP = inf;4 **for** each processor  $p_k$  **do** 5  $sched = EFT(n_i, p_k);$ 6 7  $schedules[p_k] = sched;$  $if \ sched.start < minStart \ then$ 8  $minStart = schedules[p_k].start;$ 9 end 10 end 11 12 for each processor  $p_k$  do 13  $sched = schedules[p_k];$  $edp = (sched.end - minStart)^2 * P[n_i, p_k];$ 14 if edp < minEDP then 15 minEDP = edp; minSched = sched;16 17 end else if edp == minEDP &&18 sched.end < minSched.end then 19 minSched = sched;20 end 21 end 22 assign  $n_i$  according to minSched; 23 end

execution and energy is required,  $\text{HEFT}_{\text{EDP-LB}}$  provides an effective method to reduce energy consumption without drastically sacrificing execution time performance.

# 5 RESULTS

In this subsection, we conduct evaluations using DS3 across both of the hardware-validated SoC configurations discussed in Section 3: the Odroid XU3-based system and the Xilinx Zynq Ultrascale+ ZCU102-based system. For each hardware configuration, we begin by evaluating with a workload mixture consisting of an even distribution of all 6 applications available in DS3. To provide context for the results of these experiments, we include three other schedulers: the Minimum Execution Time (MET) scheduler and Constraint Programming (CP) schedulers provided by default in DS3 as well as the well-known PEFT list scheduler [8]. MET provides a useful point of comparison as it is representative of the types of greedy heuristics commonly used for runtime environments. Meanwhile, as discussed in Section 4.3, CP provides an effective lower bound on frame execution time, particularly at low injection rates where it is feaible to find optimal solutions. Finally, as PEFT is a list scheduler with the same algorithmic runtime complexity as HEFT and has been shown to, broadly speaking, match or outperform it in the literature [6], we believed that it would be a useful point of comparison here. PEFT was implemented in DS3 using the same approach as  $\text{HEFT}_{\text{Base}}$ in Section 4.1, and as such, here we refer to it as  $PEFT_{Base}$ . Before running experiments, PEFT<sub>Base</sub> was validated against Tables 2 and 3 from the original work [8]. For further verification, all of the implementations presented here are made available in the public release of DS3 [20].

Fig. 10 shows the execution time and energy results for configuration (2), the Odroid XU3-based platform. As discussed previously, the Odroid XU3 contains a Samsung Exynos 5422 Octa big.LITTLE ARM Cortex A15. Therefore, the primary decision for schedulers to make on this platform are whether to schedule onto the big cores or the LITTLE cores. Comparing the trends observed here to those presented in Fig. 8, we reach the same conclusions. In execution-time analysis (Fig. 10a), HEFT<sub>EDP</sub> performs similarly to MET, HEFT<sub>EDP-LB</sub> performs slightly worse than  $\text{HEFT}_{\text{RT}}$ , and  $\text{HEFT}_{\text{RT}}$  outperforms all other schedulers. Additionally, HEFT<sub>Base</sub> continues to illustrate poorest scalability, with PEFT<sub>Base</sub> slightly outperforming it as expected. In energy analysis (Fig. 10b), we also find similar trends where  $\text{HEFT}_{\text{EDP-LB}}$  solves the scalability issues of  $\text{HEFT}_{\text{EDP}}$  while still managing to reduce energy consumption compared to HEFT<sub>RT</sub>.

Meanwhile, in Figure 11, we see the execution and energy results for configuration (1) (ZCU102) across all 6 applications. In this case, we observe a notable convergence among all schedulers other than MET and HEFT<sub>Base</sub>. This would seem to indicate that the primary issue for schedulers on this platform are simply to ensure that they are balancing jobs sufficiently across each of the processing elements. As both MET and HEFT<sub>Base</sub> perform effectively greedy task assignment that does not consider tasks that interleave from other applications, particular accelerators in this system become overloaded and total average frame execution is





Fig. 10: (a) average frame makespan and (b) total energy versus achieved frame rate in a workload composed of an even mixture of all six DS3 applications on configuration (2) (Odroid XU3) from Section 3.

elongated. For schedulers that are able to balance across all PEs effectively, on this SoC, minimizing energy is equivalent to minimizing execution time due to the efficiencies in both execution and energy obtained from using dedicated hardware accelerators for critical kernels in these applications.

Finally, with general trends captured, we investigate application-level performance and energy efficiency gains. Graphical plots that capture individual application execution and energy characteristics are presented for completeness in Appendix A, Fig. A.1 and A.2, but the takeaways are captured in Table 2. In this evaluation, numerical analysis is limited purely to execution time as the primary motivation for HEFT<sub>RT</sub> and its associated development in Section 4.1 was to optimize the runtime performance of HEFT<sub>Base</sub>. For similar reasons, while execution time characteristics of HEFT<sub>EDP</sub> and HEFT<sub>EDP-LB</sub> are captured via the same figures, their primary algorithmic motivation was to extend HEFT<sub>RT</sub> to reduce its energy consumption. As such, tabular analysis of these algorithms is limited purely to energy improvement that they provide with respect to HEFT<sub>RT</sub>.

In Table 2, each row captures one of the six applications under test. The first four columns capture the average and maximum percentage improvements – across both SoC configurations – in average frame execution time for frames scheduled via  $\text{HEFT}_{\text{RT}}$  over frames scheduled via  $\text{HEFT}_{\text{Base}}$ . Assuming BASE and RT are vectors containing the average frame execution time at each target frame rate, the "Avg." entries are calculated via Eq. 7.

$$AVG(100 * (BASE - RT)/(BASE))$$
 (7)

Fig. 11: (a) average frame makespan and (b) total energy versus achieved frame rate in a workload composed of an even mixture of all six DS3 applications on configuration (1) (ZCU102) from Section 3.

The maximum calculations are performed similarly, with the AVG operator replaced by MAX. In this case, we find that HEFT<sub>RT</sub> provides an average improvement in execution time of 58.2% across all applications on the Odroid XU3 and a 30.6% average improvement across all applications on the ZCU102. This difference in speedup is attributable to the accelerators present on the ZCU102 platform: while HEFT<sub>Base</sub> makes scheduling decisions that are unaware of other frames on both platforms, the shift towards accelerators on the ZCU102 platform ensures that PEs are able to become idle sooner. As such, application DAGs are less likely to interleave in ways that degrade the performance of HEFT<sub>Base</sub>. Looking at the last eight columns, we observe the improvements in energy consumption - across both SoC configurations – for frames scheduled via HEFT<sub>EDP</sub> and  $\text{HEFT}_{\text{EDP-LB}}$  compared to those scheduled via  $\text{HEFT}_{\text{RT}}$ . Looking first at HEFT<sub>EDP</sub>, we find that across all applications, HEFT<sub>EDP</sub> provides an average energy savings of 30.4% on the Odroid XU3 and 20.6% on the ZCU102. Meanwhile, HEFT<sub>EDP-LB</sub> provides an average energy savings of 8.7% on the Odroid XU3 and 19.7% on the ZCU102. As seen in the Odroid results in Fig. A.1, while HEFT<sub>EDP</sub> outperforms HEFT<sub>EDP-LB</sub> in pure energy savings, HEFT<sub>EDP-LB</sub> outperforms HEFT<sub>EDP</sub> in execution time over the same workloads. Initially, it may seem paradoxical that HEFT<sub>EDP</sub> drops by nearly 10% between the Odroid and the ZCU102 while HEFT<sub>EDP-LB</sub> gains nearly 10%, but looking at the plots, we find that this, again, is attributable to the presence of accelerators. On the Odroid platform, the decrease in energy

|                        | Execution Improvement Over HEFT <sub>Base</sub> |            |             |            | Energy Improvement Over HEFT <sub>RT</sub> |            |             |            |                        |            |             |            |
|------------------------|-------------------------------------------------|------------|-------------|------------|--------------------------------------------|------------|-------------|------------|------------------------|------------|-------------|------------|
|                        | HEFT <sub>RT</sub>                              |            |             |            | HEFT <sub>EDP</sub>                        |            |             |            | HEFT <sub>EDP-LB</sub> |            |             |            |
|                        | Odroid XU3                                      |            | ZCU102      |            | Odroid XU3                                 |            | ZCU102      |            | Odroid XU3             |            | ZCU102      |            |
| Application            | Avg.<br>(%)                                     | Max<br>(%) | Avg.<br>(%) | Max<br>(%) | Avg.<br>(%)                                | Max<br>(%) | Avg.<br>(%) | Max<br>(%) | Avg.<br>(%)            | Max<br>(%) | Avg.<br>(%) | Max<br>(%) |
| WiFi TX                | 54.5                                            | 84.1       | 16.6        | 42.8       | 44.8                                       | 59.1       | 21.0        | 35.2       | 5.5                    | 19.1       | 19.5        | 29.7       |
| WiFi RX                | 66.2                                            | 86.8       | 30.0        | 56.2       | 46.2                                       | 53.8       | 19.8        | 21.8       | 3.0                    | 17.1       | 19.8        | 21.8       |
| Radar<br>Correlator    | 68.5                                            | 90.1       | 47.2        | 78.5       | 22.3                                       | 28.7       | 22.5        | 42.2       | 12.1                   | 23.5       | 20.7        | 36.2       |
| Temporal<br>Mitigation | 60.0                                            | 88.8       | 30.1        | 72.9       | 1.5                                        | 2.8        | 27.3        | 59.3       | 1.1                    | 2.5        | 25.2        | 48.7       |
| Single<br>Carrier TX   | 29.9                                            | 61.6       | 14.1        | 57.0       | 23.2                                       | 28.7       | 15.1        | 26.2       | 23.1                   | 28.7       | 15.1        | 26.2       |
| Single<br>Carrier RX   | 69.8                                            | 88.4       | 45.3        | 83.7       | 44.5                                       | 53.0       | 17.7        | 24.5       | 7.1                    | 24.9       | 17.7        | 24.5       |
| Averages               | 58.2                                            | 83.3       | 30.6        | 65.2       | 30.4                                       | 37.7       | 20.6        | 34.9       | 8.7                    | 19.3       | 19.7        | 31.2       |

TABLE 2: Improvements in average frame execution time of  $\text{HEFT}_{\text{RT}}$  relative to  $\text{HEFT}_{\text{Base}}$  across both SoC configurations followed by improvements in total energy consumption of  $\text{HEFT}_{\text{EDP}}$  and  $\text{HEFT}_{\text{EDP-LB}}$  relative to  $\text{HEFT}_{\text{RT}}$ .

is accompanied by an increase in execution time, indicating that  $\text{HEFT}_{\text{EDP}}$  continues to preferentially schedule on the LITTLE cores, while  $\text{HEFT}_{\text{EDP-LB}}$  further utilizes the big cores and as such consumes more energy. Meanwhile, on the ZCU102 platform, we actually observe a convergence between  $\text{HEFT}_{\text{RT}}$ ,  $\text{HEFT}_{\text{EDP}}$ , and  $\text{HEFT}_{\text{EDP-LB}}$ , where all three schedulers give near identical execution time performance, but  $\text{HEFT}_{\text{EDP}}$  and  $\text{HEFT}_{\text{EDP-LB}}$  both give nearly a 20% reduction in energy consumption relative to  $\text{HEFT}_{\text{RT}}$ . As discussed previously with Fig. 11, this convergence occurs due to execution time minimization converging with energy minimization on this particular accelerator-rich SoC.

In summary, in this section, we present a novel and thorough analysis of HEFT<sub>Base</sub> in richly interleaving workload scenarios that, to the best of our knowledge, have not been applied previously to static schedulers like HEFT. Primary evaluation metrics of such schedulers typically include evaluation of single DAG instances against overly optimistic objectives such as the Schedule Length Ratio (SLR). In contrast, the results here illustrate that, despite modern analysis continuing to show HEFT to be an effective scheduler in the case of non-interleaving DAGs [6], static schedulers like HEFT face a number of challenges that prevent seamless deployment in rapidly varying workload mixtures. Finally, we find that, across all workloads tested, the conclusions of Section 4 continue to hold. For executionfocused scheduling, HEFT<sub>RT</sub> provides the most effective performance, for energy-focused scheduling - particularly at low rates –  $HEFT_{EDP}$  provides the most effective performance, and for a balance of the two, HEFT<sub>EDP-LB</sub> is a good compromise.

# 6 GENERALIZABILITY OF PROPOSED OPTIMIZA-TION TECHNIQUES

As the last case study, we apply the optimization strategies (DAG merging, running-task constraints, dynamic dependencies, and runtime-aware simplifications) on PEFT<sub>Base</sub>, and seek to evaluate the generalizability of these techniques for other list schedulers. We follow the methodology applied on HEFT<sub>Base</sub> to generate HEFT<sub>RT</sub> and start from the PEFT<sub>Base</sub> scheduler described in the beginning of Section 5 to generate a "PEFT<sub>RT</sub>" scheduler.

We evaluate  $PEFT_{RT}$  on a workload consisting of an even mixture of all 6 test applications on both the Odroid XU3



Fig. 12: average frame makespan versus achieved frame rate on (a) Odroid XU3 and (b) ZCU102 platforms with an even mixture of all six DS3 applications.

and ZCU102-based platform configurations, as shown in Figures 12a and 12b. We also include HEFT<sub>Base</sub> and HEFT<sub>RT</sub> results and observe that the relative performance gain between the baseline and run time versions of the two algorithms are consistent. Our optimization strategies reduce the average execution time and improve achieved frame rate for HEFT by 48.2% and 25.0% respectively, across all frame rates. Similarly, the corresponding improvements are 40.4% and 19.2% for PEFT. We also observe that  $PEFT_{RT}$  performs almost identically to HEFT<sub>RT</sub> with the plots overlapping, which is consistent with how closely HEFT<sub>RT</sub> approached the estimated CP bounds in many workloads. These results provide strong evidence to suggest that the optimizations described here are generalizable to the broader class of list schedulers, and if pursued further, may help enable system designers to reach high levels of performance even in highly complex and demanding workload scenarios.

Finally, while we do not explore it here, we believe a similar case study could be performed with regards to applying the energy optimization strategies proposed in this study to other rank-based static scheduling policies like PEFT. Namely, in many such schedulers, the proposed techniques should be broadly applicable by substituting the appropriate computation cost terms with equivalent EDP variations, such as the transformation of  $w_i$  to  $w_i^2 * p_i$ in Equation 6. Meanwhile, the EDP-based load-balancing methodology discussed here can be broadly applied in many such schedulers as well by incorporating the "earliest start time"-based EDP calculation methodology applied in Line 13 of Algorithm 2.

# 7 RELATED WORK

While there is a large body of work related to static DAG scheduling algorithms in both makespan and energy aware contexts [7], [8], [9], [10], [11], [21], [22], [23], [24], [25], [26], [27], [28], [29], [30], [31], [32], [33], [34], the evaluation methodologies of these works all assume that applications never interleave and primarily focus on metrics related to single-DAG static schedules like Schedule Length Ratio (SLR). Additionally, these works evaluate their scheduling algorithms in a vacuum, independent of any particular runtime environment. For those that are energy aware, the primary means they achieve their reduction is through DVFS, whereas the algorithms here optimize energy exclusively by choosing different processing elements. Of the available literature, the breadth of studies evaluating runtime DAG scheduling implementations is much smaller, likely because as discussed in Section 4.1, there are a number of drawbacks that arise when deploying static DAG scheduling algorithms to dynamic runtime environments which this study addresses. In the area of real time systems, Bambagini et al. [35] taxonomize multicore and single-core energy aware scheduling. For this work, the taxonomy presented for multicore energy-aware scheduling is much narrower than the corresponding alternative presented for single-core scheduling, and none of the methods presented explore the use of list schedulers. Additionally, there are a large number of non list scheduling-based algorithms for runtime DAG scheduling, ranging from software schedulers [36], [37] to hardware schedulers [38], [39], [40], [41], [42], [43], [44]. However, as none of these works specifically explore runtime DAG scheduling with list-based algorithms, we consider the work presented here to be orthogonal to these studies. To the best of our knowledge, there are very few publications that describe runtime performance of a HEFTinspired list scheduler. One example of such a work can be found in StarPU [45], and as they discuss in a later work [46], there are actually a number of key differences between the baseline HEFT algorithm and the various implementations they provide in their *dmda* family of schedulers [47]. Namely, the upward rank is assumed to be precomputed rather than calculated during scheduling, and these algorithms only schedule ready tasks, ignoring opportunities to implement insightful planning for future tasks that may be critical to overall makespan. Even while this approach is, at a high level, similar to the approach taken by  $\text{HEFT}_{\text{RT}}$ , these evaluations do not consider workloads with such a heavy degree of interleaving DAG instances as is done here. For instance, later work [48] performs a similar throughputstyle analysis where performance is analyzed as a function of increasing problem size for a single application, but each instance of that application is assumed independent and executed separately from all other instances. Meanwhile, works such as [49] explore the use of HEFT - along with a proposed algorithm "XEFT" - in a computer visionfocused runtime system called OpenVX. This work similarly acknowledges that HEFT by itself produces improved, but suboptimal, execution schedules relative to greedy scheduling policies. However, the solution proposed to improve HEFT's performance, XEFT, differs in its approach from those taken here. XEFT instead attempts to maximize the

time spent executing tasks with high levels of "exclusive overlap": a metric that captures whether a given set of tasks support opposing sets of resources (i.e. one task may only support CPU execution while another may only support GPU). Because their supported resources are disjoint, they can trivially be scheduled in parallel across their respective resources. In this work, we instead focus on optimizing HEFT across multiple DAGs in highly interleaved workload scenarios while leaving the behavior at the single-DAG level nearly unchanged. In summary, we believe that the experiments presented here yield valuable insights into workloads that are rarely explored in the DAG scheduling literature.

## 8 CONCLUSIONS

In summary, this work presents analysis of the well known HEFT algorithm from a new dynamic runtime perspective via  $\text{HEFT}_{\text{Dvn}}$  and  $\text{HEFT}_{\text{RT}}$ , and it presents novel EDP-aware modifications via HEFT<sub>EDP</sub> and HEFT<sub>EDP-LB</sub> that adapts it for use in power-constrained heterogeneous platforms. Notably, we believe that the techniques presented here can be broadly generalized to map similar list scheduling algorithms like HEFT and PEFT for use on heterogeneous SoC platforms. With regards to SoC design, we illustrate the benefits of pairing a suitably realistic simulation environment with effective scheduling algorithms in rapid iteration to a final SoC platform. Future work will explore adaptively switching between HEFT<sub>EDP</sub> and HEFT<sub>EDP-LB</sub> based on system utilization. Also, future work will explore expanding DS3 to support reference-calibrated applications that are outside the domain of communications and radar in order to evaluate our proposed algorithms in a broader set of heterogeneous workload scenarios. Additionally, the proposed schedulers will be extended to work with different DVFS governors present in current heterogeneous platforms. With that, the scheduler will adapt task scheduling based on the processor's current frequency and voltage states, which affect both the system's performance and power dissipation.

## ACKNOWLEDGEMENT

This material is based on research sponsored by Air Force Research Laboratory (AFRL) and Defense Advanced Research Projects Agency (DARPA) under agreement number FA8650-18-2-7860. The U.S. Government is authorized to reproduce and distribute reprints for Governmental purposes notwithstanding any copyright notation thereon. The views and conclusion contained herein are those of the authors and should not be interpreted as necessarily representing the official policies or endorsements, either expressed or implied, of Air Force Research Laboratory (AFRL) and Defence Advanced Research Projects Agency (DARPA) or the U.S. Government.

# REFERENCES

- A. A. Khokhar, V. K. Prasanna, M. E. Shaaban, and C. Wang, "Heterogeneous computing: challenges and opportunities," *Computer*, vol. 26, no. 6, pp. 18–27, Jun. 1993.
- vol. 26, no. 6, pp. 18–27, Jun. 1993.
  [2] V. Gupta, P. Brett, D. Koufaty, D. Reddy, S. Hahn, K. Schwan, and G. Srinivasa, "The Forgotten 'Uncore': On the Energy-Efficiency of Heterogeneous Cores," 2012, pp. 367–372.
  [Online]. Available: https://www.usenix.org/conference/atc12/technical-sessions/presentation/gupta

- [3] J. D. Ullman, "NP-complete scheduling problems," Journal of Computer and System sciences, vol. 10, no. 3, pp. 384–393, 1975.
- [4] F. Wu, Q. Wu, and Y. Tan, "Workflow scheduling in cloud: a survey," *The Journal of Supercomputing*, vol. 71, no. 9, pp. 3373– 3418, 2015.
- [5] H. Topcuoglu and S. Hariri, "Performance-effective and lowcomplexity task scheduling for heterogeneous computing," *IEEE Transactions on Parallel and Distributed Systems*, vol. 13, no. 3, pp. 260–274, 2002.
- [6] A. K. Maurya and A. K. Tripathi, "On benchmarking task scheduling algorithms for heterogeneous computing systems," *The Journal* of *Supercomputing*, vol. 74, no. 7, pp. 3039–3070, 2018.
- [7] L. F. Bittencourt, R. Sakellariou, and E. R. M. Madeira, "DAG Scheduling Using a Lookahead Variant of the Heterogeneous Earliest Finish Time Algorithm," in 2010 18th Euromicro Conference on Parallel, Distributed and Network-based Processing, Feb 2010, pp. 27–34.
- [8] H. Arabnejad and J. G. Barbosa, "List scheduling algorithm for heterogeneous systems by an optimistic cost table," *IEEE Transactions on Parallel and Distributed Systems*, vol. 25, no. 3, pp. 682–694, 2014.
- [9] N. Zhou, D. Qi, X. Wang, Z. Zheng, and W. Lin, "A list scheduling algorithm for heterogeneous systems based on a critical node cost table and pessimistic cost table," *Concurrency and Computation: Practice and Experience*, vol. 29, no. 5, p. e3944, 2017.
- [10] G. Xie, G. Zeng, X. Xiao, R. Li, and K. Li, "Energy-Efficient Scheduling Algorithms for Real-Time Parallel Applications on Heterogeneous Distributed Embedded Systems," *IEEE Transactions on Parallel and Distributed Systems*, vol. 28, no. 12, pp. 3426– 3442, Dec. 2017.
- [11] M. F. Akbar, E. U. Munir, M. M. Rafique, Z. Malik, S. U. Khan, and L. T. Yang, "List-Based Task Scheduling for Cloud Computing," in 2016 IEEE International Conference on Internet of Things (iThings) and IEEE Green Computing and Communications (GreenCom) and IEEE Cyber, Physical and Social Computing (CPSCom) and IEEE Smart Data (SmartData), Dec. 2016, pp. 652–659.
- [12] "ODROID-XU3," https://wiki.odroid.com/old\_product/ odroid-xu3/odroid-xu3 Accessed 19 Aug. 2019.
- [13] "ZCU102 Evaluation Board," https://www.xilinx.com/support/ documentation/boards\_and\_kits/zcu102/ug1182-zcu102-evalbd.pdf, Accessed 3 Mar. 2019.
- [14] S. Arda, N. Anish, A. A. Goksoy, J. Mack, N. Kumbhare, A. L. Sartor, A. Akoglu, R. Marculescu, and U. Y. Ogras, "DS3: A system-level domain-specific system-on-chip simulation frame-work," *IEEE Transactions on Computers*, 2020.
- [15] X. Chen, Y. Lei, Z. Lu, and S. Chen, "A variable-size FFT hardware accelerator based on matrix transposition," *IEEE Transactions on Very Large Scale Integration (VLSI) Systems*, vol. 26, no. 10, pp. 1953– 1966, 2018.
- [16] J. D. Tobola and J. E. Stine, "Low-Area Memoryless optimized Soft-Decision Viterbi Decoder with Dedicated Paralell Squaring Architecture," in 2018 52nd Asilomar Conference on Signals, Systems, and Computers. IEEE, 2018, pp. 203–207.
- [17] T. D. Braun *et al.*, "A Comparison of Eleven Static Heuristics for Mapping a Class of Independent Tasks onto Heterogeneous Distributed Computing Systems," *Journal of Parallel and Distributed computing*, vol. 61, no. 6, pp. 810–837, Jun 2001.
- [18] P. Laborie, "Ibm ilog cp optimizer for detailed scheduling illustrated on three problems," in *International Conference on AI and OR Techniques in Constraint Programming for Combinatorial Optimization Problems*. Springer, 2009, pp. 148–162.
- [19] H. Zhao and R. Sakellariou, "Scheduling multiple DAGs onto heterogeneous systems," in *Proceedings 20th IEEE International Parallel Distributed Processing Symposium*, April 2006.
- [20] "Complete source code and documentation of the simulation environment available," https://github.com/segemena/DS3, accessed: 2021-08-18.
- [21] S. Baskiyar and K. K. Palli, "Low Power Scheduling of DAGs to Minimize Finish Times," in *High Performance Computing -HiPC 2006*, ser. Lecture Notes in Computer Science, Y. Robert, M. Parashar, R. Badrinath, and V. K. Prasanna, Eds. Springer Berlin Heidelberg, 2006, pp. 353–362.
- [22] J. Song, G. Xie, R. Li, and X. Chen, "An Efficient Scheduling Algorithm for Energy Consumption Constrained Parallel Applications on Heterogeneous Distributed Systems," in 2017 IEEE International Symposium on Parallel and Distributed Processing with Applications

and 2017 IEEE International Conference on Ubiquitous Computing and Communications (ISPA/IUCC), Dec. 2017, pp. 32–39.

- [23] L. Zhang, K. Li, C. Li, and K. Li, "Bi-objective workflow scheduling of the energy consumption and reliability in heterogeneous computing systems," *Information Sciences*, vol. 379, pp. 241–256, 2017.
- [24] U. U. Tariq, H. Ali, L. Liu, J. Panneerselvam, and X. Zhai, "Energyefficient Static Task Scheduling on VFI based NoC-HMPSoCs for Intelligent Edge Devices in Cyber-Physical Systems," *Physical Systems*, vol. 1, no. 1, p. 23, 2019.
- [25] J. Teller, F. Özgüner, and R. Ewing, "Scheduling Task Graphs on Heterogeneous Multiprocessors with Reconfigurable Hardware," in 2008 International Conference on Parallel Processing - Workshops, Sep. 2008, pp. 17–24.
- [26] J. Teller and F. Özgüner, "Scheduling tasks on reconfigurable hardware with a list scheduler," in 2009 IEEE International Symposium on Parallel Distributed Processing, May 2009, pp. 1–4.
- [27] Z. Tang, L. Qi, Z. Cheng, K. Li, S. U. Khan, and K. Li, "An Energy-Efficient Task Scheduling Algorithm in DVFSenabled Cloud Environment," *Journal of Grid Computing*, vol. 14, no. 1, pp. 55–74, Mar. 2016. [Online]. Available: https://doi.org/10.1007/s10723-015-9334-y
- [28] Y. C. Lee and A. Y. Zomaya, "Minimizing Energy Consumption for Precedence-Constrained Applications Using Dynamic Voltage Scaling," in 2009 9th IEEE/ACM International Symposium on Cluster Computing and the Grid, May 2009.
- [29] W. Li, Y. Xia, M. Zhou, X. Sun, and Q. Zhu, "Fluctuation-aware and predictive workflow scheduling in cost-effective infrastructure-asa-service clouds," *IEEE Access*, vol. 6, pp. 61 488–61 502, 2018.
- [30] Q. Wu, M. Zhou, Q. Zhu, Y. Xia, and J. Wen, "MOELS: Multiobjective evolutionary list scheduling for cloud workflows," *IEEE Transactions on Automation Science and Engineering*, vol. 17, no. 1, pp. 166–176, 2020.
- [31] B. Hu, Z. Cao, and M. Zhou, "Energy-minimized scheduling of real-time parallel workflows on heterogeneous distributed computing systems," *IEEE Transactions on Services Computing*, pp. 1–1, 2021.
- [32] Y. Wang and X. Zuo, "An effective cloud workflow scheduling approach combining pso and idle time slot-aware rules," *IEEE/CAA Journal of Automatica Sinica*, vol. 8, no. 5, pp. 1079–1094, 2021.
- [33] Q.-H. Zhu, H. Tang, J.-J. Huang, and Y. Hou, "Task scheduling for multi-cloud computing subject to security and reliability constraints," *IEEE/CAA Journal of Automatica Sinica*, vol. 8, no. 4, pp. 848–865, 2021.
- [34] Z. Wen, S. Garg, G. S. Aujla, K. Alwasel, D. Puthal, S. Dustdar, A. Y. Zomaya, and R. Ranjan, "Running industrial workflow applications in a software-defined multicloud environment using green energy aware scheduling algorithm," *IEEE Transactions on Industrial Informatics*, vol. 17, no. 8, pp. 5645–5656, 2021.
- [35] M. Bambagini, M. Marinoni, H. Aydin, and G. Buttazzo, "Energy-Aware Scheduling for Real-Time Systems: A Survey," ACM Trans. Embed. Comput. Syst., vol. 15, no. 1, pp. 7:1–7:34, Jan. 2016. [Online]. Available: http://doi.acm.org/10.1145/2808231
- [36] D. Liu, J. Spasic, P. Wang, and T. Stefanov, "Energy-Efficient Scheduling of Real-Time Tasks on Heterogeneous Multicores Using Task Splitting," in 2016 IEEE 22nd International Conference on Embedded and Real-Time Computing Systems and Applications (RTCSA), 2016, pp. 149–158.
- [37] W. Ali and H. Yun, "RT-Gang: Real-Time Gang Scheduling Framework for Safety-Critical Systems," arXiv:1903.00999 [cs], Mar. 2019. [Online]. Available: http://arxiv.org/abs/1903.00999
- [38] S. Hounsinou, A. Vasu, and H. Ramaprasad, "Work-in-Progress: Hardware Implementation of a Multi-Mode-Aware Mixed-Criticality Scheduler," in 2018 International Conference on Hardware/Software Codesign and System Synthesis (CODES+ISSS), Sep. 2018, pp. 1–2.
- [39] M. Nasri and B. B. Brandenburg, "Offline equivalence: A nonpreemptive scheduling technique for resource-constrained embedded real-time systems (outstanding paper)," in 2017 IEEE Real-Time and Embedded Technology and Applications Symposium (RTAS). IEEE, 2017, pp. 75–86.
- [40] M. Dellinger, P. Garyali, and B. Ravindran, "Chronos linux: a besteffort real-time multiprocessor linux kernel," in *Proceedings of the* 48th Design Automation Conference. ACM, 2011, pp. 474–479.
- [41] P. Kuacharoen, M. A. Shalan, and V. J. M. III, "A Configurable Hardware Scheduler for Real-Time Systems," in in Proceedings of

the International Conference on Engineering of Reconfigurable Systems and Algorithms. CSREA Press, 2003, pp. 96–101.
[42] Y. Tang and N. W. Bergmann, "A Hardware Scheduler Based

- [42] Y. Tang and N. W. Bergmann, "A Hardware Scheduler Based on Task Queues for FPGA-Based Embedded Real-Time Systems," *IEEE Transactions on Computers*, vol. 64, no. 5, pp. 1254–1267, May 2015.
- [43] V. G. Gaitan, N. C. Gaitan, and I. Ungurean, "CPU Architecture Based on a Hardware Scheduler and Independent Pipeline Registers," *IEEE Transactions on Very Large Scale Integration (VLSI) Systems*, vol. 23, no. 9, pp. 1661–1674, Sep. 2015.
- [44] T. Gomes, P. Garcia, S. Pinto, J. Monteiro, and A. Tavares, "Bringing Hardware Multithreading to the Real-Time Domain," *IEEE Embedded Systems Letters*, vol. 8, no. 1, pp. 2–5, Mar. 2016.
- [45] C. Augonnet, S. Thibault, R. Namyst, and P.-A. Wacrenier, "StarPU: a unified platform for task scheduling on heterogeneous multicore architectures," *Concurrency and Computation: Practice and Experience*, vol. 23, no. 2, pp. 187–198, 2011.
- [46] S. Thibault, "On Runtime Systems for Task-based Programming on Heterogeneous Platforms," Ph.D. dissertation, Université de Bordeaux, 2018.
- [47] C. Augonnet, J. Clet-Ortega, S. Thibault, and R. Namyst, "Dataaware task scheduling on multi-accelerator based platforms," in 2010 IEEE 16th International Conference on Parallel and Distributed Systems, Dec 2010, pp. 291–298.
- [48] E. Agullo, O. Beaumont, L. Eyraud-Dubois, and S. Kumar, "Are Static Schedules so Bad? A Case Study on Cholesky Factorization," in 2016 IEEE International Parallel and Distributed Processing Symposium (IPDPS), May 2016, pp. 1021–1030.
- [49] F. Lumpp, S. Aldegheri, H. D. Patel, and N. Bombieri, "Task Mapping and Scheduling for OpenVX Applications on Heterogeneous Multi/Many-Core Architectures," *IEEE Transactions on Computers*, vol. 70, no. 8, pp. 1148–1159, Aug. 2021.



**Joshua Mack** is a Ph.D. student in the Electrical and Computer Engineering program at the University of Arizona. His research interests include reconfigurable systems; emerging architectures; and intelligent workload partitioning across heterogeneous systems.



Samet E. Arda received his M.S. and Ph.D. degrees in Electrical Engineering from Arizona State University in 2013 and 2016. He is currently an Assistant Research Scientist at ASU. His Ph.D. thesis focused on development of dynamic models for small modular reactors. His current research interests include system-level design and optimization techniques for scheduling in heterogeneous SoCs.



**Umit Y. Ogras** received his Ph.D. degree in Electrical and Computer Engineering from Carnegie Mellon University, Pittsburgh, PA, in 2007. From 2008 to 2013, he worked as a research scientist at the Strategic CAD Laboratories, Intel Corporation. He is an Associate Professor at the School of Electrical, Computer and Energy Engineering, and the Associate Director of WISCA Center.



Ali Akoglu received his Ph.D. degree in Computer Science from the Arizona State University in 2005. He is an Associate Professor in the Department of Electrical and Computer Engineering and the BIO5 Institute at the University of Arizona. He is the site-director of the National Science Foundation Industry-University Cooperative Research Center on Cloud and Autonomic Computing. His research focus is on high performance computing and non-traditional computing architectures.

APPENDIX A SUPPLEMENTAL PLOTS



Fig. A.1: Odroid-XU3 application-level plots. Plots are grouped into vertical pairs of Execution & Energy. Applications from left to right, top to bottom: WiFi TX, WiFi RX, Radar Correlator, Temporal Mitigation, Single Carrier TX, Single Carrier RX. We find that the same general trends hold as presented in Section 5 across all applications individually with HEFT RT providing the best execution results, HEFT EDP providing the most energy savings, and HEFT EDP-LB falling between the two. The largest outlier is the Single Carrier TX application, with all three HEFT RT, EDP, and EDP-LB schedulers performing nearly identically, due to the fact that this is the lightest workload.





Fig. A.2: ZCU102 application-level plots. Plots are grouped into vertical pairs of Execution & Energy. Applications from left to right, top to bottom: WiFi TX, WiFi RX, Radar Correlator, Temporal Mitigation, Single Carrier TX, Single Carrier RX. We find that the same general trends hold as presented in Section 5 across all applications individually with HEFT RT providing the best execution results, HEFT EDP providing the most energy savings, and HEFT EDP-LB falling between the two. The largest outlier is the Single Carrier TX application, with all three HEFT RT, EDP, and EDP-LB schedulers performing nearly identically, due to the fact that this is the lightest workload.