Using Template Matching to Infer Parallel Design Patterns
The triumphant spread of multicore processors over the past decade increases the pressure on software developers to exploit the growing amount of parallelism available in the hardware. However, writing parallel programs is generally challenging. For sequential programs, the formulation of design patterns marked a turning point in software development, boosting programmer productivity and leading to more reusable and maintainable code. While the literature is now also reporting a rising number of parallel design patterns, programmers confronted with the task of parallelizing an existing sequential program still struggle with the question of which parallel pattern to apply where in their code. In this article, we show how template matching, a technique traditionally used in the discovery of sequential design patterns, can also be used to support parallelization decisions. After looking for matches in a previously extracted dynamic dependence graph, we classify code blocks of the input program according to the structure of the parallel patterns we find. Based on this information, the programmer can easily implement the detected pattern and create a parallel version of his or her program. We tested our approach with six programs, in which we successfully detected pipeline and do-all patterns.
Top-30
Journals
1
2
|
|
Lecture Notes in Computer Science
2 publications, 12.5%
|
|
Transactions on Architecture and Code Optimization
1 publication, 6.25%
|
|
Concurrency Computation Practice and Experience
1 publication, 6.25%
|
|
Journal of Automated Reasoning
1 publication, 6.25%
|
|
1
2
|
Publishers
1
2
3
|
|
Springer Nature
3 publications, 18.75%
|
|
Association for Computing Machinery (ACM)
1 publication, 6.25%
|
|
Wiley
1 publication, 6.25%
|
|
1
2
3
|
- We do not take into account publications without a DOI.
- Statistics recalculated only for publications connected to researchers, organizations and labs registered on the platform.
- Statistics recalculated weekly.