関数の近似.pptVIP

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
関数の近似

方程式の数値解析 解析的には解が得られない 方程式を数値的に求める。 例:4次方程式 2分法 関数が負と正となる間に必ず解が有る。 C言語における関数の利用 P66式(4.1)の例 ニュートン?ラフソン法 関数の傾き(微係数)を用いて求析。 ニュートン?ラフソン法 P66の式(4.1) 第4章 章末問題1 複素数の解を求める 複素数の解を求める * * f(x) = a4x4+a3x3+a2x2+a1x1+a0 = 0 f(a)* f(b)0 x y a b x f(a) f(b) 中点の関数値を求める。 x y a b x f(a) f(b) f(c) f(a)*f(c)0 a-c 間に解 c 中点cを新たに端点bとする。 x y a b x f(a) f(b) f(a)*f(b)0 a-b 間に解 c f(a)*f(c)0 Yes No a ← c b ← c x y a b f(a) f(c) x y a b f(b) f(c) f(c) (b-a)/ce スタート x = c Yes No 例:y(x) = x2 #include math.h double y(double x) { return (x*x); } int main(void) y(a)として利用可能。 関数: y(x) = x3 + 6x2 + 21x +32 =0 初期値: a = -5 b = -1 繰返し数: n = 10000 判定値: eps = 1.0e-6 #include stdio.h #include math.h double y(double x) { return ((x+6.0)*x+21.0)*x+32.0; } int main(void) { double a, b, c, eps; int i, n = 10000; eps = 1.0e-6; a = -5.0; b = -1.0; fabs( ) のため 関数 関数値が正負となる範囲 } 解の桁数 c = 0.5*(a+b); for(i = 0; i n; i++){ if(fabs((b-a)/c)eps){break;} c = 0.5*(a+b); if(y(a)*y(c) 0.0) b = c; else a = c; } printf(x = %f\n,c); return 0; } 中点の計算 x y x0 f(x0) y = f’(x0)(x-x0) - f(x0) x1 = x0 - f(x0)/f’(x0) x y x0 x1 x2 x3 f(xi+1)e Yes No xi+1 = xi - f(xi)/f’(xi) スタート x = xi+1 x0 y x x2 x1 xi ← xi+1 y(x) = x3 + 6x2 + 21x +32 =0 の解をニュートン?ラフソン法で求めよ。 #include stdio.h #include math.h double f(double x) { return x*x*x + 6.0*x*x + 21.0*x + 32.0; } double fd(double xd) { return 3.0*x*2 + 12.0*x + 21.0 ; } fabs( ) のため 関数 導関数 double x0, x1, eps; int i, n = 10000; eps = 1.0e-6; x0 = 0.0; for(i = 0; i n; i ++){ x1 = x0 – f(x0)/fd(x0); if(fabs(f(x1)) eps){break;} x0 = x1; } printf(“x=%f\n”,x1); 初期値 y = e-x - x2 の解をニュートン?ラフソン法で求めよ。 #include stdio.h #include math.h double f(double x) { return exp(-x) - x*x; } double fd(double xd) { return -exp(-xd) -2.0*xd; } fabs( ) のため 関数 導関数 double x0, x1, eps; int i, n = 10000; eps = 1.0e-6; x0 = 0.0; for(i = 0; i n; i ++){ x1 = x0 - f(x0)/fd(x0); if(fabs(f(x1)) eps){break;} x0 = x1; } printf(“x=%f\n”,x1); 初期値 f(z) =

文档评论(0)

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

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

1亿VIP精品文档

相关文档