-
Data: 2010-01-21 20:25:11
Temat: Re: matlab taki wydajny?
Od: bartekltg <b...@g...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]On 21 Sty, 19:21, thrunduil <t...@w...pl> wrote:
> On 21 Sty, 16:10, bartekltg <b...@g...com> wrote:
>
> > To nie ma nic wspolnego z pamiecia, przynajmniej nie tak, jak
> > sugerujesz.
> > Jesli by mialo, to moj prosty kod (podany na koncu) tez by mizernie
> > dzialal.
> > Ale on nie chec, 1000 roznych mnozen wektorka dlugosci 1000
> > przez macierz 1000x1000 liczy w niecale 6s.
>
> nie do konca rozumiem:
> Matlab: A * B =>
> 0.18sec
> Matlab: for i:1000; A*v; end => 1.84sec
> kod c for i:1000; A*v; end, wersja bledna => 1,33 sec
> kod c for i:1000; A*v; end, wersja poprawna => 7.00 sec
>
> A = 1000x1000, B = 1000x1000; v =1000x1
>
> jest blad w kodzie, ma byc
> t+=v[i]*M[j+n*i]; zamiast t+=v[i]*M[j+2*i];
O kurde, jaki wstyd przed ryskiem;/
Wersja poprawione idzie u mnie prawie 50s.
Ale w koncu uwierzylem w portege matlaba;)
Pozostaje pytanie, dlaczego Mariuszowi wychodzilo szybiej.
> co to ma pokazywac oprocz tego, ze pamiec ma znaczenie? Blad w kodzie
> nie zmienia liczby wykonanych operacji.
rzeczywiscie, masz racje, latam tam po obszarze pamieci
3000*8 a nie 10^6*8 i to jedyna roznica.
> zreszta
> dla A = 3000x1000; B =1000x1000; v = 1000x1
> Matlab: A * B =>
> 0.537sec
> Matlab: for i:1000; A*v; end => 5.33sec
>
> W obu wersjach mnozenie przez wektor w petli jest 10x wolniejsze.
> Petla jest wykonywana 1000 razy, wiec roznica nie moze miec
> nic wspolnego z narzutem petli.
pozdrawiam
bartekltg
Następne wpisy z tego wątku
- 21.01.10 20:31 bartekltg
- 21.01.10 20:45 Mariusz Marszałkowski
- 21.01.10 21:08 Wit Jakuczun
- 21.01.10 22:10 Mariusz Marszałkowski
- 22.01.10 09:05 lolo
- 22.01.10 09:15 Mariusz Marszałkowski
- 22.01.10 09:34 bartekltg
- 22.01.10 09:45 thrunduil
- 22.01.10 15:20 Mariusz Marszałkowski
- 23.01.10 09:11 Mariusz Marszałkowski
- 23.01.10 09:34 Wit Jakuczun
- 23.01.10 09:42 Mariusz Marszałkowski
- 23.01.10 09:57 Wit Jakuczun
- 23.01.10 09:58 Mariusz Marszałkowski
- 24.01.10 10:23 thrunduil
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-05-26 O co chodzi?
- 2024-05-26 PJ autobus-tramwaj
- 2024-05-26 Renault Trafic i lampka z czerwonym STOP
- 2024-05-26 cena pięciocyfrowa
- 2024-05-26 Re: Jak dobra KE "okrada" złą Rosję "dla Ukrainy"
- 2024-05-25 supercap
- 2024-05-25 Sulzbach => Technischer Rollouter (d/m/w) <=
- 2024-05-25 Warszawa => Senior Account Manager <=
- 2024-05-25 Warszawa => Mid PHP Developer (Laravel) <=
- 2024-05-25 Warszawa => Mid PHP Developer (Laravel) <=
- 2024-05-25 Warszawa => Interactive/Experience Designer <=
- 2024-05-25 Warszawa => Key Account Manager <=
- 2024-05-25 Warszawa => SAP WM Consultant / Execution <=
- 2024-05-25 Warszawa => Key Account Manager <=
- 2024-05-25 Re: znów ten wrocław