DAA-Strassen의 행렬 곱셈

이 장에서는 먼저 일반적인 행렬 곱셈 방법에 대해 설명하고 나중에 Strassen의 행렬 곱셈 알고리즘에 대해 설명합니다.

문제 설명

두 개의 행렬을 고려해 보겠습니다. XY. 결과 행렬을 계산하고 싶습니다.Z 곱하여 XY.

나이브 방법

먼저 순진한 방법과 그 복잡성에 대해 논의 할 것입니다. 여기에서 우리는Z = X × Y. Naïve 방법을 사용하여 두 개의 행렬 (XY) 행렬의 순서가 다음과 같으면 곱할 수 있습니다. p × qq × r. 다음은 알고리즘입니다.

Algorithm: Matrix-Multiplication (X, Y, Z) 
for i = 1 to p do 
   for j = 1 to r do 
      Z[i,j] := 0 
      for k = 1 to q do 
         Z[i,j] := Z[i,j] + X[i,k] × Y[k,j]

복잡성

여기서는 정수 연산이 O(1)시각. 세 가지가 있습니다for이 알고리즘에 루프가 있고 하나는 다른 알고리즘에 중첩됩니다. 따라서 알고리즘은O(n3) 실행할 시간입니다.

Strassen의 행렬 곱셈 알고리즘

이러한 맥락에서 Strassen의 행렬 곱셈 알고리즘을 사용하면 시간 소비를 약간 개선 할 수 있습니다.

Strassen의 행렬 곱셈은 다음에서만 수행 할 수 있습니다. square matrices 어디 n 이다 power of 2. 두 행렬의 순서는 다음과 같습니다.n × n.

나누기 X, YZ 다음과 같이 4 개의 (n / 2) × (n / 2) 행렬로-

$ Z = \ begin {bmatrix} I & J \\ K & L \ end {bmatrix} $ $ X = \ begin {bmatrix} A & B \\ C & D \ end {bmatrix} $$ Y = \ begin {bmatrix} E & F \\ G & H \ end {bmatrix} $

Strassen의 알고리즘을 사용하여 다음을 계산합니다.

$$ M_ {1} \ : \ colon = (A + C) \ times (E + F) $$

$$ M_ {2} \ : \ colon = (B + D) \ times (G + H) $$

$$ M_ {3} \ : \ colon = (AD) \ times (E + H) $$

$$ M_ {4} \ : \ colon = A \ times (FH) $$

$$ M_ {5} \ : \ colon = (C + D) \ times (E) $$

$$ M_ {6} \ : \ colon = (A + B) \ times (H) $$

$$ M_ {7} \ : \ colon = D \ times (GE) $$

그때,

$$ I \ : \ colon = M_ {2} + M_ {3}-M_ {6}-M_ {7} $$

$$ J \ : \ colon = M_ {4} + M_ {6} $$

$$ K \ : \ colon = M_ {5} + M_ {7} $$

$$ L \ : \ colon = M_ {1}-M_ {3}-M_ {4}-M_ {5} $$

분석

$ T (n) = \ begin {cases} c & if \ : n = 1 \\ 7 \ : x \ : T (\ frac {n} {2}) + d \ : x \ : n ^ 2 및 그렇지 않으면 \ end {cases} $ 여기서 cd 는 상수입니다.

이 반복 관계를 사용하면 $ T (n) = O (n ^ {log7}) $가됩니다.

따라서 Strassen의 행렬 곱셈 알고리즘의 복잡성은 $ O (n ^ {log7}) $입니다.