版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、- PAGE 52 -Matlab 與數(shù)學實驗講義第一章Matlab 初步Matlab 是 Mathworks 公司于 1984 年推出的數(shù)值計算軟件.其三大核心功能為:數(shù)值計算符號計算繪圖能夠在很多領域進行應用,如:數(shù)值分析數(shù)值和符號計算工程與科學繪圖控制系統(tǒng)的設計與仿真數(shù)字圖像處理技術數(shù)字信號處理技術通訊系統(tǒng)設計與仿真財務與金融工程第一節(jié)Matlab 的界面與運行一、Matlab 的界面Matlab 的界面上共有五個窗口:1、命令窗口(Commandwindow)在命令窗口中可以直接輸入命令,以實現(xiàn)計算或繪圖的功能.2、起始面板(Launch Pad)該窗口中顯示 Matlab 總包和已安
2、裝的工具箱的幫助、演示、GUI 工具和產品主頁 4 個方面的內容.3、工作空間(workspace)該窗口顯示當前 Matlab 的內存中使用變量的信息,包括變量名、變量數(shù)組大小,變量字節(jié)大小和變量類型.可以雙擊變量名,打開數(shù)組編輯器窗口(ArrayEditor),顯示變量的具體內容,也可以修改數(shù)據(jù).4、命令歷史(CommandHistory)該窗口顯示所有執(zhí)行過的命令.其作用在于:查看曾經執(zhí)行的命令;重復利用原來輸入的命令行.在命令歷史窗口中直接雙擊命令,就可以執(zhí)行該命令行.5、當前目錄(CurrentDirectory)該窗口顯示當前工作目錄下所有文件的文件名、文件類型和最后修改時間 .可
3、以在窗口上方的小窗口中修改工作目錄.二、Matlab 的運行方式兩種運行方式:1、命令行方式在命令窗口中輸入命令,按回車鍵程序將運行.這種方式的缺點是難以處理比較復雜的問題和有大量數(shù)據(jù)的問題.2、M 文件方式M 文件方式是指一個以 m 為擴展名的 M 文件中輸入一系列命令和數(shù)據(jù),然后讓 Matlab 來執(zhí)行.建立 M 文件的步驟為:點擊 FileNew M-file;在 M 文件編輯窗口中輸入程序內容;點 File Save,以 m 為擴展名存盤.注意:1、M 文件名有兩種類型:腳本 M 文件和函數(shù) M 文件.其中函數(shù) M 文件的文件名必須與函數(shù)名一致(在后面將具體講解).2、M 文件可以在命
4、令行中隨時調用執(zhí)行,也可以在 M 文件編輯窗口中的Debug菜單中選擇 Run 執(zhí)行.第二節(jié)簡單數(shù)學運算一、運算表加法運算,適用于兩個數(shù)或兩個同階矩陣相加.減法運算*乘法運算.*點乘運算,用于數(shù)組(或矩陣)之間的運算,表示對應元素相乘/除法運算./點除運算,用于數(shù)組(或矩陣)之間的運算,表示對應元素相除乘冪運算.點乘冪運算,用于數(shù)組(或矩陣)之間的運算,表示對應元素作冪運算反斜杠表示左除,用于矩陣之間的運算在計算中“( )”表示運算優(yōu)先級。 1 11 4 1例 1 作數(shù)學運算: 4 100 2 83 2 9 9 100(1/4)*(1/9)(-1/2)+8(-1/3)*(4/9)(1/2)%表
5、示回車鍵注意:命令中的%及其后面的內容不必輸入,它是對命令的解釋和說明。二、數(shù)學函數(shù)Matlab 提供了若干函數(shù),在編寫程序時可以直接按照以下格式調用,注意其中的括號不能省略.函數(shù)名稱函數(shù)名稱abs(x)x 絕對值sqrt(x)開平方exp(x)以 e 為底的指數(shù)log(x)自然對數(shù)log2(x)以 2為 底的數(shù)log10(x)以 10 為底的數(shù)min(x)最小值max(x)最大值sum(x)元素的總和sign(x)符號函數(shù)rem(x,y)x 除以y 的余數(shù)fix(x)取整round(x)最接近 x 的整gcd(x,y)整數(shù) x,y 的最大公因數(shù)數(shù)g,c,d=gcd(x,y)求 g,c,d 滿
6、足lcm(x,y)整數(shù) x,y 的最小公倍g=cx+dy數(shù)sin(x)正弦函數(shù)asin(x)反正弦函數(shù)cos(x)余弦函數(shù)acos(x)反余弦函數(shù)反 正tan(x)正切函數(shù)atan(x)切數(shù)sinh(x)雙曲正弦asinh(x)反雙曲正弦cosh(x)雙曲余弦acosh(x)反雙曲余弦tanh(x)雙曲正切atanh(x)反雙曲正切real(z)復數(shù) z 的實部imag(z)復數(shù) z 的虛部abs(z)復數(shù) z 的模conj(z)復數(shù) z 的共軛angle(z)復數(shù) z 的幅角factorial(n)求 n 的階乘combntns(x,m)perms(x)nchoosek(n,m) prod(
7、n:m)列舉出從 n 個元素中取出 m 個元素的組合。其中,x 是含有 n 個元素的向量給出向量 x 的所有排列從 n 各元素中取 m 個元素的所有組合數(shù)求排列數(shù):m*(m-1)*(m-2)*(n+1)*n1例 2、作數(shù)學運算sin 24 e3 3ln(2 5) 10sin(1/10)+24+exp(3)+3*log(2+sqrt(5) 三、Matlab 中的數(shù)1、實數(shù)Matlab 中的實數(shù)只有一種數(shù)據(jù)格式,那就是雙精度數(shù)值,其有效值是十進制16 位,范圍是 10 的308 次冪,即實數(shù)有七種顯示格式,以 為例,見下表:Matlab 命令顯 示 形 式說明2.225110 3081.79771
8、0+308formatlong3.1415926535897916位十進制數(shù)format elong3.14159265358979e+016位十進制加指數(shù)format eshort3.1416e+0005位十進制數(shù)加指數(shù)formatshort3.1416二位整數(shù), 四位小數(shù)formatbank3.14兩位小數(shù)formathex400921fb54442d1816位十六進制數(shù)formatrat355 / 113有理數(shù)分數(shù)近似Matlab 在默認情況下以 format short 格式顯示.2、復數(shù)虛數(shù)符號 Matlab 啟動時定為 i,j,連寫在數(shù)字后面可以不用乘號 .例如a=1+2i,b=c
9、os(2)+sin(2)*i如果用戶在程序中另外給 i,j 賦值,則它們的虛數(shù)意義就失效.例 3在不同的數(shù)據(jù)顯示顯示下計算 5+sin75+sin(7) ans=5.6570format rat5+sin(7) ans=3117/551format long5+sin(7) ans= 5.65698659871879第三節(jié)變量一、變量Matlab 中參與計算的數(shù)據(jù)需要存放在一個儲存空間中,每個儲存空間都給予一個名稱,就是變量的名稱。Matlab 中變量的命名規(guī)則是:變量名必須是不含空格的單個詞;變量名區(qū)分大小寫;變量名最多不超過 19 個字符;變量名必須以字母打頭;變量名中不允許使用標點符號;
10、不要使用內部函數(shù)名。變量賦值格式:變量名=數(shù)給變量賦值時滿足新值代替舊值的規(guī)則.二、特殊變量(常量)在 Matlab 中一些特殊的變量,如下:特殊變量ans pi eps flops inf NaN i,jnargin nargout realminrealmax取值用于結果的缺省變量名圓周率計算機的最小數(shù),和 1 相加時產生一個比 1 大的數(shù)浮點運算數(shù)無窮大,如 1/0不定量,如 0/0i=j=1所用函數(shù)的輸入變量數(shù)目所用函數(shù)的輸出變量數(shù)目最小可用正實數(shù)最大可用正實數(shù)三、常見基本操作:Matlab 命令who 變量名whosclearsave 變量名load clcshift +enter解
11、釋查詢變量的信息查詢所有變量的信息刪除所有變量保存指定變量載入數(shù)據(jù)文件中的變量察除所有命令換行編寫命令,但不執(zhí)行命令四、標點符號標點符號需要在英文狀態(tài)下輸入,常見的有,;%命令分隔符號,顯示的結果命令分隔符號,不顯示的結果它后面為注釋文字()續(xù)行符號(使用時前面加空格)運算優(yōu)先級例 1a=20;b=3;c=a+b,d=a*b運行結果:c =23d =60例 2 交換兩個變量的取值a=1;b=2;c=a; a=b; b=c; a,b 運行結果:a =2b =1第四節(jié)符號運算數(shù)值運算是指實數(shù)之間的運算。在運算中,如果有變量不被賦值像字母一樣運算,這種運算為符號運算.符號運算需要先將變量符號化。一、
12、創(chuàng)建符號變量命令格式 1:sym(變量)命令格式 2:syms變量 1變量 2變量 n例 1sqrt(2) ans =1.4142sqrt(sym(2) ans =2(1/2)二、創(chuàng)建符號表達式方法 1:sym(表達式)方法 2:先創(chuàng)建符號變量,再用符號變量及運算符表示表達式例 2建立符號表達式 ax2+by+c,并求 x=1,y=2 的值syms a b c x y u=a*x2+b*y+c, x=1;y=2;eval(u) 運行結果:u = a*x2+b*y+cans =a+2*b+c其中命令 eval 表示計算符號表達式的值,但并不改變 u 本身的值.三、符號表達式的運算1、四則運算與冪
13、運算與數(shù)值的運算一致.2、合并同類項命令格式:collect(S)%其中S 為符號表達式,以默認變量(離x 最近的變量)作為輸出變量collect(S,v)%以變量 v 作為輸出變量例 3syms x ys=x2*y+y*x-x2-2*x;collect(s) ans =(y-1)*x2+(y-2)*xcollect(s,y) ans =(x2+x)*y-x2-2*x3、因式分解命令格式:factor(S)說明:其中 S 為符號表達式.例 4 syms a b x y s=5*a*x+5*b*x+3*a*y+3*b*y; factor (s) ans = (a+b)*(5*x+3*y)4、符號
14、表達式的簡化命令格式: simple(S)說明:其中 S 為符號表達式,有些時候要用兩次.例 5syms xS=2*cos(x)2-1; simple(S) 運行結果:simplify: 2*cos(x)2-1 radsimp:2*cos(x)2-1 combine(trig):cos(2*x) factor:2*cos(x)2-1 expand:2*cos(x)2-1 combine:cos(2*x) convert(exp):2*(1/2*exp(i*x)+1/2/exp(i*x)2-1 convert(sincos):2*cos(x)2-1 convert(tan):2*(1-tan(1
15、/2*x)2)2/(1+tan(1/2*x)2)2-1 collect(x):2*cos(x)2-1 ans = cos(2*x)5、復合運算命令格式:compose(f,g) 計算 fg(x)例 6syms x f=1/(1+x2);g=sin(x);compose(f,g) ans =1/(1+sin(x)2)6、反函數(shù)運算命令格式:finverse(f) 或者 finverse(f,v)說明: finverse(f,v)中,返回變量為 v 的函數(shù) f 的反函數(shù),未指定時, 默認為 x.例 7syms x f=x2;finverse(f) Warning: finverse(x2) is
16、not unique. In D:matlabtoolboxsymbolicsymfinverse.m at line 43 ans =x(1/2)7、替換求值命令格式:subs(S,old,new)或者 subs(S, new)說明:將符號表達式 S 中的變量 old 用 new 代替.若沒有指定變量 old,則默認將 x 代替為 new.例 8syms x y s=x2*y+x*sin(y); subs(s,x,2) ans =4*y+2*sin(y)subs(s,y,pi) ans = x2*pi四、符號型與數(shù)值型數(shù)據(jù)的顯示命令格式 1:x=double(S)說明:顯示符號表達式 S 的
17、雙精度數(shù)值型數(shù)據(jù),不改變 S 本身的值.命令格式 2:s=sym(x,選型)說明:顯示數(shù)值型數(shù)據(jù)的符號型數(shù)據(jù),不改變 x 本身的值. 選項可以是:r或f或e,它們分別表示有理數(shù)形式,雙精度形式,指數(shù)顯示.例 9a=sym(2/5) a = 2/5 double(a) ans =0.4000 sym(0.007,r) ans = 7/1000命令格式 3:vpa(S,n)%顯示表達式 S 的 n 個有效數(shù)字,S 是符號型或數(shù)值型例 10 vpa(pi,20) ans = 3.1415926535897932385五、建立函數(shù)的 4 種方法Matlab 中常用的函數(shù)類型有 4 種,不同的命令適用不
18、同的函數(shù),效果也不一樣。1、函數(shù) M 文件函數(shù) M 文件是 M 文件類型之一,它的作用是定義新函數(shù).函數(shù) M 文件建立步驟如下:點擊 FileNew M-file;在 M 文件編輯窗口中輸入程序內容;點 File Save,以 m 為擴展名存盤,且文件名等于函數(shù)名.其中在 M 文件編輯窗口中,程序第一行格式為:function因變量名=函數(shù)名(自變量名)(x 120)2 1202下面各行為從自變量計算因變量的語句,并將最終結果賦給因變量.(x 20)2 1002例 11定義函數(shù) f (x) 第一步建立函數(shù):在 M 文件編輯窗口中輸入程序: function yy=ff(x),并求 f (100
19、)yy=sqrt(x-20)2+1002)+sqrt(x-120)2+1202)以 ff.m 為文件名存盤.第二步計算在 Matlab 命令窗口中輸入程序:ff(120) 2、符號函數(shù)符號函數(shù)就是關于自變量 x 的符號表達式例 12建立函數(shù) y x2 x 1 ,并求當 x 1 時, y 的值。syms x y=x2+x+1; x=1;eval(y) ans =33、字符串函數(shù)字符串量本質上就是以符號量為元素的向量。例 13建立函數(shù) y x2 x 1 ,并求當 x 1 時, y 的值。syms xy=x2+x+1;%y 是一個字符串量x=1;eval(y) ans =34、inline 函數(shù)建立
20、格式:函數(shù)名=inline(函數(shù)表達式,自變量 1,自變量 2)函數(shù)名=inline(函數(shù)表達式)%自變量默認為 x 注:inline 函數(shù)與函數(shù) M 文件基本一致,優(yōu)點在于更方便。例 14建立函數(shù) y x2 x 1 ,并求當 x 1 時, y 的值。ff=inline(x2+x+1);ff(1) ans =3第五節(jié)數(shù)組與矩陣初步本節(jié)僅介紹數(shù)組與矩陣的創(chuàng)建和簡單運算,其更深入的介紹見附錄線性代數(shù)部分. Matlab 的基本運算單位是矩陣,即便是一般實數(shù)也是一行一列的矩陣, 所以對矩陣的處理很重要。一、基本概念定義:稱 m 行 n 列的數(shù)表 aaa 11121n aaa21222n為矩陣,稱 1
21、 行 n 列的數(shù)表aaam1m2mna , a 1n或者 n 行 1 列的數(shù)表 a 1 a n為數(shù)組(或向量)。數(shù)組是特殊的矩陣。二、創(chuàng)建1、數(shù)組的創(chuàng)建有兩種方式:直接輸入例 1x=1,2,3,5,-5,8 %元素之間也可以用空格隔開x =1235-58等差元素數(shù)組數(shù)組的元素構成等差數(shù)列,則使用下列命令:x=a:b%創(chuàng)建從 a 開始,以 1 為公差,到b 結束的行向量x=a:d:b%創(chuàng)建從 a 開始,以d 為公差,到b 結束的行向量x=linspace(a,b,n)%創(chuàng)建從 a 開始,到b 結束,有n 個元素的行向量例 2 a=2:5 a =2345b=2:3:10b =258 c=linsp
22、ace(1,5,3) c =1352、矩陣的創(chuàng)建逗號或空格用于分隔某一行的元素,分號用于區(qū)分不同的行. 除了分號,在輸入矩陣時,按 Enter 鍵也表示開始新一行. 輸入矩陣時,嚴格要求所有行有相同的列.例 3 A=1 2 3 4;5 6 7 8;9 10 11 12 B=111122223333 A =123456789101112B =111122223333三、運算設 a=a1,a2,an, c 是標量,則a+c=a1+c,a2+c,an+c a.*c=a1*c,a2*c,an*ca./c= a1/c,a2/c,an/c (右除) a.c= c/a1,c/a2,c/an (左除) a.c
23、= a1c,a2c,ancc.a= ca1,ca2,can 設 a=a1,a2,an, b=b1,b2,bn,則a+b= a1+b1,a2+b2,an+bn a.*b= a1*b1,a2*b2,an*bna./b= a1/b1,a2/b2,an/bn a.b=b1/a1,b2/a2,bn/an a.b=a1b1,a2b2,anbn矩陣之間的、.*、./、.運算與數(shù)組一致。凡點運算都是指對應元素分別運算。例 4 a=1,2,3;b=4,5,6;a+b,a.*b,a.bans =579ans =41018ans =132729 c=1,2,3;4,5,6;d=4,5,6;7,8,9;c+d,c.*
24、d,c.dans=579111315ans=41018284054ans=1327291638439062510077696四、元素的調用1、數(shù)組元素的調用x(i)%表示數(shù)組 x 的第 i 個元素.x(a,b,c)%表示數(shù)組 x 中第 a 個、第b 個、第c 個元素組成的數(shù)組2、矩陣元素的調用A(i)%表示矩陣 A 的第 i 個元素,矩陣元素的順序為從第一列的元素開始計數(shù),然后第二列,依次類推A(i,j)%表示矩陣 A 的第 i 行,第 j 列元素A(i,:)%表示矩陣 A 的第 i 行元素A(:,j)%表示矩陣 A 的第 j 列元素A(a:b,c:d)%表示矩陣 A 的第 a 行至第 b 行
25、,第 c 列至第 d 列組成的新矩陣第二章程序設計對于簡單的問題,可以直接調用命令解決,但對于復雜一些,特別是計算過程較長的問題,就需要編程計算了。Matlab 可以像 c 語言一樣進行程序編寫和設計.關系操作符說明邏輯操作說明一、關系與邏輯符小于且大于否定=大于或等于= =等于=不等于利用關系與邏輯的符號,可以編寫很多數(shù)學表達式.二、循環(huán)語句循環(huán)語句最好以 M 文件的方式編寫和運行.1、for 循環(huán)命令格式: orx=數(shù)組命令串;end在for 和end 語句之間的命令串按數(shù)組中的每一列執(zhí)行一次. 在每一次迭代中,x 被指定為數(shù)組的下一列,即在第 k 次循環(huán)中,x=數(shù)組中的第 k 個元素.n
26、例 1對 n=1,2,20,分別求 x = sin n 的值.10程序如下:forn=1:20 x(n)=sin(n*pi/10);% 將每一次的運算值付給向量的一個元素,以方便調用end x例 2求數(shù)列an 1 的前 100 項和。n2s=0;n=100;fork=1:ns=s+1/k2;end s運行結果:s =1.6350例 3建立一個求階乘的函數(shù) M 文件,并求10 1。(2n)!在 M 文件窗口中輸入: functiony=jc(x) p=1;for k=1:xp=p*k; endy=p;以 jc 為文件名保存,在命令窗口中輸入: s=0;n=10;for k=1:ns=s+jc(2
27、*k);n1end s運行結果:s = 2.4393e+0182、While 循環(huán)命令格式: while條件命令串;end只要條件為真,就執(zhí)行while 和 end 語句之間的命令串. 它與 for 循環(huán)以固定次數(shù)求一組命令相反,while 循環(huán)以不定的次數(shù)求一組語句的值.例 4 求滿足不等式1 1 1 10 的最小 n 的值。2n s=0;n=0;while s1y=x2+1;endif xx= 0:0.001:2*pi;%0.001 為向量元素的公差,越小越點越多,圖形越真實y1=sin(x); y2=cos(x);plot(x,y1,r,x,y2, co) 例 2在0, 上畫 y=cos
28、 x 的圖形. 程序如下:ezplot(cos(x) ,0,pi) 也可以這樣編寫:syms x y=cos(x);ezplot(y,0,pi) 例 3在0,2 上畫 x cos3t , y sin3t 星形圖.程序如下: ezplot(cos(t)3,sin(t)3,0,2*pi) 例 4在-2,0.5,0,2上畫隱函數(shù)ex sin(xy) 0 的圖. 程序如下:ezplot(exp(x)+sin(x*y),-2,0.5,0,2) 例 5在區(qū)間1,1 畫出函數(shù) y sin 1 的圖形.x程序如下:fplot(sin(1/x),-1,1) 例 6作出極坐標方程為r 2(1 cos t) 的曲線
29、的圖形.程序如下:t=0:0.1:2*pi;r=2*(1-cos(t);polar(t,r) 例 7分別作出取整函數(shù) y x 和函數(shù) y x x 的圖形程序如下:subplot(1,2,1),ezplot(fix(x),subplot(1,2,2),ezplot(x-fix(x) 例 8畫冪函數(shù) y xk, k 1,2,3,4 的圖像. 程序如下: hold on, x=-1:0.1:4;for k=1:4 y=x.k; plot(x,y), endhold offcos x, x 0,例 9作出分段函數(shù) f (x) 5, x 0,的圖形程序如下:ex 10, x 0,x1=-2:0.1:0;
30、x2=0:0.1:2;y1=cos(x1);y2=exp(x2)+10;plot(x1,y1,x2,y2) 為畫出分解點出的情況,可以繼續(xù)輸入命令: hold on,plot(0,cos(0),ro), plot(0,exp(0)+10,ro),plot(0,5,r*) 也可以先建立函數(shù) M 文件,在調用 fplot 命令繪圖(對于函數(shù)圖像跳躍程度比較劇烈的必須使用這種方法)。第二節(jié)三維繪圖基本命令:1、plot3plot3 (x,y,z,s)% x,y,z 是維數(shù)相同的向量,它們的元素分別表示空間點的坐標,s 表示連線的顏色、線形和點的形狀.plot3(x,y,z)%x,y,z 同型矩陣,對
31、應每一列表示一條曲線,可以做出若干條曲線.2、meshgridU,V=meshgrid(x,y)%x,y 為向量,x,y 可以構成網格點陣,命令產生的矩陣 U 的元素為點陣的橫坐標,V 的元素為點陣的縱坐標,見下圖所示 x 的 5 個值與y 的 4 個值產生 45 的兩個點陣 U,V,其矩陣元素分別來自 x,y3、meshmesh(X,Y,Z)%X,Y,Z 是維數(shù)相同的矩陣,它們的元素分別表示空間點的三個坐標,所得曲面是將點用平面連接的曲面(網格曲面).meshc(X,Y,Z)%除了 mesh (X,Y,Z)的功能外,還在曲面下方畫出等高線4、surfsurf(X,Y,Z)% X,Y,Z 是維
32、數(shù)相同的矩陣,它們的元素分別表示空間點的坐標,所得曲面是將點用平滑的曲面連接的曲面.surfc(X,Y,Z)%除了 surf(X,Y,Z)的功能外,還在曲面下方畫出等高線5、ezmesh 和 ezsurfezmesh(f(x,y)%畫出函數(shù) z=f(x,y),這是字符串型函數(shù)繪圖ezsurf(f(x,y)%同上ezmesh(x,y,z)%作出參數(shù)曲面 x=x(s,t),y= y(s,t),z= z(s,t),其中 s,t 默認范圍是-2*pis2*pi,-2*pit2*pi,x,y,z 都是符號表達式ezmesh(x,y,z,s1 s2 t1 t2)%作用同上,只是 s,t 的范圍改為 s1s
33、s2,t1t7) 那么輸出結果ii =24678910例 1在區(qū)間0,10畫出參數(shù)曲線 x=sint,y=cost,z=t.程序如下: t=0:pi/50:10*pi; plot3(sin(t),cos(t),t,ro) 例 2作出函數(shù) z x2 y2 的圖像,并作出 10 條等高線.程序如下: x=-3:0.1:3;y=x;X,Y=meshgrid(x,y); Z=X.2+Y.2;subplot(1,2,1),mesh(X,Y,Z),subplot(1,2,2), clabel(contour(X,Y,Z,10) 例 3 作出橢球面 x2 y 2 z 2 1 的圖形491程序如下:x=2*c
34、os(s)*sin(t);y=3*cos(s)*cos(t);z=sin(s); ezmesh(x,y,z) 注意:沒有直接作出曲面 F(x,y,z)=0 圖像的命令。例 4作出單葉雙曲面 x2 y 2 z 2 1 的圖形149程序如下:x=-3:0.01:3;y=-3:0.01:3;x,y=meshgrid(x,y); z=sqrt(9*(x.2+y.2/4-1);ii=find(imag(z)=0);% imag(z)表示 z 的虛部z(ii)=NaN;z1=-z;mesh(x,y,z), hold on, mesh(x,y,z1) 注意:本例也可以用例 12 的方法來做。例 5作出錐面
35、z x2 2 y2 和 z x2 y2 5相交的圖形程序如下:x,y=meshgrid(-2:0.01:2);z1=x.2-2*y.2; z2=x.2+y.2-5; mesh(x,y,z1); hold on mesh(x,y,z2);ii=find(abs(z1-z2)n=1:100;y=n.(1./n);plot(y,ro) 圖像如下:可以看出極限是 1.從數(shù)值計算來看:for n=1:1:10 x(n,1)=n;x(n,2)=n(1/n);x(n,3)=n(1/n)-1;end x運行結果(x 的第二列是數(shù)列的項,第三列是項與 1 的差): x =1.00001.000002.00001
36、.41420.41423.00001.44220.44224.00001.41420.41425.00001.37970.37976.00001.34800.34807.00001.32050.32058.00001.29680.29689.00001.27650.276510.00001.25890.2589例 2、數(shù)列1 3 計算數(shù)列的前 30 項的近似值. 作散點圖, 觀x0 1, xn 2 xn1 x.n1 察點的變化趨勢.程序如下:x(1)=sqrt(2); for n=1:30 x(n+1)=sqrt(2+x(n); endplot(x,ro) 可以看出數(shù)列取值趨近于 2.ab例
37、3、求極限lim x(1 )x sin( )xxx程序如下:syms a b x; y=x*(1+a/x)x)*sin(b/x);limit(y,x,inf) 例 4、求極限limx0ex3 11 cosx sin x程序如下:syms x;y=(exp(x3)-1)/(1-cos(sqrt(x-sin(x);limit(y,x,0,right) 例 5函數(shù) y e2 x ln(x2 1)tan(x) ,求 y, y syms xy=sin(x)/(x2+4*x+3); y1=diff(y), y3= diff(y,3) 例 6求函數(shù) f ( x) sin ax cos bx 的一階導數(shù). 并
38、求 f 1 . a b syms x a by=sin(a*x)*cos(b*x);y1=diff(y),x=1/(a+b);y11=eval(y1) 例 7函數(shù),求2 z 2 z 2 zz ax2 y3 b sin(xy)syms a b x y z=a*x2*y3+b*sin(x*y);x2,y2,xyzxx=diff(z,x,2), zyy=diff(z,y,2), zxy=diff(diff(z,x),y) 例 8參數(shù)式函數(shù) x a(t sin t) ,求 dysyms a t y a(1 cos t)dxx=a*(t+sin(t);y=a*(1-cos(t); diff(y,t)/d
39、iff(x,t) 例 9隱函數(shù)exy x y 1 ,求 dydxsyms x yz=exp(x*y)+x+y-1;-diff(z,x)/diff(z,y) 例 10 求下列積分dxx2 1 x2(1) 1dx ;(2) 1dx ;(3) 3.sin2 x cos2 xsyms x ax2 a21y1=1/(sin(x)2*cos(x)2);y2=1/(x2-a2);y3=1/(x2*sqrt(1+x2); i1=int(y1,x),i2=int(y2,x),i3=int(y3,x,1,sqrt(3) 例 11計算積分 1 e x2dx 。0方法一: y=exp(-x.2);quad(y,0,1
40、) 方法二:x=0:0.01:1;y=exp(-x.2);trapz(x,y) 例 12計算重積分 D1 x2 y2 d D 是由圓周 x2 y2 1 及坐標軸在第一象1 x2 y2限圍成的閉區(qū)域。syms x yz=sqrt(1-x2-y2)/(1+x2+y2); int(int(z,y,0,sqrt(1-x2),x,0,1) 顯示結果:Warning: Explicit integral could not be found.換為極坐標下計算:syms t rz=sqrt(1-r2)/(1+r2)*r;int(int(z,r,0,1),t,0,2*pi) 例 13計算1 dy 1xydx
41、的近似值。1 x30y2下載 quad2dggen.m 及相關文件(可在機房老師處拷貝)裝到 matlab/work 目錄下.命令格式:quad2dggen(fun,x1,x2,y1,y2)%計算積分 y 2 dy x 2 f (x, y)dxy1x1quad2dggen(fun,x1,x2,y1,y2,c)%同上,c 為精度注意:該命令只能計算 y-型區(qū)域的二重積分。其中 fun,x1,x2 均為向量型的 inline 函數(shù) fun=inline(x.*y./sqrt(1+x.3); x1=inline(y.2); x2=inline(1); quad2dggen(fun,x1,x2,0,1
42、) 例 14求 y2 ds , x 3cos t, y 3sin t, t 2,2 Lsyms t x=3*cos(t);y=3*sin(t);z=y2*sqrt(diff(x,t)2+diff(y,t)2); int(z,t,-2*pi,2*pi) 第二節(jié)泰勒多項式、級數(shù)1、泰勒多項式函數(shù) y f (x) 的泰勒多項式是指形如a a x a x2 a xn012n的多項式,其中a f (k ) (0) , k 0,1, n 。而關于 x x的泰勒多項式是指形如kk !a0 a (x x ) a (x x )2 a (x x )n01020n0的多項式,其中a kf (k ) (x )0k !
43、, k 0,1, n。其中n稱為泰勒多項式的階數(shù)。階數(shù)越高泰勒多項式越和函數(shù)本身接近。命令格式:taylor(fun,x,n)%符號函數(shù)關于 x 的 n-1 階泰勒多項式taylor(fun)%符號函數(shù)關于 x 的 5 階泰勒多項式taylor(fun,x,n,x )%符號函數(shù)關于x-x 的n-1 階泰勒多項式00例 1設函數(shù) f (x) x arctan x ln 1 x2 ,求關于 x 的 10 階泰勒多項式;關于 x-2 的 10 階泰勒多項式。syms xy=x*atan(x)-log(sqrt(1+x2); y1=taylor(y,x,11), y2=taylor(y,x,11,2)
44、 例 2設 y sin x ,求該函數(shù)的 3 階、8 階、15 階泰勒多項式,并畫出圖形觀察它們與 y sin x 的關系。 syms x y=sin(x);subplot(2,2,1),ezplot(y), k=2;for n=4,9,16yy=taylor(y,x,n),subplot(2,2,k),ezplot(yy),k=k+1;end2、級數(shù)求和命令格式:sum(x)%計算向量 x 的元素的和symsum(an,n,a,b)%計算通項為an 的數(shù)列對變量n 從a 到b 項的和例 3求和1 3 99x=1:2:99;sum(x) 例 4求和(1) 100 n3 ;(2) 1(2n 1)
45、(2n 1)n1n 1symsnx;(3) xnn0an=n3;bn=1/(2*n-1)*(2*n+1);cn=xn symsum(an,n,1,100),symsum(bn,n,1,inf), symsum(cn,n,0,inf) 第三節(jié)方程與微分方程一、一般方程1、圖解法畫出函數(shù)圖象,然后盡量放大圖像,可以觀察根的大小。例 1 解方程ex 2x 10 hold on,ezplot(exp(x),-100,100),ezplot(-2*x+10,-100,100)放大之后為:可以看出根在 1.8221.823 之間。2、多項式求根命令格式:x=roots(A)說明:x 為根向量,A 為多項式
46、系數(shù)向量,按降冪排列.最高次數(shù)小于 5 可以求出根的準確形式,次數(shù)大于或等于 5 很多方程只能求近似形式.例 2解方程 x3 9x 10 0a=1,0,9,-10;roots(a) 3、代數(shù)方程求根所謂代數(shù)方程是指通常指“整式方程”,即由多項式組成的方程。命令格式:x=solve(F)對方程 F=0 的默認變量求解x=solve(F,v)對方程 F=0 的指定變量 v 求解x=solve(F1,F(xiàn)n)對 n 個方程的默認變量求解x=solve(F1,F(xiàn)n,v1,,vn)對 n 個方程的 n 個指定變量求解說明:1、solve 命令適合于符號方程,默認未知量為x,沒有 x 則指在字母表中離x 最
47、近的字母;2、solve 命令主要求解代數(shù)方程或代數(shù)方程組,也可以用于超越方程的求解,但能力有限。例 3解方程 x2 ax 4b 0syms a b xF=x2-a*x-4*b;solve(F,x) x 3y 0例 4解方程組x2 y2 1syms x yf1=x+3*y;f2=x2+y2-1; x,y=solve(f1,f2,x,y)4、超越方程求根超越方程指除多項式函數(shù)方程之外的方程,一般超越方程只能求近似解,對于超越方程組在很多情況下連近似解也求不出來.一元方程的情形命令格式:x=fzero(fun,x )0 x=fzero(fun,x ,tol)0 x=fzero(fun,a,b)說明
48、:fzero(fun,x )表示在 x 的附近收索方程 fun=0 的根,tol 表示求根的00精度, fzero(fun,a,b) 表示在a,b上收索方程 fun=0 的根,要求函數(shù) fun在區(qū)間端點異號. 函數(shù) fun 的形式為字符串型或者 M 文件型均可。例 5求方程 x cos2 x 在 1 附近的根。fzero(x-cos(x)2 ,1) 多元方程組的情形命令格式:x=fsolve(fun,x )0 x=fsolve(fun,x ,tol)0 x=fsolve(fun,a,b) x y2例 6 解方程組在點(1,2) 附近的根。 y cos xfun=x(1)-x(2)2,x(2)-
49、cos(x(1); fsolve(fun,1,2) 二、微分方程1、符號解命令格式:dsolve(方程 1,方程 2,方程n,初始條件,自變量)例 7求微分方程 dy y2的解.dxdsolve(Dy=y2, x) d2 y 4 dy 29 y 0 dx2例 8求微分方程組dx的解. y(0) 0, y (0) 15y=dsolve(D2y+4*Dy+29*y=0,y(0)=0,Dy(0)=15,x),ezplot(y,-1,2)%本命令是畫出解在區(qū)間1,2 上的圖像說明:其中 Dy 表示 y 的一階導數(shù),D2y 表示 y 的二階導數(shù) dt dx 2x 3y 3z dt例 9求微分方程組dy
50、4x 5 y 3z 的通解.dz 4x 4 y 2z dtx,y,z=dsolve(Dx=2*x-3*y+3*z,Dy=4*x-5*y+3*z,Dz=4*x-4*y+2* z, t);x=simple(x),% 該行的作用是將 x 化簡y=simple(y),% 該行的作用是將 y 化簡z=simple(z) % 該行的作用是將 z 化簡2、數(shù)值解很多復雜微分方程的符號解是求不出來的,這時只能求數(shù)值解(近似解).求數(shù)值解實際上是求出其積分曲線上若干點的坐標(近似的),為方便直觀,通常將這些離散的點畫出來.命 令 格 式 : t,x=ode45(equ,t0,tf,x0) 說明:1、t 表示自變
51、量值;x 表示函數(shù)值;equ 表示由待解方程寫成的 M 文件名; t0、tf 為自變量的初值和終值;x0 表示函數(shù)的初值2、在解含 n 個未知數(shù)的方程組時,x0 和 x 均為 n 維向量,M 文件中的待解方程組應以 x 的分量形式寫出.3、高階微分方程必須等價地變換成一階微分方程組.d2 x例 10求 dt 2dxd 的解.1000(1 x2 )x0tx(0) 2; x (0) 0分析:令 x = dx , x x1 dt2則微分方程變?yōu)橐浑A微分方程組: dx1 1000(1 x2 )x x dt212 ,初始條件 x (0) 0, x (0) 2dx122xdt1Matlab 解法如下:1
52、、 建 立 M 文 件 equ.m 如 下 : function dxdt=equ(t,x) dxdt(1)=1000*(1-x(2)2)*x(1)+x(2);dxdt(2)= x(1);2、取 t0=0,tf=3000,輸入命令: t,x=ode45(equ,0 3000,0 2);plot(t,x(:,1),o) %畫出解的圖像第五章優(yōu)化問題求極值問題,就是優(yōu)化問題,它一般由目標函數(shù)和約束條件兩部分構成。優(yōu)化問題實踐性很強,廣泛應用于生產管理、軍事指揮和科學試驗等各種領域。第一節(jié)多元函數(shù)的建立優(yōu)化問題中的目標函數(shù),往往是多元函數(shù),因此需要建立多元函數(shù)。其建立的方式與一元函數(shù)的方式一致,下面
53、通過例子來說明。例 1定義二元函數(shù) z 5x2 4 y3 sin(xy) ,當 x 1, y 2 時,求 z 的值. 建立方法一:syms x yz=5*x2+4*y3+sin(x*y), x=1;y=2;eval(z) 建立方法二:z=5*x(1)2+4*x(2)3+sin(x(1)*x(2), x=1,2;eval(z) 例 2定義二元函數(shù) z 5x2 4 y3 sin(xy) ,并求當 x=1,y=2 時的函數(shù)值.除了使用上面的方法,還可以用 M 文件的方法建立,步驟如下: 1、建立 M 文件:functionz=f1(x,y) z=5*x2+4*y3+sin(x*y);以 f1.m 為
54、文件名保存.2、在 Matlab 命令區(qū)輸入命令:z=f1(1,2) 第二節(jié) 無約束條件的優(yōu)化一、一元函數(shù)的情形求一元函數(shù) y f (x) 在區(qū)間a, b 內的極小值。命令格式:x=fminbnd(fun,a,b)x,fval=fminbnd(fun,a,b)說明:1、函數(shù) fun 的格式可以為:字符串型、M 文件型、inline 函數(shù)2、x 為在區(qū)間a, b 內函數(shù) fun 的極小值點,fval 為在極小值;3、函數(shù) fminbnd 的算法基于黃金分割法和二次插值法,要求目標函數(shù)y f (x) 連續(xù),并可能只給出局部最優(yōu)解.例 1 求 y = 2 e x sin x 在 0 x f=2*ex
55、p(-x)*sin(x);fplot(f,0,8);%作出函數(shù)圖象xmin,ymin=fminbnd (f, 0,8)%求出函數(shù)最小值點,和最小值f1=-2*exp(-x)*sin (x);a,b=fminbnd (f1, 0,8); xmax=a, ymax=-b%求出函數(shù)最大值點,和最大值運行結果:xmin = 3.9270ymin = -0.0279xmax =0.7854ymax =0.6448二、多元函數(shù)的情形命令格式 1:x= fminunc(fun,X0) x,fval= fminunc(fun,X0) 命 令 格 式 2: x=fminsearch(fun,X0)x,fval=
56、 fminsearch(fun,X0)說明:1、fminunc 是采用擬牛頓法尋優(yōu);fminsearch 是用單純形法尋優(yōu). 2、X0 是初始點,它最好位于極值點的附近.3、可能得到局部最優(yōu)解.4、對于求解二次以上的問題,fminunc 函數(shù)比 fminsearch 函數(shù)有效,但對于高度非線性不連續(xù)問題時,fminsearch 函數(shù)更具穩(wěn)鍵性。例 2 求 f (x , x ) 2x 3 4x x 3 10 x x x 2 的最小值。1211 21 22解:在 Matlab 中實現(xiàn)如下: f=2*x(1)3+4*x(1)*x(2)3-10*x(1)*x(2)+x(2)2; x0=0,0;x,fm
57、in=fminsearch(f,x0) 或著:1、在 Matlab 編輯器中編輯 M 文件: function f=fun(x)f=2*x(1)3+4*x(1)*x(2)3-10*x(1)*x(2)+x(2)2; 2、命令窗口運行: x0=0,0;x,fmin=fminsearch(fun,x0) 第三節(jié)線性規(guī)劃與二次規(guī)劃帶有約束條件類優(yōu)化問題分為兩種情況,一是線性規(guī)劃;二是非線性規(guī)劃。對于線性規(guī)劃,Matlab 能夠完全有效地解出,而非線性規(guī)劃,也有強大解決功能。一、線性規(guī)劃線性規(guī)劃是帶有約束條件類優(yōu)化問題中最常見的一類,它一般形式為:minz c x c x1 1n n a x a x b
58、不等式約束條件11 1 a x1n n1 a x bs.t. m1 1mn nm等式約束條件 e x e xd11 1 e x1n n1變量上、下界 e x d m1 1mn nml x m , i 1,2, n可以用矩陣的形式表示為:iiiminz cX AX bs.t. AeqX beqvlb x vub其中: X 為 n 維未知列向量, c 為目標函數(shù)的系數(shù)向量, A 是不等式約束的系數(shù)矩陣,b 是常數(shù)項向量, Aeq 是等式約束的系數(shù)矩陣,beq 常數(shù)項向量,vlb, vub 分別是自變量取值的下界和上界約束的常數(shù)向量.命 令 格 式 : x=linprog(c,A,b) x=linp
59、rog(c,A,b,Aeq,beq)x=linprog(c,A,b,Aeq,beq, VLB,VUB) x=linprog(c,A,b,Aeq,beq, VLB,VUB, X0) x,fval = linprog(.)x,fval,exitflag = linprog(.) x,fval,exitflag,output = linprog(.) x,fval,exitflag,output,lambda = linprog(.) 說明:x = linprog(c,A,b) 求解問題 min c*x,約束條件為 A*x0表示目標函數(shù)收斂于解 x 處;=0表示已經達到函數(shù)評價或迭代的最大次數(shù); f
60、=-5;-4;-6; A=1 -1 1;3 2 4;3 2 0; b=20;42;30; lb=zeros(3,1); x,fval,exitflag,output,lambda=linprog(f,A,b,lb) Optimization terminated successfully.x =0.000015.00003.0000fval =-78.0000exitflag = 1output =iterations: 6cgiterations: 0 algorithm: lipsollambda =ineqlin: 3x1 double eqlin: 0 x1 double upper:
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 《從多元文化觀點談》課件
- 2022年高考物理大一輪總復習(江蘇專版-)題庫-第二章-相互作用-章末
- 2021年高考英語考點總動員系列-專題04-形容詞和副詞(解析版)
- 【紅對勾】2020-2021學年人教版高中物理選修3-1:綜合評估
- 【KS5U原創(chuàng)】新課標2021年高二物理暑假作業(yè)9《楞次定律》
- 【KS5U原創(chuàng)】新課標2021年高二暑假化學作業(yè)(九)
- 【全程復習方略】2022屆高考數(shù)學(文科人教A版)大一輪階段滾動檢測(五)第一~八章-
- 五年級數(shù)學(小數(shù)乘法)計算題專項練習及答案
- 2022年行政管理實習報告范文
- 2022年成人高考《大學語文》章節(jié)練習題答案及解析
- 2025年正規(guī)的離婚協(xié)議書
- 2025中國地震應急搜救中心公開招聘應屆畢業(yè)生5人高頻重點提升(共500題)附帶答案詳解
- 醫(yī)療健康大模型白皮書(1.0版) 202412
- 部編版八年級初二語文上冊第六單元《寫作表達要得體》說課稿
- 公共衛(wèi)生管理制度(3篇)
- 政治-2025年八省適應性聯(lián)考模擬演練考試暨2025年四川省新高考教研聯(lián)盟高三年級統(tǒng)一監(jiān)測試題和答案
- 2024年中國醫(yī)藥研發(fā)藍皮書
- 坍塌、垮塌事故專項應急預案(3篇)
- 2024年融媒體中心事業(yè)單位考試工作人員另選錄用55人內部選題庫及參考答案(研優(yōu)卷)
- 排水管道疏通、清淤、檢測、修復方案
- 陜西省安康市2023-2024學年高一上學期期末考試 生物 含解析
評論
0/150
提交評論