The Scientific World Journal

Volume 2014, Article ID 465702, 9 pages

http://dx.doi.org/10.1155/2014/465702

## A Synthesized Heuristic Task Scheduling Algorithm

Institute of Information and Communication, Guilin University of Electronic Technology, Guilin 541004, China

Received 3 June 2014; Revised 24 July 2014; Accepted 7 August 2014; Published 1 September 2014

Academic Editor: Dehua Xu

Copyright © 2014 Yanyan Dai and Xiangli Zhang. This is an open access article distributed under the Creative Commons Attribution License, which permits unrestricted use, distribution, and reproduction in any medium, provided the original work is properly cited.

#### Abstract

Aiming at the static task scheduling problems in heterogeneous environment, a heuristic task scheduling algorithm named HCPPEFT is proposed. In task prioritizing phase, there are three levels of priority in the algorithm to choose task. First, the critical tasks have the highest priority, secondly the tasks with longer path to exit task will be selected, and then algorithm will choose tasks with less predecessors to schedule. In resource selection phase, the algorithm is selected task duplication to reduce the interresource communication cost, besides forecasting the impact of an assignment for all children of the current task permits better decisions to be made in selecting resources. The algorithm proposed is compared with STDH, PEFT, and HEFT algorithms through randomly generated graphs and sets of task graphs. The experimental results show that the new algorithm can achieve better scheduling performance.

#### 1. Introduction

A heterogeneous computing system (HCS) is a computing platform with diverse sets of interconnected resources via high speed network to execute parallel and distributed applications. Due to diverse computational resources, the efficiency of an application on the available resources is one of the key factors for achieving high performance computing. The general form of task scheduling problem in HCS can be represented as directed acyclic graph (DAG). The common objective of scheduling is to assign tasks onto suitable resources and order their execution so that task precedence requirements are satisfied with a minimum schedule length [1]. The scheduling problem is shown to be NP-complete [2–4], so it is expected to be solved by heuristic algorithm.

A typical task scheduling model is based on a directed acyclic graph, including static and dynamic scheduling. Heuristic algorithm is static scheduling algorithm, which is composed of duplication-based algorithms, clustering algorithms, and list scheduling algorithms [3]. List scheduling algorithms are widely used for their high scheduling efficiency and simple design idea. The basic idea of list scheduling is to construct a schedule list by assigning priority for each task, and tasks are selected to a processor which minimizes the execution time. Classical examples of list scheduling algorithms were proposed in [5–10]. The heterogeneous earliest finish time (HEFT) [5] uses a recursive procedure to compute the rank of a task by traversing the graph upwards from the exit task and vice-versa for critical path on a processor (CPOP) [5]. Improvement heterogeneous earliest finish time (IHEFT) [6] acquires a better task list by changing the task’s upward weight calculation method. Stand deviation-based algorithm for task scheduling (SDBATS) [7] uses the standard deviation of the expected execution time of a given task on the available resources as a key attribute for assigning task priority. In [8], the proposed algorithm determines the critical path of the task graph and selects the next task to be scheduled in a dynamic fashion. Predict earliest finish time (PEFT) [9] algorithm is only based on computation of an optimistic cost table (OCT) that is used to rank tasks and for resource selection. A novel algorithm named the longest dynamic critical path (LDCP) [10] assigns priorities by considering the critical path attribute of the given DAG.

The idea of task duplication is to try to duplicate the parents of the current selected task onto the selected resource or on to the other resources, aiming to reduce or optimize the task finish time. Many duplication-based algorithms are proposed in recent years; for example, in [11], a path priority-based heuristic task scheduling algorithm was studied. Heterogeneous critical task (HCT) [12] scheduling algorithm defines the critical task and the idle time slot. Selected task duplication for heterogeneous (STDH) [13] duplicates the parent tasks for advancing the earliest starting time of the current candidate task to reduce the inter processor communication cost. Heterogeneous earliest finish time with duplication (HEFD) [14] uses task variance as computation capacity heterogeneity factor for setting weights to tasks and edges. The algorithm in [15] is a three-phase algorithm with a dynamic phase to assign a priority to each task. To search and delete redundant task duplications dynamically in the process of scheduling, a novel resource-aware scheduling algorithm with duplications (RADS) was proposed in [16]. There are some researches such as [17, 18] combining DVS technique with duplication strategy to reduce energy consumption. The algorithms proposed in [19, 20] are designed to solve the problem of resource waste. Other duplication-based algorithms such as selective duplication (SD) [21] and heterogeneous critical parents with fast duplicator (HCPFD) [22] are also worth studied.

Clustering algorithms merge tasks in a DAG to an unlimited number of clusters, and tasks in a cluster are allocated on the same resource. Some classical examples are cluster mapping algorithm (CMA) [23], clustering and scheduling system (CASS) [24], objective flexible clustering algorithm (OFCA) [25], and so on. In [26, 27], two novel algorithms were proposed, but they have limitations in higher heterogeneity systems. To reduce energy consumption without increasing the schedule length, [28] reclaims both static and dynamic slack time and employs different frequency adjusting techniques in different slack time, and [29] studies the slack time for noncritical jobs, extends their execution time, and reduces the energy consumption without increasing the task’s execution time as a whole. Additionally, these methods are based on DAG scheduling: heterogeneous critical path first synthesized (HCPFS) [30], heterogeneous select value (HSV) [31], heterogeneous chip multiprocessor global comparatively optimum task scheduling (HGCOTS) [32], and so on.

The HEFT [5] algorithm has two phases: the task prioritizing phase and the processor selection phase. In the first phase, a task list is generated by sorting the tasks in decreasing order of the upward rank. In the processor selection phase, tasks are scheduled to the best processor that minimizes the task’s finish time. However, the algorithm does not take into account the critical task and interprocessor communication cost impact on the whole task graph scheduling time. Task scheduling efficiency is not high which still should be optimized further.

The PEFT [9] algorithm is based on the computation of an optimistic cost table (OCT) on which task priority and processor selection are based. The OCT is a matrix in which the rows indicate the number of resources, where each element indicates the maximum of the shortest paths of children’s tasks to the exit node considering that resource is selected for task . The algorithm has the same time complexity as the HEFT and SDBATS algorithms, that is, for tasks and resources. But the algorithm does not take into account the critical tasks, which decide the whole DAG scheduling time. So this algorithm delays the scheduling length to some extent.

The STDH [13] algorithm duplicates the parent tasks for advancing the earliest starting time of the current candidate task to reduce the interprocessor communication cost. By this way, the overall run time of application is shortened, but the algorithm scheduled only by one attribute. In the case of that different tasks should have the same priority, it cannot work well. Therefore, in order to evaluate the priority of tasks reasonably, multiple attributes are more suitable for sorting tasks.

In this paper, we propose a synthesized heuristic task scheduling algorithm based on both duplication-based techniques and list-based approach for heterogeneous computing systems. The HCPPEFT algorithm has two phases, the task prioritizing phase and the resource selection phase (see Algorithm 1). In the first phase, we suggest a new approach of critical task, the tasks with longer path to exit task, and the number of predecessors to construct the scheduling queue. In the second phase, the duplication of tasks is optimized for all immediate parent tasks and look ahead policies is to guarantee the tasks ahead will finish earlier. The rest of the paper is organized as follows. In Section 2, we define the task scheduling problem and discuss some basic attributes of DAG scheduling. Section 3 introduces HCPPEFT algorithm and in Section 4 the results of the experiment are discussed. Section 5 concludes the paper.

#### 2. Problem Definition

##### 2.1. Task Model

A scheduling system model is composed of an application in heterogeneous computing environment. An application is represented by , where is the set of tasks and is the set of e edges between the tasks. Each edge represents the precedence constraint such that task should complete its execution before task starts. Communication cost required to be transmitted from task to task is represented by a matrix, in which each gives the amount of data on edge. The heterogeneous system consists of a set of resources of independent resources fully connected by a high speed network. A computation cost matrix is represented as , in which each gives the estimated time to execute on resource . We further assume that any two connecting tasks scheduled on the same resource have zero communication costs.

##### 2.2. DAG Scheduling Attributes

Before proceeding to the next section, it is necessary to discuss some scheduling attributes such as rank upward, rank downward, earliest start time, earliest finish time, and optimistic cost table, which will be used in the proposed scheduling algorithm.

*Definition 1. *A task with no predecessors is called an entry task , and denotes the set of immediate predecessors of task in a given task graph. Similarly, a task with no successors is called an exit task , and denotes the set of immediate successors of task in a given task graph. If a task graph has multiple entry or exit nodes, a dummy entry or exit node with zero communication edges and zero weight can be added to the graph.

*Definition 2. *The upward rank of a task is calculated using the following equation:
where is the average computation cost of task , and is the average communication cost of the edge from task to task . For the exit task , upward rank value is
Similarly, the downward rank of task is defined by the following equation:
For the entry task , the downward rank value is equal to zero.

*Definition 3. * and are the earliest start time and earliest finish time of a task on the resource and are defined by
where is the earliest time at which resource is ready for task execution, is actual finish time of task , and is communication cost of the edge from task to task . Before computing earliest finish time of a task , all the immediate predecessor tasks of must have been scheduled. For the entry task , .

*Definition 4. *If the task start execution time depends on the arrival time of parent tasks, there will be a free time slot, that is, the task to wait for the time of arrival of the parent task, can be defined as

*Definition 5. *The OCT is a matrix in which the rows indicate the number of tasks and the columns indicate the number of resources, where each element represents the maximum optimistic processing time of the children of task . The OCT value of task on resource is recursively defined by

*Definition 6. *The schedule length (makespan) of the task graph denotes the finish time of the last task and is defined as follows:

The objective function of the task scheduling problem is to determine an assignment of tasks of a given task graph to resources, such that its schedule length is minimized, which satisfying all precedence constraints.

#### 3. The Proposed Algorithm HCPPEFT

##### 3.1. Task Prioritizing Phase

The critical path is a path with the longest execution time in directed acyclic graph, which of task play a decisive role to finish time. In the process of task scheduling, critical task is assigned the highest priority to make it firstly scheduled. However, critical task usually have one or more parent tasks. If parent tasks cannot get a reasonable scheduling, the start execution time will be delayed. Therefore it not only assigns besides the critical tasks the highest priority, but also needs the parent tasks of critical tasks to allocate higher-priority. Immediate parent tasks are sorted in a decreasing order of rank upward values. If the rank upward values are equal, select the tasks with respect to the predecessors increase. In order to construct the task scheduling queue, two empty queues of tasks are constructed firstly, which are CTQ and RTQ. CTQ is used to store critical task and RTQ is used to store the task scheduling ready queue. The process of constructing task scheduling queues is expressed as Figure 1. The detailed explain is presented as follows.(1)Upward rank (), downward rank (), and the summation of upward and downward ranks values for all tasks are computed.(2)The critical path length is equal to the entry task’s priority. The entry task is marked as a critical path task. If for each task in DAG, then , where is the entry task, is the set of tasks on the critical path. The all critical path task will be added to the CTQ by decreasing order of .(3)The CTQ at the beginning contains all critical tasks. In fact a critical task will be omitted from the CTQ and added to the RTQ after all parent tasks are added to the RTQ. The priority of the parent tasks is determined based on their . The parent task with the highest gets high priority.(4)If there are two or more parent tasks of are equal. The priority of the parent tasks is generated by increasing order of the number of predecessors.(5)The above steps are executed until the CTQ queue is null. The RTQ queue is task scheduling queue.

To illustrate how the task prioritizing queue is constructed, a random task graph with 10 tasks and 16 edges is shown in Figure 2. The corresponding computation cost with respect to each resource is presented in Table 1. Based on the values in Table 2, the critical path in Figure 2 is . The all critical tasks will be added to the CTQ by decreasing order of rank upward values; that is, . Because the entry task has no parent task, it will be omitted from the CTQ and added to the RTQ immediately. After that, task is added in RTQ and deleted from CTQ. Until parents tasks and have been selected, the critical task can be selected. Till now, we can get and . Before the critical task is selected, the parent tasks and must have been scheduled. But the rank upward values of parent tasks and are equal, selecting tasks with respect to the predecessors increase. Task is selected and then is task . At this time, the scheduling order of remaining tasks is . Finally, the task queue is constructed, which is .

##### 3.2. Resource Selection Phase

In this phase, tasks are assigned to the resources and duplication is employed to minimize the finish time. To start execution on a resource, the task has to wait for the data arrivals from all of its immediate parents, so as to meet precedence constraints. The parent task of task whose schedule on different resources and whose data arrival time at task is the latest parent task. Duplication condition [13] is defined as

If it is satisfied, then the parent task will be duplicated on the resource that assigned to. Simultaneously compute the earliest finish time by (5) and update the free time slots by (6). It is to be noted that the best-suited resource may not be achieved if we followed by (5). Because the best scheduling consider not only the current task’s gain in complete time but also the gain in a sequence of tasks. With computation of an OCT by (7) not only cannot increase the time complexity but also guarantee that the tasks ahead will finish earlier. In this way, we compute the optimistic EFT (), which sums to EFT the computation time of the longest path to the exit task, to select a best-suited resource. is defined as

For a given DAG, the time complexity of scheduling algorithm is usually expressed in terms of number of tasks and number of resources . The time complexity of STDH is of constructing schedule queue . The resource selection for all tasks can be done in time complexity . The total time is . PEFT requires the computation of an OCT table is , and to assign the tasks to resources, the time complexity is of the order . The total time is . The HEFT algorithm has a complexity for tasks and resources. The HCPPEFT algorithm requires the construing task scheduling queue is , and the time complexity of resource select phase is . That is, the HCPPEFT algorithm has the same time complexity as the STDH, PEFT, and HEFT algorithms.

##### 3.3. HCPPEFT Algorithm Implementation

To evaluate the performance of the HCPPEFT algorithm, we implement this algorithm on the PC platform using MATLAB software.

A randomly generated task graph is shown in Figure 2 firstly. Then the corresponding computation costs are presented in Table 1. By calculating (7), the OCT values are shown in Tables 3 and 4 which give an example that demonstrates the HCPPEFT for the DAG of Figure 2 in the end.

As an illustration, Figure 3 presents the schedules obtained by the HCPPEFT algorithm, where the gray blocks with numbers are the duplicated tasks. The schedule length, which is equal to 69, is shorter than that of the related algorithms; specifically, the schedule lengths of STDH, PEFT, and HEFT Algorithm are 73, 78, and 77, respectively.

#### 4. Experimental Results and Discussion

This section presents a performance comparison of the proposed algorithm HCPPEFT with four well-known task scheduling algorithms such as STDH, PEFT, and HEFT by randomly generated task graph and sets of task graphs. Three metrics are used for performance evaluation.

##### 4.1. Comparisons Metrics

###### 4.1.1. Scheduling Length Ratio

Since a large set of task graphs with different properties is used, it is necessary to normalize the schedule length to the lower bound, which is called the schedule length ratio (SLR). SLR is defined as follows: where is the minimum computation cost of the critical path tasks in SLR. There is no makespan less than the denominator of the SLR equation since the denominator is the lower bound. Therefore, the algorithm with the lowest SLR is the best algorithm with respect to performance.

###### 4.1.2. Speedup

The speedup value for a given task graph is defined as the ratio of sequential execution times to the parallel execution times. The sequential execution time is computed by assigning all tasks to a single resource that minimizes the computation costs. Speedup is defined as follows:

###### 4.1.3. Efficiency

In the general case, efficiency is defined as the ratio of the speedup value to the number of resources used in schedule task graph. Efficiency is defined as follows:

##### 4.2. Randomly Generated Task Graph and Performance Comparison

To evaluate the performance of the HCPPEFT algorithm, we first considered randomly generated task graphs. For this purpose, a random graph generator available at [13] was implemented to generate a variety of weighted graphs with various characteristics. The input parameters of the generator are the communication to computation ratio (CCR), number of tasks, out degree of a node (out_degree), edge weight, node weight, and number of resources. Our simulation framework first generate a large set of random task graphs with different characteristics, which is followed by the execution of the task scheduling algorithms, and finally, it computes the performance metrics.

The performance of the HCPPEFT, STDH, PEFT, and HEFT algorithms is compared with respect to various graph characteristics according to SLR, speedup, and efficiency.

Firstly, we have evaluated the performance of the algorithm with respect to various numbers of tasks and the number of resources was considered as a fixed value of 10. Each value of the experimental results is the average of the results produced from 200 different random task graphs. In these experiments CCR and out_degree were considered as fixed value of 2 and 5, and was restricted to the following values: 20, 40, 60, 80, 100, 120, 150, 200}. The edge weight is generated randomly from 1 to 300, as the node weight is 1 to 30. In Figures 4 and 5, the simulation results show that the new algorithm outperforms the other algorithms according to the SLR and speedup. The average SLR value of the HCPPEFT algorithm is better than the HEFT algorithm by 19.99%, the PEFT algorithm by 14.43%, and the STDH algorithm by 5.72%; and the average speedup value of the HCPPEFT algorithm is better than the HEFT algorithm by 16.33%, the PEFT algorithm by 10.79%, and the STDH algorithm by 8.69%.

The next experiment is with respect to CCR increment. Each value of the experimental results is the average of the results produced from 200 different random task graphs. In each graph, the CCR is randomly selected from 0.1, 0.25, 0.5, 1, 2, and 5, and the node weight is generated randomly from 1 to 30, as the edge weight is 1 to 300. Also , , and out_degree are fixed to 10, 100, and 5, respectively. The results are shown in Figures 6 and 7. In comparison to the HEFT, PEFT, and STDH algorithms on all the generated graphs, the average SLR value obtained by the HCPPEFT algorithm is better by as much as 43.35%, 32.83%, and 7.08%, respectively; and the average speedup value is better by as much as 31.62%, 24.56%, and 7.72%, respectively. This improvement is due to the duplication phase and predicting earliest finish time. The communication cost can reach its lowest ratio by duplication with respect to the increment of CCR; therefore the new algorithm will have great improvement. On the other hand, we can select the best-suited resource that achieves a shorter finish time for the tasks in the next steps by forecasting the impact of an assignment for all children of the current task.

The last set of experiments compare the performance of the algorithm as the value of resource numbers increase. Each value of the experimental results is the average of the results produced from 200 different random task graphs. In these experiments CCR, , and out_degree were fixed to 0.5, 150, and 5, respectively, and the edge weight is generated randomly from 1 to 300 and the node weight is 1 to 30. The number of resources was restricted to the following values: 5, 8, 10, 12, 15}. In Figure 8, the simulation results show that the HCPPEFT algorithm outperforms the HEFT, PEFT, and STDH algorithms by 30.98%, 22.95%, and 7.45%, respectively. As was expected, the average scheduling length of HCPPEFT, HEFT, PEFT, and STDH algorithms is reduced as the number of resources increases. This decrement is due to parallelism characteristics.

##### 4.3. Sets of Task Graphs and Performance Results

In addition to randomly generated task graph, we also use the sets of task graphs to evaluate the performance of the new algorithm. The reference and related parameters of the sets of task graphs are shown in Tables 3 and 5. The schedule lengths of HCPPEFT, STDH, PEFT, and HEFT algorithmss are presented in Figure 9. The results show that the performance of the HCPPEFT algorithm outperforms the other algorithms.

#### 5. Conclusion

In this paper, we have proposed a synthesized task scheduling algorithm for heterogeneous computing systems called HCPPEFT. This new algorithm is a two-phase algorithm that combines mechanisms of list-scheduling-based, duplication-based, and look-ahead-based algorithms. Therefore, the HCPPEFT algorithm provides a more efficient way to schedule general task graphs. In the task prioritizing phase, three levels of priority are proposed to choose task. The method of constructing task scheduling queue not only takes account of critical tasks but also takes account of the importance of parent tasks. In the resource selection phase, the duplication of parent tasks is to reduce communication costs. Forecasting the impact of an assignment for all children of the current task is to select a best resource. The effective performance of the new algorithm is compared to three of the best existing scheduling algorithms: HEFT, PEFT, and STDH algorithms. The comparative study is based on randomly generated task graph and the sets of task graphs. The HCPPEFT algorithm outperforms the other algorithms in terms of average SLR, speedup, and efficiency.

#### Conflict of Interests

The authors declare that there is no conflict of interests regarding the publication of this paper.

#### Acknowledgments

This work was supported by the Foundation items (NFS of China: no. 61363031, GuangXiSci. and Tech. Development Foundation: no. GKG1211-80172C, GuilinSci. and Tech. Development Foundation: no. 20120104-13) for supporting our work.

#### References

- R. C. Corrêa, A. Ferreira, and P. Rebreyend, “Scheduling multiprocessor tasks with genetic algorithms,”
*IEEE Transactions on Parallel and Distributed Systems*, vol. 10, no. 8, pp. 825–837, 1999. View at Publisher · View at Google Scholar · View at Scopus - M. R. Garey and D. S. Johnson,
*Computers and Intractability: A Guide to the Theory of NP-Completeness*, W. H. Freeman, New York, NY, USA, 1979. - E. G. Coffman,
*Computer and Job-Shop Scheduling Theory*, John Wiley & Sons, New York, NY, USA, 1976. - J. D. Ullman, “$NP$-complete scheduling problems,”
*Journal of Computer and System Sciences*, vol. 10, no. 3, pp. 384–393, 1975. View at Publisher · View at Google Scholar · View at MathSciNet · View at Scopus - H. Topcuoglu, S. Hariri, and M.-Y. Wu, “Performance-effective and low-complexity task scheduling for heterogeneous computing,”
*IEEE Transactions on Parallel and Distributed Systems*, vol. 13, no. 3, pp. 260–274, 2002. View at Publisher · View at Google Scholar · View at Scopus - X. Wang, H. Huang, and S. Deng, “List scheduling algorithm for static task with precedence constraints for cyber-physical systems,”
*Acta Automatica Sinica*, vol. 38, no. 11, pp. 1870–1879, 2012. View at Publisher · View at Google Scholar · View at Scopus - E. U. Munir, S. Mohsin, A. Hussain, M. W. Nisar, and S. Ali, “SDBATS: a novel algorithm for task scheduling in heterogeneous computing systems,” in
*Proceedings of the IEEE 27th International Parallel and Distributed Processing Symposium Workshops & PhD Forum (IPDPSW '13)*, vol. 43, pp. 43–53, Cambridge, Mass, USA, May 2013. View at Publisher · View at Google Scholar - Y. Kwok and I. Ahmad, “Dynamic critical-path scheduling: an effective technique for allocating task graphs to multiprocessors,”
*IEEE Transactions on Parallel and Distributed Systems*, vol. 7, no. 5, pp. 506–521, 1996. View at Publisher · View at Google Scholar · View at Scopus - 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. View at Publisher · View at Google Scholar - M. I. Daoud and N. Kharma, “A high performance algorithm for static task scheduling in heterogeneous distributed computing systems,”
*Journal of Parallel and Distributed Computing*, vol. 68, no. 4, pp. 399–409, 2008. View at Publisher · View at Google Scholar · View at Zentralblatt MATH · View at Scopus - J. Y. Zhu and D. Xiao, “Path priority-based heuristic task scheduling algorithm for cloud computing,”
*Computer Engineering and Design*, vol. 34, no. 10, pp. 3511–3515, 2013. View at Google Scholar - Z. Lan and S. X. Sun, “Scheduling algorithm based on critical tasks in heterogeneous environments,”
*Journal of Systems Engineering and Electronics*, vol. 19, no. 2, pp. 398–405, 2008. View at Publisher · View at Google Scholar · View at Scopus - X. Meng and W. Liu, “A DAG scheduling algorithm based on selected duplication of precedent tasks,”
*Journal of Computer-Aided Design and Computer Graphics*, vol. 22, no. 6, pp. 1056–1062, 2010. View at Publisher · View at Google Scholar · View at Scopus - X. Y. Tang, K. L. Li, G. P. Liao, and R. F. Li, “List scheduling with duplication for heterogeneous computing systems,”
*Journal of Parallel and Distributed Computing*, vol. 70, no. 4, pp. 323–329, 2010. View at Publisher · View at Google Scholar · View at Scopus - M. Hosseinzadeh and H. S. Shahhoseini, “An effective duplication-based task-scheduling algorithm for heterogeneous systems,”
*Simulation*, vol. 87, no. 12, pp. 1067–1080, 2011. View at Publisher · View at Google Scholar · View at Scopus - J. Mei, K. Li, and K. Li, “A resource-aware scheduling algorithm with reduced task duplication on heterogeneous computing systems,”
*The Journal of Super Computing*, vol. 68, no. 3, pp. 1347–1377, 2014. View at Google Scholar - J. Mei and K. Li, “Energy-aware scheduling algorithm with duplication on heterogenous computing systems,” in
*Proceedings of the 13th ACM/IEEE International Conference on Grid Computing (GRID '12)*, pp. 122–129, September 2012. View at Publisher · View at Google Scholar · View at Scopus - Z. Zong, A. Manzanares, X. Ruan, and X. Qin, “EAD and PEBD: two energy-aware duplication scheduling algorithms for parallel tasks on homogeneous clusters,”
*IEEE Transactions on Computers*, vol. 60, no. 3, pp. 360–374, 2011. View at Publisher · View at Google Scholar · View at MathSciNet · View at Scopus - D. Bozdag, F. Ozguner, and U. V. Catalyurek, “Compaction of schedules and a two-stage approach for duplication-based DAG scheduling,”
*IEEE Transactions on Parallel and Distributed Systems*, vol. 20, no. 6, pp. 857–871, 2009. View at Publisher · View at Google Scholar · View at Scopus - K. S. Shin, M. J. Cha, M. S. Jang, J. Jung, W. Yoon, and S. Choi, “Task scheduling algorithm using minimized duplications in homogeneous systems,”
*Journal of Parallel and Distributed Computing*, vol. 68, no. 8, pp. 1146–1156, 2008. View at Publisher · View at Google Scholar · View at Scopus - S. Bansal, P. Kumar, and K. Singh, “An improved duplication strategy for scheduling precedence constrained graphs in multiprocessor systems,”
*IEEE Transactions on Parallel and Distributed Systems*, vol. 14, no. 6, pp. 533–544, 2003. View at Publisher · View at Google Scholar · View at Scopus - T. Hagras and J. Janeček, “A high performance, low complexity algorithm for compile-time task scheduling in heterogeneous systems,”
*Parallel Computing*, vol. 31, no. 7, pp. 653–670, 2005. View at Publisher · View at Google Scholar · View at Scopus - C. Boeres, J. V. Filho, and V. E. F. Rebello, “A cluster-based strategy for scheduling task on heterogeneous processors,” in
*Proceedings of the SBAC-PAD 16th Symposium on Computer Architecture and High Performance Computing*, vol. 214, pp. 27–29, 2004. - J. C. Liou and M. A. Palis, “An efficient task clustering heuristic for scheduling dags on multiprocessors,” in
*Workshop on Resource Management, Symposium on Parallel and Distributed Processing*, 1996. - F. Fu, Y. Bai, X. Hu, J. Wang, M. Yu, and J. Zhan, “An objective-flexible clustering algorithm for task mapping and scheduling on cluster-based NoC,” in
*Proceedings of the Laser Physics and Laser Technologies (RCSLPLT) and 2010 Academic Symposium on Optoelectronics Technology (ASOT), 2010 10th Russian-Chinese Symposium*, pp. 369–373, August 2010. View at Publisher · View at Google Scholar · View at Scopus - B. Cirou and E. Jeannot, “Triplet: a clustering scheduling algorithm for heterogeneous systems,” in
*International Conference on Parallel Processing Workshops*, pp. 231–236, 2001. - C. Boeres, J. V. Filho, and V. E. F. Rebello, “A cluster-based strategy for scheduling task on heterogeneous processors,” in
*Proceedings of the 16th Symposium on Computer Architecture and High Performance Computing (9SBAC-PAD '04)*, pp. 214–221, October 2004. View at Publisher · View at Google Scholar · View at Scopus - A. H. Liang, L. M. Xiao, Y. N. Li, Z. Z. Zhang, and L. Ruan, “Energy aware scheduling for precedence constrained parallel tasks in a power-scalable cluster,” in
*Proceedings of the IEEE International Conference on High Performance Computing and Communications*, pp. 1016–1021, Zhangjiajie, China, 2013. - L. Wang, S. U. Khan, D. Chen et al., “Energy-aware parallel task scheduling in a cluster,”
*Future Generation Computer Systems*, vol. 29, no. 7, pp. 1661–1670, 2013. View at Publisher · View at Google Scholar · View at Scopus - H. Zhao, W. Jiang, and X. H. Li, “Synthesized heuristic task scheduling algorithm for heterogeneous system,”
*Journal of Computer Application*, vol. 30, no. 5, pp. 1316–1320, 2010. View at Google Scholar - G. Q. Xie, R. F. Li, X. G. Xiao, and Y. K. Chen, “A high-performance DAG task scheduling algorithm for heterogeneous networked embedded systems,” in
*Proceedings of the 28th IEEE International Conference on Advanced Information Networking and Applications (AINA '14)*, vol. 1011, pp. 13–16, 2014. - J. M. Li, D. W. Sun, and Y. X. Wu, “Global comparatively optimum static task scheduling algorithm,”
*Application Research of Computers*, vol. 31, no. 4, pp. 1027–1030, 2014. View at Google Scholar