Python in High Performance Computing

بواسطة: FutureLearn

Overview

Speed up Python programs using optimisation and parallelisation techniques

The Python programming language is popular in scientific computing because of the benefits it offers for fast code development. The performance of pure Python programs is often suboptimal, but there are ways to make them faster and more efficient.

On this course, you’ll find out how to identify performance bottlenecks, perform numerical computations efficiently, and extend Python with compiled code. You’ll learn various ways to optimise and parallelise Python programs, particularly in the context of scientific and high performance computing.

The course is designed for Python programmers who want to speed up their codes. You should be familiar with the basics of the Python programming language.

The software needed is in the virtual machine that you will need to download and run to complete this course. You will also need a local machine with 15GB free disk space and 2GB RAM.

Optionally, you can receive instructions to install the Python environment utilised in the course (Python, Numpy, Cython, mpi4py).

Syllabus

  • Introduction and performance analysis
    • Welcome to the course
    • Performance challenges in Python
    • Performance analysis
    • Week 1 recap
  • Numerical computing
    • Using NumPy
    • Operating with NumPy arrays
    • NumPy tools
    • Deeper view into NumPy
    • Week 2 recap
  • Using compiled code and libraries
    • Using Cython
    • Interfacing with external libraries
    • Week 3 recap
  • Parallel programming
    • Introduction to parallel programming
    • Message passing with Python
    • Point-to-point communication
    • Collective communication
    • Week 4 recap
    • Course summary

Taught by

Jussi Enkovaara

Python in High Performance Computing
الذهاب الي الدورة

Python in High Performance Computing

بواسطة: FutureLearn

  • FutureLearn
  • مجانية
  • الإنجليزية
  • متاح شهادة
  • أيام محددة
  • intermediate
  • N/A