
■質問1
#include <math.h>
と書くだけで
sin, cos, tan 等の様々な関数が使えますが、
inline float __CRTDECL sin(_In_ float _X)
{return (sinf(_X)); }
inline float sinf(_In_ float _X)
{return ((float)sin((double)_X)); }
などとなっていてsinがsinfを呼び出し、sinfがsinを呼び出し、sinが・・・
とグルグル回ってる気がするのですが実際どうなのでしょうか?
■質問2
質問1で述べたように実際にどのような計算でsinの値が弾かれているかわかりません。
マクローリン展開で近似された式を利用してsin関数ができると思うのですがmath.hをずっと眺めていてもみつかりませんでした。
どこに書いてあるのでしょうか?
math.dllのようにライブラリ化しちゃってるのを呼び出してるだけなのでしょうか?
No.2ベストアンサー
- 回答日時:
C++の多重定義は理解できてますか?
C++では引数の型によって別の関数として定義することができます。
> inline float __CRTDECL sin(_In_ float _X)
とあるfloatを引数とするsinと
> {return ((float)sin((double)_X)); }
でdoubleを引数にしたsinとは別の関数になります。
引数の型まで含めて同じか別かを考えて追い掛ければ、最終的なものに辿りつけるはずです。
> ■質問2
> math.hをずっと眺めていてもみつかりませんでした。
通常、ヘッダファイルには、プロトタイプ宣言だけを書きます。例外はインライン関数とかテンプレートとかのコンパイル単位で定義が必要なものです。
> math.dllのようにライブラリ化しちゃってるのを呼び出してるだけなのでしょうか?
DLLのような動的なものか、.libのような静的なものかはちょっと調べないとわかりませんが、予めコンパイル済みのものを使っているのが普通です。
ソースが公開されているものならそれを見れますが、そうでないなら、技術資料に頼るか、逆アセンブリで解析するか、あきらめるか、になります。
それに、最近のCPUだと、浮動小数点数の計算には専用の回路(FPU)を使っていて、三角関数なら「計算プログラム」はFPUに組込み済み、CPUからは1命令で呼びだしているだけ、ってこともあります。
Cを勉強していたので、C++の多重定義は知りませんでした!
調べた結果理解することができました!
質問2については
とても難しいそうですが理解できるように頑張ります!
No.1
- 回答日時:
環境がわからないので、いいかげんな事を書いてみます。
・float版の sin関数、inline float __CRTDECL sin(_In_ float _X)
は、float 版の sinf関数にインライン展開されている。
・float版の sinf関数、inline float sinf(_In_ float _X)
は、double版の sin関数にインライン展開されている。
って、事でしょう。
そして、double版のsin関数は、上の2つとは別に用意してある。
この回答への補足
環境はVisualStudio 2010 Pro(DreamSpark)で、
VC++のWin32コンソールアプリケーションです。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
プログラムでの数字につく”f”の...
-
c言語で、繰り返し文の中で、0....
-
doubleの変数にintとintの割り...
-
数値を指数部と仮数部に分離したい
-
^この記号を使わない
-
C言語でsqrt(a^2+b^2)のテーブ...
-
doubleは常に%lfとするべきなのか
-
至急です! マクロ定義で #defi...
-
C 開放してるのにエラー(doubl...
-
最早開始時間と最遅完了時刻を...
-
【C++】関数ポインタの使い方
-
既定のコンストラクタがありま...
-
Aの値からBの値を除するとは??
-
「Aに対するBの割合」と「Aに対...
-
信頼区間の1.96や1.65ってどこ...
-
a^2の√=a が成り立たない場合
-
VB6.0での小数点の扱いについて
-
配列をnビットシフトする
-
数学 一次関数 関数 y=-3/4x+k(...
-
c languageで 簡単な質問があ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
プログラムでの数字につく”f”の...
-
C 開放してるのにエラー(doubl...
-
c言語で、繰り返し文の中で、0....
-
doubleの変数にintとintの割り...
-
至急です! マクロ定義で #defi...
-
C言語 関数プロトタイプ宣言の...
-
浮動小数点の定数
-
DWORDの警告
-
C言語の型による処理速度の違い
-
C言語で台形公式を使った二重積...
-
C言語を実行すると-infが出てき...
-
int とdoubleの比較
-
C言語初心者 構造体 課題について
-
たくさんの数の平均を求める方...
-
EXE1→DLL→EXE2数値を受け渡す方法
-
プログラミングでのテイラー展開
-
C++初心者です。簡単なスコア計...
-
【C言語】二階微分方程式をル...
-
fgets()による繰り返し入力(c言語)
-
2分法で方程式の複数の解を自...
おすすめ情報