Thematic CERN School of Computing 2022
from
Sunday 1 May 2022 (16:00)
to
Saturday 7 May 2022 (09:00)
Sunday 1 May 2022
16:00
Registration
Registration
16:00 - 18:00
19:30
Dinner (self-organized)
Dinner (self-organized)
19:30 - 20:30
Monday 2 May 2022
08:00
Breakfast
Breakfast
08:00 - 08:30
08:45
Opening Session
-
Sebastian Lopienski
(
CERN
)
Enrica Maria Porcari
(
CERN
)
Opening Session
Sebastian Lopienski
(
CERN
)
Enrica Maria Porcari
(
CERN
)
08:45 - 09:30
09:30
Self-presentation: 1 minute per person
Self-presentation: 1 minute per person
09:30 - 10:00
10:00
Coffee break
Coffee break
10:00 - 10:15
10:15
Preparing for the HL-LHC computational challenge
-
Danilo Piparo
(
CERN
)
Preparing for the HL-LHC computational challenge
(Introduction lecture)
Danilo Piparo
(
CERN
)
10:15 - 11:15
In this talk we will introduce some basic concepts related to HEP data processing and analysis workflows, seeing them in action in the context of LHC experiments. We’ll also talk about the evolution of the LHC accelerator and experiments. We’ll characterise at a high level what are the consequences of those upgrades for the HEP data processing software, in particular in the context of an evolving hardware and computing infrastructure.
11:15
Introduction to efficient computing
-
Andrzej Nowak
Introduction to efficient computing
(Track 1: Technologies and Platforms)
Andrzej Nowak
11:15 - 12:15
Technologies and Platforms - lecture 1 - The evolution of computing hardware and what it means in practice - The seven dimensions of performance - Controlling and benchmarking your computer and software - Software that scales with the hardware - Advanced performance tuning in hardware
12:20
Lunch
Lunch
12:20 - 13:00
13:00
Study time and/or daily sports
Study time and/or daily sports
13:00 - 14:00
14:00
Self-presentation: 1 minute per person
Self-presentation: 1 minute per person
14:00 - 14:20
14:20
Hardware evolution and heterogeneity
-
Andrzej Nowak
Hardware evolution and heterogeneity
(Track 1: Technologies and Platforms)
Andrzej Nowak
14:20 - 15:20
Technologies and Platforms - lecture 2 - Accelerators, co-processors, heterogeneity - Memory architectures, hardware caching and NUMA - Compute devices: CPU, GPU, FPGA, ASIC etc. - The role of compilers
15:20
Coffee break
Coffee break
15:20 - 15:45
15:45
Technologies and Platforms - exercise
-
Andrzej Nowak
Technologies and Platforms - exercise
(Track 1: Technologies and Platforms)
Andrzej Nowak
15:45 - 17:45
17:45
Data-oriented design
-
Andrzej Nowak
Data-oriented design
(Track 1: Technologies and Platforms)
Andrzej Nowak
17:45 - 18:45
Technologies and Platforms - lecture 3 - Hardware vectorization in detail – theory vs. practice - Software design for vectorization and smooth data flow - How can compilers and other tools help?
19:30
Opening dinner
Opening dinner
19:30 - 20:30
Tuesday 3 May 2022
08:00
Breakfast
Breakfast
08:00 - 08:30
08:45
Writing parallel software
-
Sebastien Ponce
(
CERN
)
Writing parallel software
(Track 2: Parallel and Optimised Scientific Software)
Sebastien Ponce
(
CERN
)
08:45 - 09:45
Parallel and Optimised Scientific Software - lecture 1 - Amdahl's and Gustafson's laws - Asynchronous execution - Finding concurrency, task vs. data parallelism - Using threading in C++ and Python, comparison with multi-process - Resource protection and thread safety - Locks, thread local storage, atomic operations
09:45
Announcements
Announcements
09:45 - 10:00
10:00
Coffee break
Coffee break
10:00 - 10:15
10:15
Modern programming languages for HEP
-
Sebastien Ponce
(
CERN
)
Modern programming languages for HEP
(Track 2: Parallel and Optimised Scientific Software)
Sebastien Ponce
(
CERN
)
10:15 - 11:15
Parallel and Optimised Scientific Software - lecture 2 - Why Python and C++ ? - Recent evolutions: C++ 11/14/17 - Modern features of C++ related to performance - Templating versus inheritance, pros and cons of virtual inheritance - Python 3, and switching from Python 2
11:15
Technologies and Platforms - exercise
Technologies and Platforms - exercise
(Track 1: Technologies and Platforms)
11:15 - 12:15
12:20
Lunch
Lunch
12:20 - 13:00
13:00
Study time and/or daily sports
Study time and/or daily sports
13:00 - 14:00
14:00
Technologies and Platforms - exercise debriefing
-
Andrzej Nowak
Technologies and Platforms - exercise debriefing
(Track 1: Technologies and Platforms)
Andrzej Nowak
14:00 - 14:20
14:20
Optimizing existing large codebase
-
Sebastien Ponce
(
CERN
)
Optimizing existing large codebase
(Track 2: Parallel and Optimised Scientific Software)
Sebastien Ponce
(
CERN
)
14:20 - 15:20
Parallel and Optimised Scientific Software - lecture 3 - Measuring performance, tools and key indicators - Improving memory handling - The nightmare of thread safety - Code modernization and low level optimizations - Data structures for efficient computation in modern C++
15:20
Coffee break
Coffee break
15:20 - 15:45
15:45
Optimizing existing large codebase - exercise
-
Sebastien Ponce
(
CERN
)
Optimizing existing large codebase - exercise
(Track 2: Parallel and Optimised Scientific Software)
Sebastien Ponce
(
CERN
)
15:45 - 18:45
Optimisation of an existing, production grade large codebase
19:30
Dinner (self-organized)
Dinner (self-organized)
19:30 - 20:30
Wednesday 4 May 2022
08:00
Breakfast
Breakfast
08:00 - 08:30
08:45
Scientific computing on heterogeneous architectures
-
Dorothea Vom Bruch
(
CPPM/CNRS
)
Scientific computing on heterogeneous architectures
(Track 3: Programming for Heterogeneous Architectures)
Dorothea Vom Bruch
(
CPPM/CNRS
)
08:45 - 09:45
Programming for Heterogeneous Architectures - lecture 1 - Introduction to heterogeneous architectures and the performance challenge - From general to specialized: Hardware accelerators and applications - Type of workloads ideal for different accelerators - Trade-offs between multi-core and many-core architectures - Implications of heterogeneous hardware on the design and architecture of scientific software - Embarrassingly parallel scientific applications in HPC and CERN
09:45
Announcements
Announcements
09:45 - 10:00
10:00
Coffee break
Coffee break
10:00 - 10:15
10:15
Student lightning talks
Student lightning talks
10:15 - 11:15
11:15
Practical vectorization
-
Sebastien Ponce
(
CERN
)
Practical vectorization
(Track 2: Parallel and Optimised Scientific Software)
Sebastien Ponce
(
CERN
)
11:15 - 12:15
Parallel and Optimised Scientific Software - lecture 4 - Measuring vectorization level - What to expect from vectorization - Preparing code for vectorization - Vectorizing techniques in C++: intrinsics, libraries, autovectorization
12:20
Lunch
Lunch
12:20 - 13:00
13:00
School photo
School photo
13:00 - 13:05
15:00
Outdoor excursion
Outdoor excursion
15:00 - 18:45
19:30
Excursion dinner
Excursion dinner
19:30 - 20:30
Thursday 5 May 2022
08:00
Breakfast
Breakfast
08:00 - 08:30
08:45
Programming for GPUs
-
Dorothea Vom Bruch
(
CPPM/CNRS
)
Programming for GPUs
(Track 3: Programming for Heterogeneous Architectures)
Dorothea Vom Bruch
(
CPPM/CNRS
)
08:45 - 09:45
Programming for Heterogeneous Architectures - lecture 2 - From SIMD to SPMD, a programming model transition - Thread and memory organization - Basic building blocks of a GPU program - Control flow, synchronization, atomics
09:45
Announcements
Announcements
09:45 - 10:00
10:00
Coffee break
Coffee break
10:00 - 10:15
10:15
Performant programming for GPUs
-
Daniel Campora
(
University of Maastricht
)
Performant programming for GPUs
(Track 3: Programming for Heterogeneous Architectures)
Daniel Campora
(
University of Maastricht
)
10:15 - 11:15
Programming for Heterogeneous Architectures - lecture 3 - Data locality, coalesced memory accesses, tiled data processing - GPU streams, pipelined memory transfers - Under the hood: branchless, warps, masked execution - Debugging and profiling a GPU application
11:15
Practical vectorization - exercise
-
Sebastien Ponce
(
CERN
)
Practical vectorization - exercise
(Track 2: Parallel and Optimised Scientific Software)
Sebastien Ponce
(
CERN
)
11:15 - 12:15
12:20
Lunch
Lunch
12:20 - 13:00
13:00
Study time and/or daily sports
Study time and/or daily sports
13:00 - 14:00
14:00
Optimisation + vectorization - exercise debriefing
-
Sebastien Ponce
(
CERN
)
Optimisation + vectorization - exercise debriefing
(Track 2: Parallel and Optimised Scientific Software)
Sebastien Ponce
(
CERN
)
14:00 - 14:40
14:40
Design patterns and best practices
-
Daniel Campora
(
University of Maastricht
)
Design patterns and best practices
(Track 3: Programming for Heterogeneous Architectures)
Daniel Campora
(
University of Maastricht
)
14:40 - 15:40
Programming for Heterogeneous Architectures - lecture 4 - Good practices: single precision, floating point rounding, avoid register spilling, prefer single source - Other standards: SYCL, HIP, OpenCL - Middleware libraries and cross-architecture compatibility - Reusable parallel design patterns with real-life applications
15:40
Coffee break
Coffee break
15:40 - 16:10
16:10
Programming for heterogeneous architectures - exercise
-
Daniel Campora
(
University of Maastricht
)
Dorothea Vom Bruch
(
CPPM/CNRS
)
Programming for heterogeneous architectures - exercise
(Track 3: Programming for Heterogeneous Architectures)
Daniel Campora
(
University of Maastricht
)
Dorothea Vom Bruch
(
CPPM/CNRS
)
16:10 - 18:45
19:00
Barbecue dinner
Barbecue dinner
19:00 - 20:00
Friday 6 May 2022
08:00
Breakfast
Breakfast
08:00 - 08:30
08:45
Programming for heterogeneous architectures - exercise
Programming for heterogeneous architectures - exercise
(Track 3: Programming for Heterogeneous Architectures)
08:45 - 10:00
10:00
Coffee break
Coffee break
10:00 - 10:15
10:15
Programming for heterogeneous architectures - exercise
Programming for heterogeneous architectures - exercise
(Track 3: Programming for Heterogeneous Architectures)
10:15 - 11:30
11:30
Announcements
Announcements
11:30 - 11:45
11:45
Programming for heterogeneous architectures - exercise debriefing
-
Daniel Hugo Campora Perez
(
University of Maastricht
)
Dorothea Vom Bruch
(
CPPM/CNRS
)
Programming for heterogeneous architectures - exercise debriefing
(Track 3: Programming for Heterogeneous Architectures)
Daniel Hugo Campora Perez
(
University of Maastricht
)
Dorothea Vom Bruch
(
CPPM/CNRS
)
11:45 - 12:15
12:20
Lunch
Lunch
12:20 - 13:00
13:00
Study time and/or daily sports
Study time and/or daily sports
13:00 - 14:20
14:20
Summary and future technologies overview
-
Andrzej Nowak
Summary and future technologies overview
(Track 1: Technologies and Platforms)
Andrzej Nowak
14:20 - 15:20
Technologies and Platforms - lecture 4 - Teaching program summary and wrap-up - Next-generation memory technologies and interconnect - Future computing evolution
15:20
Coffee break
Coffee break
15:20 - 15:45
15:45
Exam
Exam
15:45 - 16:30
16:30
Free time
Free time
16:30 - 18:00
18:00
Closing Session
-
Sebastian Lopienski
(
CERN
)
Closing Session
Sebastian Lopienski
(
CERN
)
18:00 - 19:15
19:30
Closing dinner
Closing dinner
19:30 - 20:30
Saturday 7 May 2022
08:00
Breakfast
Breakfast
08:00 - 08:30
08:30
Departure - bus leaves at 8:30
Departure - bus leaves at 8:30
08:30 - 09:00