Scheda programma d'esame
Mobile APP and cloud.
MARCO COCOCCIONI
Academic year2023/24
CourseTELECOMMUNICATIONS ENGINEERING
Code1158I
Credits6
PeriodSemester 2
LanguageItalian

ModulesAreaTypeHoursTeacher(s)
MOBILE APP E CLOUD - ANING-INF/05,NNLEZIONI60
MARCO COCOCCIONI unimap
Obiettivi di apprendimento
Learning outcomes
Conoscenze

Lo studente acquisirà conoscenze in merito ai principi e alle tecniche di progettazione di un calcolatore. In particolare, imparerà a progettare, studiare e valutare l'architettura dell'insieme di istruzioni di un calcolatore e la sua implementazione e supporto a livello di logica digitale del processore e di gerarchia delle memorie. Inoltre verrà insegnato come creare un tipo di dato astratto (classe) sia in C++ che in Matlab. Infine verrà insegnato come creare una GUI (Graphical User Interface) in Matlab, sfruttando le classi.

Knowledge

Students will acquire knowledge about the principles and the techniques for desgining the architecture of modern computers. In detail, they will learn to design, investigate, and evaluate the istruction set architecure (ISA) of a computr, and its implementation and support based on the digital logic of the processor and of the memory hierarchy.

Modalità di verifica delle conoscenze

La verifica delle conoscenze acquisite sarà oggetto di valutazione mediante prova orale con discussione prevista all'inizio di ogni sessione d'esame.

Assessment criteria of knowledge

Academic progress with repect to the acquired knowldge will be monitored and verified via an oral exam with discussion, at the beginning of each exam session.

Capacità

Lo studente sarà in grado di comprendere la struttura ed i meccanismi base del funzionamento di un calcolatore digitale e delle sue componenti principali (es, processore e memorie). Sarà altresì in grado di valutare le prestazioni di un calcolatore e di scrivere/tradurre simplici programmi in linguaggio Assembler. Sarà inoltre in grado di creare una classe sia in C++ che in Matlab, e di creare una GUI (Graphical User Interface) in Matlab, sfruttando i meccanismi di programmazione orientata agli oggetti.

Skills

Students will be able to understand the strutrue and the mechanisms that regulate the operation and the performance of modern computers, as well as those of their core components (e.g., processor and memories). Furthemore, they will to able to evaluate and compare the performance of different computer architectures and to write/translate simple programs in Assembler.

Modalità di verifica delle capacità

La verifica delle capacità acquisite sarà oggetto di valutazione mediante prova orale con discussione prevista all'inizio di ogni sessione d'esame.

Assessment criteria of skills

Academic progress with repect to the acquired skills will be monitored and verified via an oral exam with discussion, at the beginning of each exam session.

Comportamenti

Lo studente svilupperà le sue capacità ingegneristiche e di progettazione, imparando a valutare e confrontare differenti soluzioni sulla base dei requisiti di progetto.

Behaviors

Students will improve their engineering skills and their capacity to design working and efficient systems. They will learn to evaluate, compare and chose different solutions, depending on the project requirements.

Modalità di verifica dei comportamenti

La verifica dei comportamenti sviluppati sarà oggetto di valutazione mediante prova orale con discussione prevista all'inizio di ogni sessione d'esame.

Assessment criteria of behaviors

Academic progress with repect to the acquired behaviors will be monitored and verified via an oral exam with discussion, at the beginning of each exam session.

Indicazioni metodologiche

Il corso si svolgerà mediante lezioni frontali effettuate con l'ausilio di slides, del testo di riferimento e di ulteriore materiale didattico prodotto e fornito dal docente. Gli studenti avranno accesso a risorse e funzionalità aggiuntive mediante un portale Web di ateneo, dal quale sarà possibile scaricare materiali didattici, gestire eventuali lezioni a distanza e le comunicazioni docente-studenti. Le interazioni tra docente e studenti avverranno mediante ricevimenti e tramite l'uso di posta elettronica e programmi di messaggistica. Il corso si svolgerà in Italiano.

Teaching methods

The course will be articulated in a series of lectures supported by the use of slides, of the reference book and of additional teaching and training material that will be made available by the teacher. Students will benefit from the resources and functionalities offered by a university Web portal, through which they will be able to download training material, to view and/or participate to remote lessons, and to communicate with each other and with the teacher. Interactions between students and the teacher will occur by means of a combination of in-person and remote meetings, emails and messaging apps. The course will feature a combination of Italian and English languages.

Programma (contenuti dell'insegnamento)

Classi di calcolatori, principi di progettazione, livelli del software, 

livelli dell'hardware, memorie, prestazioni di un calcolatore, equazioni per il calcolo delle prestazioni, energia, sistemi multiprocessore,  istruzioni aritmetiche, registri del processore, istruzioni di trasferimento dati, rappresentazione dei numeri, numeri in complemento a 2, rappresentazione delle istruzioni, istruzioni logiche, istruzioni di controllo, salti condizionati, salti incondizionati, supporto alle procedure, lo stack e lo heap, procedure annidate, rappresentazione dei caratteri e delle stringhe, costanti a 32 bit, modalità di indirizzamento, traduzione e avvio dei programmi, aritmetica dei calcolatori, somme e sottrazioni, moltiplicazione, numeri in virgola mobile, somma in virgola mobile, istruzioni floating point, parallelismo a livello di parola, cenni di logica digitale, processore a ciclo singolo, implementazione unità di elaborazione (datapath), implementazione unità di controllo, la pipeline, hazard nelle pipeline, datapath con pipeline, unità di controllo della pipeline, predittore dinamico dei salti, eccezioni e interruzioni, introduzione alla gerarchia delle memorie, tecnologie delle memorie,  cache a mappatura diretta, gestione dei miss, gestione delle scritture, misurazione e miglioramento delle prestazioni con cache, memorie cache completamente associative e set-associative, politiche di rimpiazzamento, cache multilivello, introduzione alla memoria virtuale, traduzione degli indirizzi, tabella delle pagine, translation lookaside buffer (TLB), interazione tra TLB - tabella delle pagine - cache.

Le classi in C++. Costruttore, distruttore. Overloading degli operatori. Le classi in Matlab. Meccanismo della derivazione. Come progettare una GUI (Graphical User Interface) in Matlab.

Syllabus

Classes of computers and their performance, equations for evaluating computer performance, arithmetic instructions, registers, data transfer instructions, numbers representation, instructions repesentation, logical instructions, branches, jumps, procedures, memory organization (stack and heap), nested procedures, representation of characters and strings, computer arithmetics, addition and subtraction, mutiplication, floating point numbers, floating point operations, floating point instructions, processor's datapath and control unit, pipelining, hazards, datapath and control unit with pipelining, bypassing, branch prediction, interrupts, memory hierarchy, direct mapped cache, handling misses and writes, associative and set-associative caches, replacement policies, multilevel caches, virtual memory, address translation, page table, translation lookaside buffer.

Bibliografia e materiale didattico

David A Patterson, John L Hennessy. "Struttura e progetto dei calcolatori", 4a ed. Zanichelli.

Bibliography

David A Patterson, John L Hennessy. "Struttura e progetto dei calcolatori", 4a ed. Zanichelli.

Modalità d'esame

La verifica delle conoscenze acquisite sarà oggetto di valutazione mediante prova orale con discussione prevista all'inizio di ogni sessione d'esame.

Assessment methods

Academic progress with repect to the acquired knowledges and skills will be monitored and verified via an oral exam with discussion, at the beginning of each exam session.

Updated: 21/10/2023 11:07