GPU computing and its applications
in High Energy Physics
Lecturer:
Felice
Pantaleo
|
A
few questions |
-
Can CPU and GPU run
in
parallel?
-
GPU computing vs
CPU-only code: what
perf. gain?
-
Are GPUs ready for
real-time
applications?
All the answers at iCSC
|
|
The use of accelerators, in particular
of Graphic Processing Units (GPUs), in High Performance
Scientific Computing is growing very fast since few years. GPUs
have brought desktop and laptop computers to the Terascale (i.e.
bringing computational power beyond a Teraflop), clusters to the
Petascale and, in the foreseeable future, supercomputers to the
Exascale. In the field of high energy physics, several groups
are pursuing the use of GPUs for data analysis ( such as Maximum
Likelihood fit inside the RooFit) , for Monte Carlo
simulations of particle interactions inside the Geant4 framework
as well as in the reconstruction of complex events.
In this series of lectures, the lecturer will introduce GPU
programming using CUDA through examples and will show how GPUs
can be employed for taking decisions in a trigger system, both
as coprocessors in high level software trigger or "embedded" in
real-time, fixed-latency hardware trigger.
Targeted
audience :
This series of three lectures targets any computer scientists or physicists
interested in better understanding the virtualization and cloud
concepts.
|
A few questions addressed
in the lecture |
|
|
Monday
25 February |
|
10:15 11:10 |
Lecture
1 |
Introduction
to parallel computing on GPUs |
Felice
Pantaleo
|
Description
All computing systems, from mobile
to supercomputers, are becoming heterogeneous parallel
computers using both multi-core CPUs and many-thread GPUs
for higher power efficiency and computation throughput.
While the computing community is racing to build tools and
libraries to ease the use of these heterogeneous parallel
computing systems, effective and confident use of these
systems will always require knowledge about the low-level
programming interfaces in these systems. This lecture is
designed to introduce through examples, based on the CUDA
programming language, the three abstractions that make the
foundations of GPU programming:
- Thread hierarchy
- Synchronization - Memory hierarchy/Shared Memory
The aim of this lecture is to give the audience a solid
foundation on which to start building their own first GPU
application.
|
Audience and benefits
This lecture targets physicists and engineers who are
interested in improving the performance of their software by
using off-the-shelf graphic car.
After this lecture, the attendees are expected to have a
good understanding of the principles that govern parallel
programming in CUDA and will be able to write their first
GPU-accelerated application. |
Pre-requisite
Listeners don't need to have advanced knowledge about
parallel computing or GPU programming
|
A few questions addressed
in the lecture |
|
|
Monday
25 February |
|
11:30 12:25 |
Lecture
2 |
Use of GPUs for triggering in HEP experiments |
Felice
Pantaleo
|
Description
This lecture describes a pilot
project for the use of GPUs in a real-time triggering
application in the early trigger stages at the NA62
experiment at CERN, and the results of the first field tests
together with a prototype data acquisition (DAQ) system.
This pilot project within NA62 aims at integrating GPUs
into the central L0 trigger processor, and also to use them
as fast online processors for computing trigger primitives.
The online use of GPUs would allow the computation of more
complex trigger primitives already at this first trigger
level.
|
Audience and benefits
This lecture targets physicists and engineers who are
involved in the design of future triggering systems.
After this lecture, the attendees are expected to have a
good understanding of the reason why GPUs are considered a
key technology for the development of a "software-based"
triggering system.
|
Pre-requisite
knowledge and dependencies
Participants having not attended
lecture 1 may have difficulties to fully follow this
lecture, if they are not somewhat familiar with GPU
programming principles and abstractions.
|
|