!function(f,b,e,v,n,t,s) {if(f.fbq)return;n=f.fbq=function(){n.callMethod? n.callMethod.apply(n,arguments):n.queue.push(arguments)}; if(!f._fbq)f._fbq=n;n.push=n;n.loaded=!0;n.version='2.0'; n.queue=[];t=b.createElement(e);t.async=!0; t.src=v;s=b.getElementsByTagName(e)[0]; s.parentNode.insertBefore(t,s)}(window, document,'script', 'https://connect.facebook.net/en_US/fbevents.js'); fbq('init', '2640916329456805'); fbq('track', 'PageView');
search

31/05/2023

11:00 - 17:00

English

The Luxembourg SuperComputing Competence Center is hosting an online introduction to OpenMP programming (for multicore shared memory) course for half a day. The first part will be dedicated to theory, and the second will focus on hands-on challenges on the MeluXina supercomputer.
For whom? 
Both current or prospective users of large hybrid CPU/GPU clusters and supercomputers, who might develop or parallelise their scientific computing applications using multicore CPUs, are encouraged to participate
What will you learn and how? 
Participants from this course will learn Multicore (shared memory) CPU programming using the OpenMP programming model, such as parallel region, environmental routines, and data sharing. Furthermore, understanding the multicore shared memory architecture and how parallel threads blocks are used to parallelise the computational task. Since we deal with multicores and parallel threads, proper parallel work sharing and the synchronisation of the parallel calls are to be studied in detail. Finally, participants will also learn to use the OpenMP programming model to accelerate linear algebra (routines) and iterative solvers on the Multicore CPU. Participants will learn theories first and implement the OpenMP programming model with mentors’ guidance later in the hands-on tutorial part.
Learning outcomes 
After this course, participants will be able to:
  • Understanding the shared memory architecture
    • Unified Memory Access (UMA) and Non-Unified Memory Access (NUMA)
    • Hybrid distributed shared memory architecture
  • Implement OpenMP programming model
    • Parallel region
    • Environment routines
    • Data sharing
  • Efficient handling of OpenMP constructs
    • Work sharing
    • Synchronisation constructs
    • Single Instruction Multiple Data (SIMD) directive
  • Apply the OpenMP programming knowledge to parallelise examples from science and engineering:
    • Iterative solvers from science and engineering
    •  Vector multiplication, vector addition, etc.
Prerequisites
Priority will be given to users with good experience with C/C++ and/or FORTRAN. No prior parallel programming experience is needed.
Computing Resources
Participants attending the event will be given access to the MeluXina supercomputer during the session. To learn more about MeluXina, please consult the Meluxina overview and the MeluXina – Getting Started Guide.

Register

Speakers

Ezhilmathi KRISHNASAMY

Ezhilmathi KRISHNASAMY

Postdoctoral Researcher - University of Luxembourg

Ralf HUSTADT

Ralf HUSTADT

Special Advisor Digitalisation,Data Economy and Gaia x - Luxinnovation

Dzmitry KLIAZOVICH

Dzmitry KLIAZOVICH

Project Management Office Lead, Business Development Executive - LuxProvide

Avoiding common errors in declaring other direct costs under H202030/05/2023

Read more

Humanitarian Innovation Accelerator Programme29/06/2023

Read more
Fermer