行列の乗法

提供: miniwiki
2017/11/11/ (土) 09:49時点におけるja>Cewbotによる版 (ウィキ文法修正: 間違った画像オプション サイズの単位をpxに修正する:"\"300px\"" lintId=2962056)
(差分) ← 古い版 | 最新版 (差分) | 新しい版 → (差分)
移動先:案内検索

数学において、行列の対から別の行列を作り出す二項演算としての行列の乗法は、実数複素数などのが初等的な四則演算でいうところの乗法を持つことと対照的に、そのような「数の配列」の間の乗法として必ずしも一意的な演算を指しうるものではない。そのような意味では、一般に「行列の乗法」は幾つかの異なる二項演算を総称するものと考えることができる。行列の乗法の持つ重要な特徴には、与えられた行列の行および列の数(行列の型やサイズあるいは次元と呼ばれるもの)が関係して、得られる行列の成分がどのように特定されるかが述べられるということが挙げられる。

例えば、ベクトルの場合と同様に、任意の行列に対してスカラーを掛けるという操作が、その行列の全ての成分に同じ数を掛けるという方法で与えられる。また、加法や減法English版の場合と同様に、同じサイズの行列に対して成分ごとの乗法を入れることによって定まる行列の積はアダマール積と呼ばれる。それ以外にも、二つの行列のクロネッカー積区分行列として得られる。

このようにさまざまな乗法が定義できるという事情の中にあっても、しかし最も重要な行列の乗法は連立一次方程式やベクトルの一次変換に関するもので、応用数学工学へも広く応用がある。これは通例、行列の積(ぎょうれつのせき、: matrix product[1][2])と呼ばれるもので、An × m 行列で、Bm × p 行列ならば、それらの行列の積 ABn × p 行列として与えられ、その成分は A の各行の m 個の成分がそれぞれ順番に B の各列の m 個の成分と掛け合わされる形で与えられる(後述)。

この通常の積は可換ではないが、結合的かつ行列の加法に対して分配的である。この行列の積に関する単位元(数において 1 を掛けることに相当するもの)は単位行列であり、正方行列逆行列(数における逆数に相当)を持ち得る。行列の積に関して行列式乗法的である。一次変換行列群あるいは群の表現などの理論を考える上において行列の積は重要な演算となる。

行列のサイズが大きくなれば、二つあるいはそれ以上の行列の積の計算を定義に従って行うには、非常に膨大な時間が掛かるようになってしまうため、効果的に行列の積を計算できるアルゴリズムが考えられてきた。

スカラー倍

行列に付随するもっとも単純な形の乗法としてスカラー乗法が挙げられる(これはクロネッカー積の特別の場合になっている)。

行列 A のスカラー λ による左スカラー倍: left scalar multiplication)は、

[math] \lambda A = (\lambda a_{ij})[/math]

で与えられる A と同じサイズの行列 λA となる。つまり、

[math] \lambda A = \lambda \begin{pmatrix} a_{11} & a_{12} & \cdots & a_{1m} \\ a_{21} & a_{22} & \cdots & a_{2m} \\ \vdots & \vdots & \ddots & \vdots \\ a_{n1} & a_{n2} & \cdots & a_{nm} \end{pmatrix} = \begin{pmatrix} \lambda a_{11} & \lambda a_{12} & \cdots & \lambda a_{1m} \\ \lambda a_{21} & \lambda a_{22} & \cdots & \lambda a_{2m} \\ \vdots & \vdots & \ddots & \vdots \\ \lambda a_{n1} & \lambda a_{n2} & \cdots & \lambda a_{nm} \end{pmatrix}\,.[/math]

同様に、行列 A のスカラー λ による右スカラー倍: right scalar multiplication)は

[math] A\lambda = \begin{pmatrix} a_{11} & a_{12} & \cdots & a_{1m} \\ a_{21} & a_{22} & \cdots & a_{2m} \\ \vdots & \vdots & \ddots & \vdots \\ a_{n1} & a_{n2} & \cdots & a_{nm} \end{pmatrix}\lambda = \begin{pmatrix} a_{11} \lambda & a_{12} \lambda & \cdots & a_{1m} \lambda \\ a_{21} \lambda & a_{22} \lambda & \cdots & a_{2m} \lambda \\ \vdots & \vdots & \ddots & \vdots \\ a_{n1} \lambda & a_{n2} \lambda & \cdots & a_{nm} \lambda \end{pmatrix}[/math]

で定義される。

基礎とするが(例えばまたは複素数のような)可換環ならば、左及び右スカラー倍の概念は一致して、単にスカラー倍と呼ばれる。より一般の環では(四元数体のように)非可換であるから左右が異なれば異なる乗法である。

通常の行列の積

二つの行列の積

まずは二つの行列を掛け合わせることを考える(任意個数への一般化は後述)。

ファイル:Matrix multiplication row column correspondance.svg
行列の積の計算過程の図示。行列Aの第i行列Bの第jの各成分の積を実線部分のように取り、続いて点線のように加えていくことにより、積ABij 成分を得る。

n × m 行列 Am × p 行列 B

[math]A=\begin{pmatrix} a_{11} & a_{12} & \cdots & a_{1m} \\ a_{21} & a_{22} & \cdots & a_{2m} \\ \vdots & \vdots & \ddots & \vdots \\ a_{n1} & a_{n2} & \cdots & a_{nm} \end{pmatrix},\quad B=\begin{pmatrix} b_{11} & b_{12} & \cdots & b_{1p} \\ b_{21} & b_{22} & \cdots & b_{2p} \\ \vdots & \vdots & \ddots & \vdots \\ b_{m1} & b_{m2} & \cdots & b_{mp} \end{pmatrix}[/math]

とするとき、これらの行列の積 AB(通例、乗法記号は特に用いずに併置で表す)は、 各 (i, j) 成分 cijA の第 i 行に横に並ぶ成分 aikB の第 j 列に縦に並ぶ成分 bkjk = 1, 2, ..., m に亙って足し合わせた和

[math] c_{ij} = \sum_{k=1}^m a_{ik}b_{kj}[/math]

で与えられる n × p 行列

[math]AB =\begin{pmatrix} c_{11} & c_{12} & \cdots & c_{1p} \\ c_{21} & c_{22} & \cdots & c_{2p} \\ \vdots & \vdots & \ddots & \vdots \\ c_{n1} & c_{n2} & \cdots & c_{np} \end{pmatrix}[/math]

である[3][4][5][6]。従って、積 AB が定義されるのは A の列の本数と B の行の本数が一致している場合に限られる(今の場合は m 本)。

多数の行列の積

二つ以上の個数の行列に対しても、それらの連続する各対に関してサイズの条件が満たされるならば、行列の積を定義することができる。

n-個の行列 A1, A2, ..., An がそれぞれサイズ s0 × s1, s1 × s2, ..., sn − 1 × sn であるとき(ここで s0, s1, s2, ..., sn は何れも単に正整数であって、これらの下付き添数はそれぞれどの行列に対応するのかを示す以上の意味は無い)、これら行列の積

[math] \prod_{i=1}^n A_i = A_1A_2\cdots A_n = (a_{ij}^{(1)})(a_{ij}^{(2)})\cdots(a_{ij}^{(n)})[/math]

s0 × sn 行列であり、その任意の (i0, in)-成分は

[math] \sum_{i_1=1}^{s_1}\sum_{i_2=1}^{s_2}\cdots\sum_{i_{n-1}=1}^{s_{n-1}} a_{i_0,i_1}^{(1)} a_{i_1,i_2}^{(2)} \cdots a_{i_{n-1},i_n}^{(n)}[/math]

で与えられる。

行列の冪

正方行列に関しては、行の本数と列の本数が常に等しいから、通常の数と同様に自分自身を繰り返し掛けることができて、この行列の積の特別の場合としての反復乗積は行列の: matrix power)を定義することができる。行の本数と列の本数が一致しない一般の矩形行列では冪を考えることができない。即ち、n × n 行列 A と正整数 k に対して

[math]A^k = \underset{k \text{ times}}{AA\cdots A}.[/math]

の逆として行列の冪根を考えたり、また冪級数として行列の指数函数やその逆写像として行列の対数函数などを定義したりすることもできる。

その他の乗法

二つの行列に対して定義されるその他の乗法を以下にいくつか挙げる。実は通常の乗法よりも定義としては単純なものもいくつかある。

アダマール積

同じサイズの二つの行列に対し、アダマール積: Hadamard product)、要素ごとの積: element-wise product)、点ごとの積: pointwise product)、成分ごとの積: entrywise product)あるいはシューア積: Schur product)などと呼ばれる積を定義することができる[7]。同じサイズの二つの行列 A, B のアダマール積 AB はもとと同じサイズの行列で、その (i, j)-成分は A(i, j)-成分と B(i, j)-成分との積で与えられる。つまり、

[math] A \circ B = (a_{ij}b_{ij}),[/math]

全部書けば、

[math]\begin{pmatrix} a_{11} & a_{12} & \cdots & a_{1m} \\ a_{21} & a_{22} & \cdots & a_{2m} \\ \vdots & \vdots & \ddots & \vdots \\ a_{n1} & a_{n2} & \cdots & a_{nm} \end{pmatrix}\circ\begin{pmatrix} b_{11} & b_{12} & \cdots & b_{1m} \\ b_{21} & b_{22} & \cdots & b_{2m} \\ \vdots & \vdots & \ddots & \vdots \\ b_{n1} & b_{n2} & \cdots & b_{nm} \end{pmatrix} =\begin{pmatrix} a_{11}b_{11} & a_{12}b_{12} & \cdots & a_{1m}b_{1m} \\ a_{21}b_{21} & a_{22}b_{22} & \cdots & a_{2m}b_{2m} \\ \vdots & \vdots & \ddots & \vdots \\ a_{n1}b_{n1} & a_{n2}b_{n2} & \cdots & a_{nm}b_{nm} \end{pmatrix}\,.[/math]

この演算は(mn 個ある各成分において)通常の数の積を一斉に行うことに他ならない。故にアダマール積は可換結合的、かつ成分ごとの和に対して分配的になる。これはまた、クロネッカー積の主小行列でもある。

フロベニウス積

フロベニウス(内)積: Frobenius inner product)は行列を単にベクトルと見做してとった成分ごとの内積で、A : B などと書かれることもある。これはアダマール積の成分の和でもあり、具体的に書けば

[math]A : B = \sum_{i,j} a_{ij} b_{ij} = \operatorname{vec}({}^t\! A) \operatorname{vec}(B) = \operatorname{tr}({}^t\! A B) = \operatorname{tr}(A\,{}^t\!B)[/math]

となる。ただし "tr" は行列のであり、"vec" は行列の一列化である。この内積からフロベニウスノルムが誘導される。

クロネッカー積

二つの行列 A, B のサイズがそれぞれ m × n, p × q であるとき、これらがどのようなサイズであったとしても(サイズに関する制約条件なしに)、この二つの行列のクロネッカー積: Kronecker product)は

[math] A \otimes B = \begin{pmatrix} a_{11}B & a_{12}B & \cdots & a_{1n}B \\ a_{21}B & a_{22}B & \cdots & a_{2n}B \\ \vdots & \vdots & \ddots & \vdots \\ a_{m1}B & a_{m2}B & \cdots & a_{mn}B \end{pmatrix}[/math]

で与えられるサイズ mp × nq の行列である[8]。これはより一般のテンソル積を行列に対して適用したものになっている。

関連項目

  1. R.G. Lerner, G.L. Trigg (1991). Encyclopaedia of Physics, 2nd, VHC publishers. ISBN 3-527-26954-1. 
  2. C.B. Parker (1994). McGraw Hill Encyclopaedia of Physics, 2nd. ISBN 0-07-051400-3. 
  3. S. Lipschutz, M. Lipson (2009). Linear Algebra, 4th, Schaum's Outlines, McGraw Hill (USA), 30–31. ISBN 978-0-07-154352-1. 
  4. K.F. Riley, M.P. Hobson, S.J. Bence (2010). Mathematical methods for physics and engineering. Cambridge University Press. ISBN 978-0-521-86153-3. 
  5. R. A. Adams (1995). Calculus, A Complete Course, 3rd, Addison Wesley. ISBN 0 201 82823 5. 
  6. Horn, Johnson (2013). Matrix Analysis, 2nd, Cambridge University Press. ISBN 978 0 521 54823 6. 
  7. テンプレート:Harvard citations
  8. Steeb, Willi-Hans (1997), Matrix Calculus and Kronecker Product with Applications and C++ Programs, World Scientific, p. 55, ISBN 9789810232412, http://books.google.com/books?id=7iYS23cC7YIC&pg=PA55 .

参考文献

  • Henry Cohn, Robert Kleinberg, Balazs Szegedy, and Chris Umans. Group-theoretic Algorithms for Matrix Multiplication. テンプレート:Arxiv. Proceedings of the 46th Annual Symposium on Foundations of Computer Science, 23–25 October 2005, Pittsburgh, PA, IEEE Computer Society, pp. 379–388.
  • Henry Cohn, Chris Umans. A Group-theoretic Approach to Fast Matrix Multiplication. テンプレート:Arxiv. Proceedings of the 44th Annual IEEE Symposium on Foundations of Computer Science, 11–14 October 2003, Cambridge, MA, IEEE Computer Society, pp. 438–449.
  • Coppersmith, D., Winograd S., Matrix multiplication via arithmetic progressions, J. Symbolic Comput. 9, p. 251-280, 1990.
  • Horn, Roger A.; Johnson, Charles R. (1991), Topics in Matrix Analysis, Cambridge University Press, ISBN 978-0-521-46713-1 
  • Knuth, D.E., The Art of Computer Programming Volume 2: Seminumerical Algorithms. Addison-Wesley Professional; 3 edition (November 14, 1997). ISBN 978-0-201-89684-8. pp. 501.
  • Press, William H.; Flannery, Brian P.; Teukolsky, Saul A.; Vetterling, William T. (2007), Numerical Recipes: The Art of Scientific Computing (3rd ed.), Cambridge University Press, ISBN 978-0-521-88068-8 .
  • Ran Raz. On the complexity of matrix product. In Proceedings of the thirty-fourth annual ACM symposium on Theory of computing. ACM Press, 2002. doi:10.1145/509907.509932.
  • Robinson, Sara, Toward an Optimal Algorithm for Matrix Multiplication, SIAM News 38(9), November 2005. PDF
  • Strassen, Volker, Gaussian Elimination is not Optimal, Numer. Math. 13, p. 354-356, 1969.
  • Styan, George P. H. (1973), “Hadamard Products and Multivariate Statistical Analysis”, Linear Algebra and its Applications 6: 217–240, doi:10.1016/0024-3795(73)90023-2 
  • Vassilevska Williams, Virginia, Multiplying matrices faster than Coppersmith-Winograd, Manuscript, May 2012. PDF

テンプレート:Linear algebra