-
Data: 2012-04-01 22:29:53
Temat: Re: dalsza optymalizacja
Od: " M.M." <m...@N...gazeta.pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]bartekltg <b...@g...com> napisał(a):
> TrochÄ skromnie to opisaĹeĹ i nie do koca widzÄ, jak to robisz.
>
> Jak dokĹadnie zapisujesz X i ma m*n. jedynki[] to tablica
> z ktĂłrymi pozycjami?
Pisząc z pamięci:
Dla jednej pary x i y:
x to wektor zer i jedynek.
y to wartość skalarna którą chcemy aproksymować.
m to macierz układu równań normalnych
x ma rozmiar x.size // notacja za Cormenem
m ma rozmiar x.size wierszy i (x.size+1) kolumn, ostatnia kolumna to wyrazy
wolne równania.
Na początku m jest wyzerowane.
Rozszerzam x przez przylaczenie na koniec y:
x[x.size] = y;
x.size = x.size+1
potem w dwóch pętlach:
for( i=0 ; i<x.size-1 ; i++ )
for( j=0 ; j<x.size ; j++ )
m[i][j] += x[i] * x[j];
I tak dla każdego wektora. Potem oddzielna sprawa rozwiązać ten układ
równań.
Pierwsza optymalizacja:
Ze względu na to że macierz jest symetryczna, to można wyliczyć tylko
jeden trójkąt:
for( i=0 ; i<x.size-1 ; i++ )
for( j=i ; j<x.size ; j++ )
m[i][j] += x[i] * x[j];
I druga optymalizacja:
ze względu na to że dane to zera i jedynki, zapamiętuję w
jedynki[] pozycje jedynek (posortowane) i wychodzi:
for( i=0 ; i<jedynki.size ; i++ ) {
for( j=i ; j<jedynki.size ; j++ )
m[ jedynki[i] ][ jedynki[j] ] ++ ; // x[ jedynki[i] ] * x[ jedynki[j] ];
m[i][x.size-1] += y;
}
Można coś ulepszyć?
Pozdrawiam
--
Wysłano z serwisu Usenet w portalu Gazeta.pl -> http://www.gazeta.pl/usenet/
Następne wpisy z tego wątku
- 01.04.12 22:44 bartekltg
- 01.04.12 22:49 bartekltg
- 01.04.12 22:50
- 01.04.12 23:56 M.M.
- 01.04.12 23:59 bartekltg
- 02.04.12 00:11 M.M.
- 02.04.12 00:13 M.M.
- 02.04.12 01:20 bartekltg
- 02.04.12 02:58 M.M.
- 02.04.12 08:25
- 02.04.12 10:40 zażółcony
- 02.04.12 10:46
- 02.04.12 11:46
- 02.04.12 14:58 bartekltg
- 02.04.12 15:00 bartekltg
Najnowsze wątki z tej grupy
- Popr. 14. Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- Arch. Prog. Nieuprzywilejowanych w pełnej wer. na nowej s. WWW energokod.pl
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
Najnowsze wątki
- 2025-02-03 Kraków => iOS Developer (Swift experience) <=
- 2025-02-03 Gdańsk => Specjalista ds. Sprzedaży <=
- 2025-02-03 Warszawa => QA Engineer (Quality Assurance) <=
- 2025-02-03 Katowice => Key Account Manager (ERP) <=
- 2025-02-03 Pies z kulawą nogą nie kupi twojego elektryka
- 2025-02-01 "Nie kupujcie samochodów elektrycznych
- 2025-02-01 jakie małe auto duże w środku :-)
- 2025-02-01 Re: pytanie do oponiarzy lub szybkojeżdzących (opony Hankook Ventus Prime, S1 Evo, alternatywy)
- 2025-02-01 T-1000 was here
- 2025-02-01 Warszawa => DevOps Engineer <=
- 2025-02-01 Katowice => Administrator IT - Operating Systems and Virtualization <=
- 2025-02-01 Warszawa => Spedytor międzynarodowy <=
- 2025-02-01 Śmierć mózgu a narządy do pobrania
- 2025-01-31 A niektórym to naprawdę zależy na ekologi w miastach LPG POWRACA ;-)
- 2025-01-31 Lublin => Programista Delphi <=