式をC言語で立てれません
こんにちは。私は今実験で円板振動子の中心軸上の音圧分布を求めています。
そこで写真のような図をプロットするために与えられた式をC言語で書いています。
式の詳細は
P/2ρcV = |sinπ(√(r/λ)^2 + (a/λ)^2)(√はここまで)-(r/λ)^2)|
です。
しかしうまくプロットできません。
プログラムは
-------------------------------------
#include <stdio.h>
#include <math.h>
#define F 120 //周波数(Hz)
#define C 1500 //音速(m/s)
#define A 0.2 // 半径(m)
int main()
{
double x, m, s, p, o, w, l;
int i;
for (i=0; i<100; i++)
{ x= (double)i; //観測点までの距離を表しました。距離が変化することで音圧が変わるためです。
l = C/F; //λをlとして音速÷周波数で定義できます。
m = x/l; //x軸です。
o = m*m + (A/l)*(A/l); //式のsinの中身です。
s = sin(M_PI*(sqrt (o) - m)); //sin全体を定義します。
w = fabs(s); //sin全体を絶対値に置き換えます。
p = w; //新しい変数に入れます。
printf("%9.9f %9.9f\n", m, p);
}
return 0;
}
------------------------------
といった感じです。先生からはx軸のプログラムだけいじれば勝手に
y軸も出てくるとヒントを頂いているのでx軸についてのプログラムを
書いています。コンパイルはできても写真のようにいきません。
半径やλや周波数はa/λ=2.5と書いてあったので値は推測です。
C言語はあまり得意ではないので困っています。
お分かりになる方、ご教授お願い致します。
No.2ベストアンサー
- 回答日時:
C/Fはint
なので精度が出ない。
科学技術計算は(メモリが許す限り)精度をとっておくか、(きちんと理解していれば)不要な精度を落とすかどちらか
l=(double)(C)/F;
で問題ないと思います。
No.1
- 回答日時:
あまり良く分かりませんが、とりあえず
> s = sin(M_PI*(sqrt (o) - m)); //sin全体を定義します。
は
s = sin(M_PI*(sqrt (o) - m*m));
じゃないかと……
この回答への補足
すみません!
式はP/2ρcV = |sinπ(√(r/λ)^2 + (a/λ)^2)(√はここまで)-(r/λ))|です!
最後の二乗いりませんでした。
これでよろしくお願いします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# このプログラミング誰か教えてくれませんか 1 2022/06/02 15:27
- C言語・C++・C# C言語 プログラミング 4 2022/05/22 11:53
- C言語・C++・C# C 言語の Gauss Jordan 法について 2 2022/12/28 11:16
- C言語・C++・C# LU分解法のピボット選択機能実装について(C言語・gcc-9) 1 2022/07/22 15:20
- C言語・C++・C# C言語 3 2022/10/04 15:07
- C言語・C++・C# 10個の実数に対する降順ソート結果を出力するプログラムを作りたいのですが、以下のプログラムをどう直せ 1 2022/07/09 22:16
- C言語・C++・C# LU分解法のピボッティングについて(C言語/gcc-9) 3 2022/07/11 23:10
- C言語・C++・C# C言語の課題が出たのですが自力でやっても分かりませんでした。 要素数がnであるint型の配列v2の並 3 2022/11/19 17:41
- C言語・C++・C# C言語初心者 構造体 課題について 2 2023/03/10 19:48
- C言語・C++・C# C言語のエラーについて 2 2022/07/11 13:56
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
プログラムでの数字につく”f”の...
-
C 開放してるのにエラー(doubl...
-
C言語 関数プロトタイプ宣言の...
-
数値を指数部と仮数部に分離したい
-
学校の課題で2次方程式のプログ...
-
関数におけるif文とreturn文に...
-
C言語を実行すると-infが出てき...
-
float型とdouble型の変数の違い...
-
C言語で表記についの質問です
-
指数の表示
-
2分法で方程式の複数の解を自...
-
doubleは常に%lfとするべきなのか
-
物体が往復する動きを作りたい
-
C言語で内積、、、わかりません。
-
c言語のコンパイルエラー canno...
-
C言語のpow関数の不具合
-
処理時間計測
-
float?数字の後にLがつくもの
-
「割り算」 と 「分数の掛け算」
-
C++標準ライブラリィーのcomple...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
プログラムでの数字につく”f”の...
-
float型とdouble型の変数の違い...
-
doubleの変数にintとintの割り...
-
C言語を実行すると-infが出てき...
-
C 開放してるのにエラー(doubl...
-
至急です! マクロ定義で #defi...
-
c言語で、繰り返し文の中で、0....
-
関数におけるif文とreturn文に...
-
C言語 関数プロトタイプ宣言の...
-
C言語初心者 構造体 課題について
-
C言語の型による処理速度の違い
-
Cで3乗根を求める方法
-
C言語で-23乗を取り扱うには
-
2分法で方程式の複数の解を自...
-
doubleは常に%lfとするべきなのか
-
c言語のコンパイルエラー canno...
-
C言語で直角三角形の斜辺を求め...
-
C言語のプログラムで#include<m...
-
int とdoubleの比較
-
C++で外積
おすすめ情報