- Docente: Giuseppe Lisanti
- Credits: 6
- SSD: ING-INF/05
- Language: English
- Moduli: Giuseppe Lisanti (Modulo 1) Samuele Salti (Modulo 2)
- Teaching Mode: Traditional lectures (Modulo 1) Traditional lectures (Modulo 2)
- Campus: Bologna
- Corso: Second cycle degree programme (LM) in Artificial Intelligence (cod. 9063)
-
from Feb 17, 2025 to Apr 14, 2025
-
from Apr 28, 2025 to Jun 12, 2025
Learning outcomes
At the end of the course, the student masters the basic algorithms, tools and systems for the management, processing and analysis of digital images. The student is able to design and develop simple systems oriented to real-world computer vision applications such as those requiring segmentation and classification of objects in digital images.
Course contents
Introduction: basic definitions related to computer vision. An overview across major application domains.
Image formation and acquisition: geometry of image formation; lenses; field of view and depth of field; image sampling and quantization.
Spatial filtering: linear shift-invariant operators; mean and Gaussian filtering; median filtering; bilateral filtering.
Edge detection: image gradient; non-maxima suppression; Laplacian of Gaussian; Canny edge detector.
Local invariant features: detectors and descriptors; Harris Corners; scale-invariant features; SIFT features.
Instance detection: pattern matching; shape-based matching; Hough transform.
Camera calibration: Intrinsic and extrinsic camera parameters; projective coordinates and perspective projection matrix; Zhang's algorithm; image warping and homographies between cameras.
Image classification: the case for and implication of data-driven computer vision; datasets; linear classifier as template matching; cross-entropy loss; gradient descent and stochastic gradient descent.
Image representations: Bag of Visual Words; representation learning for images; convolutional layers; pooling; batch normalization.
Successful CNNs: LeNet5; AlexNet; ZFNet; VGG; Inception v1 and v3; ResNet.
Regularization and training recipes: bias/variance; learning rate schedulers; weight decay; label smoothing; dropout; data augmentations; FixRes; cutout; mix-up; cut-mix; pytorch case study.
The theory is complemented by lab sessions. Lab sessions cover selected topics such as spatial filtering, camera calibration, local invariant features, image classification and transfer learning.
Readings/Bibliography
All the slides from the lectures of the course will be made available on the Virtuale platform. There is no official textbook; further details on some of the topics of the course can be found in:
- Gonzalez, R. C., "Digital Image Processing", Pearson education, 2009.
- Hartley, R., & Zisserman, A., "Multiple View Geometry in Computer vision". Cambridge university press, 2003.
- http://d2l.ai/ - Aston Zhang and Zachary C. Lipton and Mu Li and Alexander J. Smola "Dive into Deep Learning", 2020
Further readings, such as scientific papers and online resources, might be recommended during the lectures of the course.
Teaching methods
Teaching methods include taught lessons and lab sessions. The datasets and code snippets for the lab sessions will be provided. The code used in the lab is based on Python, the OpenCV library and the PyTorch framework.
Assessment methods
1. a written exam in which the student will answer to questions on the theory presented in the whole course;
2. a practical part consisting of two assignments, one for each part of the course.
Teaching tools
The pdf of the slides used in the course will be made available on the website of the course before each lecture.
The python scripts and datasets required for the lab sessions will be made available on the website of the course.
Office hours
See the website of Giuseppe Lisanti
See the website of Samuele Salti