matlab入門教程課件_第1頁
matlab入門教程課件_第2頁
matlab入門教程課件_第3頁
matlab入門教程課件_第4頁
matlab入門教程課件_第5頁
已閱讀5頁,還剩359頁未讀 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

28.12.2024.1MATLAB

——數學建?;A教程主講者:高陳燕28.12.2024.2MATLAB

——數學建?;A教程MATLAB的概述MATLAB程序設計基礎MATLAB在數值計算中的應用MATLAB的符號計算MATLAB的圖形處理28.12.2024.3MATLAB程序設計基礎MATLAB語言的基本要素MATLAB語言的核心——矩陣單元型數據和結構型數據M文件流程控制語句28.12.2024.4MATLAB語言的基本要素變量

變量不需要事先聲明,也不需要指定變量類型,它會自動根據所賦予變量的值或對變量的操作來確定變量的類型;賦值過程中,如果變量已存在,則用新值代替舊值,以新的類型代替舊的類型。變量的命名規(guī)則:變量名區(qū)分大小寫;變量名長度不超過31位,第31位之后的字符被忽略;變量名以字母開頭,變量名中可以包含字母、數字、下劃線,但不能使用標點。

變量一般為局部變量,即僅在其調用的M文件內部有效;若要定義全局變量,須在變量前加關鍵字global。Matlab語言主要是由幾個基本要素構建而成的,其中包括變量、常量、數值、字符串、運算符及標點等?;氐街髂夸?8.12.2024.5常量

matlab中預定義的一些特殊的量。

i,j虛數單位 Realmin最小的正浮點數,

pi圓周率 Realmax最大的浮點數,

eps浮點運算的相對精度 Inf 無窮大

NaNNot-a-Number,表示不定值

例如:

>>pi ans=%ans是默認的結果變量

3.141628.12.2024.6>>1/0Warning:Dividebyzero.ans=Inf>>0/0Warning:Dividebyzero.ans=NaN28.12.2024.7

定義變量時應避免與常量名相同,如果改變了某個常量的值,可以用“clear+常量名”命令來恢復該常量的初始設定值。>>pi=1pi=1>>clearpi>>pians=3.141628.12.2024.8數值數值缺省為實數保留小數點后4位浮點數表示。其輸入格式與C語言一致:如:9-730.19991.475e6

輸出格式由format命令控制,只是影響屏幕顯示效果,不影響內部存儲和計算。下面以pi為例。>>formatlong;pians=3.14159265358979>>formatlonge;pians=3.141592653589793e+000>>formatlongg;pians=3.1415926535897928.12.2024.9>>z=2*exp(pi/3i)z=1.0000+1.7321iMatlab語言還提供了復數的表達和運算功能。復數的基本單位表示為i或j。例如:如果是表達式,必須在虛部的數值與i、j之間使用乘號。>>sin(pi/3)+cos(pi/3)j???sin(pi/3)+cos(pi/3)j

Error:UnexpectedMATLABexpression.>>sin(pi/3)+cos(pi/3)*jans=0.8660+0.5000i28.12.2024.10字符串字符串用單引號輸入或賦值;字符串的每個字符都是都是字符數組的一個元素;字符串和字符數組基本上等價。>>s='iloveyou's=iloveyou>>size(s)ans=110>>s(2)ans=>>s(10)ans=u字符串的每個字符(包括空格)都是字符數組的一個元素。在matlab中,字符串與字符數組或矩陣基本上是等價的。28.12.2024.11

如果在字符串內使用單引號時,可以用連續(xù)兩個單引號表示。例如:

字符串之間的轉換函數:

double字符串轉換為數值代碼num2str數字轉換為字符串

int2str整數轉換為字符串mat2str矩陣轉換為字符串

str2num轉換字符串為數字>>double(s)‘%s=‘iloveyou’ans=1053210811111810132121111117>>s='it''sgood‘s=it'sgood28.12.2024.12>>a=[1:5]a=12345>>b=num2str(a)b=2345>>a*2ans=246810>>b*2ans=98646410064641026464104646410628.12.2024.13

matlab對字符串的操作與C語言中的幾乎完全相同:

strcat鏈結串strcmp比較串strvcat垂直鏈結串

strncmp比較串的前n個字符findstr在其他串中找此串

upper轉換串為大寫lower轉換串為小寫

blanks生成空串deblank移去串中空格……例如:把前面的字符串s轉化成大寫。s=“it’good”>>upper(s)ans=IT'SGOOD執(zhí)行字符串的功能用eval來實現(xiàn)。>>t=‘1/(a*b-1)’;a=2;b=3;c=eval(t)%可以在一行中表示。c=0.200028.12.2024.14運算符

在matlab語言中運算符包括算術運算符、關系運算符和邏輯運算符。其中算術運算符見右表:其中點運算是指操作元素點對點的運算,也就是說矩陣內元素對元素之間的運算,點運算要求參與運算的變量在結構上必須是相似的。例如:操作符定義+算術加-算術減*算術乘.*點乘^算術乘方.^點乘方\算術左除.\點左除/算術右除./點右除28.12.2024.15>>a=[1,2,3;4,5,6;7,8,9]a=123456789>>b=[123456789]b=123456789>>c=a*bc=303642668196102126150>>d=a.*bd=149162536496481思考:題目:通過描點法得到sin(x)xcos(x)函數在0-pi區(qū)間上的曲線。提示:通過點運算獲得。(附件diancheng。txt)28.12.2024.16Matlab語言的關系運算符如右表:當判斷一個矩陣是否為空矩陣時,一般不用“==”,而應當使用函數isempty。操作符定義==等于~=不等于>大于>=大于等于<小于<=小于等于28.12.2024.17Matlab語言的邏輯運算符如右表:進行邏輯判斷時,所有非零數值均被認為為真,而零為假;在邏輯判斷結果中,判斷為真時輸出1,為假時輸出0.三種運算符中,它們的優(yōu)先級關系先后為:算術運算符、關系運算符、邏輯運算符。操作符定義&邏輯與|邏輯或~邏輯非xor邏輯異或any當向量中存在非零元素時為真all當向量中所有元素非零時為真28.12.2024.18>>a=[1:3;4:6;7:9];>>x=5;>>y=ones(3)*5;>>xa=x<=axa=000011111>>b=[010;101;001];>>ab=a&bab=010101001>>nb=~bnb=10101011028.12.2024.19>>a=magic(5);>>a(:,3)=zeros(5,1)a=17240815235014164602022101202131118029>>a1=all(a(:,1)<10)a1=0>>a2=all(a>3)a2=11000>>a11=any(a(:,1)>10)a11=1>>a22=any(a>10)a22=1101128.12.2024.20標點在matlab中一些標點符號也被賦以特殊的意義,或表示要進行一定的運算等,如下表:標點定義標點定義:冒號,具有多種應用功能…續(xù)行符;區(qū)分行,及取消結果顯示%注釋標記,區(qū)分列,及函數參數分隔符等!調用操作系統(tǒng)運算()指定運算過程中的先后次序等[]矩陣定義的標志等{}用于構成單元數組等‘字符串的標示符28.12.2024.21

下面對上表中各標點作進一步的介紹。首先,用冒號來定義行向量。基本格式:x=x1:step:x2(初始值:步長:尾元素數值限)

x=x1:x2(默認步長為1)注意:這里強調x2為尾元素數值限,而不是尾元素值。當x2-x1恰為步長的整數倍時,x2才能成為尾值。例如:28.12.2024.22>>a=1:2:12a=1357911>>a=12:-2:1a=12108642>>a=1:6a=123456>>a=2:2:12a=2468101228.12.2024.23其次,通過使用冒號,可以截取指定矩陣中的部分。例如:>>a=[1:18];a=reshape(a,3,6)%重組矩陣a=147101316258111417369121518>>a1=a(:,1:3)%提取矩陣a的第1到3列元素組成的子矩陣。a1=147258369>>a2=a(1:2,3:end)a2=71013168111417思考:B1=a(1:3,:)?28.12.2024.24

分號在matlab語言中所起的作用是作為分隔行的標志,這里包括在矩陣定義中對行的區(qū)分以及在程序代碼中對行的劃分。在矩陣定義中,分號之間的數據被認為是矩陣的同一行。對于以分號結尾的行語句,matlab語言不會把其運算結果顯示在命令窗口中。逗號主要起兩個作用。其一是逗號是函數參數的分隔符,也是矩陣下標的分隔符。其二是逗號也是區(qū)分矩陣列的標志,在同一行中,逗號分隔開的是各個列。括號是調整運算先后次序的標點,可以通過引用括號來調整運算次序。矩陣的定義需要使用中括號。此外,中括號可以表示空矩陣,并通過該空矩陣實現(xiàn)對矩陣的部分刪除。以下舉例:28.12.2024.25>>a=[1,2,3,4;5,6,7,8;4,3,2,1;8,7,6,5]a=1234567843218765>>a(:,1:2)=[]a=34782165>>b=a([13],:)b=342128.12.2024.26

大括號是單元型數據所特有的標點。后面介紹。小數點“.”,它起到了數學符號的作用;而作為點運算的標志符,它又構成了各種各樣的點運算;最重要的是它可作為結構型數組應用時的專有符號?!啊睘閙atlab語言中的續(xù)行符,但是該續(xù)行符只能出現(xiàn)在各個語義群之間,也就是說不能出現(xiàn)在變量名之間,否則出錯。例如:>>a=sin(pi/4)+cos(pi/4)-tan(pi/4)...+cot(pi/4)a=1.4142>>a=sin(pi/4)+cos(pi/4)-t...an(pi/4)???an(pi/4)|Error:UnexpectedMATLABexpression.28.12.2024.27

在matlab語言中,一行內在“%”之后的文字均被認為是對M文件或程序代碼的解釋部分?!?!”可以在命令窗口直接調用操作系統(tǒng)命令,例如DOS命令,并將結果展示在命令窗口中,比如在命令窗口中調用“!dirc”,以顯示C盤的文件列表。單引號作為字符串的標示符而存在,同時,它在矩陣運算中也表示矩陣的轉置運算及復數的共軛值。28.12.2024.28>>a=[1,2,3,4;5,6,7,8]a=12345678>>a'ans=15263748>>s=3-4i;s'ans=3.0000+4.0000i回到主目錄28.12.2024.29MATLAB語言的核心——矩陣矩陣的生成直接輸入小矩陣(最簡便的方法)

注意點:輸入矩陣時要以“[]”為其標識,即矩陣的元素應在“[]”內部。矩陣的同行元素之間可由空格或“,”分隔,行與行之間用“;”或回車符分隔。矩陣元素可為運算表達式。無任何元素的空矩陣也合法?;氐街髂夸?8.12.2024.30>>A=[1,2,3;4,5,6;7,8,9]A=123456789>>a=[123456789]a=123456789創(chuàng)建帶有運算表達式的矩陣:>>b=[sin(pi/3),cos(pi/4);log(9),tan(pi/4)];%什么樣的結果?28.12.2024.31利用中括號將小矩陣合成一個大矩陣>>b=[1,2;3,4];>>a=[b,b';b^2,b*3]a=12133424710361522912從外部文件引用矩陣(excel,txt)(shuju1,shuju2)28.12.2024.32特殊矩陣的生成常用的特殊矩陣空陣:[]

單位陣:eye(m,n);eye(m)

零矩陣:zeros(m,n);zeros(m)

全1陣:ones(m,n);ones(m)

對角陣:對角元素向量V=[a1,a2,…,an] A=diag(V)

隨機陣:rand(m,n)產生一個m×n的均勻分布的隨機矩陣28.12.2024.33>>eye(2,3)ans=100010>>zeros(2,3)ans=000000>>ones(2,3)ans=11111

1>>v=[567];a=diag(v)a=500060007>>eye(2)ans=1001>>zeros(2)ans=0000>>ones(2)ans=1111

如果已知a為方陣,則v=diag(a)可以提取a的對角元素構成向量v。28.12.2024.34其他特殊矩陣

compan友矩陣函數magic魔方矩陣

hankelHankel矩陣 rosser對稱特征值測試矩陣

hilbHilbert矩陣pascalPascal矩陣

invhilb反Hilbert矩陣vander范德蒙矩陣

……

其中,compan(c),結果是生成一以向量c為系數的多項式的特征矩陣。hilb所生成的hilbert矩陣的特點是矩陣中的元素值為1/(i+j-1)。28.12.2024.35單元型數據和結構型數據單元型變量

單元型變量是matlab語言中較為特殊的一種數據類型。本質上講,單元型變量為任意類型的多維數組。單元型變量可有兩種方式:一種是用賦值語句直接定義,另一種是由cell函數預先分配存儲空間,然后對單元元素逐個賦值。在直接賦值過程中,與在矩陣的定義中使用中括號不同,單元型變量的定義需用大括號,而元素間用逗號隔開?;氐街髂夸?8.12.2024.36>>a=[1,2;3,4]a=1234>>b={1:4,a,‘abcd’}b=[1x4double][2x2double]'abcd'>>cellplot(b)%圖形顯示單元型變量的內容>>celldisp(b)%顯示單元型變量的內容b{1}=1234b{2}=1234b{3}=abcd28.12.2024.37

單元型變量元素的引用采用大括號為下標標識,用小括號只顯示該元素的壓縮形式。例如:>>b{2}ans=1234>>b(2)ans=[2x2double]注意:單元型變量的元素不是以指針方式保存的。思考:如果改變了上例中的a矩陣,那么單元型變量b中的第二個元素改變不?28.12.2024.38

單元型變量與矩陣的另一個區(qū)別是單元型變量自身可以嵌套。例如:>>c=cell(1,3)%另一種定義法>>c{1,1}=1:4;>>c{1,2}=a;>>c{1,3}=b;%b={1:4,a,‘abcd’}>>cc=[1x4double][2x2double]{1x3cell}>>c{3}{3}ans=abcd28.12.2024.39結構型變量

在matlab語言中結構型變量的定義也有兩種方法,其一是直接賦值定義,其二是由函數struct定義。以指針操作符“.”連接結構型變量名與屬性名。直接賦值時,應當指出結構中的屬性名。例如:>>A.a1=‘abcd’;%字符串類型>>A.a2=1;%數值類型>>A.a3=[1,2,3,4];%數組類型>>AA=a1:'abcd'a2:1a3:[1234]

思考:如何引用結構型變量名A中a1屬性的c元素。

28.12.2024.40

由函數struct定義結構型變量,其調用格式如下:結構型變量名=struct(元素名1,元素值1,元素2,元素值2,……)>>B=[1,2;3,4];>>C=struct('c1',1,'c2',B,'c3','abcd')C=c1:1c2:[2x2double]c3:'abcd‘>>C.c2ans=123428.12.2024.41

結構型變量可以嵌套定義。例如:

>>C.c1=A%前面結構型變量AC=c1:[1x1struct]c2:[2x2double]c3:'abcd‘>>C.c1.a1%嵌套結構型變量的引用ans=abcd28.12.2024.42M文件

所謂M文件就是由matlab語言編寫的可在matlab語言環(huán)境下運行的程序源代碼文件。Matlab語言中的M文件可分為命令式(script)和函數式(function)兩種形式。M文件可在matlab的程序編輯器中編寫,也可在其他的文本編輯器中編寫,并以“.m”為擴展名加以保存。命令式文件

命令式文件就是命令行的簡單疊加,matlab會自動按順序執(zhí)行文件中的命令。值得注意的是,命令式文件在運行過程中可以調用matlab工作域內所有的數據,而且所產生的所有變量均為全局變量?;氐街髂夸?8.12.2024.43函數式文件函數式文件主要用于解決計算中的參數傳遞和函數調用的問題。函數式的標志是它的第一行為function語句。函數式文件可以有返回值,也可以沒有。函數式文件執(zhí)行之后,只保留最后結果,不保留任何中間過程,所定義的變量也僅在函數內部起作用,并隨著調用的結束而被清除。即除無特殊聲明外,其變量均為局部變量。注意:存儲函數式M文件時文件名要與主函數名相一致。28.12.2024.44函數式文件:functionabcd(a,b)c=a+bd=b-a保存為abcd.m在工作窗口中調用:>>a=2;b=[3,4,5,6];>>abcd(a,b)c=5678d=1234>>c%結果是什么?命令式文件:a=2;b=[3456];c=a+b;d=b-a;保存為:abcd.m在工作窗口中調用:>>abcd%文件名即可>>cc=5678>>dd=123428.12.2024.45函數變量及變量作用域變量主要有輸入變量、輸出變量及函數內部變量。輸入變量相當于函數的入口數據,是一個函數操作的主要對象。函數的作用就是對輸入變量進行加工以實現(xiàn)一定的功能。函數的輸入變量為形式參數,即只是傳遞變量的值而不是變量的地址,函數對輸入變量的一切的操作和修改如果不依靠輸出變量傳出的話,將不會影響工作空間中該變量的值。

matlab語言提供了函數nargin來控制輸入變量的個數,即可以實現(xiàn)不定參數輸入的操作。例如:在函數test1中,如果調用過程時只提供一個輸入變量,則求該輸入變量的模;如果是兩個輸入變量,則求兩個輸入變量的和28.12.2024.46%如果調用過程時只提供一個輸入變量,則求該輸入變量%的模;如果是兩個輸入變量,則求兩個輸入變量的和functionc=test1(a,b)ifnargin==1c=norm(a);elseifnargin==2c=a+b;end在工作窗口調用:>>a=[234]a=234>>test1(a)ans=5.3852>>b=3;>>test1(a,b)ans=56728.12.2024.47

同時,matlab語言還提供了另一個針對輸入變量的函數varargin。該函數可以實現(xiàn)不定數目輸入變量的函數的程序設計。此時,對函數的一切輸入變量均將存儲在以varargin命名的單元型數組中。例:在函數test2中,實現(xiàn)如下功能:通過使用函數varargin,用戶可以輸入任意多個學生的數學、英語及語文的成績,然后求各科目的平均值。程序如下:28.12.2024.48function[mathavg,englishavg,chineseavg]=test2(varargin)s=length(varargin);%求數組的長度mathsum=0;englishsum=0;chinesesum=0;forj=1:smathsum=mathsum+varargin{j}(1);englishsum=+varargin{j}(2);chinesesum=+varargin{j}(3);endmathavg=mathsum/s;englishavg=englishsum/s;chineseavg=chinesesum/s;思考:此函數如何調用。28.12.2024.49

與輸入變量相對應,matlab語言對輸出變量也提供了相應的函數,如nargout、varargout等。具體的使用與函數nargin和varargin相似。下面給出一個綜合應用示例。示例函數test3中,綜合使用了函數nargin、nargout、narargin、narargout等,函數目的是求各學生(總數不確定)的個人平均成績,以及指定科目的平均成績等。函數test2的調用:[90,89,60]分別表示數學、英語、語文的成績>>[a,b,c]=test2([90,89,60],[79,89,66],[99,98,100])a=89.3333b=32.6667c=33.3333思考:如果多個學生的成績是同一科目的成績放在一個數組中,如何修改test2函數。28.12.2024.50

function[vararout]=test3(lessons,varargin)inputnum=nargin;lessonnum=length(lessons);outputnum=nargout;fori=1:lessonnumswitchlessons(i)case'math'vararout{1}=sum(varargin{1:inputnum}(1));case'english'vararout{2}=sum(varargin{1:inputnum}(2));case'chinese'vararout{3}=sum(varargin{1:inputnum}(3));endendfori=1:inputnumvarargout{i+3}=sum(varargin{i}(:));end28.12.2024.51

在matlab中,函數內部定義的變量除特殊聲明外均為局部變量。如果需要使用全局變量,則應當使用命令global定義,而且在任何使用該全局變量的函數中都應加以定義,在命令窗口中也不例外。注意:變量之間必須以空格分隔,而不能用逗號分隔。示例:function[avgs]=test4(A)globalsss%定義全局變量[m,n]=size(A);fori=1:ms(i)=sum(A(i,:));endss=sum(s);avgs=ss/(m*n);調用test4:>>a=[435;678;357;134];>>test4(a)ans=4.6667>>globalsss>>ssss=56>>ss=122115828.12.2024.52子函數與局部函數

Matlab中也可以定義子函數,用來擴充函數的功能。在函數文件中題頭定義的函數為主函數,而在函數體內定義的其他函數均被視為子函數。子函數只能為主函數或同一主函數下的其他的子函數所調用。示例:functionc=test(a,b)%主函數c=test1(a,b)*test2(a,b);functionc=test1(a,b)%子函數1c=a+b;functionc=test2(a,b)%子函數2c=a-b;28.12.2024.53

局部函數與子函數的區(qū)別是:局部函數可以被其父目錄下的所有函數所調用,而子函數則只能被其所在M文件的主函數所調用;在函數編輯的結構上,局部函數與一般的函數文件的編輯相同,而子函數則只能在主函數文件中編輯。28.12.2024.54程序設計的輔助函數用戶交互函數

鍵盤輸入函數包括函數input及keyboard。函數input用于提示用戶輸入指定參數的值,調用格式:

var=input(‘提示性語句’)

其中,“提示性語句”將給出相應的提示信息以告知用戶輸入的對象,在這種調用過程中,用戶可以有鍵盤輸入任何的可計算的表達式或已賦值的當前工作空間中的變量名,而且返回至變量var中的值也是數值型,所有的輸入以回車鍵加以確認。

28.12.2024.55第一種調用格式:>>a=input('inputexample\n')inputexample1+4a=5>>ischar(a)ans=0第二種調用格式:>>b=input('inputexample\n','s')inputexample1+4b=1+4>>ischar(b)ans=1函數input的另一種調用格式:

var=input(‘提示性語句’,’s’)以該格式調用時,input函數將視用戶鍵盤輸入的一切字符為字符型賦予變量var,而不對其進行任何計算。在提示型語句中可以用“\n”來控制顯示時的換行。例如:28.12.2024.56

另一種輸入函數為keybroad,該函數出現(xiàn)在M文件中時,將終止程序的運行,此時用戶可以查看運算過程中各變量的值必要時也可進行適當的干涉及編輯。同時該函數在matlab語言中均可應用,直到鍵入return并回車,這時程序返回中斷處,繼續(xù)執(zhí)行其余代碼。

matlab也提供了一種中斷函數pause,其調用格式:

pause(n)該命令的作用是中斷程序運行并等待n秒。如果不帶參數,則程序無限期中斷,直到用戶在鍵盤上鍵入任意鍵。28.12.2024.57流程控制語句

Matlab語言的流程控制語句主要有for、while、if-else-end和switch-case這四種語句。for語句

for循環(huán)語句是流程控制語句中的基礎,使用該循環(huán)語句可以以指定的次數重復執(zhí)行循環(huán)體內的語句。

for循環(huán)語句的調用形式:

for循環(huán)控制變量=<循環(huán)次數設定>(可以是已定義的向量,也可在for循環(huán)語句中定義)循環(huán)體

end回到主目錄28.12.2024.58fori=1:4%初始值:步長:終值(步長默認為1) forj=4:-1:1 H(i,j)=1/(i+j-1); endend結果:>>HH=1.00000.50000.33330.25000.50000.33330.25000.20000.33330.25000.20000.16670.25000.20000.16670.142928.12.2024.59

循環(huán)次數的設定還可以由mxn矩陣來實現(xiàn),此時,整個循環(huán)將執(zhí)行n次,并且每次循環(huán)變量為一列向量。例如:a=[1234;5678];s=0;fori=ais=s+1;endi=15i=26i=37i=48s=?28.12.2024.60while語句

while循環(huán)語句與for循環(huán)語句不同的是,前者是以條件的滿足與否來判斷循環(huán)是否結束的,而后者則是以執(zhí)行次數是否達到指定值來判斷的。

while循環(huán)語句的一般形式:

while<循環(huán)判斷語句>

循環(huán)體

end

循環(huán)判斷語句為某種形式的邏輯判斷表達式。當表達式的值為真時就執(zhí)行循環(huán)體內的語句;否則退出。當循環(huán)判斷語句為矩陣時,當且僅當所有的矩陣元素非零時,邏輯表達式的值為真。例如:28.12.2024.61n=0;while2^n<100n=n+1;end

從例子中可以看出while循環(huán)語句與for循環(huán)語句是有異曲同工之處的。但是兩者還是有區(qū)別的,for循環(huán)語句一般適用于已知到循環(huán)次數,而不知道循環(huán)運算目標的問題;while循環(huán)語句則一般適用于已知循環(huán)運算目標,而循環(huán)次數未知的問題。break語句:當程序流程運行至該命令時,則不論循環(huán)控制變量是否滿足循環(huán)判斷語句,均將退出當前循環(huán),執(zhí)行循環(huán)后的其他語句。continue命令:當程序流程運行至該命令時,會忽視其后的循環(huán)體操作轉而執(zhí)行下一層的循環(huán)。28.12.2024.62例1.計算級數:S=1+2+22+23+···+263=法一:s=0;i=0;whilei<64s=s+2^i;i=i+1;end法二:>>n=0:1:63;>>S=sum(2.^n)28.12.2024.63if-else-end語句

if-else-end語句的一般形式:

if<邏輯判斷語句>

邏輯值為“真”時執(zhí)行語句

else

邏輯值為“假”時執(zhí)行語句

end例如:

ifa==1a=a+1;elsea=a+2;end28.12.2024.64

在程序設計中,也常碰到需要進行多重邏輯選擇的問題,這時可以采用if-else-end語句的嵌套形式:

if<邏輯判斷語句1>

邏輯值1為“真”時執(zhí)行語句

elseif<邏輯判斷語句2>

邏輯值2為“真”時執(zhí)行語句

elseif<邏輯判斷語句3>……else

當以上所有的邏輯值均為“假”時執(zhí)行語句

end28.12.2024.65IfA>B'greater'elseifA<B'less'elseifA==B'equal'elseerror('AandBaredifferentdata')end解讀這段程序:a=10000;n=0;z=1;whilez<an=n+1;ifmod(n,2)==1continueendz=2^n-1;if~isprime(z)%是否質數

breakendend28.12.2024.66switch-case語句

switch-case語句是用于解決多分支判斷選擇的問題。switch-case語句的一般表達形式:

switch<選擇判斷量>case選擇判斷值1

選擇判斷語句1case選擇判斷值2

選擇判斷語句2……otherwise

判斷執(zhí)行語句end28.12.2024.67例如:code=1switchcodecase-1disp('error');case0disp('writeinEnglish');case1disp('writeinChinese');otherwisedisp('writeinFrench');end結果:writeinChinese

注意:在matlab語言中,即使有多條case判斷語句為真,也只執(zhí)行所遇到的第一條為真的語句。不必像C語句那樣,在每條case語句后加上break語句防止繼續(xù)執(zhí)行后面為真的case條件語句。28.12.2024.68例:求雞兔同籠問題:雞兔同籠,頭共36,腳共100.求雞、兔各幾只?程序如下:i=1;while1ifmod(100-2*i,4)==0&i+(100-2*i)/4=36%函數mod表示取余

break;endenda1=i;a2=36-i;上述程序中有兩個錯誤,請指出!28.12.2024.69MATLAB在數值計算中的應用數值計算的基本要素及相關函數數據的統(tǒng)計分析曲線擬合及插值數值分析28.12.2024.70數值計算的基本要素及相關函數MATLAB語言在數值計算中的基本要素主要有數組、多項式和矩陣。數組及相關函數數組的創(chuàng)建數組的定義相當簡捷,主要有三種格式:

x=x1:step:x2(初始值:步長:尾元素數值限)y=linspace(x1,x2,n)(初始值:終止值:數組元素個數)n默認為100y=logspace(x1,x2,n)(初始值:終止值:數組元素個數)n默認為50回到主目錄28.12.2024.71例如:>>a=1:2:12a=1357911>>b=linspace(1,10,10)b=12345678910>>c=logspace(0,2,10)c=1.00001.66812.78264.64167.742612.915521.544335.938159.9484100.000028.12.2024.72數組的操作

例如:a=1357911>>a(3)%取a數組中的第3個元素ans=5>>a(2:5)%取數組a中第2個元素到第5個元素ans=3579>>a.^2%數組的平方ans=19254981121>>length(a)%檢測數組的長度,返回數組的元素個數ans=628.12.2024.73多維數組多維數組從某種角度來看,它是矩陣在維數上的擴張,實際上也是矩陣中的一個特例。它可以是數值型、字符型、單元型或結構型等。多維數組在創(chuàng)建及處理上與一維數組或普通矩陣有很大的不同。其創(chuàng)建方法有很多,可以仿照一維數組的定義,也可以通過matlab的有關函數來創(chuàng)建。直接賦值:例如:>>A(:,:,1)=[123;456;678];>>A(:,:,2)=[789;567;321];>>A(:,:,3)=[987;654;234];28.12.2024.74注意多維數組的顯示方法:>>AA(:,:,1)=123456678A(:,:,2)=789567321A(:,:,3)=987654234A(2,3,2)=?A(:,:,1)A(:,:,2)A(:,:,3)123456678789567321987654234數組A就像一個分塊矩陣,每塊都是3x3的矩陣。28.12.2024.75

還可以簡單的只對其中某一維的元素進行賦值。系統(tǒng)會根據賦值的情況來確定該變量的具體維數結構并將其他未賦值的元素自動賦為零。例如:>>B(:,:,3)=[1,2;3,4];>>BB(:,:,1)=0000B(:,:,2)=0000B(:,:,3)=1234>>C(:,2,:)=[12;34];>>CC(:,:,1)=0103C(:,:,2)=0204問:e(:,2,:)=[123;456]將是什么樣的數組?S(2,:,:)=[123;456]?123428.12.2024.76matlab語言中也提供了相應的函數來創(chuàng)建多維數組,如rand、ones、zeros等。其使用方法與創(chuàng)建一維數組相同。例如:>>D=rand(2,3,2,2)%該例中顯示了四維數組。%類似于2x2的分塊矩陣,每塊都是2x3的矩陣。D(:,:,1,1)=0.95010.60680.89130.23110.48600.7621D(:,:,2,1)=0.45650.82140.61540.01850.44470.7919D(:,:,1,2)=0.92180.17630.93550.73820.40570.9169D(:,:,2,2)=0.41030.05790.81320.89360.35290.00991112212228.12.2024.77

函數cat也是創(chuàng)建多維數組的一個實用的工具。其調用方法:cat(dim,A1,A2,…)

輸入參數中的dim為定義的維數,A1、A2等為構建數組的元素。例如:>>E=cat(4,[12;34],[56;78])E(:,:,1,1)=1234E(:,:,1,2)=567828.12.2024.78多項式及相關函數

多項式的定義

多項式的定義如下:對于多項式,用以下行向量表示:這樣就把多項式的問題轉化為行向量的問題了。28.12.2024.79

最簡單的多項式輸入即為直接的向量輸入,matlab自動將向量元素按降冪順序分配給各系數值。例如:輸入多項式x^3-5x^2+6x-33.>>p=[1-56-33];>>poly2sym(p)%此函數可將多項式向量表示成符號多項式形式

ans=x^3-5*x^2+6*x-3328.12.2024.80多項式的操作下表是matlab中較常用的多項式函數。函數名說明函數名說明roots多項式求根polyfit多項式擬合poly由根創(chuàng)建多項式polyder求多項式導數polyval多項式求值conv多項式乘法polyvalm矩陣多項式求值deconv多項式除法28.12.2024.81

多項式求根函數roots的調用格式:

roots(P)通過該函數可以求得方程p=0在復數范圍內的解。例如:函數poly與roots相對應,其作用是由多項式對應的方程的根來創(chuàng)建多項式。例如:>>p=[103211];>>r=roots(p)r=0.3202+1.7042i0.3202-1.7042i-0.72090.0402+0.6780i0.0402-0.6780i>>poly(r)ans=1.00000.00003.00002.00001.00001.0000可見roots與poly是互逆運算。注意:由poly創(chuàng)建的多項式最高次系數為1.28.12.2024.82Matlab中通過函數polyval和函數polyvalm可求得多項式在給定點的值:函數polyval:在輸入變量值代人多項式計算時是以數組為單位的,polyval(p,v)。函數polyvalm:以矩陣為計算單位,進行矩陣式運算,以求多項式的值,polyvalm(p,v)。這兩種計算在數值上有很大差別。例如:對同一多項式及變量值分別計算矩陣計算值和數組計算值。28.12.2024.83>>p=[11155125];b=[11;11];>>polyval(p,b)ans=192192192192>>polyvalm(p,b)ans=206818120628.12.2024.84

多項式的乘法由函數conv來實現(xiàn),此函數同于向量的卷積;多項式的除法由函數deconv來實現(xiàn),此函數同于向量的解卷。例:計算兩個多項式的乘除法。>>p=[2-56-19];poly2sym(p)ans=2*x^4-5*x^3+6*x^2-x+9>>d=[3-90-18];poly2sym(d)ans=3*x^2-90*x-18>>pd=conv(p,d)pd=6-195432-4539-792-162>>poly2sym(pd)ans=6*x^6-195*x^5+432*x^4-453*x^3+9*x^2-792*x-162>>p1=deconv(pd,d)%與p相同p1=2-56-1928.12.2024.85多項式的微分由函數polyder來實現(xiàn)。例:對上例中多項式p進行微分計算。>>p=[2-56-19];poly2sym(p)ans=2*x^4-5*x^3+6*x^2-x+9>>dp=polyder(p)dp=8-1512-1>>poly2sym(dp)ans=8*x^3-15*x^2+12*x-128.12.2024.86矩陣及相關函數矩陣的基本運算矩陣的加減運算與傳統(tǒng)的矩陣運算相同,但在乘法運算中,就有關于算術乘(矩陣乘方)與點乘(點乘方)的區(qū)別,下面用示例說明兩者的具體差別。>>a=[12;34];>>b=[56;78];>>c=a*bc=19224350>>d=a.*bd=5122132>>a^2ans=7101522>>a.^2ans=1491628.12.2024.87

在介紹矩陣除法前,先介紹矩陣與線性方程組之間的關系。對于線性方程組Ax=b,其中A為(n×m)階矩陣:n=m且非奇異時,方程為恰定方程;n>m 方程為超定方程;(方程個數大于未知數的個數)n<m方程為不定方程。(方程個數小于未知數的個數)如果n>m,矩陣除法仍然可以得到方程的解,但不是精確解,而是近似解,該解確保誤差向量Ax-b的二范數最小。如果n<m,即存在無窮多解,矩陣除法將會產生包含零元素最多的解,并一定是最小二乘解。28.12.2024.88例如:n>m>>A=[1,4,6;3,5,6;7,8,3;4,6,7];>>b=[34,54,57,87];>>x=A\b'x=25.2078-20.520114.8480>>res=A*x-b‘;>>norm(res,2)ans=9.8821例如:n<m>>A=[2445;3451;7836];>>b=[234557];>>x=A\b'x=010.21871.8333-5.0417>>norm(A*x-b',2)ans=2.5619e-01428.12.2024.89線性方程組的另一種解法:就是利用偽逆函數pinv:x=pinv*b。例如:>>A=[2445;3451;7836];>>b=[234557];>>y=pinv(A)*b‘y=4.97104.00503.4903-3.3847>>norm(A*x-b',2)ans=2.5619e-01428.12.2024.90矩陣函數

這里介紹部分常用的函數。以示例的形式說明。>>A=[123;456;789];>>diag(A)%抽取矩陣的對角線ans=159>>diag(diag(A))%由矩陣的對角線生成對角陣ans=10005000928.12.2024.91A=123456789>>tril(A)%抽取矩陣的下三角ans=100450789>>flipdim(A,2)%以第2列為軸線翻轉矩陣ans=32165498728.12.2024.92A=123456789>>find(A)‘%返回矩陣A的非零元素的存儲下標,是列向量,故轉置顯示ans=123456789>>rot90(A)%矩陣A逆時針旋轉90度ans=369258147>>rank(A)%求矩陣A的秩ans=228.12.2024.93A=123456789>>det(A)%求矩陣A的行列式ans=0>>cond(A)%求矩陣的條件數ans=5.0524e+016

在matlab中,判斷矩陣的奇異性一般用函數cond,求矩陣的條件數,即矩陣最大奇異值與最小奇異值的比值。當矩陣的條件數很大時,說明矩陣趨近于奇異。28.12.2024.94函數[x,y]=eig(A)可以求出矩陣A的特征值和特征向量的值

x為特征向量矩陣,y為特征值矩陣。>>A=[73-2;34-1;-2-13];>>[x,y]=eig(A)x=0.57740.0988-0.8105-0.5774-0.6525-0.49080.5774-0.75130.3197y=2.00000002.39440009.605628.12.2024.95Svd函數給出了矩陣的奇異值以及奇異值分解矩陣。[U,S,V]=svd(X)其中X=U×S×V’>>a=[1;1];>>[U,S,V]=svd(a)U=0.7071-0.70710.70710.7071S=1.41420V=128.12.2024.96

LU分解:[L,U]=lu(A)又稱三角分解,目的是分解成一個下三角陣L和一個上三角陣U的乘積,即A=L×U>>a=[123;241;467];>>[l,u]=lu(a)l=0.25000.50001.00000.50001.000001.000000u=4.00006.00007.000001.0000-2.5000002.5000注意:L實際上是一個“心理上”的下三角矩陣,它事實上是一個置換矩陣P的逆矩陣與一個真正下三角矩陣L1(其對角線元素為1)的乘積。28.12.2024.97Chol分解:如果A為n階對稱正定矩陣,則存在一個非奇異下三角實矩陣L,使得A=LLT,當限定L的對角元素為正時,這種分解是唯一的。>>a=[4-11;-14.252.75;12.753.5];>>chol(a)ans=2.0000-0.50000.500002.00001.5000001.000028.12.2024.98

正交分解:A=QR將矩陣A做正交化分解,使得Q*R=A,其中Q為正交矩陣(其范數為1,指令norm(Q)=1),R為對角化的上三角矩陣。>>a=[111;2-1-1;2-45];>>[q,r]=qr(a)q=-0.3333-0.6667-0.6667-0.6667-0.33330.6667-0.66670.6667-0.3333r=-33-30-3300-328.12.2024.99數據的統(tǒng)計分析

一般來講,矩陣的每一列代表統(tǒng)計過程不同的數據結果,而每一行則相應代表不同的樣品。統(tǒng)計函數介紹

統(tǒng)計函數中的大部分函數都是針對列進行操作的。下表中列出部分常用的統(tǒng)計函數?;氐街髂夸?8.12.2024.100函數說明函數說明max最大分量cumsum列累計和min最小分量cumprod列累計積mean平均值或列的平均值sort按升序排列std列的標準差sortrows按升序對行排列var列的方差trapz梯形數值積分corrcoef相關系數cov協(xié)方差矩陣sum列求和conv卷積prod列求積hist直方圖28.12.2024.101應用實例

數據如下給出了12個學生的英語、數學、物理、化學和哲學的成績。score=90999897779067875667899976677778889876895666754586677878899088788975856575766374736384769076869

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論