前提
【C言語】2x^2 - 12sin(x) = 0
の解のうち,0より大きいものを二分法で精度10-6で求めるプログラムを書きました。
###質問
検算の結果( fx(xm) )が0に近づいたはずなのに、途中で幅が広がってしまいます。
なぜですか?
###前置き
はじめにf(x) = 2x^2 - 12sin(x)
グラフはエクセルで作ったところ以下のようになったので、
初期値xa``````xb
はそれぞれxa = 2
,xb = 3
としました。
コード
c
1#include <stdio.h> 2#include <math.h> 3#define EPS 1.0e-6 4float f(float x); 5int main(void) 6{ 7 float xa,xb,xm; 8 xa = 2; 9 xb = 3; 10 printf("f(x)="); 11 printf("%.6f\n", f(xa)); 12 13 do{ 14 xm = (xa+xb)/2; 15 printf("%f\n", xm); 16 printf("f(xm) = %f\n", f(xm)); 17 if( f(xa)*f(xb) < 0 ) 18 { 19 xb = xm; 20 } 21 else 22 { 23 xa = xm; 24 } 25 }while( xb-xa>EPS ); 26 27 printf("xm = %.6f\n", xm); 28 printf("検算の結果\nf(xm)=%.6f\n", f(xm)); 29 printf("よって解はx=%.6f\n", xm); 30} 31 32float f(float x){ 33 float y; 34 y = 2*x*x-12*sin(x); 35 36 return(y); 37}
結果
f(x)=-2.911569 2.500000 f(xm) = 5.318334 2.250000 f(xm) = 0.788122 2.125000 f(xm) = -1.172588 // 前の幅より、大きくなっているのはなぜ? 2.062500 f(xm) = -2.070545 2.093750 f(xm) = -1.628595 2.109375 f(xm) = -1.402337 2.117188 f(xm) = -1.287897 2.121094 f(xm) = -1.230351 2.123047 f(xm) = -1.201496 2.124023 f(xm) = -1.187049 xm = 2.124023 検算の結果 f(xm)=-1.187049 よって解はx=2.124023
以上、よろしくお願いします。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/10/17 15:56