MATLAB、Python、Scilab、Julia比較ページはこちら
https://www.simulationroom999.com/blog/comparison-of-matlab-python-scilab/
はじめに
の、
MATLAB,Python,Scilab,Julia比較 第5章 その88【複素フーリエ係数⑬】
を書き直したもの。
任意波形から複素フーリエ係数抽出。
それを元に元波形を複素フーリエ級数で再現。
これをMATLABで実施する。
【再掲】プログラムフロー
まずはプログラムフローの再掲。
- csvファイル読み込み
- 各種変数初期化
- フーリエ係数算出
- n=10,50,200のパターンでフーリエ級数で波形を合成
- グラフにプロット
これをMATLABで実現する。
MATLABコード
使用するcsvファイルはこれ。
MATLABコードは以下。
N=1000; % 係数算出項数(同定元波形のplotよりも少なく)
wave=csvread('wave.csv'); % 同定波形読み込み
points=length(wave); % 波形のplot数取得
fx=wave'; % 波形を行ベクトルへ
dx=2*pi/points; % 1plotあたりのx軸幅
x=linspace(-pi,pi,points); % -π~+πの範囲で波形plot数分の等差数列
C = zeros(1,N*2+1); % C係数群格納用(±両方)
for n = -N:N
% 係数C_n算出
% C(N+1)がC_0
% C_n = (1/2π)∫f(x)exp(-inx)dx
C(n+N+1) = fx*exp(-1j*n*x).'*dx/(2*pi);
end
Ns = [10,50,200];
for i = 1:length(Ns)
NN = Ns(i); % 今回のC_n項数
% f(x)=Σ(C_n exp(inx))
Fourier_series = zeros(1,points); % 合成関数を0初期化
for n = -NN:NN
Fourier_series = Fourier_series+(C(n+N+1)*exp(1j*n*x));
end
% 元波形と複素フーリエ級数波形の表示
subplot(length(Ns),1,i);
hold on
plot(x, fx,'LineWidth',3);
plot(x, real(Fourier_series),'-r','LineWidth',2);
title(sprintf('n=±%d',NN),'FontSize',24,'FontWeight','bold');
ylim([-0.1,1.1]);
xlim([-pi,pi]);
grid();
end
処理結果
処理結果は以下。
実数フーリエのときと同じ結果。
処理結果からは見えないが、複素フーリエ係数(C_0)は複素数。
複素数だが、確かにあまり気にしなくても良い。
位相とかを調べたい場合は、複素平面上の偏角を求めたりするが、
今回は、そこまではやらない。
まとめ
- 任意波形から複素フーリエ係数抽出し、それを元に元波形を複素フーリエ級数で再現をMATLABで実施。
- 実数フーリエと同じ結果が得られた。
- 係数は複素数であり、偏角から位相を求めることも可能。
MATLAB、Python、Scilab、Julia比較ページはこちら
マンガでわかるフーリエ解析
Amazon.co.jp
手を動かしてまなぶ フーリエ解析・ラプラス変換
手を動かしてまなぶ フーリエ解析・ラプラス変換 | 山根 英司 | 数学 | Kindleストア | Amazon
Amazonで山根 英司の手を動かしてまなぶ フーリエ解析・ラプラス変換。アマゾンならポイント還元本が多数。一度購入いただいた電子書籍は、KindleおよびFire端末、スマートフォンやタブレットなど、様々な端末でもお楽しみいただけます。
物理数学 量子力学のためのフーリエ解析・特殊関数
Amazon.co.jp
単位が取れるフーリエ解析ノート
Amazon.co.jp
今日から使えるフーリエ変換 普及版 式の意味を理解し、使いこなす
Amazon.co.jp
コメント