MATLAB、Python、Scilab、Julia比較ページはこちら
https://www.simulationroom999.com/blog/comparison-of-matlab-python-scilab/
はじめに
の、
MATLAB,Python,Scilab,Julia比較 第5章 その81【複素フーリエ係数⑥】
を書き直したもの。
複素フーリエ係数のシリーズ。
今回は、複素指数関数の直交性をPythonで確認する。
【再掲】複素指数関数の直交性確認内容
まずは複素指数関数の直交性確認内容を再掲
\(
\begin{eqnarray}
e^{ix}\cdot e^{-ix}&=&6.28319\\
e^{ix}\cdot e^{-i2x}&=&0.00000\\
e^{i2x}\cdot e^{-i2x}&=&6.28319\\
e^{i3x}\cdot e^{-i2x}&=&0.00000
\end{eqnarray}
\)
今回は、これをPythonで確認する。
Pythonコード
Pythonコードは以下。
import numpy as np
N = 1000000 # 要素数
L = np.pi # 0を中心とした±幅
x = np.linspace(-L,L,N) # x軸
dx= 2*L/N # Δx
y=np.exp(1j*1*x)@np.exp(-1j*1*x).T*dx
print('e^(ix)・e^(-ix)=%.5f+i(%.5f)'%(y.real,y.imag))
y=np.exp(1j*1*x)@np.exp(-1j*2*x).T*dx
print('e^(ix)・e^(-i2x)=%.5f+i(%.5f)'%(y.real,y.imag))
y=np.exp(1j*2*x)@np.exp(-1j*2*x).T*dx
print('e^(i2x)・e^(-i2x)=%.5f+i(%.5f)'%(y.real,y.imag))
y=np.exp(1j*3*x)@np.exp(-1j*2*x).T*dx
print('e^(i3x)・e^(-i2x)=%.5f+i(%.5f)'%(y.real,y.imag))
処理結果
処理結果は以下。
e^(ix)・e^(-ix)=6.28319+i(0.00000)
e^(ix)・e^(-i2x)=-0.00001+i(-0.00000)
e^(i2x)・e^(-i2x)=6.28319+i(0.00000)
e^(i3x)・e^(-i2x)=-0.00001+i(0.00000)
PythonもMATLABと似た感じ。
これも演算誤差は入るが期待通り。
まとめ
- 複素指数関数の直交性をPythonで確認した。
- おおよそ狙い通りの挙動ではあるが、三角関数由来の誤差は入る。
MATLAB、Python、Scilab、Julia比較ページはこちら
マンガでわかるフーリエ解析
Amazon.co.jp
手を動かしてまなぶ フーリエ解析・ラプラス変換
手を動かしてまなぶ フーリエ解析・ラプラス変換 | 山根 英司 | 数学 | Kindleストア | Amazon
Amazonで山根 英司の手を動かしてまなぶ フーリエ解析・ラプラス変換。アマゾンならポイント還元本が多数。一度購入いただいた電子書籍は、KindleおよびFire端末、スマートフォンやタブレットなど、様々な端末でもお楽しみいただけます。
物理数学 量子力学のためのフーリエ解析・特殊関数
Amazon.co.jp
単位が取れるフーリエ解析ノート
Amazon.co.jp
今日から使えるフーリエ変換 普及版 式の意味を理解し、使いこなす
Amazon.co.jp
コメント