Strassenアルゴリズムでのマトリックスの選択の背後にある大きな画像


17

Strassenアルゴリズムでは、2つの行列Bの積を計算するために、行列AB2 × 2ブロック行列に分割され、アルゴリズムは単純な8ブロック行列ではなく、7ブロック行列-行列積を再帰的に計算します。行列積、すなわち、我々は場合はC = A BA = [ 1 1 A 1 2 A 2 1 A 2 2ABAB2×278C=AB 次に、我々は C 1 1 = A 1 1件のB 1 1 + A 1

A=[A11A12A21A22] 、 B=[B11B12B21B22] 、 C=[C11C12C21C22]
必要8個の乗算します。代わりシュトラッセに、我々は、計算 M 1= 1 1 + A 2 2 B 1 1 + B 2 2
C11=A11B11+A12B21C12=A11B12+A12B22C21=A21B11+A22B21C22=A21B12+A22B22
8 及び得る CをI Jの使用 M 、Kのような C 1 1 = M 1 + M 4 M 5 + M 7
M1:=A11+A22B11+B22M2:=A21+A22B11M3:=A11B12B22M4:=A22B21B11M5:=A11+A12B22M6:=A21A11B11+B12M7:=A12A22B21+B22
CjMk しかし、の選択は、行列 Mの K「sは私に任意見えます。A Bの部分行列のこれらの特定の積を選択する理由について、より大きな画像がありますか?また、 M kには A i j B i jが対称的に関係していると思われますが、ここではそうではないようです。たとえば、 M 2があります:=
C11=M1+M4M5+M7C12=M3+M5C21=M2+M4C22=M1M2+M3+M6
MkABMkAjBj。私は、その相手と言う期待 1 1B 1 2 + B 2 2も計算します。ただし、他の M kから取得できるためです。M2:=A21+A22B11A11B12+B22Mk

誰かがこれに何らかの光を当てることができれば幸いです。

回答:


15

2×22×2

2×2

Schönhageはかつて、Strassenがアルゴリズムをこの方法で見つけたと下限を証明しようと言ったことを一度言ったと言っていました。


11

A0A1A2A3B0B1B2B32×2ABj{0A0A1A2A3B0B1B2B3}A0=B0ABA0=B0A1A2A3B1B2B3M

Strassenがこの見方を思いついたかどうかはわかりません。高速行列乗算アルゴリズムの基礎となる他のアイデンティティを考慮すると、何らかの式がうまく機能していることよりも、何かが深く進行しているかどうかは明らかではありません。私たちは以前にそれを経験しました-ラグランジュは4平方定理(以前に知られていました)を使用して4平方定理を証明しました。最初は奇妙な代数的アイデンティティであったに違いありませんが、今では、四元数ノルムの乗法性の性質を述べていることがわかりました。現在の知識の状態を考えると、上記の解釈が生産的であるかどうかを見分けるのは困難です。


3
2×2
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.