MATLAB中的符号运算.ppt
- 文档编号:18728429
- 上传时间:2023-10-21
- 格式:PPT
- 页数:61
- 大小:247.50KB
MATLAB中的符号运算.ppt
《MATLAB中的符号运算.ppt》由会员分享,可在线阅读,更多相关《MATLAB中的符号运算.ppt(61页珍藏版)》请在冰点文库上搜索。
MATLAB中的符号运算,2004.8.4,MATLAB所具有的符号数学工具箱与其它所有工具不同,它适用于广泛的用途,而不是针对一些特殊专业或专业分支。
另外,MATLAB符号数学工具箱与其它的工具箱区别还因为它使用字符串来进行符号分析,而不是基于数组的数值分析。
符号数学工具箱是操作和解决符号表达式的符号数学工具箱(函数)集合,有复合、简化、微分、积分以及求解代数方程和微分方程的工具。
另外还有一些用于线性代数的工具,求解逆、行列式、正则型式的精确结果,找出符号矩阵的特征值而无由数值计算引入的误差。
工具箱还支持可变精度运算,即支持符号计算并能以指定的精度返回结果。
符号数学工具箱中的工具是建立在功能强大的Maple之上。
它最初是由加拿大的滑铁卢(Waterloo)大学开发的。
当要求MATLAB进行符号运算时,它就请求Maple去计算并将结果返回到MATLAB命令窗口。
因此,在MATLAB中的符号运算是MATLAB处理数字的自然扩展。
符号表达式是代表数字、函数、算子和变量的MATLAB字符串,或字符串数组。
不要求变量有预先确定的值,符号方程式是含有等号的符号表达式。
符号算术是使用已知的规则和给定符号恒等式求解这些符号方程的实践,它与代数和微积分所学到的求解方法完全一样。
符号矩阵是数组,其元素是符号表达式。
符号表达式,1/(2*xn),y=1/sqrt(2*x),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)%differentiatecos(x)withrespecttoxM=sym(a,b;c,d)M=a,bc,d%createasymbolicmatrixMdeterm(M)ans=a*d-b*c%findthedeterminantofthesymbolicmatrix,上面的第一个例子的符号表达式是用单引号以隐含方式定义的。
它告诉MATLABcos(x)是一个字符串并说明diff(cosx)是一个符号表达式而不是数字表达式;而在第二个例子中,用函数sym显式地告诉MATLABM=sym(a,b;c,d)是一符号表达式。
在MATLAB可以自己确定变量类型的场合下,通常不要求显式函数sym。
符号变量当字符表达式中含有多于一个的变量时,只有一个变量是独立变量。
如果不告诉MATLAB哪一个变量是独立变量,MATLAB将基于以下规则选择一个:
在符号表达式中缺省的独立变量是唯一的,除去i和j的小写字母,不是单词的一部分。
如果没有这种字母,就选择x作为独立变量。
如字符不是唯一的,就选择在字母顺序中最接近x的字母。
如果有相连的字母,就选择在字母表中较后的那一个。
缺省的独立变量,有时称作自由变量,在表达式1/(5+cos(x)中是x;在3*y+z中是y;在a+sin(t)是t。
在表式sin(pi/4)-cos(3/5)中自由符号变量是x,因为此式是一个符号常数无符号变量。
可利用函数symvar询问MATLAB在符号表达式中哪一个变量它认为是独立变量。
symvar(a*x+y*)%findthedefaultsymbolicvariableans=xsymvar(a*t+s/(u+3)%uistheclosesttoxans=usymvar(sin(omega)%omegaisnotasingleecharacter。
ans=xsymvar(3*i+4*j)%iandjareequeltosqrt(-1)ans=xsymvar(y+3*s,t)ans=s%findthevariableclosesttotratherthanx,如果利用规则symvar不能找到一个缺省独立变量,它便假定无独立变量并返回x。
这一结论对含有由多个字母组成的变量,如:
alpha或s2的表达式,或不含变量的符号常数均成立。
如果需要,绝大多数命令都使用用户选项以指定独立变量。
diff(xn)%differentiatewithrespecttothedefaultvariablexans=xn*n/xdiff(xn,n)%differentiatexnwithrespecttonans=xn*log(x)diff(sin(omega)%differentiateusingthedefaultvariables(x)ans=0diff(sin(omega),omega)%specifytheindependentvariableans=cos(omega),符号表达式运算,一旦创建了一个符号表达式,或许想以某些方式改变它;也许希望提取表达式的一部分,合并两个表达式或求得表达的数值。
有许多符号工具可以帮助完成这些任务。
所有符号函数(很少特殊例外的情况)作用到符号表达式和符号数组,并返回符号表达式或数组。
其结果有时可能看起来象一个数字,但事实上它是一个内部用字符串表示的一个符号表达式。
可以运用MATLAB函数isstr来找出像似数字的表达式是否真是一个整数或是一个字符串。
如果表达式是一个有理分式(两个多项式之比),或是可以展开为有理分式(包括哪些分母为1的分式),可利用numden来提取分子或分母。
例如,给定如下的表达式:
提取分子和分母,在必要时,numden将表达式合并、有理化并返回所得的分子和分母。
进行这项运算的MATLAB语句是:
m=x2%createasimpleexpressionm=x2n,d=numden(m)%extractthenumeratoranddenominatorn=x2d=1f=a*x2/(b-x)%createarationalexpressionf=a*x2/(b-x)n,d=numden(f)%extractthenumeratoranddenominatorn=a*x2d=b-x,g=3/2*x2+2/3*x-3/5%rationalizeandextractthepartsg=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)%thesumofrationalpolynomialsh=(x2+3)/(2*x-1)+3*x/(x-1)n,d=numden(h)%rationalizeandextractn=x3+5*x2-3d=(2*x-1)*(x-1),很多标准的代数运算可以在符号表达式上执行,函数symadd、symsub、symlnul和symdiv为加、减、乘、除两个表达式,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)%findanexpressionforf/gans=(2*x2+3*x-5)/(x2-x+7)sympow(f,3*x)%findanexpressionforans=(2*x2+3*x-5)3*,变换函数,函数sym可获取一个数字参量并将其转换为符号表达式。
函数numneric的功能正好相反,它把一个符号常数(无变量符号表达式)变换为一个数值。
phi=(1+sqrt(5)/2%thegoldenratiophi=(1+sqrt(5)/2%converttoanumericvaluenumeric(phi)ans=1.6180,符号函数sym2poly将符号多项式变换成它的MATLAB等价系数向量。
函数poly2syrn功能正好相反,并让用户指定用于所得结果表达式中的变量。
f=2*x2+x3-3*x+5%fisthesymbolicpolynomialsf=2*x2+x3-3*x+5n=sym2poly(f)%extractehtnumericcoefficientvectorn=12-35poly2sym(n)%recreatethepolynomialsinx(thedefault)ans=2*x2+x3-3*x+5poly2sym(n,s)%recreatethepolynomialsinsans=s3+2*s2-3*s+5,变量替换,假设有一个以x为变量的符号表达式,并希望将变量转换为y。
MATLAB提供一个工具称作subs,以便在符号表达式中进行变量替换。
其格式为subs(f,new,old),其中f是符号表达式,new和old是字符、字符串或其它符号表达式。
新字符串将代替表达式f中各个旧字符串。
f=a*x2+b*x+c%createafunctionf(x)f=a*x2+b*x+csubs(f,s,x)%substitutesforxintheexpressionfans=a*s2+b*s+c,subs(f,alpha,a)%substitutealphaforainfans=alpha*x2+b*x+cg=3*x2+5*x-4%createanotherfunctiong=3*x2+5*x-4h=subs(g,2,x)%substitute2forxingh=18isstr(h)%showthattheresultisasymbolicexpressionans=1,微分和积分,微分和积分是微积分学研究和应用的核心,并广泛地用在许多工程学科。
MATLAB符号工具能帮助解决许多这类问题。
微分,导数(包括偏导数),函数diff格式diff(S,v)、diff(S,sym(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阶导数。
symsxytD1=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,符号表达式的微分以四种形式利用函数diff:
f=a*x3+x2-b*x-c%defineasymbolicexpressionf=a*x3+x2-b*x-c,diff(f)%differentiatewithrespecttothedefaultvariablexans=3*a*x2+2*x-b,diff(f,a)%differentiatewithrespecttoaans=x3diff(f,2)%differentiatetwicewithrespecttoxans=6*a*x+2diff(f,a,2)%differentiatetwicewithrespecttoaans=0,函数diff也可对数组进行运算。
如果F是符号向量或数组,diff(F)对数组内的各个元素进行微分。
F=sym(a*x,b*x2;c*x3,d*s)%createasymbolicarrayF=a*x,b*x2c*x3,d*sdiff(F)%differentiatetheelementwithrespecttoxans=a,2*b*x3*c*x2,0,积分,积分函数int(f),其中f是一符号表达式,它力图求出另一符号表达式F使diff(F)=f。
正如从研究微分学所了解的,积分比微分复杂得多。
积分或逆求导不一定是以封闭形式存在,或许存在但软件也许找不到,或者软件可明显地求解,但超过内存或时间限制。
当MATLAB不能找到逆导数时,它将返回未经计算的命令。
函数int格式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)/exp(x2)%attempttointegrateans=log(x)/exp(x2)同微分一样,积分函数有多种形式。
形式int(f)相对于缺省的独立变量求逆导数;形式(f,s)相对于符号变量s积分;形式int(f,a,b)和int(f,s,a,b),a,b是数值,求解符号表达式从a到b的定积分;形式int(f,m,n)和形式int(f,s,m,n),其中m,n是符号变量,求解符号表达式从m到n的定积分。
f=sin(s+2*x)%crateasymbolicfunctionf=sin(s+2*x)int(f)%integratewithrespecttoxans=-1/2*cos(s+2*x)int(f,s)%integratewithrespecttosans=-cos(s+2*x)int(f,pi/2,pi)%integratewithrespecttoxfrompi/2topians=-cos(x),int(f,s,pi/2,pi)%integratewithrespecttosfrom/2toans=cos(2*x)-sin(2*x)int(f,m,n)%integratewithrespecttoxfrommtonans=-1/2*cos(s+2*n)+1/2*cos(s+2*m)正如函数diff一样,积分函数int对符号数组的每一个元素进行运算。
F=sym(a*x,b*x2;c*x3,d*s)%createasymbolicarrayF=a*x,b*x2c*x3,d*sdiff(F)%ubtegratethearrayelementswithrespecttoxans=1/2*a*x2,1/3*b*x31/4*c*x4,d*s*x,symsxztalphaINT1=int(-2*x/(1+x3)2)INT2=int(x/(1+z2),z)INT3=int(INT2,x)INT4=int(x*log(1+x),0,1)INT5=int(2*x,sin(t),1)INT6=int(exp(t),exp(alpha*t),当xa时:
limit(F,a)%用命令findsym(F)确定F中的自变量,设为变量x,再计算F的极限值;当xa时:
limit(F)%用命令findsym(F)确定F中的自变量,设为变量x,再计算F的极限值;当x0时:
limit(F,x,a,right)或limit(F,x,a,left)%计算符号函数F的单侧极限:
左极限xa-或右极限xa+。
极限,函数limit格式limit(F,x,a):
%计算符号表达式F=F(x)的极限值,,symsxathn;L1=limit(cos(x)-1)/x)L2=limit(1/x2,x,0,right)L3=limit(1/x,x,0,left)L4=limit(log(x+h)-log(x)/h,h,0)v=(1+a/x)x,exp(-x);L5=limit(v,x,inf,left)L6=limit(1+2/n)(3*n),n,inf)计算结果为:
L1=0、L2=inf、L3=-inf、L4=1/xL5=exp(a),0、L6=exp(6),符号表达式画图,在许多的场合,将表达式可视化是有利的。
MATLAB提供了函数ezplot来完成该任务。
y=16*x2+64*x+96%expressiontoploty=16*x2+64*x+96ezplot(y),ezplot绘制了定义域为-2x2的给定符号函数,并相应地调整了y轴比例,还加了网格栅和标志。
在这个例子中,我们感兴趣的时间是从0到6。
让我们再试一下,并指定时间范围.ezplot(y,06)%plotyfor0x6,符号表达式简化,有时MATLAB返回的符号表达式难以理解,有许多工具可以使表达式变得更易读懂。
第一个就是函数pretty,该命令以类似于数学课本上的形式来显示符号表达式。
f=taylor(log(x+1)/(x-5)%6termsisthedefaultf=-1/5*x+3/50*x2-41/750*x3+293/7500*x4-1207/37500*x5+O(x6)pretty(f)24132934120756-1/5x+3/50x-x+-x-x+O(x)750750037500,符号表达式可用许多等价形式来提供。
在不同的场合,某种形式可能胜于另一种。
MATLAB用许多命令来简化或改变符号表达式。
f=sym(x2-1)*(x-2)*(x-3)%createafunctionf=(x2-1)*(x-2)*(x-3)collect(f)%collectallliketermsans=x4-5*x3+5*x2+5*x-6hornor(ans)%changetoHornerornestedrepresentationans=-6+(5+(5+(-5+x)*x)*x)*xfactor(ans)%expressasaproductofpolynomialsans=(x-1)*(x-2)*(x-3)*(x+1)expand(f)%distributeproductsoversumsans=x4-5*x3+5*x2+5*x-6,Simplify是功能强大、通用的工具。
它利用各种类型代数恒等式,包括求和、积分和分数幂、三角、指数和log函数、Bessel函数、超几何函数和函数,来简化表达式。
下面例子说明函数的乘幂。
simplify(log(2*x/y)ans=log
(2)+log(x)-log(y)simplify(sin(x)2+3*x+cos(x)2-5)ans=3*x-4simplify(-a2+1)/(1-a)ans=a+1,方程求解,用MATLAB所具有的符号工具可以求解符号方程。
有一些工具已经在前面介绍过,更多将在本节予以检验。
求解单个代数方程:
MATLAB具有求解符号表达式的工具。
若表达式不是一个方程式(不含等号),则在求解之前函数solve将表达式置成等于0。
solve(a*x2+b*x+c)%solvefortherootsofthequadraticeqution,ans=1/2/a*(-b+(b2-4*a*c)1/2)1/2/a*(-b-(b2-4*a*c)1/2)结果是符号向量,其元素是方程的2个解。
如果想对非缺省x变量求解,solve必须指定变量。
solve(a*x2+b*x+c,b)%solveforbans=-(a*x2+c)/x,带有等号的符号方程也可以求解。
f=solve(cos(x)=sin(x)%solveforxf=1/4*pit=solve(tan(2*x)=sin(x)t=0acos(1/2+1/2*3(1/2)acos(1/2=1/2*3(1/2),并得到数值解。
numeric(f)ans=0.7854numeric(t)ans=00+0.8314i1.9455,注意在求解周期函数方程时,有无穷多的解。
在这种情况下,solve对解的搜索范围限制在接近于零的有限范围,并返回非唯一的解的子集。
代数方程组求解,可以同时求解若干代数方程,语句solve(s1,s2,.,sn)对缺省变量求解n个方程,语句solve(s1,s2,.,sn,v1,v2,.,vn)对n个v1,v2,.vn的未知数求解n个方程。
如果电影票价为3.00美元,爆米花为1.00美元,糖棒为50美分,她有足够的钱去买这三样东西?
如何处理中小学典型的代数问题?
黛安娜(Diane)想去看电影,她从小猪存钱罐倒出硬币并清点,她发现:
10美分的硬币数加上5美分的硬币总数的一半等于25美分的硬币数。
1美分的硬币数比5美分、10美分以及25美分的硬币总数多10。
25美分和10美分的硬币总数等于1美分的硬币数加上1/4的5美分的硬币数25美分的硬币数和1美分的硬币数比5美分的硬币数加上8倍的10美分的硬币数多1。
首先,根据以上给出的信息列出一组线性方程,假如p,n,d和q分别表示1美分,5美分,10美分,和25美分的硬币数,然后,建立MATLAB符号方程并对变量求解。
eq1=d+(n+p)/2=q;eq2=p=n+d+q-10;eq3=q+d=p+n/4;eq4=q+p=n+8*d-1;pennies,nickles,dimes,quarters=solve(equ1,equ2,equ3,equ4,p,n,d,q)pennies=16nickles=8dimes=3quarters=15,所以,黛安娜有16枚1美分的硬币,8枚5美分的硬币,3枚10美分的硬币,15枚25美分的硬币,这就意味着money=.01*16+.05*8+.10*3+.25*15money=4.6100她就有足够的钱去买电影票,爆米花和糖棒并剩余11美分。
单个微分方程,常微分方程有时很难求解,MATLAB提供了功能强大的工具,可以帮助求解微分方程。
函数dsovle计算常微分方程的符号解。
因为我们要求解微分方程,就需要用一种方法将微分包含在表达式中。
所以,dsovle句法与大多数其它函数有一些不同,用字母D来表示求微分,D2,D3等等表示重复求微分,并以此来设定方程。
任何D后所跟的字母为因变量。
方程=0用符号表达式D2y=0来表示。
独立变量可以指定或由symvar规则选定为缺省。
函数dsolve格式r=dsolve(eq1,eq2,cond1,cond2,v)说明:
对给定的常微分方程(组)eq1,eq2,中指定的符号自变量v,与给定的边界条件和初始条件cond1,cond2,.求符号解(即解析解)r;若没有指定变量v,则缺省变量为t;在微分方程(组)的表达式eq中,大写字母D表示对自变量(设为x)的微分算子:
D=d/dx,D2=d2/dx2,。
微分算子D后面的字母则表示为因变量,即待求解的未知函数。
,,初始和边界条件由字符串表示:
y(a)=b,Dy(c)=d,D2y(e)=f,等等,分别表示,;若边界条件少于方程(组)的阶数,则返回的结果r中会出现任意常数C1,C2,;dsolve命令最多可以接受12个输入参量(包括方程组与定解条件个数,当然我们可以做到输入的方程个数多于12个,只要将多个方程置于一字符串内即可)。
若没有给定输出参量,则在命令窗口显示解列表。
若该命令找不到解析解,则返回一警告信息,同时返回一空的sym对象。
这时,用户可以用命令ode23或ode45求解方程组的数值解。
例如,一阶方程dy/dx=1
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- MATLAB 中的 符号 运算