-
Data: 2013-12-05 10:05:36
Temat: Re: minmax(a,b,c)
Od: firr <p...@g...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]>
> Jednak te skoki nie są takie straszne, czy kompilator
>
> za głupi? cmov to chyba już pentium pro.
>
>
>
>
>
> I też używają trzech instrukcji i dodatkowego rejestru
>
> na swap. Czyżby jednak było to szybsze niż xchg?
>
> Internet twierdzi, że nie.
>
> A CMPXCHG?
>
prawdopodobnie nie chodzi o ilosc cmp i movow
(oraz o to czy xcchg jest szybsze od movow bo
raczej na pewno jesli nie zostalo uzyte jest wolniejsze)
tylko o ilosc skokow, gdyby pisac moja rozwinieta
procedure w wersji 'bezposredniej' to byloby to
cos takiego
cmp a, b
jg n1
cmp a, c
jg n2
mov min, a
cmp b, c
jg n3
mov max, c
j exit
n3: mov max, b
j exit
n2:
mov min, c
mov max, b
j exit
n1:
cmp a, c
jl n4
mov max, a
cmp b, c
jl n5
mov min, c
j exit
n5: mov min, b
j exit
n4:
mov min, b
mov max, c
exit:
5 skokow warunkowych, 5 skokow
bezwarunkowych, czyli razem 10 skokow,
5 porownan, 10 movow,
co prawda chyba raczej powinno sie liczyc nie sumarycznie a po danej sciezce
wykonania ale
z tego co sie slyszy liczy sie tez chyba ilosc
missów, tak czy owak ten kod ktory zminimalizowal
ilosc skokow do 2 jak dla mnie akurat wyglada tutaj calkiem dobrze
ciekawe czy dalo by sie to recznie np z uzyciem
wlasnie bezifowców jeszcze to skompaktowac do jednego lub zero jumpow
Następne wpisy z tego wątku
- 05.12.13 10:23 g...@g...com
- 05.12.13 10:44 firr
- 05.12.13 11:08 g...@g...com
- 05.12.13 11:54 firr
- 05.12.13 12:18 intuicjonista
- 05.12.13 13:18 firr
- 05.12.13 13:42 firr
- 05.12.13 15:07 firr
- 06.12.13 13:07 firr
- 06.12.13 13:15 firr
- 07.12.13 16:16 firr
Najnowsze wątki z tej grupy
- 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
- CfC 28th Ada-Europe Int. Conf. Reliable Software Technologies
- Młodzi programiści i tajna policja
Najnowsze wątki
- 2024-11-24 Aby WKOOOORWIĆ ekofaszystów ;-)
- 2024-11-22 OC - podwyżka
- 2024-11-22 wyszedł z domu bez buta
- 2024-11-22 Bieda hud.
- 2024-11-24 DS1813-10 się psuje
- 2024-11-23 Białystok => Inżynier bezpieczeństwa aplikacji <=
- 2024-11-23 Szczecin => QA Engineer <=
- 2024-11-23 Warszawa => SEO Specialist (15-20h tygodniowo) <=
- 2024-11-22 Warszawa => Kierownik Działu Spedycji Międzynarodowej <=
- 2024-11-22 Warszawa => Senior Account Manager <=
- 2024-11-22 Warszawa => Key Account Manager <=
- 2024-11-22 Warszawa => DevOps Specialist <=
- 2024-11-22 Kraków => IT Expert (Network Systems area) <=
- 2024-11-22 Warszawa => Infrastructure Automation Engineer <=
- 2024-11-22 Warszawa => Presales / Inżynier Wsparcia Technicznego IT <=