MATLAB,Python,Scilab,Julia比較 第5章 その82【複素フーリエ係数⑦】

MATLAB,Python,Scilab,Julia比較 第5章 その82【複素フーリエ係数⑦】 数値計算
MATLAB,Python,Scilab,Julia比較 第5章 その82【複素フーリエ係数⑦】

バックナンバーはこちら。
https://www.simulationroom999.com/blog/compare-matlabpythonscilabjulia5-backnumber/

はじめに

複素フーリエ係数のシリーズ。
今回は、複素指数関数の直交性をScilabで確認する。

登場人物

博識フクロウのフクさん

指差しフクロウ

イラストACにて公開の「kino_k」さんのイラストを使用しています。
https://www.ac-illust.com/main/profile.php?id=iKciwKA9&area=1

エンジニア歴8年の太郎くん

技術者太郎

イラストACにて公開の「しのみ」さんのイラストを使用しています。
https://www.ac-illust.com/main/profile.php?id=uCKphAW2&area=1

【再掲】複素指数関数の直交性確認内容

太郎くん
太郎くん

まずは複素指数関数の直交性確認内容を再掲

\(
\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}
\)

フクさん
フクさん

今回は、これをScilabで確認する。

Scilabコード

フクさん
フクさん

Scilabコードは以下。

N = 1000000;        // 要素数
L = %pi;             // 0を中心とした±幅
x=linspace(-L,L,N); // x軸
dx = 2*L/N;         // Δx

y=exp(1*%i*1*x)*exp(1*%i*(-1)*x).'*dx;
printf('e^(ix)・e^(-ix)=%.5f\n',y);

y=exp(1*%i*1*x)*exp(-1*%i*2*x).'*dx;
printf('e^(ix)・e^(-i2x)=%.5f\n',y);

y=exp(1*%i*2*x)*exp(-1*%i*2*x).'*dx;
printf('e^(i2x)・e^(-i2x)=%.5f\n',y);

y=exp(1*%i*3*x)*exp(-1*%i*2*x).'*dx;
printf('e^(i3x)・e^(-i2x)=%.5f\n',y);

処理結果

フクさん
フクさん

処理結果は以下。

e^(ix)・e^(-ix)=6.28319
e^(ix)・e^(-i2x)=-0.00001
e^(i2x)・e^(-i2x)=6.28319
e^(i3x)・e^(-i2x)=-0.00001
太郎くん
太郎くん

コードも結果もMATLABと一緒だね。

フクさん
フクさん

コードの方は、虚数単位が%iになることに注意だな。

太郎くん
太郎くん

また微妙なところが違うのか・・・。

まとめ

フクさん
フクさん

まとめだよ。

  • 複素指数関数の直交性をScilabで確認した。
  • おおよそ狙い通りの挙動ではあるが、三角関数由来の誤差は入る。
  • 虚数単位が%iになることに注意。

バックナンバーはこちら。

マンガでわかるフーリエ解析

Amazon.co.jp

手を動かしてまなぶ フーリエ解析・ラプラス変換

Amazon.co.jp

物理数学 量子力学のためのフーリエ解析・特殊関数

物理数学 量子力学のためのフーリエ解析・特殊関数 | 柴田 尚和, 是常 隆 | 数学 | Kindleストア | Amazon
Amazonで柴田 尚和, 是常 隆の物理数学 量子力学のためのフーリエ解析・特殊関数。アマゾンならポイント還元本が多数。一度購入いただいた電子書籍は、KindleおよびFire端末、スマートフォンやタブレットなど、様々な端末でもお楽しみい...

単位が取れるフーリエ解析ノート

https://amzn.to/3V83fIl

今日から使えるフーリエ変換 普及版 式の意味を理解し、使いこなす

https://amzn.to/3ysbfvf

コメント

タイトルとURLをコピーしました