2017-10-09 回答

用matlab解方程的三个实例

1、对于多项式p(x)=x3-6x2-72x-27,求多项式p(x)=0的根,可用多项式求根函数roots(p),其中p为多项式系数向量,即

>>p =

p =

1.00 -6.00 -72.00 -27.00

p是多项式的matlab描述方法,我们可用poly2str(p,'x')函数 ,来显示多项式的形式:

>>px=poly2str(p,'x')

px =x^3 - 6 x^2 - 72 x - 27

多项式的根解法如下:

>> format rat %以有理数显示

>> r=roots(p)

r =

2170/179

-648/113

-769/1980

2、在matlab中,求解用符号表达式表示的代数方程可由函数solve实现,其调用格式为:solve(s,v):求解符号表达式s的代数方程,求解变量为v。

例如,求方程(x+2)x=2的解,解法如下:

>> x=solve('(x+2)^x=2','x')

x =

.69829942170241042826920133106081

得到符号解,具有缺省精度。如果需要指定精度的解,则:

>> x=vpa(x,3)

x =

.698

3、使用fzero或fsolve函数 ,可以求解指定位置(如x0)的一个根,格式为:x=fzero(fun ,x0)或x=fsolve(fun,x0)。例如,求方程0.8x+atan(x)-=0在x0=2附近一个根,解法如下:

>> fu=@(x)0.8*x+atan(x)-pi;

>> x=fzero(fu,2)

x =

2.4482

>> x=fsolve('0.8*x+atan(x)-pi',2)

x =

2.4482

________________________________________

当然了,对于该方程也可以用第二种方法求解:

>> x=solve('0.8*x+atan(x)-pi','x')

x =

2.4482183943587910343011460497668

对于第一个例子,也可以用第三种方法求解:

>> f=@(x)x^3-6*x^2-72*x-27

f =

@(x)x^3-6*x^2-72*x-27

>> x=fzero(f,10)

x =

12.1229

对于第二个例子,也可以用第三种方法:

>> fun=@(x)(x+2)^x-2

fun =

@(x)(x+2)^x-2

>> x=fzero(fun,1)

x =

0.6983

最近有多人问如何用matlab解方程组的问题,其实在matlab中解方程组还是很方便的,例如,对于代数方程组ax=b(a为系数矩阵 ,非奇异)的求解,matlab中有两种方法:

(1)x=inv(a)*b — 采用求逆运算解方程组;

(2)x=a\b — 采用左除运算解方程组。

例:

x1+2x2=8

2x1+3x2=13

>>a=;b=;

>>x=inv(a)*b

x =

2.00

3.00

>>x=a\b

x =

2.00

3.00;

即二元一次方程组的解x1和x2分别是2和3。

对于同学问到的用matlab 解多次的方程组,有符号解法,方法是:先解出符号解,然后用vpa(f,n)求出n位有效数字的数值解.具体步骤如下:

第一步:定义变量syms x y z ...;

第二步:求解=solve('eqn1','eqn2',...,'eqnn','var1','var2',...'varn');

第三步:求出n位有效数字的数值解x=vpa(x,n);y=vpa(y,n);z=vpa(z,n);...。

如:解二(多)元二(高)次方程组:

x^2+3*y+1=0

y^2+4*x+1=0

解法如下:

>>syms x y;

>>=solve('x^2+3*y+1=0','y^2+4*x+1=0');

>>x=vpa(x,4);

>>y=vpa(y,4);

结果是:

x =

1.635+3.029*i

1.635-3.029*i

-.283

-2.987

y =

1.834-3.301*i

1.834+3.301*i

-.3600

-3.307。

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐