430 likes | 610 Views
LUISS Corso di Metodi matematici per economia e finanza. Prof. F. Gozzi Lezione del 9/11/2009 Elementi di MATLAB- Prof.ssa G. Rotundo. Testi di riferimento. MATLAB – manuale di riferimento I. Capuzzo Dolcetta, M. Falcone, L’analisi al calcolatore , Zanichelli, ISBN 88 – 08 – 03904 - 8
E N D
LUISS Corso di Metodi matematici per economia e finanza. Prof. F. Gozzi Lezione del 9/11/2009 Elementi di MATLAB- Prof.ssa G. Rotundo
Testi di riferimento MATLAB – manuale di riferimento I. Capuzzo Dolcetta, M. Falcone, L’analisi al calcolatore, Zanichelli, ISBN 88 – 08 – 03904 - 8 J. Stoer, Introduzione all’analisi numerica, Zanichelli ed., 1974
Help: accesso al manuale di istruzioni Che cos'è Matlab? Matlab è un linguaggio software per il calcolo scientifico che integra funzioni di calcolo matematico, visualizzazione grafica e programmazione. Esso è implementato in un potente ambiente di lavoro ad interfaccia grafica, avente una struttura modulare che ne rende notevolmente espandibili le funzionalità. All’avvio si apre una interfaccia utente: La linea che inizia con >> si chiama linea di comando. Dare un comando a MATLAB significa scrivere istruzioni appropriate su questa linea e premere il tasto invio.
In generale: Come scrivere ‘istruzioni appropriate’ sulla linea di comando di MATLAB? Un insieme di ‘istruzioni appropriate’, scritte in un apposito linguaggio, costituisce un comando MATLAB. Il linguaggio è un insieme di regole formali che consente di scrivere i comandi Si possono scrivere più istruzioni nella stessa riga separandole con ; Le istruzioni sono dette “esecutive” perché indicano a MATLAB le operazioni da eseguire e sono “interpretate”, cioè tradotte in codice macchina ed eseguite immediatamente. Vediamo come utilizzare MATLAB come calcolatrice avanzata
Matlab come calcolatrice … E’la modalità di impiego più semplice per valutare espressioni numeriche, ad esempio per calcolare 4 + √ 2 - sin(0.2 π)2 + e2 è sufficiente digitare in Command window: 4+sqrt(2) – sin(0.2*pi)^2 + exp(2) e inviare. Il risultato viene scritto nella variabile ans (abbreviazione di answer). Esempio: Istruzioni digitate dall’utente Risultato stampato da MATLAB. ‘ans=‘ è l’abbreviazione di ‘answer’.
Problema: come utilizzare valori già calcolati? • MATLAB non permette di modificare comandi già eseguiti; • Possono essere richiamati sulla riga di comando premendo ‘freccia su’ più volte, oppure cliccando sul relativo comando nella finestra ‘Command history’ (se appare’); • Oppure si possono salvare i valori calcolati nelle variabili: • Una variabile è rappresentata da un nome e può cambiare il valore ad essa associato. • Per assegnare il valore ad una variabile bisogna usare una espressione del tipo • variabile= espressione • L’espressione viene calcolata ed il risultato viene immesso nella variabile.
Definizione di variabili E’ possibile definire variabili (ed anche espressioni non numeriche più complesse) ed ultilizzarle per ulteriori calcoli. Esempio: assegnare un valore alla variabile a, uno alla variabile b ed utilizzarli per calcolare il prodotto: Istruzioni digitate dall’utente Risultato stampato da MATLAB. ‘ans=‘ è l’abbreviazione di ‘answer’. N.B.: se il comando è seguito da ; il calcolo è effettuato, ma non viene stampato nulla
Esercizio Scrivere le istruzioni per calcolare la somma dei numeri 100, 10, 2 e dividerla per tre. Possibile svolgimento: a=100+10+2; b=a/3;
Il Workspace Ogni variabile definita in questo modo viene conservata in memoria, nel Workspace. Per vedere una lista delle variabili definite, digitare whos, oppure selezionare workspace. Per cancellare una variabile, ad esempio a, digitare clear a.
Come salvare il risultato dei calcoli? Lettura e scrittura su file. Mediante i comandi load e save è possibile salvare su file le variabili del workspace. • loadnomefile variabile1 variabile2…. Carica dal file nomefile.mat le variabili elencate. • savenomefile variabile1 variabile2…. Scrive nel file nomefile.mat le variabili elencate. • loadnomefile carica tutte le variabili in nomefile. • savenomefile salva tutto il workspace in nomefile.mat.
I numeri MATLAB fa differenza tra • Costanti intere ( i numeri interi nel senso usuale della matematica): 1, 2, 3,… • Costanti reali (numeri con cifre decimali) che sono rappresentati mediante A. notazione in virgola mobile per vedere a schermo 16 cifre digitare format long per vedere a schermo 5 cifre digitare format short B. notazione esponenziale: digitare format long e oppure format short e
Esercizio Digitare pi format long pi format short pi format long e pi format short e pi
I file script • Invece di digitare ogni volta tutti i comandi sulla linea di comando, MATLAB permette di memorizzarli in un file. • Si può ottenere l’esecuzione di tutti i comandi del file digitandone il nome sulla riga di comando. • Il file deve avere estensione .m ed essere salvato nella directory ‘MATLAB’ (versione R2007) oppure “work” (versioni precedenti). • Il file può essere scritto mediante l’editor di MATLAB. Per richiamarlo basta dare il comando ‘edit nomefile’. • Nel file si possono inserire commenti: basta far iniziare la riga che contiene il commento con il simbolo %
Ordine di esecuzione delle operazioni L’elevamento a potenza (simbolo ^) viene eseguito per primo Moltiplicazione e divisione sono eseguite subito dopo Addizione e sottrazione sono eseguite per ultime. Esercizio: determinare il risultato di >>5*2^3-1 e di >>(5*2)^(3-1)
Vettori e Matrici La struttura matematica su cui si fonda Matlab è la matrice: in Matlab anche uno scalare è una matrice… di dimensioni 1x1. La struttura dati astratta matrice è in pratica in Matlab il tipo fondamentale. Non a caso Matlab è l’acronimo di MATrix LABoratory. Digitando ad esempio x = 2.45, abbiamo dichiarato la variabile x e le abbiamo assegnato il valore 2.45. L’omissione del punto e virgola fa si che a schermo venga visionato il contenuto della variabile x. Matlab manipola solo matrici, ed infatti un’ispezione al Workspace ci dice che x è una matrice di dimensioni 1x1.
Vettori riga (di lunghezza qualsiasi) Inizia con una parentesi quadra aperta. Finisce con una parentesi quadra chiusa. Gli elementi all’interno si separano o con spazi o con vigole. Esempio >>[ 1 2 3 4]; >>[1,2,3,4]; Sono lo stesso vettore riga. Per memorizzarlo nella variabile v digitare >> v=[1 2 3 4]; L’istruzione length(v) restituisce la lunghezza del vettore.
Vettori colonna Inizia con una parentesi quadra aperta Finisce con una parentesi quadra chiusa Gli elementi all’interno si separano o con “a capo” o con punto e vigola. Esempio >>[ 1 2 3 4]; >>[1;2;3;4]; Sono lo stesso vettore colonna. Per memorizzarlo nella variabile v digitare >> v=[1 ;2; 3; 4]; Anche in questo caso l’istruzione length(v) restituisce la lunghezza del vettore L’incolonnamento non è importante
Questo viene digitato dall’utente Questo viene stampato da matlab Matrici Una matrice è una tabella con n righe e m colonne Esempio: A matrice 3x3 >> A=[ 1 2 3 4 5 6 7 8 9 ]; A= 1 2 3 4 5 6 7 8 9
Altri modi di assegnare una matrice >>A=[1 2 3; 4 5 6; 7 8 9] >>A=[1, 2, 3; 4, 5 , 6; 7 , 8, 9] >> A=[1, 2, 3 4, 5, 6 7, 8, 9] Si ottiene sempre lo stesso risultato: A = 1 2 3 4 5 6 7 8 9
ISTRUZIONI ULTERIORI matrice identica di ordine n eye(n) Esempio: >>A= eye(3) A= 1 0 0 0 1 0 0 0 1 ATTENZIONE: MATLAB DISTINGUE MAIUSCOLE E MINUSCOLE
ISTRUZIONI ULTERIORI Sotto matrice della matrice identica eye(n,m) Esempio: >>A= eye(2,3) A= 1 0 0 0 1 0
ISTRUZIONI ULTERIORI Vettore colonna zero zeros(n,1) >>v=zeros(3,1) v= 0 0 0 matrice zero • zeros(n) Esempio: >>A= zeros(3) A= 0 0 0 0 0 0 0 0 0
ISTRUZIONI ULTERIORI Costruire una matrice zero ovunque e con il vettore v sulla diagonale: • A=diag(v) Esempio: >>v=[1 2 3]; A= diag(v) A= 1 0 0 0 2 0 0 0 3 Oppure A=diag([1 2 3]);
Definizione di vettori. In Matlab, è possibile definire vettori di punti equispaziati con dimensione arbitrariamente grande. E’ possibile utilizzare l’istruzione: x = [inizio : passo : fine] che definisce un vettore riga di punti equispaziati da passo tra inizio e fine. Ad esempio x = [0 : 0.1 : 1]. In alternativa si può utilizzare l’istruzione linspace(inizio , fine , N) che definisce N elementi equispaziati tra inizio e fine. Ad esempio y = linspace(0,1,10) è equivalente a x=[0:0.1:1]
Ulteriori operazioni con vettori e matrici norm(v) calcola la norma del vettore v norm(v,1) calcola la norma del vettore v mean(v) calcola la media dei valori contenuti in v std(v) calcola la deviazione standard A’ calcola la matrice trasposta A*B calcola il prodotto delle matrici A e B A*v calcola il prodotto della matrice A per il vettore v inv(A) calcola l’inversa di A eig(A) calcola gli autovalori di A [V,D] = eig(A) calcola gli autovalori (in D) e gli autovettori (in V) tali che A*V = V*D
Esercizio Scrivere un m-file (script file) che Memorizza nel vettore v i voti degli esami sostenuti Ne calcola la media La divide per 30 La moltiplica per 110 (Suggerimento: l’istruzione mean(v) calcola la media degli elementi contenuti nel vettore v)
Esercizio Scrivere in un m-file la matrice A= [1 3 4; 5 6 7; 6 7 8]; Scrivere anche il vettore v=[1; 2; 3]; Calcolare il prodotto A*v Calcolare v’*(A*v) Il risultato è un numero, un vettore oppure una matrice?
Esempi ed esercizi vettori e matrici • Scrivere una matrice A=[1 2 3;4 5 6;7 8 9]; • Scrivere un vettore riga, colonna v=[1;2;3]; • eyes(n,m): sottomatrice della matrice identica • zeros(n,m): matrice nulla • zeros(n,1): vettore colonna • norm(v) : norma 2 del vettore v • norm(v,1) : norma 1 del vettore v • A’ calcola la matrice trasposta • A*B calcola il prodotto delle matrici A e B • A*v calcola il prodotto della matrice A per il vettore v • inv(A) calcola l’inversa di A • eig(A) calcola gli autovalori di A
ATTENZIONE L’istruzione inv(A) esegue l’inversa generalizzata, cioè fornisce un risultato anche quando il det(A)=0, ma questo non è il risultato cercato! Esempio: digitare A=[1 2 3; 4 5 6; 7 8 9]; det(A) inv(A) e commentare i risultati
Risoluzione di sistemi lineari Ax=b • Caso in cui valgono teorema e regola di Cramer: Ipotesi: matrice quadrata, determinante non nullo MATLAB calcola esplicitamente la soluzione X=inv(A)*b Esempio: Data A=[1 0; 1 1]; b=[-2;3]; Calcolo det(A), controllo che non sia zero, poi eseguo x=inv(A)*b ed ottengo il risultato Serve quindi l’istruzione di scelta condizionata
L’istruzione if if condizione1 istruzione 1 else istruzione 2 end Eseguita se condizione 1 è verificata Eseguita se condizione 1 NON è verificata
A=[1 2 3; 4 5 6; 7 8 9]; v=[1 2 3]; if det(A) ~ =0 x=inv(A)*b; else disp(‘Errore’); end disp(x)
Una funzione y=f(x) x è l’argomento della funzione y è il risultato
In matlab si definiscono funzioni y=f(x) function [output1, output2, … ] =funzione (input1, input2,…) Input: argomenti della funzione Output: risultati
Le funzioni matlab si scrivono in un m-file function [output1, output2, … ] =funzione(input1, input2,…) Qui vanno scritte le istruzioni che permettono di calcolare output1, output2, ecc utilizzando input1, input2, ecc. Esempio: Salvare l’m-file quadrato.m function f=quadrato(x) %calcola il quadrato di x f=x^2; Digitare sulla riga di comando di MATLAB >>x=2; >> y=quadrato(x) y = 4
Utilizzo delle funzioni nei calcoli Le funzioni di matlab possono essere utilizzate direttamente nei calcoli. Per esempio l’espressione >> 3 *quadrato(x)+1 Restituisce ans = 13
Esempio – funzione con più output Scrivere un m-file che calcola la funzione f(x)=x2 e la sua derivata function [f,df]=quadrato(x) %calcola il quadrato di x f=x^2; df=2*x;
Esercizio: scrivere un m-file che calcola la funzione e ne disegna il grafico function disegno %funzione senza input x=[-2:0.1:2]; f=quadrato(x); plot(x,f) function [f,df]=quadrato(x) %calcola il quadrato di x f=x.^2; df=2*x; N.B.: quadrato di ciascuna componente
Calcolo simbolico della derivata >> syms x >> diff(x^2) ans = 2*x >> f='x^2' f = x^2 >> diff(f) ans = 2*x function [f,df]=quadrato(x) %calcola il quadrato di x f=x^2; df=diff(x^2);
Esercizio: scrivere un m-file che calcola la funzione e ne disegna il grafico e la tangente in x0=1 function disegno %funzione senza input x=[-2:0.1:2]; [f,df]=quadrato(x); y=df(31)*(x-x(31))+f(31) plot(x,f,x,y) function [f,df]=quadrato(x) %calcola il quadrato di x f=x.^2; df=2*x; N.B.: quadrato di ciascuna componente