Ogni modulo equivale a 3 crediti ECTS. È possibile scegliere un totale di 10 moduli/30 ECTS nelle seguenti categorie:
- 12-15 crediti ECTS in moduli tecnico-scientifici (TSM)
 I moduli TSM trasmettono competenze tecniche specifiche del profilo e si integrano ai moduli di approfondimento decentralizzati.
- 9-12 crediti ECTS in basi teoriche ampliate (FTP)
 I moduli FTP trattano principalmente basi teoriche come la matematica, la fisica, la teoria dell’informazione, la chimica ecc. I moduli ampliano la competenza scientifica dello studente e contribuiscono a creare un importante sinergia tra i concetti astratti e l’applicazione fondamentale per l’innovazione
- 6-9 crediti ECTS in moduli di contesto (CM)
 I moduli CM trasmettono competenze supplementari in settori quali gestione delle tecnologie, economia aziendale, comunicazione, gestione dei progetti, diritto dei brevetti, diritto contrattuale ecc.
La descrizione del modulo (scarica il pdf) riporta le informazioni linguistiche per ogni modulo, suddivise nelle seguenti categorie:
- Insegnamento
- Documentazione
- Esame
This module introduces students with different categories of advanced algorithms and typical application areas. 
In the first part of the module, the students will have a sound understanding of data structures and algorithms for efficiently handling either very large, complex or dynamic data sets or combinations thereof. They will be able to evaluate suitable algorithms and to apply them to typical tasks such as efficiently indexing, searching, retrieving, inserting or updating data such as large volumes of hypertext or spatial data. 
The students will be familiar with dynamic algorithms used, for example, in artificial intelligence.
The second part of the module will present basic techniques for designing algorithms for hard combinatorial optimization problems. The combination of these basic components —problem modeling, problem decomposition, solution building, solution improvement, learning— lead to classical metaheuristics like genetic algorithms, ant colonies or tabu search. The students will be able to design new algorithms for hard combinatorial optimization problems and to apply them.
Requisiti
The student has working knowledge of:
- Geometry, linear algebra, algorithms (sorting, searching, hashing) and data structures (linear structures, trees)
- Basics of graph data structures and algorithms
- Algorithmic complexity, logic, probability theory.
These topics are generally contained in books introducing algorithms. For instance, chapters 1-12, 15-17, 22-26, 28-29, 34-35 of (Cormen 09) covers very well the prerequisites
Obiettivi di apprendimento
This module gives the student an overview of frequently used algorithms classes. Based on this strong foundation, students can design and implement the most suitable and efficient algorithms for use in their own applications. The student:
- is familiar with different categories of advanced algorithms and with typical application areas;
- has a sound understanding of data structures and algorithms for efficiently handling either very large, complex or dynamic data sets or combinations thereof;
- is able to evaluate suitable algorithms and to apply them to typical tasks such as efficiently indexing, searching, retrieving, inserting or updating data, including data types such as large volumes of hypertext or spatial data;
- is familiar with dynamic algorithms used in robotics, artificial intelligence.
Contenuti del modulo
Algorithms and data structures for selected practical problems. Weight 50%
- Reminder on linear structures, binary search tree, heap and algorithmic complexity
- Randomized algorithms (qsort, selection in linear time, kD tree, range tree, Delaunay triangulation)
- Deterministic algorithms(selection, kD tree)
- Sweep algorithms (closest pair of points, segment intersection)
- Greedy algorithms (Huffman code, Dijkstra, Fibonacci heap)
Design of heuristic algorithms. Weight 50%
- Reminder on complexity theory, combinatorial optimization problems, problem modelling
- Greedy heuristics
- Local search heuristics
- Decomposition methods
- Randomized heuristics
- Learning heuristics
- Classical metaheuristics: GRASP, ant colonies, tabu search, simulated annealing, noising methods, genetic algorithms
Metodologie di insegnamento e apprendimento
- Ex-cathedra teaching
- Presentation and discussion of case studies
- Problem-based learning
- Theory and programming exercises
Bibliografia
M. de Berg, G. Cheong, M. van Kreveld, M. Overmars. Computational Geometry : Algorithms and Applications, Springer, Third Edition 2008.
T. H. Cormen, C. E. Leiserson, R. L. Rivest, C. Stein. Introduction to Algorithms, third edition, MIT Press, 2009.
P. Siarry (ed.), Metaheuristics, ISBN 978-3-319-45403-0, Springer, 2016.
H. H. Hoos, Th. Stützle Stochastic Local Search: Foundations and Applications, Morgan Kaufmann / Elsevier, 2004.
Éric D. Taillard
Design of Heuristic Algorithms for Hard Optimization
(Series: Graduate Texts in Operations Research)
Springer, 2023
ISSN 2662-6012
ISSN 2662-6020 (electronic)
ISBN 978-3-031-13713-6
ISBN 978-3-031-13714-3 (eBook)
Scarica il descrittivo completo del modulo
Indietro