バックナンバーはこちら。
https://www.simulationroom999.com/blog/stock-predict-matlabpython-backnumber/
はじめに
前回は回転因子を行列表現し、
回転因子であるが故の各種最適化を実施。
これだけでも便利な概念ではある。
今回は、これをバタフライ演算に繋げるべくさらに最適化していく。
登場人物
博識フクロウのフクさん
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="指差しフクロウ"
イラストACにて公開の「kino_k」さんのイラストを使用しています。
https://www.ac-illust.com/main/profile.php?id=iKciwKA9&area=1
エンジニア歴8年の太郎くん
data:image/s3,"s3://crabby-images/ebc9c/ebc9ca6dafb1ae82606cceaa3c40e0f2d33a96fd" alt="技術者太郎"
イラストACにて公開の「しのみ」さんのイラストを使用しています。
https://www.ac-illust.com/main/profile.php?id=uCKphAW2&area=1
異なる回転因子を混ぜる
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
前回は回転因子が円状にあることを利用して最適化をしたが、
ここに対して異なるNの回転因子を混ぜることが可能だ。
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
異なるNの回転因子?
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
前回は\(N=4\)をベースにした回転因子だったが、
この中の\(n=0,2\)って
\(N=2\)に於ける\(n=0,1,\)と同じ値になるんだよね。
data:image/s3,"s3://crabby-images/0f4a3/0f4a3412b4e6b4c485d018cd2f8825371049af7c" alt="太郎くん"
あ、そっか。
言われてみれば回転因子としては同じ位置になるね。
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
よって、以下に表現し直せる。
\(f_n\)の並びが変わっているところに注意だ。
\(
\begin{bmatrix}
F_0 \\
F_1 \\
F_2 \\
F_3 \\
\end{bmatrix}
=
\begin{bmatrix}
W_2^0 & W_2^0 & W_4^0W_2^0 & W_4^0W_2^0 \\
W_2^0 & W_2^1 & W_4^1W_2^0 & W_4^1W_2^1 \\
W_2^0 & W_2^1 & W_4^2W_2^0 & W_4^2W_2^0 \\
W_2^0 & W_2^1 & W_4^3W_2^0 & W_4^3W_2^1 \\
\end{bmatrix}
\begin{bmatrix}
f_0 \\
f_2 \\
f_1 \\
f_3 \\
\end{bmatrix}
\)
data:image/s3,"s3://crabby-images/57173/57173c22a9926dc375e9aba2a2701ee383ee12f9" alt="太郎くん"
なんか余計ややこしくなったようにも見えるが・・・。
良く見ると、なんかルールはありそうにも見える・・・。
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
左上の2×2の行列だけを抜き出してみよう。
\begin{bmatrix}
W_2^0 & W_2^0 \\
W_2^0 & W_2^1 \\
\end{bmatrix}
data:image/s3,"s3://crabby-images/0f4a3/0f4a3412b4e6b4c485d018cd2f8825371049af7c" alt="太郎くん"
あ!他の右上、左下、右下にも同じ並びがあるね。
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
これをいい感じに整理したのがこれだ
\(
\begin{bmatrix}
F_0 \\
F_1 \\
F_2 \\
F_3 \\
\end{bmatrix}
=
\begin{bmatrix}
1 & 0 & W_4^0 & 0 \\
0 & 1 & 0 & W_4^1 \\
1 & 0 & W_4^2 & 0 \\
0 & 1 & 0 & W_4^3 \\
\end{bmatrix}
\begin{bmatrix}
W_2^0 & W_2^0 & 0 & 0 \\
W_2^0 & W_2^1 & 0 & 0 \\
0 & 0 & W_2^0 & W_2^0 \\
0 & 0 & W_2^0 & W_2^1 \\
\end{bmatrix}
\begin{bmatrix}
f_0 \\
f_2 \\
f_1 \\
f_3 \\
\end{bmatrix}
\)
中間変数を置いてみる。
data:image/s3,"s3://crabby-images/57173/57173c22a9926dc375e9aba2a2701ee383ee12f9" alt="太郎くん"
キレイに整理されていくように見える反面、
行列が分離した魔境臭もしてきたぞ・・・。
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
行列が分離するということは演算もキレイに分離できるってことだ。
つまり、中間変数\(G_n\)を挟んで2段階に分けて計算すると以下になる。
\(
\begin{bmatrix}
G_0 \\
G_1 \\
\end{bmatrix}
=
\begin{bmatrix}
W_2^0 & W_2^0 \\
W_2^0 & W_2^1 \\
\end{bmatrix}
\begin{bmatrix}
f_0 \\
f_2 \\
\end{bmatrix}
\)
\(
\begin{bmatrix}
G_2 \\
G_3 \\
\end{bmatrix}
=
\begin{bmatrix}
W_2^0 & W_2^0 \\
W_2^0 & W_2^1 \\
\end{bmatrix}
\begin{bmatrix}
f_1 \\
f_3 \\
\end{bmatrix}
\)
\(
\begin{bmatrix}
F_0 \\
F_1 \\
F_2 \\
F_3 \\
\end{bmatrix}
=
\begin{bmatrix}
1 & 0 & W_4^0 & 0 \\
0 & 1 & 0 & W_4^1 \\
1 & 0 & W_4^2 & 0 \\
0 & 1 & 0 & W_4^3 \\
\end{bmatrix}
\begin{bmatrix}
G_0 \\
G_1 \\
G_2 \\
G_3 \\
\end{bmatrix}
\)
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
そして、\(W_4^2=-W_4^2\)、\(W_4^3=-W_4^1\)なので、
\(
\begin{bmatrix}
F_0 \\
F_1 \\
F_2 \\
F_3 \\
\end{bmatrix}
=
\begin{bmatrix}
1 & 0 & W_4^0 & 0 \\
0 & 1 & 0 & W_4^1 \\
1 & 0 & -W_4^0 & 0 \\
0 & 1 & 0 & -W_4^1 \\
\end{bmatrix}
\begin{bmatrix}
G_0 \\
G_1 \\
G_2 \\
G_3 \\
\end{bmatrix}
\)
data:image/s3,"s3://crabby-images/ebc9c/ebc9ca6dafb1ae82606cceaa3c40e0f2d33a96fd" alt="太郎くん"
なんか\(0,1,W_4^0,W_4^1\)だけになっちゃったね。
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
これでバタフライ演算の準備が整った状態だ。
まとめ
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
まとめだよ。
- Nの回転因子にN/2の回転因子を含めることが可能
- 複数段の行列に分解可能。
- つまり、演算を分解できる。
- 最終的に残る値はかなり限られる。
- これを利用してバタフライ演算を行うことになる。
バックナンバーはこちら。
コメント