DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 6 – Info B Marco D. Santambrogio – Riccardo Cattaneo –

Slides:



Advertisements
Presentazioni simili
Process synchronization
Advertisements

MATLAB.
MATLAB. Scopo della lezione Programmare in Matlab Funzioni Cicli Operatori relazionali Esercizi vari.
Dipartimento di Matematica
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 5 – Info B Marco D. Santambrogio – Riccardo Cattaneo –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Costrutti iterativi Marco D. Santambrogio – Ver. aggiornata al 20 Marzo 2013.
Process synchronization
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Costrutti iterativi Marco D. Santambrogio – Ver. aggiornata al 9 Agosto 2013.
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Algoritmi e basi del C Marco D. Santambrogio – Ver. aggiornata al 9 Agosto 2013.
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 2 – Info B Marco D. Santambrogio – Riccardo Cattaneo –
Process synchronization
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 6: 16 Maggio 2013 Gianluca Durelli – Marco D. Santambrogio –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 2: 04 Aprile 2013 Marco D. Santambrogio – Gianluca Durelli –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Stringhe e tipi di dati strutturati Marco D. Santambrogio – Ver. aggiornata al.
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 2: 25 Marzo 2013 Marco D. Santambrogio – Gianluca Durelli -
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 5: 29 Aprile 2013 Gianluca Durelli – Marco D. Santambrogio –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 6: 13 Maggio 2013 Gianluca Durelli – Marco D. Santambrogio –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 1 – Info B Marco D. Santambrogio – Riccardo Cattaneo –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 7: 10 Giugno 2013 Gianluca Durelli – Marco D. Santambrogio –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 3: 24 Ottobre 2011 Sadegh Astaneh – Marco D. Santambrogio –
Process synchronization
Process synchronization
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Ulitma lezione… fine corso IEIM 2013 Marco D. Santambrogio – Ver. aggiornata al.
MATLAB. …oggi… Programmare in Matlab Programmare in Matlab m-file m-file script script Funzioni Funzioni Cicli Cicli Operatori relazionali Operatori relazionali.
MATLAB.
MATLAB. …oggi… Programmare in Matlab Programmare in Matlab Funzioni Funzioni Cicli Cicli Operatori relazionali Operatori relazionali Indipendenza lineare,
MATLAB. …oggi… Programmare in Matlab Programmare in Matlab Funzioni Funzioni Cicli Cicli Operatori relazionali Operatori relazionali Esercizi vari Esercizi.
APPUNTI SUL LINGUAGGIO C
EQUAZIONI DI SECONDO GRADO
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 3 – Info B Marco D. Santambrogio – Riccardo Cattaneo –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 6 – Info B Marco D. Santambrogio – Riccardo Cattaneo –
Diagrammi 2D e 3D Funzioni di ordine superiore
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Input/output 1 Marco D. Santambrogio – Ver. aggiornata al 2 Dicembre 2013.
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Script 1 Marco D. Santambrogio – Ver. aggiornata al 2 Dicembre 2013.
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 2 – Info B Marco D. Santambrogio – Riccardo Cattaneo –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 7: 13 Giugno 2013 Gianluca Durelli – Marco D. Santambrogio –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Array e stringhe Marco D. Santambrogio – Ver. aggiornata al 9 Agosto 2013.
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 5 – Info B Marco D. Santambrogio – Riccardo Cattaneo –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 8 – Info B Marco D. Santambrogio – Riccardo Cattaneo –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Strutture di controllo Marco D. Santambrogio – Ver. aggiornata al 16 Dicembre 2013.
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Come affrontare un problema… Marco D. Santambrogio – Ver. aggiornata al 18 Ottobre.
Milano, 17 Dicembre 2013 Informatica B Informatica B Matlab Laboratorio del 14/01/2014 Responsabili di laboratorio: Gianluca Durelli:
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Esercitazione 1 Marco D. Santambrogio – Ver. aggiornata al 9 Aprile 2014.
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Come affrontare un problema… Marco D. Santambrogio – Ver. aggiornata al 21 Agosto.
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Costrutti iterativi Marco D. Santambrogio – Ver. aggiornata al 20 Ottobre 2014.
#include void main() { int a,b,c,; float s, x,x1,x2,delta,alfa,beta; int num[3]; int i; printf("La forma classica dell'equazione di 2° grado è: a*x^2+b*x+c=0\n.
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 3: 31 Marzo 2014 Marco D. Santambrogio – Gianluca Durelli –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 6 – Info B Marco D. Santambrogio – Riccardo Cattaneo –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Costrutti iterativi Marco D. Santambrogio – Ver. aggiornata al 26 Marzo 2014.
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 7 – Info B Marco D. Santambrogio – Riccardo Cattaneo –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 2: 27 Marzo 2014 Marco D. Santambrogio – Gianluca Durelli –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 5 – Info B Marco D. Santambrogio – Riccardo Cattaneo –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 3 – Info B Marco D. Santambrogio – Riccardo Cattaneo –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 4 L Maggio 2015 Marco D. Santambrogio – Gianluca Durelli -
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 2 – Info B Marco D. Santambrogio – Matteo Ferroni –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 5 – Info B Marco D. Santambrogio – Matteo Ferroni –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 4 – Info B Marco D. Santambrogio – Matteo Ferroni –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 4 – Info B Marco D. Santambrogio – Matteo Ferroni –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 5 – Info B Marco D. Santambrogio – Matteo Ferroni –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Strutture di controllo Marco D. Santambrogio – Ver. aggiornata al 24 Agosto 2015.
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 6 – Info B Marco D. Santambrogio – Matteo Ferroni –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 2 – Info B Marco D. Santambrogio – Matteo Ferroni –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 6 – Info B Marco D. Santambrogio – Matteo Ferroni –
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Costrutti iterativi Marco D. Santambrogio – Ver. aggiornata al 22 Marzo 2016.
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 3 – Info B Marco D. Santambrogio – Matteo Ferroni –
Process synchronization
Process synchronization
Process synchronization
Process synchronization
Process synchronization
Transcript della presentazione:

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 6 – Info B Marco D. Santambrogio – Riccardo Cattaneo – Ver. aggiornata al 9 Agosto 2013

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 5: Obiettivi Introduzione a Matlab/Octave Cicli Funzioni Strutture 2

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 5: Agenda Warm Up (40) Qualche cosa un po' più divertente (90) Altri exe… (110) 3

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 5: Warm up Warm Up (40) Inserisci numeri Temperatura mcm Qualche cosa un po' più divertente (90) Altri exe… (110) 4

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Problema: Inserisci numeri Acquisiamo numeri da tastiera finché non viene inserito un numero negativo. In ogni caso non accettiamo più di mille numeri 5

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Soluzione: Inserisci numeri vector = [ ]; %crea il vettore vuoto for count = 1:1000 %Raccoglierà al max 1000 valori value = input('next number '); if value < 0 break %Se value negativo usciamo dal ciclo else vector(count) = value; end vector %permette di visualizzare il contenuto di vector 6

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Problema: Temperatura Scrivere un programma che prende in input la temperatura in gradi Celsius e restituisce in output i gradi Fahrenheit Formula: Fahrnait = Celsius * 9/

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Soluzione: Temperatura temp_c = input('Inserire la temperatura in gradi Celsius: '); temp_f = temp_c * 9/5 + 32; disp(['La temperatura in gradi Fahrenheit è ', num2str(temp_f)]); 8

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE mcm: problema Dati due numeri x ed y, si definisce il minimo comune multiplo come mcm = x*y/MCD(x,y) Si risolve il problema creando una funzione mcm 9

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE mcd in Octave function [div] = mcd(x,y) if(x == y) div = x; elseif(x < y) for cont = x:-1:1 if mod(x,cont) == 0 && mod(y,cont) == 0 div = cont; break end else for cont = y:-1:1 if mod(x,cont) == 0 && mod(y,cont) == 0 div = cont; break end 10

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE mcm in Octave function [mul] = mcm(x,y) mul = x * y / mcd(x,y); 11

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 5: Un po di divertimento Warm Up (40) Qualche cosa un po' più divertente (90) Maggiore Equazione secondo grado Rilievi altimetrici Altri exe… (110) 12

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Problema: Maggiore Scrivere un programma che prenda in input un array e conti tutti i numeri che sono maggiore di un numero n inserito dallutente 13

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Soluzione: Maggiore mag = input('Vuoi contare i numeri maggiori di quanto? '); disp('Array (ricorda di inserire i numeri tra parentesi quadre):'); inarray = input(''); counter = 0; for ii=1:length(inarray) if inarray(ii)>mag counter = counter+1; end disp(['I numeri maggiori di ',num2str(mag),' sono ',num2str(counter)]); 14

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Soluzione: Maggiore (in due righe) mag = input('Vuoi contare i numeri maggiori di quanto? ) disp('Array (ricorda di inserire i numeri tra parentesi quadre):) inarray = input() magV= inarray(inarray>mag); counter = size(magV,2); disp(['I numeri maggiori di ',num2str(mag),' sono ',num2str(counter)]); 15

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Problema: Equazione secondo grado Scrivere una funzione per il calcolo dell'equazione di secondo grado: ax^2 + bx + c. Inseriti a, b e c la funzione deve ritornare il valore di delta, e i valori delle radici reali (se esistono). In caso che delta sia uguale a 0, x1 contiene la soluzione, mentre x2 non è un numero (NaN). 16

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Soluzione: Equazione secondo grado function [delta, x1, x2] = eq2g(a,b,c) delta = b^2-4*a*c; if (delta==0) x1=(-b)/(2*a); x2=(-b)/(2*a); else x1=(-b+sqrt(delta))/(2*a); x2=(-b-sqrt(delta))/(2*a); end 17

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Esercizio: Rilievi altimetrici Si sviluppi un programma in matlab che acquisisce da tastiera i dati relativi a rilievi altimetrici e stampa a video laltitudine media di tutti quelli che hanno latitudine compresa tra 10 e 80 e longitudine tra 30 e 60 18

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Soluzione (1ma parte) : rilievi altimetrici more = input('vuoi inserire valori altimetrici? (s/n)'); ii=1; while more=='s' arch(ii).altitudine = input('altitudine '); arch(ii).longitudine = input('longitudine '); arch(ii).latitudine = input('latitudine '); ii = ii+1; more = input('vuoi inserire altri valori altimetrici? (s/n)'); end 19

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Soluzione (2nda parte) : rilievi altimetrici jj=1; for ii=1:length(arch) %attenzione: la condizione deve essere scritta sulla stessa linea… if arch(ii).latitudine>=10&&arch(ii).latitudine =30&&arch(ii).longitudine<=60 elemSelez(jj) = arch(ii).altitudine; jj=jj+1; end disp(['la media degli elementi selezionati e` ' num2str(mean(elemSelez))]); 20

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Lab 5: Altri exe Warm Up (40) Qualche cosa un po' più divertente (90) Altri exe… (110) Cambio base Scambio elementi Matrici Città 21

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Problema: Cambio base Ricevere un vettore che rappresenti le singole cifre di un numero in base 2 stampare a video il valore in base 10 22

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Cambio base - Soluzione 23 function [ris] = cambioBase(n) % N vettore di 0 e 1 esp=[length(n)-1:-1:0]; Basi=2.^esp; disp(sum(n.*basi));

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Problema: Scambio elementi Scrivere un programma che dati due array scambi gli elementi di indice dispari usare la funzione mod 24

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Soluzione: Scambio elementi function [inarray1, inarray2] = swapOdd(inarray1, inarray2) for ii=1:min(length(inarray1),length(inarray2)) if (mod(ii,2) == 1) temp=inarray1(ii); inarray1(ii)=inarray2(ii); inarray2(ii) = temp; end 25

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Soluzione: Scambio elementi disp('Array1 (ricorda di inserire i numeri tra parentesi quadre):'); inarray1 = input(''); disp('Array2 (ricorda di inserire i numeri tra parentesi quadre):'); inarray2 = input(''); [inarray1, inarray2] = swapOdd(inarray1, inarray2); disp('Ora gli array sono: '); disp(inarray1); disp(inarray2); 26

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Problema: Matrici Date le seguenti matrici A e B: A = [ ; ; ; ]; B = [ ; ; ; ]; Si verifichi che AB != BA, (A*B) T != A T *B T ma che (AB) T = B T *A T ( T significa matrice trasposta). Provare anche che (A + B)2 != A2 + 2AB + B2. 27

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Soluzione: Matrici (prima parte) AB=A*B; BA=B*A; val = (AB==BA); if (sum(sum(val))==0) disp('Le due matrici A*B e B*A sono diverse'); else disp('Le due matrici A*B e B*A sono uguali'); end ABT = (A*B)'; ATBT = (A')*(B'); val = (ABT==ATBT); if (sum(sum(val))==0) disp('Le due matrici (A*B)T e AT*BT sono diverse'); else disp('Le due matrici (A*B)T e AT*BT sono uguali'); end 28

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Soluzione: Matrici (seconda parte) ABT = (A*B)'; BTAT = (B')*(A'); val = (ABT==BTAT); if (sum(sum(val))==0) disp('Le due matrici (A*B)T e BT*AT sono diverse'); else disp('Le due matrici (A*B)T e BT*AT sono uguali'); end PR = (A+B)^2; SE = (A^2)+(2*A*B)+(B^2); val = (PR==SE); if (sum(sum(val))==0) disp('Le due matrici (A + B)2 e A2 + 2AB + B2 sono diverse'); else disp('Le due matrici (A + B)2 e A2 + 2AB + B2 sono uguali'); end 29

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Problema: Città Sono date N città definite dalle loro coordinate euclidee (x,y). Tali coordinate sono scritte in due vettori di N elementi ciascuno (un vettore per le x, uno per le y). Ad esempio, x(1) e y(1) rappresentano le coordinate per la prima città. Generare casualmente i vettori x e y come segue: x=rand(1,N); y=rand(1,N); osservare i valori risultanti, ed eventualmente moltiplicare i due vettori per 100 in modo che tali valori possano essere interpretati come coordinate espresse in km. Disegnare la posizione di ogni città (plot) Calcolare e stampare la matrice NxN delle distanze, in cui ogni cella (i,j) rappresenta la distanza euclidea tra la città i e la città j, calcolata tramite il teorema di pitagora. Impostare a NaN la diagonale principale (in modo da non si considerare la distanza tra una città e stessa). Facoltativo: visualizzare la matrice tramite il comando image. 30

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Soluzione: Città N = input('Quante città: '); x = rand(1,N); y = rand(1,N); x = 100*x; y = 100*y; plot(x,y,'bo'); hold on distanze = zeros(N,N); for i1 = 1:N for i2 = 1:N distanzai1i2quad = (x(i1) - x(i2))^2 + (y(i1) - y(i2))^2; distanze(i1,i2) = sqrt(distanzai1i2quad); end disp(distanze); % Si può fare con un ciclo for oppure con una 'matrice logica' % for i1 = 1:N % distanze(i1,i2) = NaN; % end logicaldiag = logical(eye(N)); distanze(logicaldiag) = NaN; disp(distanze); 31

DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Fonti per lo studio Introduzione alla programmazione in MATLAB, A.Campi, E.Di Nitto, D.Loiacono, A.Morzenti, P.Spoletini, Ed.Esculapio Capitoli 2, 3 e 4 Credits Emanuele Panigati 32