3MATLAB的符號運算_第1頁
3MATLAB的符號運算_第2頁
3MATLAB的符號運算_第3頁
3MATLAB的符號運算_第4頁
3MATLAB的符號運算_第5頁
已閱讀5頁,還剩55頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、第三章 MATLAB的符號運算 matlab 不僅具有數值運算功能,還開發(fā)了在matlab環(huán)境下實現(xiàn)符號計算的工具包SymbolicMath Toolbox 符號運算的功能符號表達式、符號矩陣的創(chuàng)建符號線性代數因式分解、展開和簡化符號代數方程求解符號微積分符號微分方程一、符號運算的基本操作什么是符號運算與數值運算的區(qū)別 數值運算中必須先對變量賦值,然后才能參與運算。 符號運算無須事先對獨立變量賦值,運算結果以標準的符號形式表達。特點: 運算對象可以是沒賦值的符號變量 可以獲得任意精度的解Symbolic Math Toolbox符號運算工具包通過調用Maple軟件實現(xiàn)符號計算的。maple軟件

2、主要功能是符號運算,它占據符號軟件的主導地位。 2. 符號變量與符號表達式f = sin(x)+5xf 符號變量名sin(x)+5x 符號表達式 符號標識v符號表達式一定要用 單引 號括起來matlab才能識別。 的內容可以是符號表達式,也可以是符號方程。例: f1=ax2+bx+c 二次三項式 f2= ax2+bx+c=0 方程 f3=Dy+y2=1 微分方程符號表達式或符號方程可以賦給符號變量,以后調用方便;也可以不賦給符號變量直接參與運算3.符號矩陣的創(chuàng)建 數值矩陣A=1,2;3,4 A=a,b;c,d 不識別用matlab函數sym創(chuàng)建矩陣(symbolic 的縮寫)命令格式:A=sy

3、m( ) 符號矩陣內容同數值矩陣 需用sym指令定義 需用 標識例如:A = sym(a , 2*b ; 3*a , 0) A = a, 2*b 3*a, 0 這就完成了一個符號矩陣的創(chuàng)建。注意:符號矩陣的每一行的兩端都有方 括號,這是與 matlab數值矩陣的 一個重要區(qū)別。用字符串直接創(chuàng)建矩陣v 模仿matlab數值矩陣的創(chuàng)建方法v 需保證同一列中各元素字符串有相 同的長度。例:A = a,2*b; 3*a, 0 A = a, 2*b 3*a, 0 符號矩陣的修改 a.直接修改 可用、 鍵找到所要修改的矩陣,直接修改 b.指令修改v 用A1=sym(A,new) 來修改。v 用A1=sub

4、s(A, new, old)來修改v A1=subs(A, old ,new)例如:例如:A = a, 2*b 3*a, 0A1=sym(A,2,2, 4*b) A1 = a, 2*b 3*a, 4*b A(2,2)=4*b;A3=AA3 = a, 2*b 3*a, 4*bA2=subs(A1, c, b) A2 = a, 2*c 3*a, 4*c v將數值矩陣轉化為符號矩陣 函數調用格式:sym(A)A=1/3,2.5;1/0.7,2/5A = 0.3333 2.5000 1.4286 0.4000sym(A)ans = 1/3, 5/210/7, 2/5 符號矩陣與數值矩陣的轉換v將符號矩

5、陣轉化為數值矩陣函數調用格式: numeric(A)A = 1/3, 5/210/7, 2/5numeric(A)ans = 0.3333 2.5000 1.4286 0.4000符號矩陣運算 數值運算中,所有矩陣運算操作指令都比較直觀、簡單。例如:a=b+c; a=a*b ;A=2*a2+3*a-5等。 而符號運算就不同了,所有涉及符號運算的操作都有專用函數來進行二、符號運算符號矩陣運算的函數:symadd(a,d) 符號矩陣的加symsub(a,b) 符號矩陣的減symmul(a,b) 符號矩陣的乘symdiv(a,b) 符號矩陣的除sympow(a,b) 符號矩陣的冪運算symop(a,

6、b) 符號矩陣的綜合運算例1:f= 2*x2+3*x-5; g= x2+x-7;h= symadd(f,g)h= 3*x2+4*x-12例2:f=cos(x);g= sin(2*x);symop(f,/,g,+,f,*,g) ans =cos(x)/sin(2*x)+cos(x)*sin(2*x)例1:f= 2*x2+3*x-5; g= x2+x-7; syms x f=2*x2+3*x-5; g= x2+x-7; h=f+gh = 3*x2+4*x-12例2:f=cos(x);g= sin(2*x); syms x f=cos(x);g=sin(2*x); f/g+f*gans =cos(x

7、)/sin(2*x)+cos(x)*sin(2*x) 符號運算函數:symsize 求符號矩陣維數charploy 特征多項式determ 符號矩陣行列式的值eigensys 特征值和特征向量inverse 逆矩陣transpose 矩陣的轉置jordan 約當標準型simple 符號矩陣簡化2. 任意精度的數學運算 在symbolic中有三種不同的算術運算:數值類型 matlab的浮點算術運算有理數類型 maple的精確符號運算vpa類型 maple的任意精度算術 運算 浮點算術運算1/2+1/3 (定義輸出格式format long)ans =0.83333333333333符號運算sym

8、(1/2)+(1/3)ans = 5/6 精確解 任意精度算術運算digits(n) 設置可變精度,缺省16位vpa(x,n) 顯示可變精度計算digits(25)vpa(1/2+1/3)ans =.8333333333333333333333333vpa(5/6,40) ans =.8333333333333333333333333333333333333333 a=sym(1/4,exp(1);log(3),3/7)a = 1/4,exp(1)log(3), 3/7vpa(a,10)ans =.2500000000, 2.7182818281.098612289, .4285714286d

9、iff(f) 對缺省變量求微分diff(f,v) 對指定變量v求微分diff(f,v,n) 對指定變量v求n階微分int(f) 對f表達式的缺省變量求積分int(f,v) 對f表達式的v變量求積分int(f,v,a,b) 對f表達式的v變量在(a,b) 區(qū)間求定積分3. 符號微積分與積分變換int(被積表達式,積分變量,積分上限, 積分下限) 定積分缺省時為不定積分mtaylor(f,n) 泰勒級數展開ztrans(f) Z變換iztrans(f) 反Z變換laplace(f) 拉氏變換ilaplace(f) 反拉氏變換fourier(f) 付氏變換ifourier(f) 反付氏變換 例1.計

10、算二重不定積分dxdyxexyF=int(int(x*exp(-x*y),x),y)F= 1/y*exp(-x*y)例2.計算 f=x*exp(-x*10)的Z變換 F=ztrans(f) F= z*exp(-10)/(z-exp(-10)2 syms x y F=int(int(x*exp(-x*y),x),y)F =1/y*exp(-x*y) syms x f=x*exp(-x*10); F=ztrans(f) F=ztrans(x*exp(-x*10);F =z*exp(-10)/(z-exp(-10)2 例3. 計算指數函數eAt。用拉氏反變換法計算。eAt的公式為: eAt = L-

11、1(SI-A)-1系統(tǒng)矩陣A= 3210tttttttteeeeeeee22222222eAt =結果: a=0 1;-2 -3; syms s b=(s*eye(2)-a)b = s, -1 2, s+3 B=inv(b) (s+3)/(s2+3*s+2), 1/(s2+3*s+2) -2/(s2+3*s+2), s/(s2+3*s+2) b11=ilaplace(sym(b,1,1);b(1,1)=b11; b12=ilaplace(sym(b,1,2);b(1,2)=b12; b21=ilaplace(sym(b,2,1);b(2,1)=b21; b22=ilaplace(sym(b,2

12、,2);b(2,2)=b22; bb = -exp(-2*t)+2*exp(-t), exp(-t)-exp(-2*t) -2*exp(-t)+2*exp(-2*t), 2*exp(-2*t)-exp(-t) 4.符號代數方程求解 matlab符號運算能夠解一般的線性方程、非線性方程及一般的代數方程、代數方程組。當方程組不存在符號解時,又無其他自由參數,則給出數值解。命令格式:solve(f) 求一個方程的解Solve(f1,f2, fn) 求n個方程的解 例1. f = ax2+bx+c 求解f=a*x2+b*x+c; solve(f) 對缺省變量x求解ans =1/2/a*(-b+(b2-

13、4*a*c)(1/2)1/2/a*(-b-(b2-4*a*c)(1/2)計算機格式aacbb242一般格式例2. 符號方程cos(x)=sin(x) tan(2*x)=sin(x)求解f1=solve(cos(x)=sin(x),f1 =1/4*pi solve(f , b ) 對指定變量b求解ans =-(a*x2+c)/xf3=solve(tan(2*x)=sin(x)matlab6.5的解 0 pi atan(1/2*(-2*3(1/2)(1/2),1/2+1/2*3(1/2) atan(-1/2*(-2*3(1/2)(1/2),1/2+1/2*3(1/2) atan(1/2*2(1/2

14、)*3(1/4)/(1/2-1/2*3(1/2)+pi -atan(1/2*2(1/2)*3(1/4)/(1/2-1/2*3(1/2)-pi f2=solve(tan(2*x)=sin(x)f2 =matlab4.2的解 0acos(1/2+1/2*3(1/2)acos(1/2 -1/2*3(1/2)numeric(f3)ans = 0 3.1416 0 + 0.8314i 0 - 0.8314i 1.9455 -1.9455 numeric(f2)ans = 0 0 + 0.8314i 1.9455 matlab4.2與6.5的對比例3. 解方程組 x+y+z=1 x-y+z=2 2x-y-

15、z=1g1=x+y+z=1,g2=x-y+z=2,g3=2*x-y-z=1f=solve(g1,g2,g3)f=solve(x+y+z=1,x-y+z=2,2*x-y-z=1)f =z = 5/6, y = -1/2, x = 2/3f=solve(x+y+z=1,x-y+z=2,2*x-y-z=1)f = x: 1x1 sym f.x ans =2/3 y: 1x1 sym f.y ans =-1/2 z: 1x1 sym f.z ans =5/6 x,y,z=solve(x+y+z=1,x-y+z=2,2*x-y-z=1) x = 2/3 y =-1/2 z =5/65. 符號微分方程求解

16、 用一個函數可以方便地得到微 分方程的符號解符號微分方程求解指令:dsolve命令格式:dsolve(f,g)f 微分方程,可多至12個微分方程的求 解;g為初始條件默認自變量為 x,可任意指定自變量t, u等微分方程的各階導數項以大寫字母D表示 dtdydxdy22dtydnndtyd22dxydnndxyd或或或y的一階導數 Dyy的二階導數 D2yy的 n 階導數 Dnyy1,y2=dsolve(x1,x2,xn) 返回 微分方程的解一階微分方程dsolve(Dx=y,Dy=x,x(0)=0,y(0)=1)ans =x(t) = sin(t), y(t) = cos(t)二階微分方程ds

17、olve(D2y=-a2*y,y(0)=1,Dy(pi/a)=0)ans =cos(a*x)例3.y=dsolve(D2y+2*Dy+2*y=0,y(0)=1,Dy(0)=0)ans =exp(-x)*cos(x)+exp(-x)*sin(x)ezplot(y) 方程解y(t)的時間曲線圖22dxyddxdy202y00 )(dxdy,1)0(y求該方程的解-6-4-2024050100150200250300 xexp(-x)*cos(x)+exp(-x)*sin(x)-6-4-2024050100150200250texp(-t) sin(t)+exp(-t) cos(t)三、maple函

18、數符號運算的擴展maple是專門進行數學運算的軟件工具, 具有超強的符號運算能力,提供了 幾乎包括所有數學領域的專用函數matlab依賴于maple的內核與函數庫,擴 展了自己的符號運算功能。 matlab還設計了對maple庫函數的調用功能使得已有的maple數學功能,可以擴充matlab中,作為自身符號運算能力的擴展。1. maple內核訪問函數可以訪問maple內核的matlab函數: maple 訪問maple內核函數 mapleinit maple函數初始化 mpa maple函數定義 mhelp maple函數幫助命令 procread maple函數程序安裝. maple 的調用

19、格式maple(表達式) 將表達式送至maple內核, 返回符號表達式結果。maple (函數,變量1,變量2) 調用maple函數,傳遞給定 變量。 例1. 展開5階 bernoulli 多項式,計算 x=3 時bernoulli 數。a=maple(bernoulli(5,x)a =-1/6*x+5/3*x3+x5-5/2*x4a=maple(bernoulli(5,3)a =85例2. 化簡三角函數式sin2x+cos2xa=maple(simplify(sin(x)2+cos(x)2);)a =1例4. 求f(t)=e-3tsint的拉式變換f=maple(laplace(exp(-3

20、*t)*sin(t),t,s);)f =1/(s+3)2+1)例4. 尋找二次多項式的完全平方 f (x) = x2+2x+2a=maple(completesquare(x2+2*x+2)a =completesquare(x2+2*x+2) 將工具包裝入內存maple(with(student);)a=maple(completesquare(x2+2*x+2)a =(x+1)2+1maple軟件中的所有函數,在初始化時并沒有完全裝入內存,可用readlib指令把庫函數讀入內存,或用with指令將應用工具包裝入內存。調用格式maple(readlib(函數名);)maple(with(工具

21、包名);)例5.求sin(x2+y2)在x=0,y=0處泰勒級數展開式,8階截斷。maple(mtaylor(sin(x2+y2),x=0,y=0,8)ans =mtaylor(sin(x2+y2),x = 0, y = 0,8)maple(readlib(mtaylor);)maple(mtaylor(sin(x2+y2),x=0,y=0,8)ans =x2+y2-1/6*x6-1/2*y2*x4-1/2*y4*x2-1/6*y62. mpa maple變量定義任何一個matlab定義的函數f,可使用mpa語句直接調用,還可把 f 定義成maple變量v。maple的工作空間與matlab工

22、作空間是相互獨立的, 所以f 與v是屬于不同工作空間中的變量mpa的調用格式: mpa(v,f) mpa v ff為matlab工作空間中已存在的變量例. 電磁力計算公式為試I=0.5,x=0.1鄰域展開泰勒級數,3階截斷,令常數 ,1.直接調用maple(readlib(mtaylor);)maple(mtaylor(k*I2/x2,I=0.5,x=0.1,3);)2204)(),(xNISxIF420NSk22),(xkIxIF2.定義符號函數f(matlab6.1無map函數)f=k*I2/x2;maple(mtaylor(f,I=0.5,x=0.1,3);)ans =mtaylor(f,I = .5, x = .1,3)mpa(u,f)maple(mtaylor(u,I=0.5,x=0.1,3);)ans =25.*k-.50e3*k*(x-.1)+.10e3*k*(I-.5)+7500.000000000000*k*(x-.1)2+.1e3*k*(I-.5)2-.20e4*k*(I-.5)*(x-.1)注意:matlab符號運算時,可以識別matlab定義的符號變量,但在調用 maple 函數時,需將matlab變量定義為maple變量后,所調用的函數方可識別和執(zhí)行3.mhelp maple函數幫助命令 m

溫馨提示

  • 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

提交評論