方程求解

求解单个代数方程

MATLAB具有求解符号表达式的工具,如果表达式不是一个方程式(不含等 号),则在求解之前函数solve将表达式置成等于0

>> syms a
syms b
syms c
syms x
>> solve('a*x^2+b*x+c') ans = -(b + (b^ - *a*c)^(/))/(*a)
-(b - (b^ - *a*c)^(/))/(*a)

结果是符号向量,其元素是方程的两个解。如果想对非缺省值x变量求解,solve必须指定变量

>> solve('a*x^2+b*x+c','b')

ans =

-(a*x^ + c)/x

带有等号的符号方程也可以求解:

>> f = solve('cos(x) = sin(x)')

f =

pi/

>> t = solve('tan(2*x) = sin(x)')

t =

>> x = solve('exp(x) = tan(x)')
警告: Cannot solve symbolically. Returning a numeric
approximation instead. %不能用符号来解决。返回数字是近似值。 x = -226.19467105846511316931032359612

 代数方程组求解

>> eq1 = 'x-3 =4';
eq2 = 'x*2-x-6=0';
eq3 = 'x^2+2*x+4=0';
eq4 = '3*x+2*y-z=10';
eq5 = '-x+3*y+2*z=5';
eq6='x-y-z=-1';
>> solve(eq1) ans = >> solve(eq2) ans = >> solve(eq3) ans = - ^(/)*i -
^(/)*i - >> solve(eq4,eq5,eq6) ans = x: [1x1 sym]
y: [1x1 sym]
z: [1x1 sym]

这里,solve(eq4,eq5,eq6)是一个结构数组,其中每个元素为一符号类型的量

>> ff = solve(eq4,eq5,eq6);
>> ff.x ans = - >> ff.y ans = >> ff.z ans = -

也可以:

>> [a,b,c] = solve(eq4,eq5,eq6)

a =

-

b =

c =

-

例题:

 解题思路:

首先,根据以上给出的信息列出一组线性方程,假如p,n,d和q分别表示1美分,5美分,10美分,和25美分的硬币数

>> syms d
>> syms p
>> syms n
>> syms q
>> a = 'd+(n+p)/2=q';
>> b = 'p=n+d+q-10';
>> c = 'q+d = p+n/4';
>> d = 'q+p = n+8*d-1';
>> [pennise,nickles,dimes,quarters] = solve(a,b,c,d,'p,n,d,q')
警告: Do not specify equations and variables as character
strings. Instead, create symbolic variables with syms.
%不要将公式和变量指定为字符串。相反,使用syms创建符号变量。 pennise = nickles = dimes = quarters =

>> money = .*+.*+.*+.*

money =

    4.6100

 例题:

【0】从三维坐标初步观察两函数图形相交情况

x=-:0.05:;y=x;[X,Y]=meshgrid(x,y); %产生x-y平面上网点坐标
F1=sin(X-Y);F2=cos(X+Y);
F0=zeros(size(X));
surf(X,Y,F1),
xlabel('x'),ylabel('y'), view([-,]),hold on,
surf(X,Y,F2),surf(X,Y,F0),
shading interp,
hold off

【1】在某区域观察两函数0等位线的交点情况

x=-:0.5:;y=x;[X,Y]=meshgrid(x,y); %产生x-y平面上网点坐标
F1=sin(X-Y);F2=cos(X+Y);
v=[-0.2, , 0.2]; %指定三个等位值,是为了更可靠地判断0等位线的存在。
contour(X,Y,F1,v) %画F1的三条等位线。
hold on,contour(X,Y,F2,v),hold off %画F2的三条等位线。

【2】从图形获取零点的初始近似值

ginput 获取两个函数0 等位线(即三线组中间那条线)交点的坐标。

[x0,y0]=ginput(); %在图上取两个点的坐标
disp([x0,y0])

【3】利用 fsolve 求精确解(以求(0.7926,7843)附近的解为例。)

本例直接用字符串表达被解函数。注意:在此,自变量必须写成x(1), x(2)。
假如写成xy(1), xy(2),指令运行将出错。

fun='[sin(x(1)-x(2)),cos(x(1)+x(2))]'; %<>
xy=fsolve(fun,[x0(),y0()])
%<>

xy =

0.7854 0.7854

【4】检验

fxy1=sin(xy()-xy());fxy2=cos(xy()+xy());disp([fxy1,fxy2])

Matlab——数值计算——单个代数方程 代数方程组的更多相关文章

  1. MATLAB数值计算——0

    目录 MATLAB数值计算 1.solve() 2.fzero() 3.fsolve() MATLAB数值计算 MATLAB中文论坛基础板块常见问题归纳(出处: MATLAB中文论坛) 登录http: ...

  2. fslove - Matlab求解多元多次方程组

    fslove - Matlab求解多元多次方程组 简介: 之前看到网上的一些资料良莠不齐,各种转载之类的,根本无法解决实际问题,所以我打算把自己的学到的总结一下,以实例出发讲解fsolve. 示例如下 ...

  3. Matlab数值计算最简单的一个例子——指数衰减

    放射性衰变是指数衰减的典型例子.另外还有化学反应某反应物的减少,RC电路电流的减小,大气压随海拔高度的减小等. 指数衰减的方程: \begin{equation} \frac{dN(t)}{dt}=- ...

  4. Matlab数值计算示例: 牛顿插值法、LU分解法、拉格朗日插值法、牛顿插值法

    本文源于一次课题作业,部分自己写的,部分借用了网上的demo 牛顿迭代法(1) x=1:0.01:2; y=x.^3-x.^2+sin(x)-1; plot(x,y,'linewidth',2);gr ...

  5. matlab解三元二次方程组

    C1=7.0863; C2=6.8971; C3=0.4929; C4=0.8131; C5=1.8240; C6=3.8108; C7=3.7318; C8=-2.2238; C9=1.9905; ...

  6. Matlab 数值计算

    本博客记录一些简单的计算 det(A):矩阵求行列式 A=[1,2;3,4]; det(A) ans=-2; inv(A):矩阵求逆 A=[1,2;3,4]; B=inv(A) B=[-2,1;1,5 ...

  7. matlab 解方程组

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

  8. 【数学建模】MATLAB语法

    一.向量.矩阵的表示和使用 format long  %小数很多format short %默认4位小数format rat %显示最近的分数format short e %指数格式的数 尾数多少 e ...

  9. 【书单】matlab 科学计算、数值分析以及数学物理问题

    1. 数学计算 MATLAB数值计算 MATLAB之父 : 编程实践 2. 数学物理问题 高等应用数学问题的MATLAB求解(第3版)(豆瓣评价极好) 3. 模式识别

随机推荐

  1. mysql之innodb存储引擎

    mysql之innodb存储引擎 innodb和myisam区别 1>.InnoDB支持事物,而MyISAM不支持事物 2>.InnoDB支持行级锁,而MyISAM支持表级锁 3>. ...

  2. C语言——枚举类型用法

    1.枚举的定义 enum 枚举名{ 枚举元 素1,枚举元素2,枚举元素3...}: 2.使用枚举类型的好处 增加程序的可读性,我们都知道在计算机中所有信息都是用二进制来表示的,如果你用二进制来表示某件 ...

  3. 【30分钟学完】canvas动画|游戏基础(extra1-1):美图我也行

    前言 本文是接续系列教程的extra1,主要是介绍颜色系统在canvas中的应用. 本来是与extra1一起成文的,因为segmentfault莫名其妙的字数限制bug只能分割放送了. canvas操 ...

  4. 知名界面类控件Kendo UI for jQuery R2 2019 SP1发布|附下载

    Kendo UI for jQuery提供了在短时间内构建现在Web应用程序所需要的一切.从70多个UI中选择,并轻松地将它们组合起来,创建出酷炫响应式的应用程序,同时将开发时间加快了50%. [适用 ...

  5. 负载均衡(四)Nginx负载均衡策略

    一.Nginx的作用 1.反向代理 代理:转发请求的服务器,分代理和反向代理.代理一般指的是我们使用的DNS,反向代理是放在服务端的大家通常用Nginx来解决.实际应用中,由于服务端处于一个中心位置, ...

  6. 第四篇:存储库之mongodb、redis、mysql

    MongoDB的简单操作 一.简介 二.MongoDB基础知识 三.安装 四.基本数据类型 五.增删改查操作 六.可视化工具 七.pymongo 一.简介 MongoDB是一款强大.灵活.且易于扩展的 ...

  7. oracle基本语句(第四章、数据库安全管理)

    1.用SYS用户以SYSDBA身份登录SQL Plus,使用DBA_USERS视图查看用户信息: SELECT USERNAME, ACCOUNT_STATUS, CREATED FROM DBA_U ...

  8. 【shell】文本按行逆序

    1.最简单的方法是使用tac [root ~]$ seq |tac 2.使用tr和awk. tr把换行符替换成自定义的分隔符,awk分解替换后的字符串,并逆序输出 [root ~]$ seq | tr ...

  9. 源码编译git-go

    2018.8.29 安装指定版本的git 一,安装 编译前准备: 依赖库 yum install curl-devel expat-devel gettext-devel openssl-devel ...

  10. 洛谷 P1080 石子合并 ( 区间DP )

    题意 : 在一个圆形操场的四周摆放N堆石子,现要将石子有次序地合并成一堆.规定每次只能选相邻的2堆合并成新的一堆,并将新的一堆的石子数,记为该次合并的得分.试设计出1个算法,计算出将N堆石子合并成1堆 ...