MATLAB中的符号运算.ppt
《MATLAB中的符号运算.ppt》由会员分享,可在线阅读,更多相关《MATLAB中的符号运算.ppt(61页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、MATLABMATLAB中的符号运算中的符号运算2004.8.42004.8.4MATLAB所具有的符号数学工具箱与其它所有工具不同,它适用于广泛的用途,而不是针对一些特殊专业或专业分支。另外,MATLAB符号数学工具箱与其它的工具箱区别还因为它使用字符串来进行符号分析,而不是基于数组的数值分析。符号数学工具箱是操作和解决符号表达式的符号数学工具箱(函数)集合,有复合、简化、微分、积分以及求解代数方程和微分方程的工具。另外还有一些用于线性代数的工具,求解逆、行列式、正则型式的精确结果,找出符号矩阵的特征值而无由数值计算引入的误差。工具箱还支持可变精度运算,即支持符号计算并能以指定的精度返回结果
2、。符号数学工具箱中的工具是建立在功能强大的Maple之上。它最初是由加拿大的滑铁卢(Waterloo)大学开发的。当要求MATLAB进行符号运算时,它就请求Maple去计算并将结果返回到MATLAB命令窗口。因此,在MATLAB中的符号运算是MATLAB处理数字的自然扩展。符号表达式是代表数字、函数、算子和变量的MATLAB字符串,或字符串数组。不要求变量有预先确定的值,符号方程式是含有等号的符号表达式。符号算术是使用已知的规则和给定符号恒等式求解这些符号方程的实践,它与代数和微积分所学到的求解方法完全一样。符号矩阵是数组,其元素是符号表达式。符号表达式1/(2*xn)y=1/sqrt(2*x
3、)cos(x2)-sin(2*x)M=sym(a,b;c,d)符号表达式MATLAB表达式f=int(x3/sqrt(1-x),a,b)MATLAB符号函数可用多种方法来操作这些表达式diff(cos(x)ans=-sin(x)%differentiate cos(x)with respect to xM=sym(a,b;c,d )M=a,b c,d%create a symbolic matrix Mdeterm(M)ans=a*d-b*c%find the determinant of the symbolic matrix上面的第一个例子的符号表达式是用单引号以隐含方式定义的。它告诉MA
4、TLAB cos(x)是一个字符串并说明diff(cosx )是一个符号表达式而不是数字表达式;而在第二个例子中,用函数sym显式地告诉MATLAB M=sym(a,b;c,d )是一符号表达式。在MATLAB可以自己确定变量类型的场合下,通常不要求显式函数sym。符号变量 当字符表达式中含有多于一个的变量时,只有一个变量是独立变量。如果不告诉MATLAB哪一个变量是独立变量,MATLAB将基于以下规则选择一个:在符号表达式中缺省的独立变量是唯一的,除去i和j的小写字母,不是单词的一部分。如果没有这种字母,就选择x作为独立变量。如字符不是唯一的,就选择在字母顺序中最接近x的字母。如果有相连的字
5、母,就选择在字母表中较后的那一个。缺省的独立变量,有时称作自由变量,在表达式 1/(5+cos(x)中是 x x ;在 3*y+z 中是 y y ;在 a+sin(t)是 t t 。在表式 sin(pi/4)-cos(3/5)中自由符号变量是 x x ,因为此式是一个符号常数无符号变量。可利用函数symvar询问MATLAB在符号表达式中哪一个变量它认为是独立变量。symvar(a*x+y*)%find the default symbolic variableans=xsymvar(a*t+s/(u+3)%u is the closest to x ans=usymvar(sin(omega
6、)%omega is not a singlee character。ans=xsymvar(3*i+4*j )%i and j are equel to sqrt(-1)ans=xsymvar(y+3*s ,t )ans=s%find the variable closest to t rather than x如果利用规则symvarsymvar不能找到一个缺省独立变量,它便假定无独立变量并返回x。这一结论对含有由多个字母组成的变量,如:alpha或s2的表达式,或不含变量的符号常数均成立。如果需要,绝大多数命令都使用用户选项以指定独立变量。diff(xn )%differentiate
7、with respect to the default variable x ans=xn*n/x diff(xn ,n )%differentiate xn with respect to n ans=xn*log(x)diff(sin(omega)%differentiate using the default variables(x)ans=0 diff(sin(omega),omega )%specify the independent variable ans=cos(omega)符号表达式运算 一旦创建了一个符号表达式,或许想以某些方式改变它;也许希望提取表达式的一部分,合并两个表
8、达式或求得表达的数值。有许多符号工具可以帮助完成这些任务。所有符号函数(很少特殊例外的情况)作用到符号表达式和符号数组,并返回符号表达式或数组。其结果有时可能看起来象一个数字,但事实上它是一个内部用字符串表示的一个符号表达式。可以运用MATLAB函数isstrisstr来找出像似数字的表达式是否真是一个整数或是一个字符串。如果表达式是一个有理分式(两个多项式之比),或是可以展开为有理分式(包括哪些分母为1的分式),可利用numdennumden来提取分子或分母。例如,给定如下的表达式:提取分子和分母在必要时,numdennumden将表达式合并、有理化并返回所得的分子和分母。进行这项运算的MA
9、TLAB语句是:m=x2 m=x2%create a simple expression m=m=x2x2nn,d=d=numdennumden(m)(m)%extract the numerator and denominatorn=x2n=x2d=1d=1f=a*x2/(b-x)f=a*x2/(b-x)%create a rational expressionf=a*x2/(b-x)f=a*x2/(b-x)n n,d=d=numdennumden(f)(f)%extract the numerator and denominatorn=n=a*x2a*x2d=d=b-xb-xg=3/2*x
10、2+2/3*x-3/5%rationalize and extract the partsg=3/2*x2+2/3*x-3/5n,d=numden(g)n=45*x2+20*x-18d=30h=(x2+3)/(2*x-1)+3*x/(x-1)%the sum of rational polynomialsh=(x2+3)/(2*x-1)+3*x/(x-1)n,d=numden(h)%rationalize and extractn=x3+5*x2-3d=(2*x-1)*(x-1)很多标准的代数运算可以在符号表达式上执行,函数symadd、symsub、symlnul和symdiv为加、减、乘、
11、除两个表达式,sympow将一个表达式上升为另一个表达式的幂次。标准代数运算例如:给定两个函数f=2*x2+3*x-5%definethesymbolicexpressionf=2*x2+3*x-5g=x2-x+7g=x2-x+7symadd(f,g)%findanexpressionforf+gans=3*x2+2*x+2symsub(f,g)%findanexpressionforf-gans=x2+4*x-12symmul(f,g)%findanexpressionforf*gans=(2*x2+3*x-5)*(x2-x+7)symdiv(f,g)%findanexpressionfor
12、f/gans=(2*x2+3*x-5)/(x2-x+7)sympow(f,3*x)%findanexpressionforans=(2*x2+3*x-5)3*变换函数函数symsym可获取一个数字参量并将其转换为符号表达式。函数numnericnumneric的功能正好相反,它把一个符号常数(无变量符号表达式)变换为一个数值。phi=(1+sqrt(5)/2%the golden ratiophi=(1+sqrt(5)/2%convert to a numeric valuenumeric(phi)ans=1.6180符号函数sym2polysym2poly将符号多项式变换成它的MATLAB等
13、价系数向量。函数poly2syrnpoly2syrn功能正好相反,并让用户指定用于所得结果表达式中的变量。f=2*x2+x3-3*x+5%f is the symbolic polynomialsf=2*x2+x3-3*x+5n=sym2poly(f)%extract eht numeric coefficient vectorn=1 2 -3 5poly2sym(n)%recreate the polynomials in x(the default)ans=2*x2+x3-3*x+5poly2sym(n,s)%recreate the polynomials in sans=s3+2*s2
14、-3*s+5变量替换 假设有一个以x为变量的符号表达式,并希望将变量转换为y。MATLAB提供一个工具称作subssubs,以便在符号表达式中进行变量替换。其格式为subssubs(f f,newnew,old)old),其中f是符号表达式,newnew和oldold是字符、字符串或其它符号表达式。新字符串将代替表达式f中各个旧字符串。f=a*x2+b*x+c%create a function f(x)f=a*x2+b*x+csubs(f,s,x)%substitute s for x in the expression f ans=a*s2+b*s+c subs(f,alpha,a)%su
15、bstitute alpha for a in f ans=alpha*x2+b*x+cg=3*x2+5*x-4%create another functiong=3*x2+5*x-4h=subs(g,2,x)%substitute 2 for x in g h=18isstr(h)%show that the result is a symbolic expression ans=1微分和积分 微分和积分是微积分学研究和应用的核心,并广泛地用在许多工程学科。MATLAB符号工具能帮助解决许多这类问题。微分导数(包括偏导数)函数 diffdiff格式 diff(S,v)、diff(S,sym(
16、v)%对表达式S中指定符号变量v计算S的1阶导数。diff(S)%对表达式S中的符号变量v计算S的1阶导数,其中v=findsym(S)。diff(S,n)%对表达式S中的符号变量v计算S的n阶导数,其中v=findsym(S)。diff(S,v,n)%对表达式S中指定的符号变量v计算S的n阶导数。syms x y tD1=diff(sin(x2)*y2,2)%计算D2=diff(D1,y)%计算D3=diff(t6,6)计算结果为:D1=-4*sin(x2)*x2*y2+2*cos(x2)*y2D2=-8*sin(x2)*x2*y+4*cos(x2)*yD3=720符号表达式的微分以四种形式
17、利用函数diffdiff:f=a*x3+x2-b*x-c%define a symbolic expressionf=a*x3+x2-b*x-cdiff(f)%differentiate with respect to the default variable xans=3*a*x2+2*x-bdiff(f,a)%differentiate with respect to aans=x3diff(f,2)%differentiate twice with respect to xans=6*a*x+2diff(f,a,2)%differentiate twice with respect to
18、 aans=0函数diffdiff也可对数组进行运算。如果F是符号向量或数组,diff(F)diff(F)对数组内的各个元素进行微分。F=sym(a*x,b*x2;c*x3,d*s)%create a symbolic arrayF=a*x,b*x2c*x3,d*sdiff(F)%differentiate the element with respect to x ans=a,2*b*x 3*c*x2,0积分 积分函数intint(f)(f),其中f是一符号表达式,它力图求出另一符号表达式F使diff(F)=fdiff(F)=f。正如从研究微分学所了解的,积分比微分复杂得多。积分或逆求导不一
19、定是以封闭形式存在,或许存在但软件也许找不到,或者软件可明显地求解,但超过内存或时间限制。当MATLAB不能找到逆导数时,它将返回未经计算的命令。函数 intint 格式 R=int(S,v)%对符号表达式S中指定的符号变量v计算不定积分。注意的是,表达式R只是函数S的一个原函数,后面没有带任意常数C。R=int(S)%对符号表达式S中的符号变量v计算不定积分,其中v=findsym(S)。R=int(S,v,a,b)%对表达式s中指定的符号变量v计算从a到b的定积分 R=int(S,a,b)%对符号表达式s中的符号变量v计算从a到b的定积分,其中v=findsym(S)。int(log(x)
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- MATLAB 中的 符号 运算
限制150内