Násobení matic
Násobení matic nebo též maticové násobení je v matematice zobecnění násobení čísel na matice. Formálně se dá definovat jako binární operace nad množinou matic. Využívá se v matematice, fyzice a jejich aplikacích pro popis skládání lineárních zobrazení.
Obsah |
Formální definice [editovat]
Pokud A je matice o rozměrech m × n a B je matice n × p, jejich součin
je matice s rozměry m × p definována vztahem
pro všechny prvky (i , j) výsledné matice.
Prvek v i-tém řádku a j-tém sloupci výsledné matice lze také chápat jako skalární součin vektoru i-tého řádku první matice s vektorem j-tého sloupce druhé matice.
Tečka
se obvykle vynechává a píše se pouze
.
Příklad výpočtu [editovat]
Definujme matice
Jejich součin je
Vlastnosti [editovat]
- Maticové násobení odpovídá skládání lineárních zobrazení, které matice reprezentují.
- Maticové násobení je distributivní vůči sčítání, t.j.
pro všechny matice, pro které má rovnice smysl. - Násobení reálných resp. komplexních matic je lineární vůči násobení reálným resp. komplexním číslem, t.j.
pokud má rovnice smysl. - Matice vzhledem k součinu můžou být dělitelé nuly, t.j. součin dvou nenulových matic může být nulová matice.
- Maticové násobení není komutativní, tedy obecně
. - Násobení matice
jednotkovou maticí
zprava i zleva je identické zobrazení, t.j.
, pokud má rovnice smysl. - Maticové násobení je asociativní, tedy
, pokud prvky matice jsou z asociativního okruhu (např reálná nebo komplexní čísla). - Pro čtvercové matice platí
, t.j. determinant součinu je součin determinantů. - Transpozice součinu matic je součin transponovaných matic v opačném pořadí, t.j.

- Inverzní matice součinu regulárních matic je součin inverzních matic v opačném pořadí, t.j.

- Hermiteovské sdružení součinu matic je součin hermitovsky sdružených matic v opačném pořadí, t.j.

Výpočetní náročnost [editovat]
Výpočetní náročnost výše popsaného algoritmu je
(počítáme n2 čísel; pro každé potřebujeme n násobení). Existují však algoritmy s nižší složitostí vhodné pro matice vyšších řádů. Nejpoužívanější z nich je Strassenův algoritmus se složitostí
. Nižší složitost u tohoto algoritmu však získáváme za cenu snížené numerické stability. Asymptoticky nejrychlejší ze známých algoritmů je Coppersmithův-Winogradův algoritmus (
), který je však použitelný až pro matice tak velkých řádů, že je nelze zpracovávat pomocí současných počítačů[1].
Teoreticky by se dala složitost ještě zmenšit, ale nikdy nemůže být menší než
, neboť počítáme n2 čísel.
Hledání nejkratší cesty v grafu [editovat]
Pro vkladatele šablony: Na diskusní stránce zdůvodněte vložení šablony.
Násobení matic s malou výpočetní složitostí lze využít i pro hledání nejkratší cesty v grafu z každého do každého vrcholu. To má v nejjednodušší podobě složitost
.
Graf lze popsat maticí vzdáleností A. Pokud je pro výpočty operace sčítání dvou čísel definována jako jejich minimum, a místo násobení se použije sčítání, je možno matici nejkratších cest B získat jako (
) kde n je řád matice vzdáleností. Při reálném výpočtu není třeba cyklicky násobit původní maticí, ale vždy se vynásobí vzniklé výsledky - nejkratší cesty jsou získány po log2(n) násobeních. Je-li použit pro násobení algoritmus se složitostí menší než
, složitost hledání cest se tímto postupem sníží.
Reference [editovat]
- ↑ Robinson, Sara (2005), "Toward an Optimal Algorithm for Matrix Multiplication", SIAM News 38 (9), http://www.siam.org/pdf/news/174.pdf
Související články [editovat]
- Strassenův algoritmus
- Součin
- Skalární součin, Vnitřní součin
- Vektorový součin, Dvojitý vektorový součin
- Smíšený součin
- Tenzorový součin, Vnější součin
- Hadamardův součin
- Matice
Externí odkazy [editovat]
- Lineární algebra: algebra matic Aplikace, která násobí a sčítá matice zadané uživatelem a zobrazuje postup výpočtu.



pro všechny matice, pro které má rovnice smysl.
pokud má rovnice smysl.
.
zprava i zleva je identické zobrazení, t.j.
, pokud má rovnice smysl.
, pokud prvky matice jsou z asociativního okruhu (např reálná nebo komplexní čísla).
, t.j. 

