Part6——微分与差分方程.docVIP

  1. 1、本文档共28页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Part 6——微分和差分方程 这次教程有点多,望大家耐心看哦! 第一章 1.1 代数方程求解 下面主要介绍几类常用的方程求根方法。 (1)多项式——roots 调用示例: r = roots(p) 其中,p为多项式的系数,从高次到低次顺序,r为对应的多个根。 如多项式:,求解程序如下: p = [1 -6 -72 -27]; r = roots(p) r = 12.1229 -5.7345 -0.3884 注意:通过其它函数也可以多项式的根,但是不能求出所有的根,而roots可以求出多项式所有的根。下面将会看到。 参考函数:poly, residue (2)一元函数——fzero 调用示例: x = fzero(fun,x0) x = fzero(fun,x0,options) [x,fval] = fzero(...) 其中,fun为待求函数的名称,x0为初始值,x为解,fval为最优解对应的值(对于求根来说,理想情况下为0)。 如: ,求根程序如下: f = @(x)x.^3-2*x-5; z = fzero(f,2) 再看看(1)中的示例,程序 f = @(x)x.^3-6*x.^2-72*x-27; z1 = fzero(f,10) z2 = fzero(f,-4) z3 = fzero(f,0) 很容易发现,对于不同的初始值,最后的根也不一样,最后的结果分别为:12.1229、-5.7345、-0.3884,而这三个分别为(1)中roots得到的解。实际上fzero函数的实现方式是以某个初始点来迭代得到方程解的,因为初始值的选取对最终结果影响很大。下面说到的牛顿迭代之类的算法也是类似情况,对初始值的选取很敏感,而智能算法对初始值的选取并不敏感。 注意:f = @(x)...是匿名函数的表达方式,即该函数没有名字,但是通过@来指定变量,或者待求变量。 参考函数:fminbnd, optimset, function_handle (@), Anonymous Functions 小技巧:快捷注释与注释消除键,选取待注释语句,然后ctrl+R为注释,ctrl+T为消除注释。 (3)非线性方程组——fsolve 调用示例: x = fsolve(fun,x0) x = fsolve(fun,x0,options) [x,fval] = fsolve(fun,x0) 其中,fun为函数名,x0为初始值,options为参数设置(迭代算法、步长、精度等),x为最优解,fval为最优解对应的最优值。 示例如下: x0 = [-5; -5]; % 随机初始值 options=optimset(Display,iter); % 显示每次迭代的过程 [x,fval] = fsolve(@myfun,x0,options) % 调用优化函数 其中,myfun如下: function F = myfun(x) F = [2*x(1) - x(2) - exp(-x(1)); -x(1) + 2*x(2) - exp(-x(2))]; 迭代过程: 最后的解为: x = 0.5671 0.5671 fval = 1.0e-006 * -0.4059 -0.4059 注意:该函数求解性能很强,大家可以随意设置初始值x0看看结果如何,理论上结果是不变的,也就是该函数使用的迭代算法对初始值不敏感。 (4)符号方程——solve 调用示例: solve(eq) solve(eq,var) solve(eq1,eq2,...,eqn) g = solve(eq1,eq2,...,eqn,var1,var2,...,varn) 其中,eq为待求解的符号方程,默认的求解符号是x;通过var设置带求解的符号变量;求解符号方程组的话,需要依次添加每个方程,以及带求解的所有符号变量。g是存放结果的结构体变量,通过g.x调用显示结果。 示例如下: %% 求解 a*x^2 + b*x + c = 0 关于x的符号解 solve(a*x^2 + b*x + c) %% 求解 a*x^2

文档评论(0)

00625 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档