MATLAB、Python、Scilab、Julia比較ページはこちら
https://www.simulationroom999.com/blog/comparison-of-matlab-python-scilab/
はじめに
の、
MATLAB,Python,Scilab,Julia比較 第5章 その89【複素フーリエ係数⑭】
を書き直したもの。
任意波形から複素フーリエ係数抽出。
それを元に元波形を複素フーリエ級数で再現。
これをPythonで実施する。
【再掲】プログラムフロー
まずはプログラムフローの再掲。
- csvファイル読み込み
- 各種変数初期化
- フーリエ係数算出
- n=10,50,200のパターンでフーリエ級数で波形を合成
- グラフにプロット
これをPythonで実現する。
Pythonコード
使用するcsvファイルはこれ。
Pythonコードは以下。
import numpy as np
import matplotlib.pyplot as plt
N=1000 # 係数算出項数(同定元波形のplotよりも少なく)
wave=np.loadtxt('wave.csv',delimiter=',') # 同定波形読み込み
points=len(wave) # 波形のplot数取得
fx=np.array(wave) # 波形を行ベクトルへ
dx=2*np.pi/points # 1plotあたりのx軸幅
x=np.linspace(-np.pi,np.pi,points); # -π~+πの範囲で波形plot数分の等差数列
C = np.zeros(N*2+1, dtype=complex) # C係数群格納用(±両方)
for n in range(-N,N+1):
# 係数C_n算出
# C[N]がC_0
# C_n = (1/2π)∫f(x)exp(-inx)dx
C[n+N] = fx@np.exp(-1j*n*x).T*dx/(2*np.pi)
Ns = [10,50,200]
fig = plt.figure()
for i in range(0,len(Ns)):
NN = Ns[i]; # 今回のC_n項数
# f(x)=Σ(C_n exp(inx))
Fourier_series = np.zeros(points) # 合成関数を0初期化
for n in range(-NN,NN+1):
Fourier_series = Fourier_series+(C[n+N]*np.exp(1j*n*x))
ax = fig.add_subplot(len(Ns), 1, i+1)
# 元波形と複素フーリエ級数波形の表示
ax.plot(x, fx,'-b',lw=3)
ax.plot(x, Fourier_series.real,'-r',lw=2)
ax.set_title('n=±{:d}'.format(NN),fontsize=22,fontweight="bold")
ax.set_ylim(-0.1,1.1)
ax.set_xlim(-np.pi,np.pi)
ax.grid(linestyle='dotted')
plt.show()
処理結果
処理結果は以下。
これも実数フーリエのときと同じ結果。
位相とかを調べたい場合は、複素平面上の偏角を求めたりする。
まとめ
- 任意波形から複素フーリエ係数抽出し、それを元に元波形を複素フーリエ級数で再現をPythonで実施。
- 実数フーリエと同じ結果が得られた。
- 係数は複素数であり、偏角から位相を求めることも可能。
MATLAB、Python、Scilab、Julia比較ページはこちら
マンガでわかるフーリエ解析
Amazon.co.jp
手を動かしてまなぶ フーリエ解析・ラプラス変換
Amazon.co.jp
物理数学 量子力学のためのフーリエ解析・特殊関数
物理数学 量子力学のためのフーリエ解析・特殊関数 | 柴田 尚和, 是常 隆 | 数学 | Kindleストア | Amazon
Amazonで柴田 尚和, 是常 隆の物理数学 量子力学のためのフーリエ解析・特殊関数。アマゾンならポイント還元本が多数。一度購入いただいた電子書籍は、KindleおよびFire端末、スマートフォンやタブレットなど、様々な端末でもお楽しみい...
単位が取れるフーリエ解析ノート
https://amzn.to/3V83fIl
今日から使えるフーリエ変換 普及版 式の意味を理解し、使いこなす
https://amzn.to/3ysbfvf
コメント