Description
Python is a modern, object-oriented programming language, which has become popular in several areas of software development. This course introduces the basic concepts of the Python programming language and how it can be used effectively in high-performance computing. Fast array interface (numpy), message-passing interface (mpi4py), and several other useful Python packages such as scipy and matplotlib are introduced. C extension, i.e how to integrate code written in C directly as a part of a Python program, are also shown. Examples include prototyping and solving numerical problems with Python, steering simulations with Python scripts and analyzing results with the help of Python. The course consists of lectures and hands-on exercises.
Preliminary program
Day 1
- Introduction to Python
- Data types and expressions
- Control structures
- Functions and modules
- File I/O
- Text processing
Day 2
- Object oriented programming with Python
- NumPy - fast array interface to Python
Day 3
- Simple visualization with Python
- Additional tools for scientific computing
- Speeding up Python with compiled code
- mpi4py - message-passing interface for Python
Learning outcome
After the course the participants should be able to write scripts and small programs with Python and able to utilize some of the key Python packages for scientific computing (numpy, mpi4py, scipy, matplotlib).
Pre-requisites
Participants are expected to have some experience in computer programming and to be familiar with the basic concepts (e.g. variables, statements, control structures, subroutines), but previous knowledge of Python is not required. Previous experience in high-performance computing (batch systems, MPI, etc.) may be useful.
Lecturers: Sebastian von Alfthan (CSC), Jussi Enkovaara (CSC), Martti Louhivuori (CSC)
Language: English
Price: Free of charge