72943 - Digital Systems M

Academic Year 2024/2025

  • Moduli: Stefano Mattoccia (Modulo 1) Fabio Tosi (Modulo 2)
  • Teaching Mode: Traditional lectures (Modulo 1) Traditional lectures (Modulo 2)
  • Campus: Bologna
  • Corso: Second cycle degree programme (LM) in Computer Engineering (cod. 5826)

Learning outcomes

The corse provides an introduction to modern software methodologies for the design of embedded systems. Application contexts and projects are mostly concerned with image processing and deep-learning networks applied to computer vision problems.

Course contents

Architectures  and programming models for high-performance computing with a focus on computer vision and artifical intelligence.

1: Introduction to high-performance computing

  • Parallel computing principles

  • Architectures for high-performance computing: CPU multi-core, GPU, sistemi embedded

2: SIMD and Multi-threading

  • Introduction to SIMD

  • Multi-threading principles

3: GPU and CUDA C Programming

  • CUDA Programming Model

  • GPU Architectures and CUDA Execution Model

  • GPU Memory Hierarchy and Organization

  • CUDA Ecosystem: Libraries and Applications

4: Dealing with real numbers: encoding and computations 

  • Floating point

  • Fixed point

5: Emerging technologies

  • FPGA (Field Programmable Gate Array)

Readings/Bibliography

Slides and source code available on the corse website.

For further details:

Cheng, J., Grossman, M., McKercher, T. (2014). Professional CUDA C Programming. Wrox Pr Inc. (1st edition)

Kirk, D. B., Hwu, W. W. (2013). Programming Massively Parallel Processors. Morgan Kaufmann (3rd edition)

Timothy G. Mattson, Yun (Helen) He, Alice E. Koniges, The OpenMP Common Core: Making OpenMP Simple Again, MIT Press, 2019

Jean-Michel Muller , Nicolas Brunie , Florent de Dinechin , Claude-Pierre Jeannerod , Mioara Joldes , Vincent Lefèvre , Guillaume Melquiond , Nathalie Revol , Serge Torre, Handbook of Floating-Point Arithmetic, Springer Birkhäuser 2018

Jean-Michel Muller, Elementary Functions: Algorithms and Implementation, Springer Birkhäuser 2016

Teaching methods

Each ntroduced topic will be followed by hand-on senssions with software frameworks.


Assessment methods

The assessment method consists in questions concerning topics presented in the course and in the evaluation of a project developed by studends (max 2 for each team).


Teaching tools

Software development frameworks.

Office hours

See the website of Stefano Mattoccia

See the website of Fabio Tosi

SDGs

Quality education Industry, innovation and infrastructure

This teaching activity contributes to the achievement of the Sustainable Development Goals of the UN 2030 Agenda.