Programmazione Funzionale e Parallela

Corso di Laurea in Ingegneria Informatica e Automatica - A.A. 2021-2022

Home | Avvisi | Diario lezioni | Esercitazioni | Materiale didattico | Esami | Valutazioni studenti

Informazioni generali

Le lezioni vengono tenute in modalità didattica sia in presenza che a distanza nel periodo compreso tra il 29 settembre e il 23 dicembre 2021 secondo il calendario delle lezioni del corso di laurea.
  • Always code as if the guy who ends up maintaining your code will be a violent psychopath who knows where you live.
  • -- Rick Osborne

Obiettivi

L’obiettivo principale del corso è quello di migliorare le proprie capacità di programmazione assimilando i princìpi di base della programmazione funzionale e imparando ad applicarli per scrivere codice elegante, modulare, riusabile, e più efficacemente parallelizzabile. I concetti verranno esposti usando principalmente il linguaggio Scala, ma verranno messi in prospettiva in modo da essere fruibili anche programmando in altri linguaggi. Nella seconda parte del corso viene affrontata la programmazione in vari modelli di calcolo per le moderne architetture multi-core: vettorizzazione SSE/AVX su piattaforme x86-64, multi-threading e programmazione GPU in OpenCL.

Prerequisiti: conoscenza dei princìpi della programmazione imperativa e orientata agli oggetti, in particolare usando i linguaggi Java, C e Python

[ A.A. 2015-2016 | A.A. 2016-2017 | A.A. 2017-2018 | A.A. 2018-2019 | A.A. 2019-2020 | A.A. 2020-2021 ]

Valid XHTML 1.0 Transitional     Valid CSS!