- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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) =
您可能关注的文档
最近下载
- KDW127-12矿用隔爆兼本安型直流稳压电源使用说明书资料.pdf VIP
- 初中道德与法治新人教版七年级上册第三单元第10课第2框《滋养心灵》教学课件(2024秋).pptx VIP
- 5.5导学ppt:指导老年人的营养膳食 (1)课件讲解.pptx VIP
- 手术区域皮肤消毒PPT大纲.pptx VIP
- 韦德韦诺VDF650系列通用型变频器用户手册.pdf
- 个人简历——【标准模板】.doc VIP
- 2025年安全生产费用提取 和使用管理制度(4篇).pdf VIP
- 高中物理教师职业发展计划.docx VIP
- 2024年网络安全知识竞赛考试题库及答案(通用版).docx VIP
- 密闭式静脉输血操作技术.pptx VIP
文档评论(0)