MATLAB、Python、Scilab、Julia比較ページはこちら
https://www.simulationroom999.com/blog/comparison-of-matlab-python-scilab/
はじめに
の、
MATLAB,Python,Scilab,Julia比較 第5章 その36【三角関数の直交性⑪】
を書き直したもの。
フーリエ係数に至る道。
今回は三角関数の直交性をJuliaで確認してみる。
【再掲】フーリエ係数に至る道
まずは、フーリエ係数に至る道を再掲。
- 偶関数
- 奇関数
- 関数の内積
- 三角関数の加法定理
- 三角関数の積和公式
- 重要な極限値
- 三角関数の直交性
- フーリエ係数
今回は三角関数の直交性をJuliaで確認してみる。
【再掲】プログラムで確認する内容
以下をプログラムで確認。
- \(\sin(x)\cdot\cos(x)=0\)
- \(\sin(x)\cdot\cos(2x)=0\)
- \(\sin(x)\cdot\sin(x)=\pi\)
- \(\cos(2x)\cdot\cos(2x)=\pi\)
- \(\cos(x)\cdot\sin(2x)=0\)
- \(\sin(x)\cdot\cos(2x)=0\)
畳み込みを意識してみると良いだろう。
Juliaコード
Juliaコードは以下となる。
using Printf
N = 1000000; # 要素数
L = pi; # 0を中心とした±幅
x = range(-L,L,length=N); # x軸
dx = 2*L/N; # Δx
y=sin.(x)'*cos.(x)*dx;
@printf("sin(x)・cos(x)=%.5f\n", y)
y=sin.(x)'*cos.(2*x)*dx;
@printf("sin(x)・cos(2x)=%.5f\n", y)
y=sin.(x)'*sin.(x)*dx;
@printf("sin(x)・sin(x)=%.5f\n", y)
y=cos.(2*x)'*cos.(2*x)*dx;
@printf("cos(2x)・cos(2x)=%.5f\n", y)
y=cos.(x)'*sin.(2*x)*dx;
@printf("cos(x)・sin(2x)=%.5f\n", y)
y=sin.(x)'*cos.(2*x)*dx;
@printf("sin(x)・cos(2x)=%.5f\n", y)
処理結果
処理結果は以下。
sin(x)・cos(x)=0.00000
sin(x)・cos(2x)=-0.00000
sin(x)・sin(x)=3.14159
cos(2x)・cos(2x)=3.14160
cos(x)・sin(2x)=0.00000
sin(x)・cos(2x)=-0.00000
考察
ほぼMATLABと一緒だが、
生成されたベクトルが行ベクトルでは無く列ベクトルである点、
関数をベクトルとして処理する場合のドット演算子が注意点。
まとめ
- 三角関数の直交性をJuliaで確認してみた。
- 同一の関数及び角周波数の場合はπになり、それ以外は0になる。
MATLAB、Python、Scilab、Julia比較ページはこちら
マンガでわかるフーリエ解析
Amazon.co.jp
手を動かしてまなぶ フーリエ解析・ラプラス変換
手を動かしてまなぶ フーリエ解析・ラプラス変換 | 山根 英司 | 数学 | Kindleストア | Amazon
Amazonで山根 英司の手を動かしてまなぶ フーリエ解析・ラプラス変換。アマゾンならポイント還元本が多数。一度購入いただいた電子書籍は、KindleおよびFire端末、スマートフォンやタブレットなど、様々な端末でもお楽しみいただけます。
物理数学 量子力学のためのフーリエ解析・特殊関数
Amazon.co.jp
単位が取れるフーリエ解析ノート
Amazon.co.jp
今日から使えるフーリエ変換 普及版 式の意味を理解し、使いこなす
Amazon.co.jp
コメント