double DiscreteFourierTransformClass::DiscreteFourierTransformProcess(int n)
{
double e=2.7182818;
double Pai=3.1415926535;
int Tau=10;
int N=DataLen/Tau;
double Sum=0;
for(int k=0;k<N;k++)
{
Sum+=Tau*Data[k*Tau]*pow(e,i*2*Pai*k*n/N);
}
return Sum;
}
Tau*Data[k*Tau]=帯
pow(e,i*2*Pai*k*n/N)=ほしい周波数の乗算
ということで、離散フーリエ展開と同じなのでしょうか?
パソコン上で計算するには、離散フーリエ展開で計算して、
FFTというのは、pow(e,i*2*Pai*k*n/N)この回転子が3,4個程度のcos,sinで決まるから
その値で計算すれば高速になるよということでしょうか?
離散フーリエ変換
G(n/N)=Σ[k=0::N-1]{τ*f(kτ)e^-i2πkn/N}
k:何番目の値か τ:値を読んだ間隔 N:値を読んだ数 n:基本周波数の何倍か
G(n/N)->ほしいnの成分を得る
No.2ベストアンサー
- 回答日時:
私も素人理解です。
その上で読んでください。離散フーリエ展開と変換では扱ってる波の種類が違います。
展開は有限周期で、変換は無限周期です。
よって、必然的に式が異なってきます。
プログラムする場合においても、当然式が異なります。
これを全然違うと表現するのか、似たようなものと表現するのかはよくわかりません。
また、FFTは回転子が360°で周期的に変化するので、同じ計算値を使いまわすといった考えから高速化されます。
回転子が3、4個というのはサンプリングレートが3、4Hzの場合です。
FFT以前のフーリエ変換の基礎がわからないのであれば、「フーリエの冒険」という本が判りやすいです。
大きな書店の数学コーナーとかに置いています。
http://7andy.yahoo.co.jp/books/detail?accd=30514 …
FFTの話でわかりやすい書籍は私は知りません。
私もわかりやすい書籍があったら教えて欲しいです。
この回答への補足
回答ありがとうございます。
「フーリエの冒険」は私も持っています。
ぼんやりとながら、それで理解してきました。
一般的な感覚を知ることができてよかったと思います。
ご丁寧にありがとうございました。
No.1
- 回答日時:
きちんとチェックしていませんが、周波数 k の値を配列に入れてループを出てから配列を持って返らないといけないでしょう。
Data, DataLen, Tau も引数で渡すんでしょうね。なお、離散フーリエ展開ではなく離散フーリエ変換です。
N < 64 ならこのプログラムでかまいませんが、N がそれ以上大きくなると FFT が圧勝です。
この回答への補足
回答ありがとうございます。
ちょっと聞きたかったことと違うのですが、
言い方を変えますと、
離散フーリエ展開と離散フーリエ変換はプログラムをするときに、ぜんぜん違った手法になるのでしょうか?
よろしくお願いします。
また、申し訳ありませんが、
参考書籍がありましたら教えてくださいませんでしょうか?
お願いします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
O(n log n)について2
-
除算を使わずに10で割りたい。
-
c languageで 簡単な質問があ...
-
浮動小数演算は実行環境の変化...
-
ExcelでPC(パソコン)によって...
-
三菱シーケンサ(Aシリーズ)で...
-
16進数 加算 減算 C言語
-
オーディオデータの22050hzから...
-
距離から緯度経度を求める方法
-
色の判定
-
有効数字について 以前質問をし...
-
浮動小数点の切り捨てで-0.5を-...
-
2進数 → 10進数変換 模範解答と...
-
fortranでx=1としても0.9..が入る
-
CRCの計算方法について
-
2進数の足し算(C言語)
-
2÷3などの余りについて
-
信頼区間の1.96や1.65ってどこ...
-
「Aに対するBの割合」と「Aに対...
-
C言語での引数の省略方法
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
O(n log n)について2
-
VB.net Double と...
-
c languageで 簡単な質問があ...
-
ExcelのINT関数の計算結果がお...
-
有効数字について 以前質問をし...
-
ExcelでPC(パソコン)によって...
-
三菱シーケンサ(Aシリーズ)で...
-
除算を使わずに10で割りたい。
-
16進数 加算 減算 C言語
-
EXCELの関数"STDEV(標準偏差)"...
-
VB6.0での小数点の扱いについて
-
”/”を使わずに割り算したいんで...
-
距離から緯度経度を求める方法
-
VBAでミリ秒まで出力する方法
-
floatの有効桁数
-
コンピューターは指数関数をど...
-
時刻の比較
-
計算の丸め誤差の解消について
-
Double型について
-
powf を使わずにべき乗を計算
おすすめ情報