-
Data: 2014-10-12 12:53:04
Temat: Re: Algorytmiczny problem lamera... :-)
Od: bartekltg <b...@g...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]On 12.10.2014 02:31, M.M. wrote:
> On Sunday, October 12, 2014 1:17:57 AM UTC+2, bartekltg wrote:
>> Ale po co, skoro masz iterator. On się rozwija w przypadku vector
>> do gołego wskaźnika, a nie trzeba uprawiać partyzantki*).
>> GCC przy 03 i wersję z indeksem przerabia na tak samo szybką,
>> na O2 widzę kilka procent narzutu.
>> Test, pomijając szczegóły, taki:
>> [...]
>> Ogolna różnica między 2 a 3 wynika z rozwijania pętli.
> U mnie na testach byl narzut wiekszy. QVector i QList dzialaly 2-3 razy
> dluzej niz tablica statyczna.
Rzeczywiście, QVectro + indeksy coś się nie chce optymalizować.
Na O2 w tamtym teście działał w tej samej kategorii co wszyscy,
ale na O3 już prawie dwa razy wolniej. Na iteratorach
nie było problemu, biega tak samo jak vector czy goła tablica.
Jednym słowem, jeśli nie bawisz się interfejsem, używaj standardowego
vectora.
> Tak, wiem ze tablice statyczne kompilatory
> moga lepiej zopytmalizowac niz wskaznik, ale jednak nie powinny, poniewaz
> wskaznik to prawie to samo co tablica. Mialem tez ciut bardziej
> skomplikowane obliczenia, mniej/wiecej:
> QVector< QVector<typ_prosty> >
> Rozmiar wewnętrznego 30 liczb int/float
> Rozmiar zewnętrznego 200tys.
>
> Operacje mniej/wiecej takie:
>
> for( i=0 ; i<200tys ; i++ ) {
> for( j=0 ; j<30 && vector[i][j] >= min[j] && vector[i][j] >= min[j] ; j++ )
> ;
> sum += j==30 ? 1 : -1;
> }
> print( sum );
Nie kompiluje się ;-)
Jeśli zawsze i wszędzie masz 30, może array<int,30> coś poprawi.
Albo nawet adresować wszytko liniowo (skoro nie boisz się
bawić wskaźnikami, i to nie powinno być problemem.)
Poza tym,
vector[i][j] >= min[j] && vector[i][j] >= min[j]
To imho dwa razy to samo.
Czysto estetycznie, może drugiego fora zastąpić while,
(albo nawet std::find_if, w końcu szukasz pierwszego
elementu nie spełniającego pewnego kryterium), początkowo
patrząc na ten kod 'nie widziałem' tego, że for kręci pustą
instrukcją.
To się cudownie równoległa;-)
pzdr
bartekltg
Następne wpisy z tego wątku
- 12.10.14 13:39 M.M.
- 12.10.14 17:25 bartekltg
- 12.10.14 19:53 M.M.
- 12.10.14 21:03 bartekltg
- 12.10.14 22:03 M.M.
- 24.10.14 10:55 m...@g...com
Najnowsze wątki z tej grupy
- 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
- CfC 28th Ada-Europe Int. Conf. Reliable Software Technologies
- Młodzi programiści i tajna policja
- Ada 2022 Language Reference Manual to be Published by Springer
- Press Release - AEiC 2023, Ada-Europe Reliable Softw. Technol.
- Ada-Europe - AEiC 2023 early registration deadline approaching
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2023
- Ile cykli zajmuje mnożenie liczb 64-bitowych?
Najnowsze wątki
- 2024-07-01 W-wa naklejki wjazd do centrum
- 2024-07-01 ładowarka zmarła
- 2024-07-01 Koder szuka pracy. Koduję w j.: Asembler, C, C++ (z Qt) i D.
- 2024-07-01 Kraków => Kierownik Działu Spedycji Międzynarodowej <=
- 2024-07-01 Białystok => Full Stack Web Developer (.Net Core, Angular6+) <=
- 2024-07-01 Berlin => Technical Rollouter (Radio Systems Software Installation and
- 2024-07-01 Warszawa => Key Account Manager <=
- 2024-07-01 Gdańsk => Programista Full Stack .Net <=
- 2024-07-01 Zabrze => Junior HelpDesk <=
- 2024-07-01 Warszawa => Key Account Manager <=
- 2024-07-01 Bielsko-Biała => Expert Migration Architect (Azure) <=
- 2024-07-01 Mini Netykieta polskich grup dyskusyjnych
- 2024-07-01 Re: Jak wypełnić polecenie francuskiego sądu blokowania niektórych zapytań DNS? Blokując Francję
- 2024-07-01 Re: Powtórne wezwanie na PO-komisję uzdrowi Ziobrę już w 10 dni
- 2024-07-01 CA -- problem z logowaniem