Publication View

Is the schedule clause really necessary in openmp (2003)

Abstract
Abstract. Choosing the appropriate assignment of loop iterations to threads is one of the most important decisions that need to be taken when parallelizing Loops, the main source of parallelism in numerical applications. This is not an easy task, even for expert programmers, and it can potentially take a large amount of time. OpenMP offers the schedule clause, with a set of predefined iteration scheduling strategies, to specify how (and when) this assignment of iterations to threads is done. In some cases, the best schedule depends on architectural characteristics of the target architecture, data input,... making the code less portable. Even worse, the best schedule can change along execution time depending on dynamic changes in the behavior of the loop or changes in the resources available in the system. Also, for certain types of imbalanced loops, the schedulers already proposed in the literature are not able to extract the maximum parallelism because they do not appropriately trade–off load balancing and data locality. This paper proposes a new scheduling strategy, that derives at run time the best scheduling policy for each parallel loop in the program, based on information gathered at runtime by the library itself. 1

Publication details
Download http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.80.2535
Source http://people.ac.upc.es/eduard/papers/paper_a25.pdf.gz
Contributors CiteSeerX
Repository CiteSeerX - Scientific Literature Digital Library and Search Engine (United States)
Keywords threads as indicated in the SCHEDULE clause, STATIC, DYNAMIC and GUIDED (all
Type text
Language English
Relation 10.1.1.104.3829, 10.1.1.47.6699, 10.1.1.16.5625, 10.1.1.47.8935, 10.1.1.19.8198, 10.1.1.98.1323, 10.1.1.140.4844