質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.46%
C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

Q&A

解決済

1回答

829閲覧

二分法の検算結果の絶対値が、前の値より大きくなってしまう。

OHASI

総合スコア96

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

0グッド

0クリップ

投稿2021/10/17 14:48

前提

【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

以上、よろしくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

c

1 if( f(xa)*f(xb) < 0 ) 2 { 3 xb = xm; 4 } 5 else 6 { 7 xa = xm; 8 }

ここが違うからですね
f(xm)の値を参照してxa,xbのどちらを更新するか決めないといけないですよ

投稿2021/10/17 15:44

jamjam3

総合スコア165

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

OHASI

2021/10/17 15:56

なるほどですね。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.46%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問