Difference between revisions of "OpenMP in Small Bites/Tasking"
OpenMP in Small Bites/Tasking
Jump to navigation
Jump to search
(8 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
− | [[Category:Tutorials]]<nowiki /> | + | [[Category:Tutorials|Tasking (OpenMP)]]<nowiki /> |
+ | {{DISPLAYTITLE:Tasking (OpenMP)}}<nowiki /> | ||
{{Syllabus OpenMP in Small Bites}}<nowiki /> | {{Syllabus OpenMP in Small Bites}}<nowiki /> | ||
__TOC__ | __TOC__ | ||
+ | |||
+ | This video introduces another way to to express parallelism in OpenMP: Tasking. This concept enables the programmer to parallelize code regions with non-canonical loop forms or regions which do not use loops at all (including recursive algorithms). The video explains how to use OpenMP tasking, how to synchonize, how to deal with cut-off strategies and how an OpenMP runtime environment manages the tasks in queues. More examples and details about [[OpenMP_in_Small_Bites/Tasking_and_Data_Scoping|Tasking and Data Scoping]] as well as [[OpenMP_in_Small_Bites/Tasking_and_Synchronization| Tasking_and_Synchronization]] are given in further parts of this tutorial. | ||
== Video == | == Video == | ||
<youtube width="600" height="340" right>lALAUBDszrU</youtube> | <youtube width="600" height="340" right>lALAUBDszrU</youtube> | ||
+ | |||
+ | ([[Media:Hpc.nrw_05_Introduction-Tasking.pdf | Slides as pdf]]) | ||
== Quiz == | == Quiz == | ||
Line 24: | Line 29: | ||
{{hidden begin | {{hidden begin | ||
− | |title = 2. Which tasks are synchronized with by a <code> | + | |title = 2. Which tasks are synchronized with by a <code>taskwait</code> construct? |
}} | }} | ||
<quiz display=simple> | <quiz display=simple> | ||
Line 39: | Line 44: | ||
{{hidden begin | {{hidden begin | ||
− | |title = 3. Why can it be | + | |title = 3. Why can it be beneficial for the performance to use cut-off strategies for task-based OpenMP programs? |
}} | }} | ||
<quiz display=simple> | <quiz display=simple> | ||
Line 46: | Line 51: | ||
+ It can avoid overhead caused by too fine-grained tasks. | + It can avoid overhead caused by too fine-grained tasks. | ||
|| Correct. | || Correct. | ||
− | - It can | + | - It can synchronize tasks faster. |
|| Wrong. | || Wrong. | ||
- It can accelerate task stealing be enforcing one task queue per thread. | - It can accelerate task stealing be enforcing one task queue per thread. |
Latest revision as of 10:48, 18 January 2021
Tutorial | |
---|---|
Title: | OpenMP in Small Bites |
Provider: | HPC.NRW
|
Contact: | tutorials@hpc.nrw |
Type: | Multi-part video |
Topic Area: | Programming Paradigms |
License: | CC-BY-SA |
Syllabus
| |
1. Overview | |
2. Worksharing | |
3. Data Scoping | |
4. False Sharing | |
5. Tasking | |
6. Tasking and Data Scoping | |
7. Tasking and Synchronization | |
8. Loops and Tasks | |
9. Tasking Example: Sudoku Solver | |
10. Task Scheduling | |
11. Non-Uniform Memory Access |
This video introduces another way to to express parallelism in OpenMP: Tasking. This concept enables the programmer to parallelize code regions with non-canonical loop forms or regions which do not use loops at all (including recursive algorithms). The video explains how to use OpenMP tasking, how to synchonize, how to deal with cut-off strategies and how an OpenMP runtime environment manages the tasks in queues. More examples and details about Tasking and Data Scoping as well as Tasking_and_Synchronization are given in further parts of this tutorial.
Video
Quiz
Collapse
1. What is the default data scoping of a variable in a task scope? Hint: Assume that the variable is declared before the task region, but in the same function.
Collapse
3. Why can it be beneficial for the performance to use cut-off strategies for task-based OpenMP programs?