Algorytmy dla dużych rzadkich macierzy całkowitych


12

Szukam biblioteki, która wykonuje operacje macierzowe na dużych macierzach rzadkich bez poświęcania stabilności numerycznej. Macierze będą miały wartości 1000+ na 1000+, a wartości macierzy będą zawierać się w przedziale od 0 do 1000. Będę wykonywać algorytm rachunku indeksu, więc będę generował (rzadkie) wektory rzędowe macierzy szeregowo. Gdy rozwijam każdy rząd, będę musiał przetestować liniową niezależność. Po wypełnieniu mojej macierzy pożądaną liczbą wektorów liniowo niezależnych będę musiał przekształcić macierz w postać zredukowanego rzędu rzędów.

Problem polega na tym, że moja implementacja wykorzystuje eliminację Gaussa do określenia liniowej niezależności (zapewnienie formy rzutu wiersza po znalezieniu wszystkich wektorów wiersza). Biorąc jednak pod uwagę gęstość i rozmiar matrycy, oznacza to, że wpisy w każdym nowym rzędzie stają się wykładniczo większe w miarę upływu czasu, ponieważ w celu wykonania anulowania należy znaleźć lcm wiodących wpisów. Znalezienie zredukowanej formy matrycy dodatkowo zaostrza problem.

Moje pytanie brzmi zatem: czy istnieje algorytm, a może jeszcze implementacja, która może przetestować liniową niezależność i rozwiązać formę zredukowanego rzutu rzędu, przy zachowaniu możliwie najmniejszych wpisów? Wydajny test liniowej niezależności jest szczególnie ważny, ponieważ w algorytmie rachunku indeksu jest on przeprowadzany zdecydowanie najbardziej.

Odpowiedzi:


5

Możesz pracować modulo z wieloma dużymi liczbami pierwszymi, aby uzyskać wyniki modulo tych liczb pierwszych, a następnie sprawdź, czy istnieją racjonalności z wystarczającą liczbą cyfr, które spełniają te zbieżności. Jeśli tak, możesz sprawdzić przez mnożenie macierzy-wektora, czy znalezione przybliżenie jest dokładne. Można to przekształcić w algorytm dokładnej decyzji.

101000

powiązane linki:
http://cs.ucsb.edu/~koc/docs/j21.pdf
http://dl.acm.org/citation.cfm?id=355767
http://dl.acm.org/citation. cfm? id = 355765

Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.