210 likes | 435 Views
Programowanie w języku Matlab. D. Caban, P. Skurowski Wykład 2. Instrukcje sterujące, Funkcje. Instrukcje sterujące. z regu ł y stosowan e do sterowania wykonaniem podprogramów zapisanych w m-plikach if switch for while continue break try-catch return. Instrukcja if.
E N D
Programowanie w języku Matlab D. Caban, P. Skurowski Wykład 2. Instrukcje sterujące, Funkcje
Instrukcje sterujące z reguły stosowane do sterowania wykonaniem podprogramów zapisanych w m-plikach • if • switch • for • while • continue • break • try-catch • return
Instrukcja if wwi– wyrażenie warunkowe dające wynik typu logicznego pi– ciąg poleceń Części elseif i else nie są obowiązkowe if ww1 p1 elseif ww2 p2 elseif ww3 p3 : else pn end
Wyrażenia warunkowe • proste : count < limit, isreal(A) • złożone: (count < limit) && ((height - offset) >= 0) • Jeżeli wynikiem wyrażenia jest: • skalar o wartości logicznej 1, • tablica ze wszystkimi elementami o wartości logicznej 1 wówczas warunek jest spełniony. Wykonywany jest ciąg poleceń odpowiadający pierwszemu spełnionemu warunkowi lub podany po słowie else, jeżeli żaden nie jest spełniony. • Zapis niektórych wyrażeń można uprościć np. A ~= 0 jest równoważneA. • Nie zawsze zachodzi potrzeba obliczania wartości wyrażeń prostych w wyrażeniach złożonych: • A && B – wartość B jest obliczana tylko wtedy, gdy A == 1, • A || B – wartość B jest obliczana tylko wtedy, gdy A == 0.
switch wyr case s1 p1 case s2 p2 : otherwise pn end wyr – wyrażenie dające w wyniku skalar lub łańcuch si – stała lub lista stałych Część otherwisenie jest obowiązkowa Wykonywany jest ciąg poleceń odpowiadający stałej równej wartości wyrażenia lub podany po słowie otherwise przy braku zgodności Jeśli wybór odbywa się na podstawie zawartości łańcucha – lepiej stosować instrukcję switch niż if ... elseif ... else ... Instrukcja switch
Instrukcja for for zs = wyr p end zs– zmienna sterująca, wyr– wyrażenie p– ciąg poleceń Liczba powtórzeń jest równa liczbie wartości, jakie może przyjąć zmienna sterująca.
Instrukcja while while ww p end ww– wyrażenie warunkowe p– blok poleceń Ciąg poleceń wykonywany jest tak długo, jak długo warunek jest spełniony.
Sterowanie nadzwyczajne pętlą Instrukcja continue Powoduje przerwanie bieżącego obiegu pętli i przejście do następnego. Instrukcja break Powoduje przerwanie pętli.
Sterowanie dodatkowe przebiegiem m-pliku Instrukcja return Umożliwia przerwanie działania m-pliku w dowolnym miejscu Instrukcja try-catch try pt catch pc end pt, pc– ciągi poleceń Jeśli wykonanie któregoś z poleceń ciągu pt zakończy się niepowodzeniem, wykonywany jest ciąg poleceń pc
M-pliki funkcyjne Struktura m-pliku funkcyjnego:
Przykłady linii definicji • function [x,y,z] = func1(a,b,c) • function [] = func2(a) • function func2(a) • function [x,y] = func3() • function [x,y] = func3 • nazwy: funkcji i m-pliku powinny być takie same, • argumenty są przekazywane przez wartość, • zmienne tworzone w funkcji są zmiennymi lokalnymi, przechowywanymi w osobnej przestrzeni roboczej, • zmienne lokalne przestają istnieć po zakończeniu działania funkcji, chyba że zostały zadeklarowane jako trwałe (ang. persistent),
Wywołania funkcji • funkcję można wywołać z mniejszą liczbą argumentów, • funkcja może zwrócić mniejsza liczbę wartości, • funkcja może wykonywać operacje na tych zmiennych z przestrzeni roboczej, które zostaną zadeklarowane jako globalne: global z1 z2 ... • deklarację taką trzeba podać w wierszu poleceń oraz w treści funkcji.
Przykład function s = suman(n) % SUMAN suma n wyrazów ciągu % Funkcja oblicza sumę n wyrazów ciągu % 1 + 1/2 + 1/3 + .... + 1/n % Argument n powinien być skalarem. if nargin < 1 % blok 1 error('Błąd - wymagany jeden argument'); end if prod(size(n)) ~= 1 % blok 2 error('Błąd - argument powinien być skalarem'); end s = 1;% blok 3 for k = 2:n s = s + 1/k; end
Funkcjeo dowolnej liczbie argumentówiwartości • standardowe tablice komórkowe: varargin i varargout • zmienne te należy wymieniać na końcach list. function [out,varagout]=mojrys(x,varargin) out=plot(x,varargin{:}); if nargout > 1 varargout{1}=get(out,’Name’); if nargout > 2 varargout{2}=get(out,’Tag’); if nargout > 3 varargout{3}=gca; end end end wywołanie [handler]= mojrys(sin(0:.1:1),'color',[.5 .7 .3],'linestyle',':'); [handler,nazwa,tag,osie]= mojrys(sin(0:.1:1),'color',... [.5 .7 .3],'linestyle',':');
Podfunkcje • m-plik może zawierać wiele funkcji o różnych nazwach, • pierwsza funkcja to funkcja podstawowa, pozostałe to podfunkcje, • podfunkcje mogą być wywoływane tylko przez funkcję podstawową, • podfunkcja nie ma dostępu do zmiennych lokalnych funkcji podstawowej i innych podfunkcji. Funkcje zagnieżdżone • są to funkcje definiowane w treści innych funkcji, treść funkcji zagnieżdżonych, jak również treści pozostałych funkcji w m-pliku, musi być zakończona słowem end.
Przykład function A(x, y) % funkcja podstawowa B(x, y); D(y); function B(x, y) % zagnieżdżona w A C(x); D(y); function C(x) % zagnieżdżona w B D(x); end end function D(x) % zagnieżdżona w A E(x); function E(x) % zagnieżdżona w D ... end end end
Wywołania podfunkcji • funkcję zagnieżdżoną może wywołać funkcja: • z sąsiedniego wyższego poziomu zagnieżdżenia(A może wywołać: B i D, nie może wywołać: C oraz E), • z tego poziomu zagnieżdżenia (B może wywołać D i na odwrót), • z dowolnego niższego poziomu zagnieżdżenia(C może wywołać: B i D, nie może wywołać E), • funkcje z dowolnego poziomu zagnieżdżenia mogą wywoływać podfunkcje, • do zmiennych lokalnych funkcji zagnieżdżonej mogą się odwoływać funkcje z wyższych poziomów zagnieżdżenia, • funkcja zagnieżdżona ma dostęp do zmiennych lokalnych funkcji z wyższych poziomów zagnieżdżenia, • interpretacja odwołań zmiennych: varargin i varargout – zależy od tego, czy występują one w definicji funkcji czy nie
Pliki funkcji – specyficzne cechy lokalizacji • Funkcje prywatne • zapisywane w m-plikach w podkatalogach o nazwie private, • dostępne tylko dla funkcji i skryptów z katalogu nadrzędnego, podkatalogów z funkcjami prywatnymi nie należy dołączać do listy katalogów przeszukiwanych • Funkcje przeciążone • stosowane wówczas, gdy sposób przetwarzania danej zależy od jej typu, • funkcje te mają takie same nazwy, • są one przechowywane w podkatalogach o nazwach @nazwa_typu.
Definiowane funkcji w wierszu poleceń • Funkcje anonimowe: • zawierają jedno wyrażenie, postać definicji: zmienna = @(lista argumentów) wyrażenie • argumenty oddziela się przecinkami, lista może być pusta. • operator @ tworzy tzw. uchwyt funkcji, • wywołanie funkcji anonimowej zmienna(argumenty) zmienna() • w wyrażeniu mogą wystąpić zmienne z przestrzeni roboczej, ale funkcja będzie używać wartości, które zmienne miały w chwili definicji funkcji, • można tworzyć komórkowe tablice z uchwytami.
Funkcje definiowane przy użyciu inline • zawierają jedno wyrażenie, • postać definicji zmienna = inline(’wyrażenie’) zmienna = inline(’wyrażenie’, ’argument 1’, ...) • W pierwszym przypadku funkcja inline sama określi argumenty wyrażenia.
Uchwyty do funkcji • można tworzyć uchwyty również do funkcji zapisanych w m-plikach, wykorzystujemy w tym celu operator fhandle=@nazwapliku • fsin=@sin; y=feval(fsin,x); • jest równoważne: y=sin(x); • uchwyt do funkcji jest argumentem niektórych standardowych funkcji Matlaba np. feval, fzero czy pakietu optymalizacyjnego: fzero, fmincon etc [x,fval]=fmincon(@(x)objfun(x,t),x0,[],[],[],[],... [0 0 0], [1 1 1],@confun,options);