Analisi e progettazione del software

Anno accademico 2021-2022

(Attenzione, alcune delle informazioni su questo sito web, ed in particolare quelle scritte in grigio e/o su sfondo giallo, potrebbero riferirsi all'edizione precedente del corso di Analisi e progettazione del software)

Prof. Luca Cabibbo


Avvisi

(E' disponibile anche un elenco completo degli avvisi.)


Martedì 5 luglio, dalle 9:30 alle 10:30, ci sarà un ricevimento studenti straordinario in cui sarà possibile visionare le prove scritte dell'appello del 23 giugno, presso lo studio del docente oppure anche a distanza.


Risultati dell'esame di Analisi e progettazione del software del 23 giugno:

La prova scritta potrà essere visionata esclusivamente durante l'orario di ricevimento studenti, e comunque entro trenta giorni dalla pubblicazione di questo avviso.
Consultare il sito del docente per avere aggiornamenti sull'orario di ricevimento studenti.

Gli orali relativi all'appello del 23 febbraio si terranno preferibilmente mercoledì 6 o giovedì 7 luglio, in orario da concordare, presso lo studio del docente (via della Vasca Navale 79/81, Sezione di Informatica e Automazione, secondo piano, stanza 2.11).
Si ricorda che alle prove d'esame lo studente deve portare il libretto universitario oppure un documento di riconoscimento valido.

La verbalizzazione (ovvero, la registrazione) dell'esame (che viene svolta dal docente e non richiede la presenza degli studenti) avverrà con le seguenti modalità:

In caso di problemi contattare il docente, per posta elettronica, al più presto.


Ecco i risultati finali delle prove intermedie per l'anno accademico 2021-2022.

I risultati sono in trentesimi, e tengono in considerazione sia la valutazione della prima prova intermedia che la valutazione della seconda prova intermedia. 31 indica 30 e lode, mentre ins indica insufficiente.

Gli elaborati della seconda prova intermedia possono essere visionati durante il ricevimento studenti, comunque entro un mese dalla pubblicazione di questo avviso. Consultare il sito del docente per avere aggiornamenti sull'orario di ricevimento studenti.

Inoltre, sarà possibile visionare le prove intermedie anche in queste date ed orari:

Il voto proposto potrà essere verbalizzato, senza dover sostenere nessuna ulteriore prova d'esame, nell'ambito dell'appello (fittizio) del 13 giugno 2022 associato alle prove intermedie.
Non è dunque necessaria nessuna ulteriore prenotazione. 

La verbalizzazione (ovvero, la registrazione) dell'esame (che viene svolta dal docente e non richiede la presenza degli studenti) avverrà con le seguenti modalità:

In caso di problemi contattare il docente, per posta elettronica, al più presto.


Le lezioni del corso di Analisi e progettazione del software sono terminate.


Introduzione al corso

Obiettivo formativo

Il corso di Analisi e progettazione del software presenta gli aspetti fondamentali della modellazione, analisi e progettazione del software, con riferimento alle tecniche di analisi e progettazione orientata agli oggetti ed allo sviluppo, iterativo, incrementale e agile.

Lo studente che abbia superato il corso dovrà essere in grado di progettare autonomamente applicazioni software di media complessità, nonché partecipare al progetto di applicazioni software di grande complessità.

Contenuti

Prerequisiti

Costituiscono un prerequisito fondamentale di questo corso i corsi di Basi di dati e di Programmazione orientata agli oggetti. Prerequisiti specifici per il corso di Analisi e progettazione del software sono descritti in questo documento.


Lezioni

(Attenzione, alcune delle informazioni su questa parte del sito web, e in particolare quelle scritte in grigio e quelle dopo la riga gialla, potrebbero riferirsi all'edizione precedente del corso di Analisi e progettazione del software)

Legenda adottata nei lucidi

Argomenti delle lezioni svolte 

Data Argomento
(anche con riferimento ai capitoli e alle sezioni del libro di testo)
Lucidi
(non sostituiscono il libro)

1 marzo 2022

* Introduzione al corso di Analisi e progettazione del software

aps00

  1. Analisi e alla progettazione orientata agli oggetti (Capitolo 1)

aps01

4 marzo 2022

non ci sarà lezione

 

 

 

7 marzo 2022

2. Sviluppo iterativo ed evolutivo (Capitolo 2, Introduzione, da 2.1 a 2.9)

aps02

 

3. Sviluppo agile (Capitolo 3)

aps03

8 marzo 2022 4. Studi di caso (Capitolo 4)

 

 

5. Iterazione 0: analisi dei requisiti (Capitolo 5, cenni)  
  6. Requisiti evolutivi (Capitolo 6) aps06
  7. Casi d'uso (Capitolo 7, Introduzione, da 7.1 a 7.8) aps07

11 marzo 2022

7. Casi d'uso (Capitolo 7, da 7.8 a 7.13, 7.17, 7.21 e 7.22)  
  8. Altri requisiti (Capitolo 8, cenni) aps08
  9. Storie utente (Capitolo 9, Introduzione, da 9.1 a 9.3, 9.8) aps09

 

 

14 marzo 2022

non ci sarà lezione

 

15 marzo 2022 10. Iterazione 1: Concetti fondamentali (Capitolo 10, paragrafo 10.1) aps10
  * Alcune idee sui sistemi software e la loro architettura apsA
  11. Verso l'analisi a oggetti aps11
  * Dalla progettazione concettuale alla modellazione di dominio apsB
18 marzo 2022 12. Modellazione di dominio (Cap.12, da 12.1 a 12.6, nonché 12.20) aps12a (prima parte)

 

 

21 marzo 2022

12. Modellazione di dominio (Cap. 12, da 12.6 a 12.14) aps12b (seconda parte)

22 marzo 2022

12. Modellazione di dominio (Cap. 12, da 12.14 a 12.22)  

25 marzo 2022

non ci sarà lezione

 

 

 

28 marzo 2022

non ci sarà lezione

 

29 marzo 2022 Esercitazione OOA: ERedit (requisiti), modellazione di dominio  
1 aprile 2022 13. Operazioni di sistema e diagrammi di sequenza di sistema (Cap. 13) aps13

 

14. Contratti delle operazioni di sistema (Cap. 14) aps14

 

 

4 aprile 2022 Esercitazione OOA: Acme Poesia (requisiti, esercizi su modellazione di dominio)  
5 aprile 2022 15. Dai requisiti alla progettazione, iterativamente (Cap. 15)  
  16. Architettura logica (Cap. 16) aps16
  17. Verso la progettazione a oggetti (Cap. 17) aps17
  19. Diagrammi delle classi (Cap. 19, da 19.1 a 19.7, da 19.10 a 19.15) aps19
8 aprile 2022 18. Diagrammi di interazione (Cap. 18, da 18.1 a 18.6) aps18
  19. Diagrammi delle classi (Cap. 19, 19.19)  

 

 

11 aprile 2022 Esercitazione OOA: ERedit (requisiti), operazioni di sistema, contratti delle operazioni per loginUtente, creaDiagramma, apriDiagramma, creaEntità, creaAttributo, creaRelazione  
12 aprile 2022 20. GRASP: Progettazione di oggetti con responsabilità (Cap. 20, da 20.1 a 20.9) aps20a

 

 

15-19 aprile 2022 Vacanze di Pasqua  

 

 

21 aprile 2022

non ci sarà lezione

 

22 aprile 2022

non ci sarà lezione

 

 

 

26 aprile 2022 Esercitazione OOA: Acme Poesia (requisiti, esercizi su operazioni di sistema)  
28 aprile 2022 21. Esempi di progettazione a oggetti con i pattern GRASP (Cap. 21, da 21.1 a 21.4, fino a enterItem) aps21a
29 aprile 2022 21. Esempi di progettazione a oggetti con i pattern GRASP (Cap. 21, paragrafo 21.4, enterItem)  
  22. Progettare per la visibilità (Cap. 22) aps22

 

21. Esempi di progettazione a oggetti con i pattern GRASP (Cap. 21, paragrafo 21.4, endItemEntry e getTotal)  

 

 

3 maggio 2022

21. Esempi di progettazione a oggetti con i pattern GRASP (Cap. 21, paragrafo 21.4, da getTotal alla fine del paragrafo)  
  23. Trasformare i progetti in codice (Cap. 23, da 23.1 a 23.12) aps23a
5 maggio 2022 * Retrospettiva sull'iterazione 1 apsC

 

20. GRASP: Progettazione di oggetti con responsabilità (Cap. 20, da 20.10 a 20.12, introduzione ad accoppiamento e coesione, e 20.13) aps20b

6 maggio 2022

non ci sarà lezione

 

 

 

10 maggio 2022 Esercitazione OOD: ERedit (requisiti): loginUtente, apriDiagramma, creaDiagramma, creaEntità  
12 maggio 2022 Esercitazione OOD: ERedit (requisiti): creaAttributo, creaRelazione  
  Esercitazione OOP: ERedit (requisiti): codice per creaAttributo  

13 maggio 2022

non ci sarà lezione

 

 

 

17 maggio 2022

20. GRASP: Progettazione di oggetti con responsabilità (Cap. 20, 20.15)  
  21. Esempi di progettazione a oggetti con i pattern GRASP (Cap. 21, 21.5) aps21b
  23. Trasformare i progetti in codice (Paragrafo 23.13)  
  24. Sviluppo guidato dai test e Refactoring (Cap. 24, cenni) aps24
19 maggio 2022 24. Sviluppo guidato dai test e Refactoring (Cap. 24, cenni) aps24
  26. Iterazione 2: Altri pattern (Cap. 26)  
  27. Rapido aggiornamento dell'analisi (e del progetto) (Cap. 27) aps27
  34. Ulteriore modellazione di dominio (Cap. 34, da 34.1 a 34.9) aps34
20 maggio 2022
(con inizio alle ore 9:30)
Esercitazione OOD: Acme Poesia (requisiti, esercizi di progettazione a oggetti)  

 

24 maggio 2022 34. Ulteriore modellazione di dominio (Cap. 34, da 34.10 a 34.13 e 34.17)  
  35. Altri SSD e contratti (Cap. 35, cenni) aps35
  28. GRASP: altri oggetti con responsabilità (Capitolo 28, paragrafo 28.1) aps28
26 maggio 2022 28. GRASP: altri oggetti con responsabilità (Capitolo 28, da 28.2 a 28.4)  
  29. Applicare i design pattern GoF: introduzione, Adapter (cenni) (Cap. 29, da 29.1 a 29.2, cenni) aps29a
27 maggio 2022 29. Applicare i design pattern GoF: Factory, Singleton e conclusione sul problema dei servizi esterni (cenni) (Cap. 29, da 29.4 a 29.6 e 29.11, cenni)  
  29. Applicare i design pattern GoF: Strategy (in dettaglio), Facade, Observer (cenni) (Cap. 29, 29.7 (in dettaglio), 29.9 e 29.10 (cenni)) aps29b

 

 

31 maggio 2022 Prima prova intermedia (dalle ore 8:45)  

3 giugno 2022

non ci sarà lezione

 

 

 

6 giugno 2022
(con inizio alle ore 9:30)
Esercitazione OOA/D: AcmePayroll (studio di caso)  
7 giugno 2022 37. Raffinamento dell'architettura logica: collaborazioni tra strati (Cap. 37, 37.2 e 37.4, cenni) aps37a

 

39. Ulteriore progettazione a oggetti con i pattern GoF: Repository e Template Method (Cap. 39, 39.2 (cenni), 39.10 (in dettaglio), 39.11 (cenni) e 39.12 (cenni))

aps39a

9 giugno 2022 Seconda prova intermedia (dalle ore 8:45)  

10 giugno 2022

non ci sarà lezione

 

 

 

 

 

 

 

 

 

 

 

In questa tabella, tutto ciò che segue questa riga si riferisce all'anno accademico precedente

 

 

 

 

 

     

17 maggio 2021

non ci sarà lezione, ma un ricevimento studenti sul team del corso

 

28 maggio 2021 29. Applicare i design pattern GoF: Observer (cenni) (Cap. 29, 29.10 (cenni))  

 

 

31 maggio 2021

non ci sarà lezione

 

  le lezioni del corso sono terminate  

 

 

 

 

In questa tabella, tutto ciò che segue questa riga si riferisce all'anno accademico precedente

 

 

 

 

 

 

 

 

 

 

 

 

 


Prove in itinere e homework

Per ciascuna prova in itinere o homework, i requisiti sono descritti in un documento diverso da quello contenente gli esercizi della prova in itinere o homework.

  Homework/auto valutazione Requisiti Data pubblicazione Consegna elettronica Consegna cartacea
1 Acme Poesia: Analisi - Modellazione di dominio Acme Poesia 28 marzo 2022 entro le ore 20 di domenica 3 aprile no
val 1 scheda di autovalutazione dell'homework 1   4 aprile 2022 entro le ore 20 di giovedì 7 aprile no
2 Acme Poesia: Analisi - Operazioni di sistema Acme Poesia 11 aprile 2022 entro le ore 20 di mercoledì 20 aprile no
val 2 scheda di autovalutazione dell'homework 2   26 aprile 2022 entro le ore 20 di venerdì 29 aprile no
3 Acme Poesia: Progettazione a oggetti Acme Poesia 11 maggio 2022 entro le ore 20 di giovedì 19 maggio no
           

Uno studente potrà consegnare le proprie soluzioni degli homework, scritte a mano su carta e realizzate individualmente, come segue:

Saranno accettate e valutate solo consegne puntuali.

Inoltre:

Inoltre, uno studente potrà consegnare le autovalutazioni delle proprie soluzioni degli homework, come segue:

Saranno accettate e valutate solo consegne puntuali.


Programma (ordinamento 270)

Programma preliminare del corso di Analisi e progettazione del software per gli studenti dell'ordinamento 270, per l'anno accademico 2020-2021 – l'indicazione dei capitoli fa riferimento all'edizione italiana del 2020 del libro di testo Applicare UML e i pattern  

I concetti introdotti durante il corso sono esemplificati con riferimento ai seguenti studi di caso, che sono parte integrante del programma d'esame:


Materiale didattico

Libro di testo

In alternativa, la versione originale in inglese della terza edizione del libro:

Ulteriori libri, utili per la consultazione (in ordine sparso)

Sito web del corso

Pagina Moodle del corso

L’iscrizione alla pagina Moodle del corso è necessaria per iscriversi al team del corso e per seguire le lezioni.
Tuttavia, questa pagina non dovrebbe contenere materiale didattico, ma verrà usata per le prove in itinere e forse anche per le prove d’esame. 

Team del corso

Studi di caso 

I concetti introdotti durante il corso sono esemplificati con riferimento ai seguenti studi di caso, che sono parte integrante del programma d'esame:

Ulteriori studi di caso che possono essere utilizzati nel corso:


Esami (in caso di normale attività didattica)

Modalità di svolgimento degli esami di profitto per gli appelli ordinari del corso di Analisi e progettazione del software, in caso di normale attività didattica (altrimenti si vedano le indicazioni relative allo svolgimento degli esami a seguito dell'emergenza sanitaria e fino al ripristino della normale attività didattica): 

Esame con progetto

Esame senza progetto

Esame con prove in itinere

Appelli straordinari

In caso di appelli straordinari, la modalità d'esame di Analisi e progettazione del software potrà, a secondo delle circostanze, essere diversa. Ad esempio, solo esame scritto, solo esame orale, oppure progetto e esame orale, oppure progetto e esame scritto. Contattare il docente per chiarimenti.


Esami (modalità di svolgimento a seguito dell'emergenza sanitaria e fino al ripristino della normale attività didattica)

Modalità di svolgimento degli esami di profitto del corso di Analisi e progettazione del software a seguito dell’emergenza sanitaria e fino al ripristino della situazione di normale attività accademica

L'esame di Analisi e progettazione del software potrebbe svolgersi come segue (una decisione più precisa verrà presa, nel caso, più avanti):

In caso di impedimenti comprovati o di situazioni straordinarie, si prega di contattare il docente al più presto.


Date d'esame

Nell'anno accademico 2021-2022 sono previste le seguenti date d'esame (attenzione, potrebbero ancora cambiare):

Per partecipare agli esami è necessario prenotarsi ad esso presso il portale dello studente GOMP al corso di codice 20801962. La prenotazione va normalmente fatta entro quattro giorni lavorativi prima della data dell'appello (che corrispondono a circa una settimana effettiva).

Chi avesse problemi a prenotarsi presso il sito delle prenotazioni è invitato caldamente a contattare il docente per posta elettronica entro gli stessi termini.

Per motivi organizzativi, gli studenti non prenotati che comunque non contatteranno il docente entro 24 ore dall'esame non saranno ammessi all'esame stesso.


Testi di prove d'esame di appelli conclusi

Dell'anno accademico 2011-2012

Dell'anno accademico 2008-2009

Dell'anno accademico 2006-2007 

Dell'anno accademico 2005-2006 (la modalità d'esame potrebbe essere diversa da quella prevista per questo anno accademico) 

Dell'anno accademico 2004-2005 (la modalità d'esame potrebbe essere diversa da quella prevista per questo anno accademico) 

Dell'anno accademico 2003-2004 (la modalità d'esame potrebbe essere diversa da quella prevista per questo anno accademico)

Dell'anno accademico 2002-2003 (con le stesse modalità dell'anno accademico 2003-2004, ma con un programma leggermente diverso, e un livello di approfondimento minore per alcuni degli argomenti trattati)


Informazioni per studenti Erasmus

In passato, si sono verificate delle situazioni spiacevoli con alcuni studenti Erasmus.
(Ci tengo a sottolineare il fatto che ciò è avvenuto solo con alcuni studenti Erasmus: altri studenti Erasmus si sono comportati correttamente, ed hanno studiato in modo assolutamente dignitoso).

A causa di tali avvenimenti, gli studenti Erasmus interessati a frequentare e sostenere l'esame di Analisi e progettazione del software devono

Si ricorda inoltre che al corso di Analisi e progettazione del software sono attribuiti 6 CFU (crediti formativi universitari), e che pertanto l'impegno richiesto ad uno studente in possesso dei prerequisiti del corso è di circa 6x25=150 ore.

Il docente sottolinea che finora ha trattato - e continuerà a trattare - gli studenti Erasmus allo stesso modo - dunque, né meglio né peggio - degli studenti locali.
In particolare (anche se non ci dovrebbe essere bisogno di dirlo) uno studente Erasmus che studia bene la materia verrà promosso all'esame, mentre uno studente Erasmus che studia poco o studia male la materia verrà bocciato all'esame - esattamente come verrebbe bocciato all'esame uno studente locale che studia poco o studia male. Questo indipendentemente da qualunque fatto o situazione che non riguarda strettamente lo studio e la comprensione della materia. E con l'ovvia considerazione che decidere se uno studente ha studiato bene o male è responsabilità della commissione d'esame - e non dello studente.


En pasado, se han verificado unas situaciones desagradables con unos estudiantes Erasmus.
(Quiero acentuar que esto ha pasado solo con unos estudiantes Erasmus: otros estudiantes se han comportado correctamente y han siempre estudiado de una manera absolutamente decente.) 

Por esos eventos, los estudiantes Erasmus que son interesados a frecuentar y dar el examen de Analisi e progettazione del software tienen que

Se recuerda tambien que al curso de Analisi e progettazione del software se dan 6 CFU (crediti formativi universitari), y que entonces el empeño que se pide a un estudiante que ya posee los requisitos del curso es más o menos de 6x25=150 horas .

El profesor acentua que hasta ahora ha tratado – y seguirá tratando- los estudiantes Erasmus de la misma manera – es decir ni mejor ni pejor – de los estudiantes locales .
En particular, aunque no sea necesario decirlo, un estudiante Erasmus que estudia bien la materia aprobará el examen, mientras un estudiante Erasmus que estudia poco o mal la materia suspenderá el examen – de la misma manera de un estudiante local que estudia poco o estudia mal. Eso independientemente de todos los aspectos que no conciernen propiamente el estudio y la comprensión de la materia. Y, por supuesto,considerando tambien que es la Comision de Examen que decide si un estudiante ha estudiado poco o mal – y no el estudiante mismo.