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

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

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

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

Q&A

解決済

2回答

4893閲覧

モンテカルロ法による積分

langhtorn

総合スコア104

C

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

0グッド

0クリップ

投稿2020/10/30 15:22

###実現したいこと
モンテカルロ法を利用して積分の計算がしたいです。
範囲は1,0と仮定してよいです。
積分する関数は、f(x)=1-4(x-1/2)^2です。
###問題点
自分なりに作ってみたのですが、普通に手計算でした積分の結果とだいぶ誤差があるのでモンテカルロ法がなってない可能性があります。プログラムは間違っている部分があると思うのですがどこが違うでしょうか。
実行結果は以下なのですが、f(x)=1-4(x-1/2)^2を普通に計算したら**0.6666...**あたりになると思います。。。

乱数の数:10000 cnt=3389 面積の近似値は0.338900です. ------------------------------- 乱数の数:10000 cnt=3303 面積の近似値は0.330300です.

###コード

C

1//乱数による積分 2#include<stdio.h> 3#include<stdlib.h> 4#include<time.h> 5#include<math.h> 6 7//関数 8double f(double x) 9{ 10 return (1-4*pow((x-1/2),2)); 11} 12 13int main(void) 14{ 15 int n; //乱数の数 16 int i,cnt=0; 17 double x,y,S; 18 printf("乱数の数:"); 19 scanf("%d",&n); 20 21 //乱数をn個発生させる 22 srand((unsigned)time(NULL)); 23 for(i=0;i<n;i++){ 24 x=((double)rand()+1.0)/((double)RAND_MAX+1.0); 25 y=((double)rand()+1.0)/((double)RAND_MAX+1.0); 26 //printf("x=%f y=%f",x,y); 27 if(y<=f(x)){ 28 cnt++; 29 } 30 } 31 printf("cnt=%d\n",cnt); 32 33 //積分=面積 34 S=(double)cnt/n; 35 printf("面積の近似値は%fです.\n",S); 36 37 return 0; 38}

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

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

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

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

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

guest

回答2

0

ベストアンサー

return (1-4*pow((x-1/2),2));

1/2 は 0 と評価されます。

投稿2020/10/31 00:08

episteme

総合スコア16614

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

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

langhtorn

2020/10/31 01:09

1/2を0.5にしたら望みの値が出てきました。ありがとうございます。
guest

0

return (1-4*pow((x-1/2),2));

return (1.0-4pow((x-1.0/2),2));
もしかして、
return (1.0-4
pow((x-1.0)/2,2));
ってはなしかな?

投稿2020/10/30 15:34

y_waiwai

総合スコア87774

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問