トップページへ

2025 (Current Year) Faculty Courses School of Computing Department of Mathematical and Computing Science Graduate major in Mathematical and Computing Science

Practical Parallel Computing

Academic unit or major
Graduate major in Mathematical and Computing Science
Instructor(s)
Toshio Endo
Class Format
Lecture (HyFlex)
Media-enhanced courses
-
Day of week/Period
(Classrooms)
3-4 Mon / 3-4 Thu
Class
-
Course Code
MCS.T418
Number of credits
200
Course offered
2025
Offered quarter
1Q
Syllabus updated
Mar 19, 2025
Language
English

Syllabus

Course overview and goals

This lecture series will cover high performance parallel computing, which is important technology to support evolution of science and technology. The demand for high performance computing, involving extremely large amount of computation and data, is increasing for molecular simulation, protein analysis, mathematical optimization problems, and so on.
The contents will include standard parallel programming tools, MPI and OpenMP, and also include a programming tool for GPU/accelerators. In addition to lecture, there will be programming training using the large-scale supercomputer TSUBAME at Science Tokyo.

Course description and aims

[Objective] Participants shall get used to usage of parallel programming tools such as MPI, OpenMP and GPU tools, through the lecture and training. Objectives also include learning of basic technologies for performance analysis, through training using the TSUBAME supercomputer.
[Theme] For efficient usage of modern computing systems including supercomputers, the knowledge of architecture, such as parallelism and hierarchy, is necessity. Theme includes programming with OpenMP and MPI, each of which has corresponding hierarchy, and programming on many-core accelerators (GPGPU).

Keywords

parallel computing, high performance computing, multi-core, MPI, OpenMP, GPGPU

Competencies

  • Specialist skills
  • Intercultural skills
  • Communication skills
  • Critical thinking skills
  • Practical and/or problem-solving skills

Class flow

Lecture about parallel and high performance computing, and training of programming using Tokyo Tech TSUBAME supercomputer will be given.

Course schedule/Objectives

Course schedule Objectives
Class 1 Introduction to supercomputers and parallel computing Nothing
Class 2 Overview and usage of TSUBAME supercomputer/ parallel programming models Nothing
Class 3 Shared memory parallel programming with OpenMP (1) Introduction Report for shared memory part
Class 4 Shared memory parallel programming with OpenMP (2) Data Parallelism and Attributes of variables Report for shared memory part
Class 5 Shared memory parallel programming with OpenMP (3) Task Parallelism Report for shared memory part
Class 6 Shared memory parallel programming with OpenMP (4) Mutual exclusion and bottlenecks Report for shared memory part
Class 7 Distributed memory parallel programming with MPI (1) Introduction Report for distributed memory part
Class 8 Distributed memory parallel programming with MPI (2) Non-blocking communicatoin Report for distributed memory part
Class 9 Distributed memory parallel programming with MPI (3) Optimization of MPI programs Report for distributed memory part
Class 10 Distributed memory parallel programming with MPI (4) Network topology Report for distributed memory part
Class 11 GPU programming (1) Introduction Report for GPU part
Class 12 GPU programming (2) GPU Programming with OpenACC Report for GPU part
Class 13 GPU programming (3) GPU Programming and Parallelism Report for GPU part
Class 14 GPU programming (4) Optimization of GPU programs Report for GPU part

Study advice (preparation and review)

To enhance effective learning, students are encouraged to spend approximately 100 minutes preparing for class and another 100 minutes reviewing class content afterwards (including assignments) for each class.
They should do so by referring to textbooks and other course material.

Textbook(s)

Nothing particular

Reference books, course materials, etc.

Nothing particular. Information on related references and web sites will be given.

Evaluation methods and criteria

Based on the report submission. Attendance to classes is also considered.

Related courses

  • CSC.T526 : High Performance Scientific Computing
  • MCS.T233 : Computer Systems

Prerequisites

Basic knowledge on C language, especially pointers
Basic knowledge on Linux commands