72935 - Operations Research M
Learning outcomes
Mathematical models, linear programming, simplex algorithm, duality. Integer linear programming, cutting planes, branch-and-bound. Complexity. Dynamic programming. Discrete simulation.
Course contents
Course contents
Prerequisites:
It is required that the student understands spoken Italian in order to follow the lectures.
MODULE 1 (Mathematical Optimization): Silvano Martello
-
The scientific method: systems, models, methodologies
-
Mathematical Programming
2.1 Optimization problems
2.2 Convex sets and functions
2.3 Convex programming
-
Linear programming
3.1 General, canonical and standard forms
3.2 Bases e basic solutions
3.3 Convex polytopes
-
Simplex algorithm
4.1 Moving among basic solutions
4.2 Tableau and pivoting
4.3 Optimality criterion
4.4 Simplex algorithm
4.5 Two-phase method
4.6 Geometrical aspects
-
Duality
5.1 Dual of a linear programming problem
5.2 Duality properties
5.3 Farkas' lemma
5.4 Complementary slackness
5.5 Dual simplex algorithm
5.6 Sensitivity analysis
-
Integer linear programming
6.1 Unimodularity
6.2 Cutting-plane algorithms and Gomory cuts
6.3 Branch-and-bound algorithm
6.4 Exploration strategies
6.5 0-1 knapsack problem
6.6 Branch-and-cut algorithms
6.7 Software and freeware
-
Complexity theory
7.1 Recognition version
7.2 P and NP classes
7.3 NP-complete problems
7.4 Dynamic programming
7.5 Strong NP-completeness
MODULE 2 (Discrete Simulation): Andrea Lodi
Introduction to discrete simulation
Static and dynamic description of a system
Temporary and permanent entities
Events and event notices.
Exercises on modeling realistic systems.
72937 - Computer Architecture M
Learning outcomes
Focus is on quantitative aspects of computer architecture.
Expected outcome is understanding of:
instruction level parallelism and latency tolerance
memory hierarchy
Uniform Memory Access (UMA) architectures
protection and task management
architecture impact on power and performance at processor and system level
Within the course the student will practice abstraction as the most effective method to handle the complexity of modern computer architectures. The final test verifies the ability to apply methods and concepts offered by the course.
Course contents
Processor Architecture:
Instruction set architecture for multitasking protected systems (Intel IA32 architecture)
Instruction level parallelism; dependencies; hazards; hazards avoidance
superscalar architectures; superpipelining and underpipelining; non blocking architectures; out of order execution (Tomasulo approach); speculative execution;
Introduction to simultaneous multithreading, logical processors, multicore architectures and virtualisation
Memory Hierarchy
Goals, reference model and performance parameters
memory hierarchy in the Intel IA32 architecture: segmentation, virtual memory, main memory and caches
address mapping, write policies, replacement policies; implementation techniques and performance analysis
the MESI protocol for memory coherence in shared memory multiprocessor architecture (UMA architectures)
System Architecture
Interleaved memory access in multibyte data bus systems
Uniform Memory Access (UMA) architectures, and introduction to NUMA multicore based architectures
Bus hierarchy and bus protocols
Multimaster systems with DMA based I/O: hardware/software power/performance perspective
72940 - Computational Models And Languages M
Learning outcomes
At the end of this course unit, conceived according to a multi-paradigm and multi-language constructive approach, the student has a deep knowledge on the fundamental concepts of programming languages and related computational models, knows the foundations of computability, knows and is able to apply the basic interpreter and compiler techniques, and possesses the basic concepts of functional programming and is able to apply such concepts in typical practical situations.
More precisely, the student will know the main formal methods for language definition in terms of syntax and semantics, for both programming languages and specification languages, and will be able to apply the main techniques for language evaluation and recognition for interpreters and compilers, including the use of the most common tools. Students will also be able to define reasonably simple languages understanding their properties, implementing the corresponding interpreters, and evaluating the pros and cons of different choices/computational paradigms in application design.
Course contents
The course aims to provide a rational view over the fundamental concepts of programming languages, relating them to the different computational models and to the problem of language translation and recognition: solid foundations are coupled to a strong experimental approach.
Contents:
Computability and Turing machine (5hrs)
Formal description of programming languages: grammars and Chomsky classification. Relationship between grammars and language interpreters/translators: lexical analysis, top-down and bottom-up techniques for the syntactical analysis of regular languages and context-free languages. Overview on methods for the formal description of the semantic aspects of a language. (18hrs)
Structure and organisation of interpreters/compilers, and their run-time support: examples in Java. Parser generator tools. (14hrs)
Introduction to Model-Driven approaches: the Xtext case. (3 hrs)
Iterative vs. recursive computational models, tail recursion optimisation, basic concepts of functional programming, closures, models for function evaluation, intro to the basics of Lambda calculus (9hrs)
Javascript as an example of (dynamic) functional language with a prototype-based object model (6hrs)
Scala and Kotlin as notable examples of blended programming languages on the Java platform. (9hrs)
72943 - Digital Systems M
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)
72945 - Real-Time Systems M
Learning outcomes
The course aims to provide a rational view of the main issues involved in the design of real-time systems, emphasizing peculiar principles, implementation strategies, supporting environments and performance evaluation methods.
Course contents
An introduction to real-time systems: peculiar features and typical application domains. Hard vs. soft real-time tasks. Temporal parameters and reference models for periodic, sporadic and aperiodic tasks. Real-time scheduling approaches: the clock-driven approach and the priority-driven approach. Algorithms for scheduling hard real-time periodic/sporadic tasks: RM, DM, EDF and LSTF. Server-based strategies for optimizing the response time of soft real-time aperiodic tasks: polling server, deferrable server, priority exchange server, sporadic server, constant utilization server, total bandwidth server. Shared resources access protocols: priority inheritance protocol, priority-ceiling protocol, immediate priority-ceiling protocol, stack resource policy. Pre-run-time schedulability analysis of systems that schedule tasks using static or dynamic priorities: processor-utilization analysis, response-time analysis, processor-demand analysis. Exemplification of theoretical and methodological issues with reference to design patterns typical of the industrial automation application domain.
72947 - Operating Systems M
Learning outcomes
Knowledges of main design aspects concerning the organization of concurrent systems. Models for sincronization and communication between processes/threads. Methods for analysis and synthesis of concurrent systems.
Course contents
1.System protection and security
models, policies and mechanisms
multilevel security
Reference Monitor and trusted systems
2.Virtualization
hardware virtualization: goals and solutions
virtual machine monitor implementation
Case study analysis: xen hypervisor
Virtualization and cloud computing
3.Concurrent programming
preliminaries
non sequential processes.
forms of interaction between concurrent processes
architectures and languages for concurrent programming
4.Shared memory model
mutual exclusion
semaphores
monitors
conditions
Use of concurrent languages in the shared memory model. The pthread library for concurrent programming.
5.Message passing model
preliminaries
channels and communication primitives
communication primitives
guarded commands
Rendez-vous and RPC
Use of concurrent languages in the message passing model: go, ada.
6.Shared memory kernel
Implementation of thread management/synchronization in a mono-processor kernel
Implementation of thread management/synchronization in a multi-processor kernel: SMP, loosely-coupled kernels.
-
Distributed Systems
distributed programming: centralized and decentralized algorithms.Scalability, fault tolerance.
algorithms for the synchronization of distributed processes: logical clocks, distributed mutual exclusion, election algorithms.
-
Parallel Programming
Parallel architectures, HPC systems.
Architetture per il calcolo parallelo. Sistemi HPC.
Parallel programming models: shared memory and distributed memory.
Parallel software development: MPI and OpenMP libraries.
Outlines on CUDA programming.
72938 - Foundations Of Artificial Intelligence T
Learning outcomes
Introduction to main principles and methods in Artificial
Intelligence. Artificial Intelligence based methodologies and
techniques for solving problems with particular emphasis on
knowledge-based systems and computational logic techniques. Desing
and implementation of some practical systems based on procedural
and declarative programming languages.
Course contents
The course introduces the student to the principles and methods
used to solve Artificial Intelligence methods, with a particular
attention to knowledge-based systems and computational logic
approaches. In particular, the Prolog programming language is
introduced as a tool for implementing Artificial Intelligence
systems. Moreover, seminars on specific Artificial Intelligence
topics are planned. This course is preparatory for the course of
Intelligent Systems.
Prerequisites: attending the course requires a medium
knowledge of a high level programming language, in order to
successfully understand case studies and applications presented
during the lessons. Regarding the course contents, no prerequisites
are required: the student will be gradually introduced to the
fundamental notions of the Artificial Intelligence, and no
assumption about previous knowledge is made.
Contents:
Introduction to Artificial Intelligence: brief history of AI,
main application fields, introduction to knowledge-based systems
and architectural organization.
Problem solving in AI: representation through the notion of
state, forward e backward reasoning, solving as a search and search
strategies (informed and non). Games, constraint satisfaction
problems, and planning problems.
Knowledge Representation: First Order
Predicate Logic, Production Rules Systems, Knowledge-based systems,
Some hints about formal ontologies.
Languages for Artficial Intelligence. Prolog: from logic to
logic programming, Prolog programs as solvers, desing and
development of simple Prolog programs, few notes about
meta-predicates and meta-interpreters.
84531 - Infrastructures For Cloud Computing and Big Data M
Learning outcomes
The class tends to enhance the capacity of orientating in the process of defining the strategies for a distributed system and applying them in different related applications.
The students face the principles and the main problems of distributed large systems and are exposed to some standard and widely solutions, by following the class and via individual work. At the end, students are expected to be able to know the properties of most diffused middleware and the evolutions one can expect from that technology, by mastering the properties for designing a real application: most well spread strategies are presented and discussed.
Course contents
The course covers several topics central in modern global data and processing infrastructures, such as Data Centers, MultiCloud Systems, Federation of resources, etc. typically supporting Industry 5.0 and Smart city applications, via the following basic concepts:
Advanced models for large distributed & cloud systems, from C/S to message exchange. Particular importance is given to the distinction and the implications of the two models,
Replication, group and many-to-many communication, and systems for QoS
Middleware for development and management of large distributed & cloud systems
Cloud internal support and architectures: new semantics and trend derived from the Internet evolutions
Infrastructures for global data storage and processing
Specific modern systems for big data processing and scalable global supports
All above issues are basic topics on which students must be aware of and very competent of, obtained by deep reflections and personal considerations.
The class explores the following topics:
Advanced models for large distributed & cloud systems
Class Starting: general information and presentation of the Class (use cases)
Goals, Basics, and Models: classifications, C/S vs. Message exchange, service and cloud models, parallelization models
Middleware & Cloud Models: definitions, categories, basic organization, and patterns for large distributed and cloud systems, Cloud internals design.
Replication, group and many-to-many communication, and systems for QoS
Different consistency degrees and impact on service properties (BASE and CAP)
Replication: models, strategies and protocols
Communication and groups: models, protocols and algorithms
Systems and protocols for QoS
Multicast and MOM middleware
Middleware for large distributed & cloud systems
CORBA: middleware and operating environment
MOM: examples of very thin environments
OpenStack: an example of a widely-diffused cloud IaaS
Novel infrastructures for global data storage and processing
Global data storage: solutions for non-traditional NoSQL data memorization (Cassandra and MongoDB)
Global data processing: batching and streaming based big data processing (Map-Reduce, Spark, and Storm and S4)
Main properties for effective design projects
72939 - Software Systems Engineering M
Learning outcomes
Detailed knowledge about languages, models and technologies for the analysis, the development, the documentation, the deployment and the maintenance of (distributed) software systems.
Course contents
At the end of the course, the student:
is able to set-up cooperative software production processes, based on agile (SCRUM) development that exploit also executable models exprressed using custom meta-models;
is able to design and develop software systems with related testing plans, in an incremental and evolutive way, by starting from the problem and from the application domain rather than from the implementation technology, also by using executable models of requirement and problem analysis;
is able to critically evaluate the continuos evolution of software technologies, both as regars the computational aspects and the software development process, by operationally acquiring knowledge on languages, methodologies and tools such as Kotlin, Gradle, SCRUM, SpringBoot, DevOps, Docker, etc.
is able to understand the role of the different styles of software architectures (layers, client-server, pipeline, microkernel, service-based, event-driven, space-based, microservices) and how to select the most appropriate architectural style for each different sub-system;
is able to face the analysis, the design and development of distributed, heterogeneous proactive-reactive applications (together with related development platforms and run-time supports) with particular reference to computational models based on message-passing and event-driven paradigms;
is able to realize message-based interactions among distributed software components by using high-level logical models and implementations based on different protocols (TCP, UDP, HTTP, CoAP, MQTT);
is able to understand how it is possible to design and build software development environments able to automatic code generation (Sofware Factories in ecosystems like Eclipse and IntelliJ) based on Model Driven Software Development (MDSD) and on Domain Specific Languages (DSL), by considering also AI Generated Code technologies;
is able to develop application able to combine high-level aspects (with particular reference to AI) with low-level aspects related to Internet of Things (IOT) devices, in the context of both virtual and real environments, built by using low-cost computers like RaspberryPi and Arduino;
is able to apply the concepts, the devices and the tools developed in the course for the design and development of a final application that exploits one or more IOT devices - in particular Differental Drive Robots (DDR) with sensors - that can operate in relatively autonomous way in different virtual or real enviroments, without modifying the software that does express the business logic of the problem.
72942 - Information Security M
Learning outcomes
Knowledge and engineering skills related to the design, development and deployment of algorithms and protocols for securing systems and networks.
Course contents
The aim of the course is to provide an in-depth study of the models, systems and mechanisms for securing processing systems with both a theoretical and a practical focus.
Suggested background: to gain more from the course it is important to have clear the concepts and tools provided by the computer networks, operating systems and computer security laboratory courses.
The course contents are divided into three macro-areas:
-
Modern cryptography applied
Insights and pitfalls in using PRNG, stream ciphers and block ciphers, cryptographically secure hash functions, asymmetric ciphers
Examples of attacks based on the incorrect use of ciphers and correct methods of use
Examples of cryptographic applications in some scenarios (wireless networks, cloud, IoT, ..)
Symmetric and asymmetric cryptographic key management models and systems (Key distribution center, PKI, PGP)
-
Authentication Models and Systems
Recalls on authentication systems and principles of designing secure authentication protocols
Single Sign-on authentication models with related examples of protocols / systems (Kerberos, …)
Federated authentication models with relative examples of protocols / systems (Oauth, OpenID, SAML, ..)
-
Blockchain technologies
Principles of operation
Hints of operation of the Bitcoin and Ethereum platforms
84530 - Database and Big Data Technologies M
Learning outcomes
Knowledge of building principles of DataBase Management Systems. Ability to design physical databases. Technologies for the management of big data.
Course contents
A prior knowledge and understanding of models and tools for organizing, managing and designing relational databases is required to attend with profit this course. This is usually obtainable by passing the exam of "Information Systems T" of the Computer Engineering bachelor degree.
Architecture of a DBMS
Main modules and their roles.
The physical Data Base
Memory management: devices, pages and files. Representing attributes and tuples. Reading and writing disk pages: the buffer manager. File types. Cost evaluation of some basic file operations.
Mono-dimensional indices
Index types. Tree indices: B-tree and B+-tree. Hash indices: static hash, dynamic hash (linear hashing, extendible hashing).
Multidimensional (spatial) data and indices
Spatial queries. Point indices (k-D and k-D-B-tree), indices for spatial objects (R-tree), GiST.
Implementing relational operations
Logical and physical operators: sort (external Z-way sort-merge), selection (sequential scann, single index, multiple indices), projection (sort-based, hash-based, index-based), join (nested loops, block nested loops, merge scan, hash join), set operators (union and difference), aggregation operators.
Query processing
Steps of the evaluation process. Semantic checks and catalogs. Rewriting SQL queries. Statistical profiles: average values and histograms. Estimating costs and result size. Access plans: evaluation using materialization and pipeline. The optimization process: enumerating access plans and domination rules. Determining the optimal access plan using dynamic programming.
Transaction management
Concurrency control: problems, lock and Strict 2PL protocol. Fault tolerance: log file, WAL protocol, buffer and commit management, checkpoint and DB dump.
Physical design of DataBases
Query workload, index selection. Performance tuning (indices, schema and queries).
Ranking of results
Motivations and limits of existing solutions for Top-k queries. SQL extensions for ranking results.
Mono- e multi-dimensional Top-k queries: attributes space, attributes weighing, distance functions, limits of B+-tree query processing.
R-tree-based algorithms: k nearest neighbor and distance browsing. Top-k join queries: sorted and random access, scoring functions, relationships with distance functions. B0, FA, TA, CA, and NRA algorithms.
Skyline queries
Concept of domination, relationship with scoring functions, index-based algorithms (BBS) and non-index algorithms (NL, BNL, SFS, SaLSa).
Big Data & NoSQL DBMS
Hadoop and MapReduce. Non-relational data models. The CAP theorem.
72957 - Design Activity joined to Computer Architecture M
Learning outcomes
Apply the knowledge acquired in the Computer Architecture M course to independently carry out an in-depth activity on a topic agreed with the lecturer in charge of the course.
Course contents
Projects on sustainable and low-carbon Computing Architectures.
RISC-V based computing architecture projects for edge/HPC/AI and low-level software layers (Linux, Device Drivers, Compilers).
Projects on performance modelling and benchmarking of computer architectures for AI and High-Performance Computing.
72975 - Software Systems Engineering Project Work M
Learning outcomes
In this module we apply the abilities achieved in the course - INGEGNERIA DEI SISTEMI SOFTWARE LM for the devolpment of some specific argument or project
Course contents
The primary goal of the activities is the integration of various technologies for the development and maintenance of distributed software systems, with particular focus on microservices-based applications in Cloud or IoT (Internet of Things) environments.
The purpose of the activities to be agreed upon is to enable the student to acquire one or more of the following skills:
Designing and developing custom metamodels and Domain-Specific Languages in the agreed application areas, using tools such as XText and/or MPS.
Managing the deployment and maintenance of microservices in Docker and Kubernetes environments.
Building ad using a DDRrobot or other pyhisical devices with low-cost sensors connected to RaspberyPi e/o Arduino and creating simple modles of the world, by starting form the available sensor data
Addressing and evaluating the contribution of Artificial Intelligence-based technologies for automating production processes and organizing software systems.
72980 - Project Work For Computational Models And Languages M
Learning outcomes
The aim of this activity is to apply the knowledge, metholodologies and tools learned in the main module to a practical project, either proposed by the student and validated by the teacher, or proposed by the teacher ad accepted by the student.
Course contents
The project can deal with any aspect in the Languages and Computational Models area, including the development of multi-paradigm applications or the contribution to research activity in the area. The activity must state explicitly the initial requirements, provide an in-depth analysys of the problem, discuss the project and the architecture of the proposed solution (including the evaluation of possible alternatives and the motivation(s) for choosing the specific one), up to the implementation choices, testing methodologies and techniques. A final comprehensive demo is expected and adequately evaluated.
72998 - Project Work For Information Security M
Learning outcomes
Apply the knowledge acquired in the Information Security M course to independently carry out an in-depth activity on a topic agreed with the lecturer in charge of the course.
Course contents
The contents of the project activity concern topics related to the field of IT security including security of mobile systems, IoT systems, blockchain and cloud / edge
73000 - Project Work For Digital Systems M
Learning outcomes
Project development with platform and software tools introduced in Digital System M
Course contents
Development and implementation of a project concerned with the corse topics
97261 - ATTIVITA' PROGETTUALE DI TECNOLOGIE E SISTEMI PER LA GESTIONE DI DATABASES E BIG DATA M
Learning outcomes
Autonomous exploitation of knowledge obtained in the course "Technology and systems for the management of Databases and Big Data M" in a technological application on a theme in agreement with the teacher.
Course contents
The project can deal with any practical application about the contents presented in the course "Technology and Systems for the Management of Databases and Big Data M. In general, the project can be also about any topic that can be referred to the field of data management. In general, the subject of the activity must have a practical flavor, i.e. the activity must focus on the practical application of principles, methods and techniques acquired within the course. The subject of the project activity must be discussed and agreed upon with the teacher before the starting of the activity itself.
72968 - Project Work For Foundations Of Artificial Intelligence M
Learning outcomes
The aim of this activity is to apply the knowledge and tools
acquired in the associated course of "Fondamenti di Intelligenza
Artificiale M"/"Fundamentals of Artificial Intelligence M" to a
practical project. The topic of the project is proposed by the
student and must be agreed with the teacher.
Course contents
The project can deal with any practical application about the
contents presented in the course "Fondamenti di Intelligenza
Artificiale M"/"Fundamentals of Artificial Intelligence M". In
general, the project can be also about any topic that can be
referred to the AI. In general, the subject of the activity must
have a practical flavour, i.e. the activity must focus on the
practical application of principles, methods and techniques
acquired within the course. The subject of the project activity
must be discussed and agreed upon with the teacher before the
starting of the activity itself.
72994 - Project Work For Operations Research
Learning outcomes
Application of the methodologies acquired in the course "Operations Research M" to the development of an autonomous activity on a theme agreed with the teacher.
Course contents
Implementation and experimental testing of algorithms for combinatorial optimization problems and for real-life applications.
73004 - Real Time Systems Design Activities M
Learning outcomes
Apply the knowledge acquired in the Real-Time Systems M course for the autonomous development of an in-depth activity on a topic agreed with the lecturer.
Course contents
Typical, although not exclusive, topics related to this activity are:
1) development and implementation of algorithms for scheduling hard/soft real-time tasks in a single- or multi-processor platform;
2) design and implementation of the infrastructure necessary to support the application of sophisticated access protocols to shared resources;
3) development of suitable tools for a priori verification of the schedulability of real-time applications comprising an arbitrary number of tasks and shared resources.
The experimental evaluation of the performance actually achievable with the developed prototype solution represents an essential aspect of the design activity.
29206 - Innovation and Project Management M
Learning outcomes
Students will learn the key concepts and techniques concerning the strategic management of innovation and the effective management of new product development processess. Students will also learn the key methods and techniques concerning project management
Course contents
PREREQUISITES:
The understandings of the main concepts and techniques of general management represents an important prerequisite for the course (in particular for what concerns the techniques for the financial valuation of investments). The course will be held in Italian, however foreign students (i.e. Erasmus students) could complete the project work and give the final exam in English
MAIN TOPICS:
Strategic management of innovation
Innovation development projects: characteristics and specificities
Forms and models of innovation
Technological discontinuities and sector dynamics: analysis of technological trends
The diffusion curves of innovations in the market
Intellectual property management in innovation projects
The development of the innovative project plan
The project plan
Industry analysis
Understanding of customer needs and Design Thinking
Approaches for data searches
Business model
The management of innovative projects
Project management: definitions and key principles
The life cycle of projects
The organizational structures for project management
The role of the project manager and the project team
The start of the project
The stakeholders of the project
Project planning: purpose management and WBS
Project planning: time management
Plan, assign and control project resources
Project risk management
Project monitoring and control
Agile Project Management and SCRUM
72971 - Innovation And Project Management Project Work M
Learning outcomes
Apply the knowledge acquired in the course of "Gestione dell’innovazione e dei progetti LM" to carry out autonomously an in-depth activity on a topic agreed with the teacher in charge of the course.
Course contents
1.- New product development projects: key concepts.
-
– Idea generation: internal and external sources
-
– Idea selection and evaluation: key techniques.
-
– New product development: key decisions and best practices.
-
– Testing, validation and commercial launch of new products
-
– Project management: Concepts and techniques.
Readings
78098 - Project Work On Network Optimization M
Learning outcomes
Application of the methodologies acquired in the course "Network Optimization M" to the development of an autonomous activity on a theme agreed with the teacher.
Course contents
Implementation and experimental testing of algorithms for network optimization problems.
73002 - Distributed System Design Activities M
Learning outcomes
To apply the skills, competences,and abilities deriving
from the course "Distributed Systems M" in order to autonomously
complete a design/implementation project activity related to a
specifictopic previously agreed with the teacher and then
investigated in-depth, from both the analysis and project-oriented
points of view.
During and after course it will be possible to decide the
project topic by contacting the teacher via email:
The results of the project (code + documentation) should be
provided to the teacher at least 5 days before the oral
examination.
Course contents
See the syllabus and topic coverage of the course
"Distributed Systems M", and also you can refer to the web pages of the previous academic year:
R
91948 - Project Work on Algorithms for Combinatorial Optimization Problems M
Learning outcomes
At the end of the project work, the students are able to apply the techniques acquired in the Algorithms for combinatorial optimization problems m course to implement effective algorithms for determining the optimal solution of a Combinatorial Optimization problem, and to analyze the corresponding computational performance.
Course contents
Design and implementation of an exact algorithm for a combinatorial optimization problem.
78917 - Project Work On Computer Vision and Image Processing M
Learning outcomes
At the end of the project work the students are able to apply the principles, methods and skills acquired in the Computer Vision and Image Processing course to design a software system aimed at addressing a specific use case dealing with a typical application scenario.
Course contents
See "73302- Computer Vision and Image Processing M"
97432 - PROJECT WORK ON CYBERSECURITY M
Learning outcomes
At the end of the course, the student is able to apply the knowledge acquired in the Cybersecurity M course to carry out independently an in-depth activity on a topic agreed with the lecturer.
Course contents
Project work on cybersecurity
94464 - PROJECT WORK ON DIAGNOSIS AND CONTROL M
Learning outcomes
At the end of the course, students :
are aware of state-of-the-art embedded systems used in several industry segments
know the main architectures, design methodologies and tools for embedded systems
are able to design hardware and software embedded systems in some representative case studies
Course contents
See Diagnosis and Control M
78919 - Project Work On Intelligent Systems M
Learning outcomes
At the end of the project work the students are able to apply the notions and skills acquired in the intelligent system course to design tools for solving real life applications.
Course contents
To be discussed with the professor
78913 - Project Work On Mobile Systems M
Learning outcomes
The project work is assigned on an individual base, with a negotiation with the student to identify a field at the state of the art within the large area of efficient (e.g., battery-efficient) mobile middleware and mobile applications. At the end of the project, the students have acquired a deep knowledge of the selected field and also effective capabilities of fully understanding the related global solution strategies. They have to apply the notions and skills acquired in the related lectures toward the design, prototyping, testing, and performance evaluation of a typically limited solution exemplifying the selected field and exploiting specific significant enabling technologies.
Course contents
See the syllabus and topic coverage of the course "Mobile Systems M" on the Web site at Virtuale @UNIBO, which will be populated during the lecturing period.
As a reference to the previous academic years, please consider also the material about the course structure and its possible project activities at the dedicated Web site for the 2022 edition:
78909 - Project Work On Multimedia Data Management M
Learning outcomes
The project activity aims to apply the notions and skills acquired during the course by developing a project. The project consists in the resolution of a problem concerning the management of multimedia data. The topic of the project can be proposed either by the teacher and the student.
Course contents
A scientific paper is usually considered as the base for the development of a new multimedia data management algorithm and/or infrastructure and/or service.
97433 - PROJECT WORK ON SCALABLE AND RELIABLE SERVICES M
Learning outcomes
At the end of the course, the student is able to apply the knowledge acquired in the Scalable and reliable services M course to carry out independently an in-depth activity on a topic agreed with the lecturer.
Course contents
Project work on cloud platforms
73302 - Computer Vision And Image Processing M
Learning outcomes
At the end of the course the students know the basic principles of computer vision and image processing algorithms. Thereby, they are able to understand and apply a variety of algorithms and operators aimed at either extracting relevant semantic information from digital images or improving image quality. They also understand the diverse challenges and design choices characterizing the main applications and acquire familiarity with software tools widely adopted in these scenarios.
Course contents
Introduction – Basic definitions related to image processing and computer vision. An overview across major application domains.
Image Formation and Acquisition – Geometry of image formation. Pinhole camera and perspective projection. Geometry of stereopsis. Using lenses. Field of view and depth of field. Projective coordinates and perspective projection matrix. Camera calibration: intrinsic and extrinsic parameters, lens distortion. Camera calibration based on planar targets and homography estimation (Zhang’s algorithm). Image rectification and stereo calibration. Basic notions on image sensing, sampling and quantization.
Image Filtering –Convolution and correlation. Mean and Gaussian filtering. Median Filtering. Bilateral filtering. Non-local means.
Image Segmentation and Blob Analysis – Gray-level Histogram. Binarization by global thresholding. Automatic threshold estimation. Spatially adaptive binarization. Colour-based segmentation. Binary Morphology Operators. Connected components labeling and blob analysis.
Local Features – Edge features and image gradient, Smooth derivatives (Sobel), Canny edge detector. Keypoint detectors and descriptors. Harris Corners. Scale invariant features. SIFT features. Efficient feature matching by kd-trees.
Instance Detection – Pattern matching by SSD, SAD, NCC and ZNCC. Shape-based mathing. Hough Transform for analystic shapes, Generalized Hough Transform. Object detection by local invariant features: Hough-based voting, least-squares similarity estimation.
Deep Learning for Computer Vision – Review of machine learning basics. Image Classification. Linear Classifiers and Fully Connected Neural Networks. Convolutional Neural Networks (CNN). Successful CNN architectures for image classification: AlexNet, VGG, Inception, ResNet. Transfer Learning. CNN for Object Detection: R-CNN, Feature Pyramid Network (FPN), Faster R-CNN, YOLO.
Readings/Bib
B5793 - CYBERSECURITY M
Learning outcomes
In a digital world, every activity is vulnerable to cyber attacks. At the end of the course the students are able to know and evaluate the most dangerous cyber threats to the society and to specific organizations and industries. Moreover, they are expected to be able to design and build secure systems by adopting modern defensive strategies and technologies that are discussed in class and experimented in lab.
Course contents
Cyber scenario
Cybersecurity goals: information security and service availability
Analysis of cyber threats
(Too many) vulnerability issues
A top-down approach to cybersecurity
Cyber risk management
Qualitative and quantitative evaluation
Strategies, policies and technologies
Assessment and validation
Legal constraints you need to know
Modern approaches: Machine Learning for cybersecurity, Zero Trust, Deception
Competences and jobs related to cybersecurity
35166 - Diagnosis And Control M
Learning outcomes
The course aims to give a systematic overview of the main available methodologies and of the technical norms that should be used to rationally overcome problems due to faults and malfunctioning affecting modern automatic systems. Fault diagnosis and fault tolerant control methodologies as well as the functional safety tools, norms and standards that regulate safety-critical systems design are topics of the course. At the end of the course students are able to design algorithms for fault detection, to design fault tolerant schemes, and have an overview of safety norms in industrial settings.
Course contents
Introduction:
-
Basic concepts;
-
Nomenclature.
Reliability and Availability:
-
Main definitions and concepts;
-
Basics of non-state space methods;
-
Basics of state space methods;
Safety:
-
Safety critical systems;
-
The IEC61508 standard;
-
Safety life cycle;
-
Fault Analysis techniques (HAZOP, FMEA, FTA)
-
Layer of Protection Analysis (LOPA);
-
SIL levels;
Redundancy for Fault Tolerance:
-
Static and Dynamic redundancy;
-
Architectures and performance;
-
Analytic redundancy.
Basics of some application domains:
-
Automatic machines;
-
Automotive.
Model Based Fault Diagnosis;
-
Basics on Fault Detection and Isolation (FDI) and links with
previous Sections.
-
Signal-based methods
(useful for Model-based ones as well; SHT: LRT, GLRT, SPRT
\Chi^2)
-
Parity equations (I/O and SS models, Deterministic/Stochastic)
-
Unknown Input Observers (UIO).
REMARK: Contents are under review
Rea
B2125 - MACHINE LEARNING AND DATA MINING M
Learning outcomes
At the end of the course the student knows and understands: - the motivation and the components of the Data Mining process; - the general concepts, technologies and methodologies of Data Warehouse, OLAP and Data Lake, as enabling factors of the Data Mining process; - the principles and the most relevant use cases of a wide set of Machine Learning algorithms which are used to extract relevant and actionable information from large amounts of data. At the end of the course the student is able to: - design the main steps of a Data Mining process - choose the Machine Learning methods best suited for the process - evaluate the quality of the result in order to support strategic and operational decisions.
Course contents
Part 1 - Data Mining
Introduction to the Data Mining Process
Architectures of systems with data mining components
Enterprise Data Warehouse
Data Lake
Case studies
Part 2 - Machine Learning
What is Machine Learning: some history and motivating examples
Theory of learning
Supervised vs unsupervised learning
Classification and regression
Model Selection, validation and presentation of results
Regression
Classification with linear discrimination, decision trees, Bayesian inference, Support Vector Machines, k-nearest neighbors, logistic regression, random forests, adaboost
Ensemble learning, boosting, bagging
Association rules and the Apriori algorithm
Clustering/segmentation with k-means, dbscan, Expectation Maximization, hierarchical methods, kernel methods
Analysis of case studies
CRISP-DM methodology
Pre-requisites
Fundamentals of programming
Fundamentals of calculus and linear algebra
Fundamentals of statistics and probabilities
Useful some general notion on Data Base Management Systems
73025 - Distributed Systems M
Learning outcomes
This graduate course aims at providing students with deep
advanced know-how about the methodologies, models, tools, and
mechanisms for the design, implementation, and runtime
evaluation/validation of enterprise applications deployed over
wide-scale distributed systems.
Previous course requirements: no one (but some contents from the
BSc courses of Computer Networks T and Web Technologies T will be
useful in some classes)
The learning outcomes of the course will include:
architecture modeling principles for
distributed enterprise applications:
requirements and design principles
Design, development, and implementation of distributed
applications based on Application Servers
(e.g., JBoss) and components (e.g.,
Enterprise Java Beans)
management of complex and articulated
container-based distributed systems, also
via lightweight models and
technologies (e.g., via Spring) and via
advanced persistency solutions (e.g., via the JPA and Hibernate
technologies)
design, development, and implementation
of distributed support systems for runtime monitoring
and control (properties such as scalability,
fault-tolerance, reliability, …; e.g., via the JMX
technology)
design, development, and implementation of highly scalable
distributed applications for high-end clusters, by specifically
considering the clustering support available in JBoss
(full configuration); some introductory notions of online
stream processing over big data
Course contents
The course will aim at deeply and thoroughly facing the
following topics:
-
methodologies and architectural models for the
design, implementation, and deployment of enterprise-level
distributed applications
-
component-based model evolution and component
integration into distributed architectures (typically 3-tier and
Web-integrated)
-
Application Servers (e.g., JBoss) and
middleware/frameworks for the runtime support of enterprise-level
distributed applications
-
differentiated naming services and their integration,
especially in enterprise-level deployment environments; examples
related to Java Naming and Directory Interface
(JNDI)
- from the
starting Enterprise Java Beans model (EJB1.0) to the current
widespread adoption of EJB 3.0 (motivations and evolution
guidelines)
o Persistency
o Interactions with data
o Session-oriented and
message-oriented components
o Interceptors
o Transactions
o Examples and exercises
(integrated with the JBoss application server)
-
messaging systems, e.g., Java Messaging System (JMS)
and rapid overview of Enterprise Service Bus and Java Business
Integration
- towards
effective and efficient enterprise models with lightweight
containers: the Spring example
o Spring and inversion of
control
o Spring and aspect-oriented
programming
o transaction management
-
persistency: evolution of persistency support models
in the development of enterprise applications. The examples of
JPA and Hibernate.
o transparent
persistency
o mapping and query
support
o metadata support
o performance
-
monitoring, control, and runtime management of
application servers and of distributed support frameworks in
general: the JMX example
o efficiency/effectiveness
and performance evaluation
o scalability
o fault-tolerance
o reliability
-
clustering and proprietary mechanisms/solutions for
clustering in JBoss
- directions of evolution towards asynchronous models and technologies for high scalability of enterprise servers
o Framework node.js and asynch event management
o Function as a Service (FaaS) and supporting frameworks
-
introductory notions about
high-performance online stream processing of big data
over clustered distributed systems
-
several case
studies (also provided via seminars via external companies,
added to the regular classes schedule)
The course will be associated with a set of practical lab
exercises, in which the students will be solicited to perform
guided exercise activities but in an autonomous way and in their
free time. These activities will be necessary to complete the study
of the course and to reach the desired skills; texts and solutions
of these ees will be made available at the official course Web
site.
The set of proposed lab exercises will include:
- 1 exercise about EJB in the WildFly application
server
-
1 exercise about messaging and Java Business Integration (JBI)
- 1 exercise about Spring
- 1 exercise about JMX
-
1 exercise about clustering in WildFly
Readings/Bibliography
All the teachning material (presentation slides, discussed
exercises with solutions, exercise proposals, project examples and
proposals) used during the classes will be avai
92990 - System Theory and Advanced Control M
Learning outcomes
The course will provide students with the fundamental tools for the analysis and control of multivariable dynamic systems and their structural properties. Basic tools of system theory will be introduced, such as possible representation of dynamic linear systems, structural properties (stability, observability, controllability), special normal forms, Kalman decomposition, and others. The course will also address some aspects of modern multivariable control schemes starting from optimal control (in the deterministic setting), adaptive and robust control, also presenting basic aspects of nonlinear control systems.
At the end of the course students master all the basic principles of system theory by studying in a systematic way properties of multivariable dynamic systems, and have a good knowledge of modern control tools for multivariable systems.
Course contents
-
Dynamic systems representation
-
Stability of linear systems
-
Reachability and controllability
-
Observability and reconstructability
-
Robust and Adaptive Control
92858 - Autonomous and Adaptive Systems M
Learning outcomes
At the end of this course student will have a solid
understanding of the state of the art and the key conceptual and practical aspects of the design, implementation and evaluation of intelligent machines and autonomous systems that learn by interacting with their environment.
The course also takes into consideration ethical, societal and philosophical aspects related to these technologies.
Course contents
Introduction to the design of adaptive and autonomous systems: intelligent agents and intelligent machines, automatic vs autonomous decision-making.
Introduction to Reinforcement Learning (RL): multi-armed bandits, Montecarlo methods, tabular methods, approximation function methods, and policy-based methods.
Applications of RL to games, classic control theory problems and robotics.
Introduction to algorithmic game theory for multi-agent learning systems: cooperation and coordination, social dilemmas, and Multi-Agent Reinforcement Learning.
Bio-inspired adaptive systems.
Intelligent machines that create: Generative Learning and AI creativity.
The "brave new world": agentic AI systems, design of agents based on foundational models, training using Reinforcement Learning from human-feedback (RLHF) and Direct Preference Optimization (DPO).
Open problems and the future: safety, value alignment, super-intelligence, controllability, and self-awareness.
Ethical and philosophical implications of AI and autonomous systems.
The course will include labs in which we will discuss implementation oriented aspects of the techniques and methodologies presented during the course.
92995 - DISTRIBUTED AUTONOMOUS SYSTEMS M
Learning outcomes
The course focuses on the design of control, optimization and learning methods and software tools for teams of autonomous systems. These systems consist of cooperative agents, as intelligent robots, autonomous vehicles and decision systems, that aim at performing complex tasks according to a federated and distributed computing paradigm. At the end of the course students will know how to design selected distributed control, optimization and learning algorithms to solve complex tasks involving teams of autonomous systems. To bridge the gap between theory and application, laboratory activities will allow students to design software tools for the studied algorithms and apply them to a number of application domains, including, e.g., planning,guidance and optimal control of cooperative autonomous vehicles and intelligent robots as well as machine learning and data analytics for decision systems.
Course contents
Introduction to Distributed Autonomous Systems
New paradigms and applications domains of autonomous systems: decision systems for data analytics (e.g., recommender systems and localization), sensor networks, cooperative robotics, cooperative mobility, smart energy systems. Introduction to distributed systems: centralized versus distributed computing, key properties and main goals for distributed systems.
Modeling of distributed systems
Models of distributed systems. Graph theory as a tool to model communication among network agents. Preliminaries on graph theory and examples. Distributed algorithms and distributed control laws. Introduction to Python programming with a focus on distributed computing and cooperative robotics via Robotic Operating System 2.
Basic distributed algorithms
Averaging protocols and linear consensus algorithms for multi-agent systems. Complex tasks (e.g., autonomous formation control, containment in leader-follower networks) based on linear consensus algorithms. Practical Python implementation of averaging and distributed control laws on case study examples from decision and control networks.
Introduction to distributed optimization
Optimization basics. Main problem set-ups and examples from estimation, machine learning, decision making, and control in cyber-physical networks.
Distributed decision making via consensus optimization
Consensus optimization algorithms based on averaging. Distributed gradient and gradient tracking methods. Practical Python implementation on case studies from federated and distributed machine learning, e.g., logistic regression, support vector machine, training of neural networks for classification.
Cooperative robotics via distributed optimization
Aggregative optimization. Constraint-coupled optimization algorithms based on decomposition schemes. Hierarchical robotic control architectures. Practical Python implementation on case study examples from formation control, collision avoidance, surveillance and task allocation in cooperative robotics. ROS 2 toolboxes for cooperative robotics.
78778 - Intelligent Systems M
Learning outcomes
At the end of the course the students are able to use the main AI techniques to develop tools for solving real life applications.
The students are able to understand and apply a wide range of techniques such as constraint programming, symbolic and sub-symbolic machine learning techniques, planning and swarm intelligence.
Course contents
Module 1:
PLANNING
Non-linear planning
Conditional planning
Graph-based planning
Planning for robotics
OPTIMIZATION
Constraint Programming and Global constraints
Search strategies
Applications
SWARM INTELLIGENCE
Ant colony
Bee Colony
Particle Swarm Optimization
Module 2:
MACHINE LEARNING
(symbolic and sub-symbolic approaches)
Decision trees - random forests
Neural networks
Bayesian approaches
Inductive logic programming
DEEP LEARNING
Re
78779 - Mobile Systems M
Learning outcomes
At the end of the course the students are able to effectively develop and dynamically manage the runtime provisioning of mobile services. This requires acquiring expertise and theoretical skills, as well as design/implementation abilities, related to models and solutions for mobile systems, for mobile services provided on top of them, and for support systems (middleware) needed for their effective runtime execution.
Course contents
The course intends to provide students with methodology, modeling, design, and implementation skills/expertise related to the development, deployment, and runtime evaluation of mobile systems, of mobile services, and of middleware supports for the effective management of those services at provisioning time.
Constraints on previous knowledge: nothing (but the contents of the courses "Computer Networks T", "Web Technologies T" and, only very partially, "Infrastructures for Cloud Computing and Big Data M" could be useful and valuable in a few parts of the course)
Course contents
-
Introduction to wireless communication systems: propagation models; fading models; rapid introductory overview of main types of wireless communication technologies
o IEEE 802.11: general features; from CSMA/CD over Ethernet to CSMA/CA; hidden and exposed terminal issues; MACA; configurations for infrastructured and ad-hoc modes;
o IEEE 802.16;
o IEEE 802.20;
o IEEE 802.11 for municipal meshes;
o Wi-Fi Direct.
o Cellular networks and handoff: GSM architecture; handoff with common MSC; handoff with differentiated MSCs; handoff classification
o Bluetooth: protocol stack; different possible topologies; discovery service; scatternet and multi-hop communications; software stack for Bluetooth Java programming
o Rapid overview of ZigBee: features, architecture, possible topologies
-
Mobile Ad Hoc Network (MANET): definition and application domains; routing in MANET, reactive/proactive/geographic/hybrid routing; Dynamic Source Routing (DSR); Ad-hoc On Demand Distance Vector (AODV); Greedy Perimeter Stateless Routing (GPSR); rapid overview on clustering solutions; LEACH, HEED, REDMAN
-
Mobility and handoff management: introduction and definitions
-
Location update and location search. Mobile IP: features, architecture, protocol, issues. Hierarchical Mobile IPv6 (HMIPv6). Split connection and I-TCP
-
Positioning systems: motivations; taxonomy (physical/symbolic, centralized/distributed, absolute/relative, accuracy, precision, cost, and limitations). Base techniques: lateration, time difference of arrival, angulation, scene analysis, proximity
o Positioning systems for ad-hoc networks
o Positioning systems with additional hardware. GPS: features, limitations, differential GPS. Active Badge, AHLoS
o Positioning systems with no additional hardware: based on Bluetooth, PlaceLab, RADAR, Ekahau, Sensor Fusion, Universal Location Framework, JSR-179
-
Development platforms for mobile systems (smart phone): overview, general concepts, definitions; concise comparison of J2ME, .NET CF, FlashLite, Android.
-
Android: introduction; architecture; OS kernel layer; power management and wakelock; native libraries; Dalvik VM; application framework; core applications; application model; activity lifecycle; intents and intent filters; threading model; examples and exercises. Description of the proposed exercise on Android
-
Rapid overview on iOS: architecture; multi-tasking model; simple programming examples; native/Web applications for iOS (introductory overview of HTML5); unlocking and jailbreaking
-
Mobile middleware: definitions, motivations, advantages. Relevance of determining principles and patterns. Internet principles: end-to-end and robustness principles. Web principles. SOA principles. Mobile computing principles. Cross-layering principle. Architectural patterns, general and specific for mobile computing.
-
Internet of Things (IoT) platforms: definitions and reference architectues, primary state-of-the-art platforms in the market, mobile and industrial IoT, research directions under current investigation, use cases of industrial applications
-
Discovery services: definition, taxonomy, auto-configuration, discovery, access to resources/services
o Jini, with description of proposed exercise
o Service location Protocol (SLP)
o UPnP: architecture, description files, bridging possibilities, examples and exercises. Description of proposed exercise on UPnP
-
Session management in converged 4G networks: Session Initiation Protocol (SIP), main features, scalability limitations. Session management in IP Multimedia Sub-system (IMS): architecture, functional entities, protocol examples, limitations in terms of monitoring, load-balancing, and scalability
-
Messaging support in mobile systems: motivations; principles and architecture; protocols for message exchange; locator
o JMS: features, architecture, messaging models, reliability and quality, examples
o CORBA Messaging (AMI and TII)
o Rapid overview on XMPP, Web Services, and RESTful Web Services
-
Event management and pub/sub model: possible topologies for event routers. Propagation of interests and subscriptions. Routing decisions
o Examples of distributed event systems: OMG DDS (partitions and quality levels); Java model for distributed events; General Event Notification Architecture (GENA); RSS/Atom; SIP Event Framework; Web Services Eventing & Notification
-
Data synchronization in mobile systems: pessimistic/optimistic approaches; versioning; detection; reconciliation
o SyncML: representation protocol; synchronization protocol; examples
-
Edge/Fog Computing: efficient integration of sensor-edge-cloud; distributed control and intelligence; offloading; proactive approaches and mobility prediction
o ETSI Mobile Edge Computing: emerging standard specifications; deployment approaches in 5G; orchestration and ETSI MANO
-
Selection of primary application domains (4 examples, from vehicular ad hoc applications to federated social spontaneous networks),also to suggest/solicit some possible project activities to associate with the course
-
Several case studies (also presented within company seminars, in addition to the regular lectures hours)
The course will be associated with a set of practical lab exercises, where the students will have the opportunity of completing their preparation through guided and simplified projects, to be solved autonomously. These lab activities will be necessary for the full achievement of the desired abilities and course objectives; texts and solutions of proposed exercises will be available at the Course Web site. The proposed set of exercises is described in the Teaching Methods section.
78096 - Multimedia Data Management M
Learning outcomes
The course aims to provide the knowledge and skills necessary for the effective and efficient management of multimedia (MM) data, with particular attention to the problems of MM data representation, MM data retrieval models, and interaction paradigms between the user and the MM system (both for purposes of data presentation and exploration). We first consider architectures of traditional ("standalone") MM systems; then, we concentrate on more complex MM services, by primarily focusing on search engines, social networks and recommendation systems.
Course contents
Basics on Multimedia Data Management
Multimedia data and content representations
MM data and applications
MM data coding
MM data content representation
How to find MM data of interest
Description models for complex MM objects
Similarity measures for MM data content
MM Data Base Management Systems
Efficient algorithms for MM data retrieval
MM query formulation paradigms
Sequential retrieval of MM data
Index-based retrieval of MM data
Automatic techniques for MM data semantic annotations
Browsing MM data collections
MM data presentation
User interfaces
Visualization paradigms
Dimensionality reduction techniques
Result accuracy, use cases and real applications
Quality of the results and relevance feedback techniques
Use cases and demos of some applications
Multimedia Data on the Web
Web search engines
Graph-based data: semantic Web and social networks
Web recommender systems
N.B. For students of the second cycle degree programmes (LM) in Artificial intelligence and Computer Science, the "Efficient algorithms for MM data retrieval" part of the program is not required.
B5796 - SCALABLE AND RELIABLE SERVICES M
Learning outcomes
Digital services have to meet various requirements in terms of performance, scalability and reliability. We analyze the whole lifecycle of high quality services, from design to deployment, testing and operation. In each phase, we aim to provide the students with the ability to gather and analyze data, to identify sources of outages and critical dependencies, and to avoid bottlenecks and single points of failure. Finally, we expect students to be prepared to evaluate and discuss alternatives and justify investment in support of business services.
Course contents
Introduction
Cloud services
Cloud provider architectures
High-quality services: performance, scalability, reliability (and security)
Lifecycle of high-quality services
Part 1: Architectures for scalable and reliable services
Sources of outages and critical dependencies
Bottlenecks and single points of failure
Design: maturity assessment, architectural principles for reliability and scalability, AKF scale cube model
Migration to cloud
Critical data management: Strategy, Governance, Management
Implementation alternatives on cloud platforms and multi-clouds
Part 2: Service deployment
Secure and robust software production
Secure and robust DevOps
Labs on cloud platforms
Part 3: Tests
Benchmarking
Performance testing
Stress testing
Part 4: Scalable and reliable organizations
Roles and responsibilities
Leaders and managers
Putting all together
Capacity planning
Understanding and managing complexity
Managing changes
Part 5: Issues, incident and crises
Performance monitoring
Warning signs in operation
Incidents management
Crisis management
91717 - Algorithms for Combinatorial Optimization Problems M
Learning outcomes
At the end of the course, the students are able to analyze the computational complexity and to define the Mixed Integer Linear Programming (MILP) models of the Combinatorial Optimization problems. The students are able to obtain tight relaxations of the MILP models, and to design exact enumerative algorithms (based on the branch-and-bound, branch-and-cut and branch-and-price approaches) for determining the optimal solution of the Combinatorial Optimization problems.
Course contents
The main goals of the Course are the definition of the mathematical models and the design of the most effective exact algorithms for the solution of NP-Hard Combinatorial Optimization problems. The experimental evaluation of the proposed models and algorithms will be also analyzed.
The program of the Course consists of the following topics:
-
Classification of the optimization problems.
-
Definition of the Mathematical Models, and analysis of the computational complexity of important combinatorial optimization problems.
-
Exact algorithms for the solution of NP_Hard problems. "Branch-and-Bound" algorithms: decision trees, relaxation techniques. Exact algorithms for the effective solution of the Knapsack Problems, the Asymmetric Travelling Salesman Problem, and the Set Covering Problem.
-
"Branch-and-Cut" algorithms: addition of valid constraints for the strengthening of the relaxed problems, separation procedures for the solution of models with a large number of constraints. Exact algorithms for the effective solution of the Asymmetric Travelling Salesman Problem.
-
"Branch-and-Price" algorithms: column generation procedures for the solution of models with a large number of decisional variables. Exact algorithms for the effective solution of the Bin Packing Problem and of the Vertex Coloring Problem.
-
Experimental evaluation of the computational performance of the proposed models and algorithms.
Basic knowledge of Computer Science and Operations Research courses are required.
73030 - Network Optimization M
Learning outcomes
The course introduces the student to graph and network problems and to the main algorithmic techniqes in this area. At the end of the course the student has the ability to model industrial problems that can be described through graphs and networks, and has competence on the main methods for their solution.
Course contents
Prerequisites:
It is required that the student has followed the course Operations Research M or an equivalent course on Operations Research.
Contents:
-
Fundamentals from Operations Research M
-
Graphs and networks theory
2.1 Introduction
2.2 Terminology
-
Basic problems on graphs
3.1 Shortest spanning tree
3.2 Shortest path problems
3.3 CPM method for project management0
-
Flows in networks
4.1 Maximum flow problems
4.2 Minimum cost flow problems
4.3 Mathematical models for graph and network problems
4.4 Unimodularity conditions
4.5 Matching and assignment problems
-
Optimal circuits
5.1 Hamiltonian circuits
5.2 Traveling salesman problem
5.3 Vehicle routing problems
-
Relaxations
6.1 Surrogate relaxation
6.2 Lagrangian relaxation and Lagrangian decomposition
6.3 Subgradient optimization
6.4 Reduction techniques
-
Approximation and heuristic algorithms
7.1 Greedy algorithms
7.2 Worst-case performance
7.3 Local search
7.4 Metaheuristic algorithms
75493 - Protocols And Architectures For Space Networks M
Learning outcomes
At the end of the course the students know the foundamentals of architecture and protocols for sapce networking. In particular, they gain a deep knowledge of DTN architecture and Bundle Protocol, as defined by RFC4838 and RFC 5050, when applied to space communications (GEO & LEO satellites, Interplanetary Internet). They are also able to set up testbeds and cary out experiments with the two most important DTN BP implementations, DTN2 and ION.
Course contents
Challenged networks
Definition of “challenged networks”. Challenges: long delays, significant losses, intermittent connectivity, network partitioning. Examples: Interplanetary Internet, satelllite networks (GEO and LEO), emergency networks, underwater networks, communications in areas not covered by ordinary TLC networks (extreme environemnts), tactical networks, etc.
The DTN architecture
Description of the DTN architecture (RFC 4838).
The Bundle Protocol
Description of the Bundle Protocol (RFC 5050 and 9171). Lab activities: use of Unibo-BP, DTN2 and ION (NASA JPL) bundle protocol implementations.
Application of the DTN architecture to the satellite networks
Characteristics of satellite networks based on Geostationary (GEO) and Low Earth Orbit (LEO) constallations. Lab activities: example of application of the DTN architecture to GEO and LEO systems.
Application of the DTN architecture to Interplanetary Internet
Characteristics of Interplanetary networks. The LTP protocol. Lab activities: examples of application of the DTN architecture to IPN systems.
Re
B8018 - DIGITAL HEALTH M
Learning outcomes
At the end of this interdisciplinary course unit, the student will acquire a deep
knowledge on today’s healthcare delivery systems (national and international ones) and their
associated payer models, as well as on key determinants of health/wellness and the opportunities that
digital health could bring based on these determinants. In addition, the student will be able to
understand the primary models in the field, as well as the most relevant digital health technologies
(from sensing and monitoring to medical devices, including software as a medical device, to mobile
health apps, to health data science and health AI). By delving into finer details, the student will learn
about how to re-think the digital health technology space into the directions of 'personal health
informatics' and 'personal health cybernetics'. In addition, she will learn an advanced digital health
technology/study in a specific disease/condition area (selected from a list provided by the instructor
and also by the student via negotiation with the instructor). Finally, the student will learn through
practice in designing and implementing an interdisciplinary group project, which will focus on either
a personal health system or a health data science project. Lists of projects will be provided by the instructor, but student groups are welcome to propose their own projects, pending the instruction’s approval.
Course contents
Healthcare and aging care are under economical and operational capacity pressures and are currently undergoing digital transformations, mainly utilizing several technologies, data science, AI, and digitalization to significantly cut unit and total cost of care, improve health outcomes, eradicate certain costly diseases, and in general, focus more on preventive and proactive measures (active and healthy living and aging through a continuum-of-care), than maintaining the status quo of a reactive disease management system (a point-of-care system).
This ambitious transformation is collectively referred to as “Digital Health” backed by an emerging and growing “Health Tech” industry. This emerging industry and the future health care delivery systems are needy of a skilled workforce equipped with the interdisciplinary knowledge and expertise to drive the implementation of such ambitious transformational changes. This interdisciplinary course on Digital Health entails aims to prepare such workforce of the future – the agents of change and the Digital Health leaders of the future.
Course Lectures:
-
Introduction to Digital Health (4 hours) Defining digital health from several perspectives. Providing different overviews addressing the different contexts of use and applicability of digital health including the broad array of digital health technologies. This module also provides an outline of all subsequent modules below.
-
Determinants of Health & Wellbeing (6 hours) What are the key determinants of a person’s health, and which determinants stand to benefit the most from digital health? And how do we measure health and wellbeing? If we use digital health as a prevention or intervention, we should have a way to measure its effect - the health outcomes.
-
Healthcare Delivery Systems (6 hours) This module will shed light on the different care systems and their payer models in several parts of the world, spanning national and private care systems showing their unit and total cost and their pros and cons. This knowledge provides an essential context to the understanding of the roles digital health may play in anticipated future health transformations.
-
The Future of Health (6 hours) So how can digital health shape a better future for health? What would such a future look like in terms of health systems, focus, cost, center of gravity, technology, and services? We go through a "science fiction prototyping" (a visioning exercise) of such a future, and then zoom in to research-evident clues of the future of health as provided by specialized reports such as Deloitte Health Transformation group among others.
-
Group Research Project (4 hours) Systematic literature review of a digital health research/development/technology area of focus. This module will discuss the assignment and will provide a good example of a review completed by students in a prior offering of this course.
-
Case Studies (6 hours) We examine the current effect and influence of digital health through two case studies, one related to COPD (a pulmonary disease) and another to Atrial Fibrillation (a Cardiovascular disease).
-
Clinical Efficiency and Healthcare Delivery Improvements (4 hours) Covering how digital health can help improve the processes of care delivery (e.g., a consultation visits in the doctor’s office, or performing a medical or diagnostic procedure in a hospital). Also, how to reduce unit and total cost and time taken in these processes. Clinical efficiency also addresses reductions of errors and personal bias in medical practice.
-
Digital Health Systems (6 hours) This module focuses on technologies including personal health systems where wearables, Health IoT (Internet of Things) and sensors are used to create a system for a variety of purposes such as monitoring, diagnosis, intervention, support and empowerment, compliance, among other goals. A particular kind of digital health system is Mobile Health in which mobile health apps are designed with similar goals in mind and the smartphone is used as a key component of such personal health systems. Mobile apps go beyond physical markers and vital signs that can be sensed by a pervasive system to include behavioral marker and markers related to lifestyles. Then we move to a more complex digital health systems which are health platforms such as smart homes and smart hospitals. We will focus on smart homes this term. The important difference in requirement and approach between devices, solutions, and platforms will be explained. Case studies will be provided.
-
Group Hands-on Projects (4 hours) Several projects will be defined and offered in three thrust areas: mobile Health, Health AI and Health IoT (Internet of Things). Students will also be allowed to propose their own projects, but such proposals will have to be approved by Professor Helal and may be changed in scope. All projects will be discussed in the lectures of this module.
-
The Informatics and Cybernetics of Digital Health Systems (6 hours) This module adds to Module 7 by focusing on the two key directions of traffic in digital health systems. In the Informatics direction, there are methods, models, and techniques to getting all sort of the data from the users and their devices or platforms. For instance, activity recognition and episode recognition are two important informatics in digital health systems. We will cover activity recognition only this term. The Cybernetics of digital health systems represents the other direction of traffic where intervention, user/patient engagement, and health maintenance can be delivered and implemented. Ensuring user engagement and convergence is not easy and numerous “behavioral change models” have been proposed and studied. We will cover some of these models to the extent of clearly understanding the problem but not fully covering all the necessary details.
-
Introduction to Health Data Science - Health AI (6 hours): Here you will recall basics of statistics particularly emphasizing regression analysis. Then you will learn the basics of Machine Learning techniques including unsupervised learning (pattern discovery and clustering), and supervised learning (detection, classification, and prediction). You will then briefly learn the basics of Deep Learning techniques suited for medical imaging data. Finally, you will get an overview of Reinforcement Learning in the context of digital therapeutics and intervention. Health datasets will be provided as well as tutorials (in addition to the lectures) to prepare you to analyze the data and develop models and train them to answer key classification or prediction questions. Python will be required but this is the easy part as you will only need to know/learn the very basics of Python in case you do not have prior Python experience. More involved would be the Data Science libraries such as numpy, pandas, seaborn and matplotlib that you will need to learn and understand. Jupyter Notebook will also be required. You will be required to use Google Colab to avoid any individual installation issues on your laptop of Python 3.1, its libraries, Jupyter Notebook, and also to speed up your work particularly training and cross validation. You will enjoy this intense module if you are eager to learn and are motivated to be knowledgeable about Health Analytics and Health AI.
-
The Ethics and Regulatory Requirements for Conducting Digital Health Systems based Clinical Studies (6 hours): We briefly learn about the ethical issues relevant to research or product/prototype development that involves the participation of humans for any reason. We will focus on the required regulatory pathways for developing medical devices or software as a medical device. You will specifically learn about the University of Bologna Ethics Review Committee (Comitato etico) process and regulatory policies including participants recruitment, consent, and ethics protocol design, privacy, and secure data management.
Readings/Bib
72953 - Principles Of Computer Graphics M
Learning outcomes
Knowledge of basic and advanced techniques for geometry processing and computer graphics, with particular reference to modeling and realistic rendering of 3D scenes on the computer.
Course contents
Introduction to two- and three-dimensional computer graphics. The graphics pipeline: modelling and rendering. Fundamentals of input and display devices, 3D scanning, 3D printing. Scan conversion of geometric primitives, two- and three-dimensional transformations and clipping, windowing techniques, three-dimensional viewing and perspective. Basic algorithms for CG clipping, scan-conversion, hidden surface removal, ray tracing. Illumination and color models, local and global shading models, and real-time rendering methods. Polygonal meshes, parametric curves and surfaces, splines and NURBS , subdivision curves and surfaces. Surface reconstructions from 3D data set. Virtual/Augmented Reality. Digital Animation techniques. OpenGL/GLSL, and 3-D modeling tools. Emphasis is on the development of practical skills in using software Blender, graphics libraries and tools. Programming using C/C++ and OpenGL/GLSL for GPU shader.
B8019 - PROGRAMMING THE INTERNET OF THINGS M
Learning outcomes
At the end of this course unit, the student will acquire a deep knowledge on the
fundamental concepts as well as the most relevant emerging technologies about Internet of Things
(IoT) architectures, IoT platforms, IoT interaction protocols, and IoT programming/application
models. In addition, the student will be able to apply IoT models, architectures, and techniques in
typical practical situations.
More precisely, the student will know how to decouple the process of smart space construction and
IoT deployment from smart space programmability and application development. In addition to the
fundamentals, the student will acquire valuable hands-on exper applications that utilize sensors,
actuators, complex devices, microservices, and humans in the loop, as well as a deep theoretical and
application-oriented understanding of the IoT technology.
Course contents
This course focuses on the software perspective and the architectural and programmability aspects of the Internet of Things. The course will not emphasize detailed IoT hardware or wireless communication technologies. It compliments other offered IoT courses by focusing on IoT programming and application development.
The course lectures will span the following five topics:
1) Introduction to Smart Spaces (6 hours)
-
Historical Perspective: from the Jetsons to the Internet of Things.
-
Constraints, Requirements and Smart Space Challenges.
2) IoT Things (12 hours)
-
Understanding the differences between Things, Internet of Things, and IoT applications.
-
Sensors, Actuators, and Complex Devices.
-
Identification (ID) Things: RFID, QR Codes, Beacons.
-
IoT Platforms: Raspberry Pi, Arduino, Mbed OS.
3) An Example of Smart Space (8 hours)
-
The Gator Tech Smart House: a real-world deployment of a smart space as an assistive environment for graceful aging.
4) IoT Architecture (20 hours)
-
Service-Oriented Device Architecture (SODA).
-
The Atlas SODA Architecture and Middleware (Atlas 1.0)
-
The Atlas IoT Thing Architecture (Atlas 2.0)
5) IoT Programming and Application Models (18 hours)
-
SODA Application Model
-
Safety Concerns and Mechanisms in SODA
-
The Atlas Device Description Language (IoT-DDL)
-
IoTranx: IoT Transactional Model.
Readings/Bibliography