Vai al contenuto principale
Oggetto:
Oggetto:

Apprendimento Automatico

Oggetto:

Machine Learning

Oggetto:

Anno accademico 2024/2025

Codice attività didattica
INF0091
Docenti
Roberto Esposito (Titolare)
Rosa Meo (Titolare)
Corso di studio
[008515] Laurea magistrale in informatica
Anno
1° anno, 2° anno
Periodo
Primo semestre
Tipologia
Di base
Crediti/Valenza
9 CFU - Numero di ore - Number of hours: 56 (in aula) + 16 (in laboratorio)
SSD attività didattica
INF/01 - informatica
Erogazione
Tradizionale
Lingua
Italiano
Frequenza
Facoltativa
Tipologia esame
Orale
Tipologia unità didattica
corso
Prerequisiti

Conoscenze elementari di probabilità e statistica, algoritmi, sistemi informativi e basi di dati.
Insegnamenti propedeutici (forniscono le competenze attese in ingresso): Sistemi intelligenti (laurea triennale), Basi di dati (laurea triennale: corso di Basi dati e Sperimentazioni).
Basic knowledge of probability, statistics, linear algebra, algorithms, information systems and databases.
Preparatory courses (providing the expected entry skills): Intelligent systems (Bachelor level), Databases (Bachelor level). .

Oggetto:

Sommario insegnamento

Oggetto:

Avvisi

DSA o Disabilità: Sostegno e Accoglienza in UniTO e supporto in sede di Esame
Oggetto:

Obiettivi formativi

Gli obiettivi del corso introdurranno gli studenti al campo dell'Apprendimento Automatico, che unisce competenze di informatica (intelligenza artificiale, algoritmi, ottimizzazione, basi di dati) e statistica. L’acquisizione di competenze di Intelligenza Artificiale, di cui l’apprendimento automatico è una pietra angolare, fa parte degli Obiettivi formativi specifici del CdS in Informatica (LM18), in particolare tra quelli dell’indirizzo orientato ai sistemi per il trattamento dell’informazione.

Il corso insegna le differenze tra problemi e modelli e introduce gli studenti ad alcuni modelli popolari nell'Apprendimento Automatico. Il programma del corso consiste di una parte introduttiva (le differenze tra problemi e modelli) seguita dalla discussione di una serie di modelli. I docenti concorderanno con gli studenti quali degli argomenti che seguono inserire nel proprio piano di studi e seguiranno le lezioni relative a quegli argomenti. La classificazione (binaria e multi-classe), l'apprendimento di concetti tramite formule logiche, i modelli ad albero, cenni ai modelli a regole e alla ricerca di sottogruppi (subgroup discovery), i modelli lineari (dei minimi quadrati, la regressione), il percettrone, le Support Vector Machines, i metodi Kernel. Si discute la decomposizione bias-varianza e il problema dell'overfitting. Tratterà i modelli basati su distanza, come i k-nearest neighbors, il clustering basato sulle k-medie, il clustering gerarchico, e basato su densità. L'ultima parte del corso tratta delle misure di validazione dei modelli e della verifica di significatività statistica dei risultati. La parte di laboratorio del corso introdurrà gli studenti a una suite software open source (Scikit Learn in Python) che include gli algoritmi di apprendimento dei modelli visti durante il corso (e molto altro). Con Scikit Learn si svilupperanno sessioni di analisi dei dati usando dataset pubblicamente disponibili.

The objectives of the course will be introduce students to the field of Machine Learning, that merges competencies of computer science (artificial intelligence, algorithms, optimization, databases) and statistics. The acquisition of Artificial Intelligence skills, of which machine learning is a cornerstone, is part of the specific training objectives of the CdS in Informatica (LM18), in particular among those of the address oriented to systems for information processing.

The course will teach the differences between tasks and models and will introduce the students to some of the popular models in Machine Learning. The program of the course will consist in the introductory part followed by a selection of the topics taken from the following list that will be agreed with the teachers on a single-student basis, according to the student's interests. The classification (into two classes and the transformation of a binary classification model into a multiple class model), concept learning by means of logical formulas, tree models and their purposes, hints to rule models and subgroup discovery, linear models (least squares, regression), perceptron, Support Vector Machines, Kernel methods. It will discuss the concept of bias-variance decomposition and the problem of overfitting. It will present the models based on distance, such as k-nearest neighbors, k-means clustering, hierarchical clustering, and density based clustering. The last part of the course discusses the probabilistic models (Naive Bayes, logistic regression and Expectation Maximization clustering), the evaluation of the models and of the statistical significance tests on the results. The laboratory part of the course will introduce the students to a practical open software suite ([Scikit Learn http://scikit-learn.org/stable/] in Python) that includes the algorithms of learning of the models seen during the course (and much more). With Scikit Learn we will approach some sessions of data analysis using some public available datasets.

Oggetto:

Risultati dell'apprendimento attesi

  1. CAPACITÀ DI APPRENDIMENTO e CONOSCENZA E CAPACITÀ DI COMPRENSIONE
    dei principali modelli di apprendimento automatico.
  2. CONOSCENZA E CAPACITÀ DI COMPRENSIONE dei principali concetti di base di statistica per l'analisi dei dati, quali test di significatività statistica, test di indipendenza.
  3. CAPACITÀ DI APPRENDIMENTO delle modalità in cui avviene il processo di analisi dei dati.
  4. AUTONOMIA DI GIUDIZIO nella scelta delle tecniche da adottare in ciascuna fase del processo di analisi dei dati.
  5. CAPACITA' DI APPRENDIMENTO di un algoritmo di Apprendimento Automatico e di un modello da esso prodotto.
  6. CAPACITA' DI APPRENDIMENTO di utilizzo di un pacchetto software che implementa gli algoritmi di Apprendimento Automatico e produce modelli di Apprendimento Automatico.
  7. AUTONOMIA DI GIUDIZIO nella scelta della tecnica di analisi da adottare per un certo insieme di dati.
  8. CAPACITÀ DI APPLICARE CONOSCENZA E COMPRENSIONE nell'analisi di un algoritmo di Apprendimento Automatico e nell'uso di un pacchetto software specializzato allo scopo.
  9. CAPACITÀ DI APPLICARE CONOSCENZA E COMPRENSIONE  e ABILITÀ COMUNICATIVE nell'interpretazione e validazione dei risultati dell'analisi e nel comunicare il loro signficato.

  1. KNOWLEDGE AND UNDERSTANDING of the main machine learning models.

  2. KNOWLEDGE AND UNDERSTANDING of the basic statistical knowledge for data analysis, such as statistical significance tests, independence tests.
  3. APPLYING KNOWLEDGE AND UNDERSTANDING of the modalities in which the data analysis process takes place, and in the use of a software suite for the application of Machine Learning principles and algorithms.
  4. LEARNING SKILLS in the main Machine Learning models and on the models they produce.
  5. LEARNING SKILLS in the software suites implementing Machine Learning algorithms and producing Machine Learning models.
  6. MAKING JUDGEMENTS related to the choice of techniques to be adopted in each phase of the data analysis process.
  7. MAKING JUDGEMENTS related to the choice of analysis technique to be adopted for a certain set of data.
  8. APPLYING KNOWLEDGE AND UNDERSTANDING in the analysis of a machine learning algorithm.
  9. APPLYING KNOWLEDGE AND UNDERSTANDING and COMMUNICATION SKILLS in the  interpretation and validation of analysis results and in communicating their meaning.
Oggetto:

Programma

  1. Introduzione
  2. differenza tra problema e modello
  3. la classificazione binaria e la transformazione di una classificazione binaria ad una multi-classe
  4. l'apprendimento di concetti tramite formule logiche
  5. i modelli ad albero, l'apprendimento e i loro obiettivi
  6. cenni ai modelli a regole,
  7. cenni sulla ricerca di sottogruppi (subgroup discovery)
  8. i modelli lineari (dei minimi quadrati, la regressione), il percettrone,
  9. le Support Vector Machines e i metodi Kernel.
  10. decomposizione bias-varianza
  11. overfitting.
  12. modelli basati su distanza (k-nearest neighbors, clustering k-medie, clustering gerarchico, clustering basato su densità).
  13. Modelli probabilistici (naive Bayes, Expectation Maximization, regressione logistica) e principio di massimizzazione della vereosimiglianza.
  14. Validazione dei modelli e verifica di significatività statistica dei risultati.
  15. Sperimentazione con un sistema reale di analisi dei dati su vari data set: Scikit Learn Nota: L'ordine degli argomenti è indicativo.

  1. Introduction
  2. Differences between tasks and models
  3. Binary classification and transformation of a binary classification model into a multiple class model,
  4. Concept learning by means of logical formulas,
  5. Tree models and their purposes,
  6. Hints on rule models,
  7. Hints on subgroup discovery,
  8. Linear models (least squares, regression), perceptron,
  9. Support Vector Machines and Kernel methods.
  10. Bias-variance decomposition
  11. The problem of overfitting.
  12. Models based on distance, such as k-nearest neighbors
  13. K-means clustering
  14. Hierarchical clustering,
  15. Density based clustering.
  16. Probabilistic models (naive Bayes, Expectation Maximization, logistic regression) 
  17. Validation and verification of the results on data
  18. Experiments with a real system on data sets: Scikit Learn.

Note: the order of the topics is indicative.

Oggetto:

Modalità di insegnamento

Le lezioni in aula sono svolte principalmente con l'ausilio del calcolatore (proiezione di lucidi animati). Le esercitazioni in Laboratorio saranno svolte ad un calcolatore su cui è stato installato il software da sperimentare (Scikit Learn) e sul cui utilizzo lo studente verrà anche valutato in sede di esame. La didattica verrà erogata in presenza, ma verrà garantita la registrazione delle lezioni e i video saranno caricati sulla piattaforma Moodle di apprendimento a distanza. Saranno disponibili forum di discussione per la collaborazione e meeting per la consulenza.

The lectures in class are done mainly with the aid of a computer (with slides). The execizes in laboratory sessions will be done on a computer with a software (Scikit Learn) or on Colab (the same software is available on remote on cloud). The same exercizes will be part of the oral examination. Teaching is in presence but we guarantee video recordings on the Moodle platform of the course. On the same platform some discussions will take place on discussion forums and on online meetings.

Oggetto:

Modalità di verifica dell'apprendimento

Colloquio orale in cui si verifica l'apprendimento dei contenuti teorici del corso e la sperimentazione sui sistemi e gli algoritmi. GIi esami si svolgono in presenza. Qui sono elencate a titolo d'esempio alcune domande che gli anni scorsi si facevano durante il colloquio.

  • Descrivere le principali operazioni di trasformazione tra le features
  • Illustrare gli obiettivi dell'apprendimento dei modelli ad albero
  • Scrivere lo pseudo-codice di alcuni algoritmi di classificazione o clustering
  • Descrivere le misure e tecniche di validazione del processo di classificazione.
  • Discutere il significato e gli obiettivi dell'apprendimento di concetti.
  • Confrontare alcuni algoritmi per l'apprendimento dei concetti rispetto al loro ``bias''
  • Descrivere e confrontare alcuni degli approcci per fare clustering
  • Illustrare uno degli esercizi svolti in laboratorio con Scikit Learn

Oral interview in which the learning of the theoretical contents of the course and the experimentation on systems and algorithms is verified. The exams are held in presence. Here are listed by way of example some questions that were asked in previous years during the interview.

  • Describe the main transformation operations between features
  • Explain the goals of learning tree models
  • Write pseudo-code for some classification or clustering algorithms
  • Describe the measures and techniques for validating the classification process.
  • Discuss the meaning and goals of learning concepts.
  • Compare some algorithms for learning concepts against their ''bias''
  • Describe and compare some of the approaches to clustering
  • Illustrate one of the exercises carried out in the laboratory with Scikit Learn.
Oggetto:

Attività di supporto

Le esercitazioni con Scikit learn costituiscono un valido ausilio alla verifica della comprensione dei contetti teorici e alla loro messa in pratica.

The laboratory exercizes with Scikit learn constitute a valid tool to the verification of the understanding of the theorical concepts and of their practice.

Testi consigliati e bibliografia

Oggetto:

  • Peter Flach, Machine Learning - The Art and Science of Algorithms that Make Sense of Data, Cambridge University Press, 2012.

Libri di consultazione:

  • Machine Learning, Zhi-Hua Zhou, Springer, 2021.
  • Data Mining - Practical Machine Learning Tools and Techniques with Java Implementations, (2nd edition), Ian H. Witten, Eibe Frank, Morgan Kaufmann, 2006.
  • Machine Learning, Tom Mitchell, McGraw-Hill, 1997.

Additional books:

  • Machine Learning, Zhi-Hua Zhou, Springer, 2021.
  • Data Mining - Practical Machine Learning Tools and Techniques with Java Implementations, (2nd edition), Ian H. Witten, Eibe Frank, Morgan Kaufmann, 2006.
  • Machine Learning, Tom Mitchell, McGraw-Hill, 1997.

 



Oggetto:

Insegnamenti che mutuano questo insegnamento

Oggetto:

Altre informazioni

https://www.google.com/url?sa=t&rct=j&q=&esrc=s&source=web&cd=&cad=rja&uact=8&ved=2ahUKEwj4-siqtrn-AhUBQvEDHeXaBagQFnoECA0QAQ&url=https%3A%2F%2Fscikit-learn.org%2F&usg=AOvVaw3pidYsGhglQXGDh_4GMetL
Oggetto:
Ultimo aggiornamento: 31/05/2024 17:00
Location: https://magistrale.informatica.unito.it/robots.html
Non cliccare qui!