Thomas Karcher - Academia.edu (original) (raw)

Uploads

Papers by Thomas Karcher

Research paper thumbnail of Autotuning and Self-Adaptability in Concurrency Libraries

Autotuning is an established technique for optimizing the performance of parallel applications. H... more Autotuning is an established technique for optimizing the performance of parallel applications. However, programmers must prepare applications for autotuning, which is tedious and error prone coding work. We demonstrate how applications become ready for autotuning with few or no modifications by extending Threading Building Blocks (TBB), a library for parallel programming, with autotuning. The extended TBB library optimizes all application-independent tuning parameters fully automatically. We compare manual effort, autotuning overhead and performance gains on 17 examples. While some examples benefit only slightly, others speed up by 28% over standard TBB.

Research paper thumbnail of Auto-tuning support for manycore applications: perspectives for operating systems and compilers

Acm Sigops Operating Systems Review, 2009

Research paper thumbnail of Run-Time Automatic Performance Tuning for Multicore Applications

Lecture Notes in Computer Science, 2011

Research paper thumbnail of Auto-tuning support for manycore applications

ACM SIGOPS Operating Systems Review, 2009

Research paper thumbnail of Locating Parallelization Potential in Object-Oriented Data Structures

2014 IEEE 28th International Parallel and Distributed Processing Symposium, 2014

The free lunch of ever increasing single-processor performance is over. Software engineers have t... more The free lunch of ever increasing single-processor performance is over. Software engineers have to parallelize software to gain performance improvements. But not every software engineer is a parallel expert and with millions of lines of code that have not been developed with multicore in mind, we have to find ways to assist in identifying parallelization potential.

Research paper thumbnail of Autotuning and Self-Adaptability in Concurrency Libraries

Autotuning is an established technique for optimizing the performance of parallel applications. H... more Autotuning is an established technique for optimizing the performance of parallel applications. However, programmers must prepare applications for autotuning, which is tedious and error prone coding work. We demonstrate how applications become ready for autotuning with few or no modifications by extending Threading Building Blocks (TBB), a library for parallel programming, with autotuning. The extended TBB library optimizes all application-independent tuning parameters fully automatically. We compare manual effort, autotuning overhead and performance gains on 17 examples. While some examples benefit only slightly, others speed up by 28% over standard TBB.

Research paper thumbnail of Application-independent Autotuning for GPUs

Autotuning is an established technique for adjusting performance-critical parameters of applicati... more Autotuning is an established technique for adjusting performance-critical parameters of applications to their specific run-time environment. In this paper, we investigate the potential of online autotuning for general purpose computation on GPUs. Our application-independent autotuner AtuneRT optimizes GPU-specific parameters such as block size and loop-unrolling degree. We also discuss the peculiarities of autotuning on GPUs. We demonstrate tuning potential using CUDA and by instrumenting the parallel algorithms library Thrust. We evaluate our online autotuning approach with various GPUs and sample applications.

Research paper thumbnail of Autotuning and Self-Adaptability in Concurrency Libraries

Autotuning is an established technique for optimizing the performance of parallel applications. H... more Autotuning is an established technique for optimizing the performance of parallel applications. However, programmers must prepare applications for autotuning, which is tedious and error prone coding work. We demonstrate how applications become ready for autotuning with few or no modifications by extending Threading Building Blocks (TBB), a library for parallel programming, with autotuning. The extended TBB library optimizes all application-independent tuning parameters fully automatically. We compare manual effort, autotuning overhead and performance gains on 17 examples. While some examples benefit only slightly, others speed up by 28% over standard TBB.

Research paper thumbnail of Auto-tuning support for manycore applications: perspectives for operating systems and compilers

Acm Sigops Operating Systems Review, 2009

Research paper thumbnail of Run-Time Automatic Performance Tuning for Multicore Applications

Lecture Notes in Computer Science, 2011

Research paper thumbnail of Auto-tuning support for manycore applications

ACM SIGOPS Operating Systems Review, 2009

Research paper thumbnail of Locating Parallelization Potential in Object-Oriented Data Structures

2014 IEEE 28th International Parallel and Distributed Processing Symposium, 2014

The free lunch of ever increasing single-processor performance is over. Software engineers have t... more The free lunch of ever increasing single-processor performance is over. Software engineers have to parallelize software to gain performance improvements. But not every software engineer is a parallel expert and with millions of lines of code that have not been developed with multicore in mind, we have to find ways to assist in identifying parallelization potential.

Research paper thumbnail of Autotuning and Self-Adaptability in Concurrency Libraries

Autotuning is an established technique for optimizing the performance of parallel applications. H... more Autotuning is an established technique for optimizing the performance of parallel applications. However, programmers must prepare applications for autotuning, which is tedious and error prone coding work. We demonstrate how applications become ready for autotuning with few or no modifications by extending Threading Building Blocks (TBB), a library for parallel programming, with autotuning. The extended TBB library optimizes all application-independent tuning parameters fully automatically. We compare manual effort, autotuning overhead and performance gains on 17 examples. While some examples benefit only slightly, others speed up by 28% over standard TBB.

Research paper thumbnail of Application-independent Autotuning for GPUs

Autotuning is an established technique for adjusting performance-critical parameters of applicati... more Autotuning is an established technique for adjusting performance-critical parameters of applications to their specific run-time environment. In this paper, we investigate the potential of online autotuning for general purpose computation on GPUs. Our application-independent autotuner AtuneRT optimizes GPU-specific parameters such as block size and loop-unrolling degree. We also discuss the peculiarities of autotuning on GPUs. We demonstrate tuning potential using CUDA and by instrumenting the parallel algorithms library Thrust. We evaluate our online autotuning approach with various GPUs and sample applications.

Log In