LUP-dekompozíció ( LUP -decomposition) - egy adott mátrix szorzatként való megjelenítése az identitásmátrixból sorok vagy oszlopok permutálásával nyert permutációs mátrix. Az ilyen bontás bármely nem degenerált mátrixra elvégezhető . A LUP-dekompozíció az inverz mátrix kiszámítására szolgál egy kompakt sémában, egy lineáris egyenletrendszer megoldásának kiszámításához. Az LU dekompozíciós algoritmushoz képest a LUP felbontó algoritmus bármilyen nem szinguláris mátrixot képes kezelni, ugyanakkor nagyobb számítási stabilitással rendelkezik..
Legyen , , . A gyakorlatban általában a P permutációs mátrix helyett egy permutációs vektort használnak, amelyet a vektorból a P mátrixban permutált sorszámoknak megfelelő elemek permutálásával kapunk. Például, ha
akkor , mivel a P mátrixot az első és a második sor felcserélésével kapjuk. A LUP kiterjesztésének kiszámítása több lépésben történik. Legyen a mátrix C = A. Minden i-edik lépésben először egy referencia (vezető) elemet keresünk – az i-edik oszlop azon elemei közül a legnagyobb modulusú elemet, amely nem magasabb az i-edik sornál , ami után a pivot elemet tartalmazó sor felcserélődik az i -edik sorra. Ugyanakkor ugyanazt a cserét hajtják végre a P mátrixban. Ebben az esetben, ha a mátrix nem szinguláris, akkor a referenciaelem garantáltan különbözik a nullától. Ezt követően az aktuális i-edik oszlop minden elemét az i-edik sor alatt osztja el a pivot. Továbbá az i-edik sor és az i-edik oszlop alatt található összes elemből (vagyis olyanból, hogy j>i és k>i) a szorzat kivonásra kerül . Ezt követően az i számlálót eggyel növeljük, és a folyamatot addig ismételjük, amíg i<n, ahol n az eredeti mátrix dimenziója. Az összes lépés befejezése után a C mátrix a következő összeg lesz:
ahol E az azonosságmátrix .
Az algoritmus három egymásba ágyazott lineáris hurkot használ, így az algoritmus teljes összetettsége O( n ³) becsülhető .
Alább látható a fenti algoritmus programkódja C++ nyelven. Itt a Matrix egy olyan konténer, amely támogatja az indexelési műveletet. Kérjük, vegye figyelembe, hogy a visszaszámlálás nullától kezdődik, nem egytől.
void LUP ( const Matrix & A , Matrix & C , Matrix & P ) { //n - az eredeti mátrix dimenziója const int n = A . Sorok (); C = A ; //betöltjük a P mátrixba a P identitásmátrixot = IdentityMatrix ( ); for ( int i = 0 ; i < n ; i ++ ) { // pivot double pivotValue = 0 keresése ; int pivot = -1 ; for ( int sor = i ; sor < n ; sor ++ ) { if ( fabs ( C [ sor ][ i ]) > pivotValue ) { pivotValue = fabs ( C [ sor ][ i ]); pivot = sor ; } } if ( pivotValue != 0 ) { //az i-edik sort és a sort felcseréljük a P hivatkozási elemmel . SwapRows ( pivot , i ); C. _ SwapRows ( pivot , i ); for ( int j = i + 1 ; j < n ; j ++ ) { C [ j ][ i ] /= C [ i ][ i ]; for ( int k = i + 1 ; k < n ; k ++ ) C [ j ][ k ] -= C [ j ][ i ] * C [ i ][ k ]; } } } } //most C mátrix = L + U - EVektorok és mátrixok | |||||||||
---|---|---|---|---|---|---|---|---|---|
Vektorok |
| ||||||||
mátrixok |
| ||||||||
Egyéb |