1.%% 求解单变量方程
%-----例子1------
syms x
eqn=sin(x)==1;
solve(eqn,x)
%-----例子2------
syms x
eqn=sin(x)==1;
[solx,params,conds]=solve(eqn,x,'ReturnConditions',true)
%-----例子3---------------
%如果返回empty,则表明解不存在。如果返回empty+warning,则解可能存在,但是solve找不到
syms x
solve(3x+2,3x+1,x)
2.%% 求解多变量方程
%---例1-----------------
%为了避免求解方程时对符号参数产生混乱,需要指明一个等式中需要求解的变量。
%如果不指明的话,solve函数就会通过symvar选择一个变量(认为该变量是要求解的变量)
clc,clear
syms a b c x
sola=solve(ax^2+bx+c==0,a) %待求解的变量是a
sol=solve(ax^2+bx+c==0) %待求解的变量是x
%----例子2--------------
%当求解的变量大于1个时,你声明变量的顺序就是slove返回解的顺序
syms a b
[b,a]=solve(a+b==1,2*a-b==4,b,a)
3.%% solve返回的解带有:参数&条件
%为了返回一个方程的完整的解(即解中含有的参数,及对参数的限制),需要指定ReturnConditions 为:true
%---例子1:关于解的约束----
clc,clear
syms x
S=solve(sin(x)==0 ,x,'ReturnConditions',true);
S
S.x
S.parameters
S.conditions
%为了找到x的数值解,以一个值(利用函数subs)代替k。用函数isAlways检验该值是否满足关于k的限制
%检验k=4是否满足in(k, 'integer')
isAlways(subs(S.conditions,S.parameters,4))
%isAlways返回的是logical 1(true),这意味着:对于k而言,4是一个合法值。
%利用4代替k,得到x的一个解。利用函数vpa获得该逼近的数值解(vpa设置数值精度:保留几位有效数字、几位小数)
solx=subs(S.x,S.parameters,4)
vpa(solx)
%为0
assume(S.conditions)
solk=solve(S.x>0,S.x<2*pi,S.parameters)
solx=subs(S.x,S.parameters,solk)
4.%% 求解方程组(为变量分配解)————
%当求解方程组的时候,利用多个输出项对应求解的输出变量。
%solve返回一个符号数组(为每个相互独立的变量)
%-----例子1--------------
syms a u v
[sola,solu,solv]=solve(au^2+v^2==0,u-v==1,a^2+6==5a,a,u,v)
solutions=[sola,solu,solv]
%----例子2------------
syms x y z
[solx,soly,solz]=solve(35(y-x)==0,-7x-xz+28y==0,xy-3z==0,x,y,z)
solutions=[solx,soly,solz]
5.%% 返回方程组完整的解(包括:参数和约束条件)
%需要指定ReturnConditions 为:true
%输出则要多附加两项:parameters 、conditions
clc,clear
syms x y
[solx,soly,params,conditions]=solve(sin(x)==cos(2*y) , x^2==y , [x,y],'ReturnConditions',true)
solutions=[solx,soly]
6.%% 返回数值解
%解析解(analytical solution):用严格的公式表示的解。
%数值解(numerical solution):无法用严格的公式表示,是采用某种计算方法(有限元、逼近、插值)得到的。
%symbolic solver无法找到精确的用符号表示的解,因此在调用numeric solver之前会事先声明(warning)。因为等式不是多项式,所以想要找到全部可能的解需要很长时间。
%numeric solver不会尽力去找等式的全部numeric solution,它仅仅返回它找到的第一个解。
clc,clear
syms x
solve(sin(x)==x^2-1,x)
%验证上面的等式确实有一个正值解:画出等式的左右两部分的曲线
ezplot(sin(x),-2,2)
hold on
ezplot(x^2-1,-2,2)
hold off
%也可以直接用函数vpasolve求出数值解(需要定义(寻找)解的范围)
vpasolve(sin(x)==x^2-1,x,[0 2 ])
7.%% 求解不等式
%solve能求解满足约束条件的不等式
%需要指定ReturnConditions 为:true。这样可以返回解中涉及到的任何参数和约束条件
% x>0
% y>0
% x^2+y^2+xy<1
clc,clear
syms x y
S=solve(x^2+y^2+x*y<1,x>0,y>0 , [x,y], 'ReturnConditions',true);
solx=S.x
soly=S.y
params=S.parameters
conditions=S.conditions
%利用subs和isAlways检验u=7/2和v=1/2是否满足约束条件
isAlways(subs(S.conditions,S.parameters,[7/2,1/2]))
%isAlways返回loogical 1(true)表示这些值满足约束条件。将这两个参数的值带入(函数subs)S.x和S.y中,找到一个x和y的解
solx=subs(S.x,S.parameters,[7/2,1/2])
soly=subs(S.y,S.parameters,[7/2,1/2])
%用函数vpa得到解的数值形式
vpa(solx)
vpa(soly)
8.%% 返回实数解
clc,clear
syms x
solve(x^5==3125,x)
%如果仅仅需要一个实数解,那么就把选项Real设置成true
solve(x^5==3125,x,'Real',true)
9.%% 返回一个解(主值Principal)
%不是返回一个无限多元素的周期解的集合,而是选择其中的最为实际的3个解(实际的、实用性的be most practical)
syms x
solve(sin(x)+cos(2*x)==1,x)
%利用选择PrincipalValue设置为true选择一个解(主值)
solve(sin(x)+cos(2*x)==1,x,'PrincipalValue',true)
10.%% 应用简化规则来缩短结果
%solve默认是不对解采用简化规则的,但是这些解从数学上来讲,不总是正确的。这样以来,solve就不能symbolically求解方程了。
clc,clear
syms x
solve(exp(log(x)log(3x))==4 , x)
%将IgnoreAnalyticConstraints (忽略解析约束)设置为true,这样就会应用简化规则,有可能让solve找到一个结果。
%简化规则的目的就是为了找到一个解。
%但是也不是任何情况下都可以应用简化规则,因此,应用简化规则后,应该对解的正确与否进行核实
S=solve(exp(log(x)log(3x))==4 , x,'IgnoreAnalyticConstraints',true)
11.%% 忽略有关变量的假设
%sym和syms函数可以让你对符号变量进行假设(设置assumptions)。例如,可以声明x为正值
clc,clear
syms x positive
%那么,在上述假设下,求得的解只能是符合假设的解
solve(x^2+5*x-6==0,x)
%如果想要得到方程全部的解,则需要将IgnoreProperties 设置为true
solve(x^2+5*x-6==0,x,'IgnoreProperties ',true)
%为了后续计算,清除之前的假设
syms x clear
12.%% 数值逼近符号解(that Contain RootOf)
%当求解多项式的时候,solve可能返回包含RootOf的解。为了数值逼近这些解,可以采用vpa函数。
clc,clear
syms x
s=solve(x^4+x^3+1==0,x)
%因为解中没有参数,所以可以采用vpa进行数值逼近
vpa(s)
13.%% 求解高阶的多项式等式
%当求解高阶的多项式方程的时候,solve可能采用 RootOf表示求得的解
clc,clear
syms x a
solve(x^4+x^3+a==0,x)
%为了得到方程的显式解,尝试调用带有参数MaxDegree的solve函数。该选项规定了多项式最大的degree,solve以此标准返回显式解。
%默认值是3。增大该数值,就可以得到高阶多项式的显式解。
s=solve(x^4+x^3+a==0,x,'MaxDegree',4)
pretty(s)
matlab中subs()是符号计算函数,详细用法可以在Matlab的Command Windows输入:help subs。subs()函数表示将符号表达式中的某些符号变量替换为指定的新的变量,常用调用方式为:
R = subs(S, new) 利用new的值代替符号表达式S中的默认符号。
R = subs(S) 用由调用函数或Matlab工作空间中获取的值替代了在符号表达式S中的所有当前的变量。
R = subs(S, old, new) 利用new的值代替符号表达式中old的值。old为符号变量或是字符串变量名。new是一个符号货数值变量或表达式。也就是说R = subs(S,old,new)在old=new的条件下重新计算了表达式S。这种替换第一次作为Matlab表达式被尝试,如果所有在new中的数值是双精度的,计算是以双精度算术运算进行的。讲new值转化为符号可以验证符号货变量的运算精度。
如果old和new是大小和类型相同的向量或是元包数组,每一个old的元素都将被相应新的元素替换。
如果S和old是标量,new是数组或元包数组,则扩展标量去计算一个数组结果。
如果new是个数值矩阵元包数组,替换讲运行为/智能元素/(i.e., subs(x*y,{x,y},{A,B}) returns A.*B when A and B are numeric)。
如果subs(s,old,new) 没有改变S,则将会试行subs(s,new,old)。这将为前面的版本提供向前的兼容性,消除记忆参数顺序。subs(s,old,new,0)不改变参数,如果S没有改变。
subs函数的用法:
例1:
syms a b x %注意:定义的是符号变量
f = a*sin(x)+b
(符号-符号置换)
f1 = subs(f,sin(x),’log(y)’)
(符号-数字置换)
f2 = subs(f,a,2.89)
(替换所有变量)
f3 = subs(f,{a,b,x},{2,5,sym(‘pi/3’)})
代码实现如下:
>> syms a b x %注意:定义的是符号变量
f = a*sin(x)+b
f =
b + a*sin(x)
>> f1 = subs(f,sin(x),'log(y)')
f1 =
b + a*log(y)
>> f2 = subs(f,a,2.89)
f2 =
b + (289*sin(x))/100
>> f3 = subs(f,{a,b,x},{2,5,sym('pi/3')})
f3 =
3^(1/2) + 5
例2:
syms x y z %声明三个符号变量
S = x^2+y^2
1、将变量x替换为数值1:
subs(S,x,1)
2、将变量x替换为变量z:
subs(S,x,z)
3、同时将变量x和y分别替换为1和z:
subs(S,{x,y},{1,z})
4、将单变量替换为数组:
subs(S,x,[1 2;3 4])
代码实现如下:
>> syms x y z %声明三个符号变量
S = x^2+y^2
S =
x^2 + y^2
>> subs(S,x,1)
ans =
y^2 + 1
>> subs(S,x,z)
ans =
y^2 + z^2
>> subs(S,{x,y},{1,z})
ans =
z^2 + 1
>> subs(S,x,[1 2;3 4])
ans =
[ y^2 + 1, y^2 + 4]
[ y^2 + 9, y^2 + 16]
>>