-
Path: news-archive.icm.edu.pl!agh.edu.pl!news.agh.edu.pl!newsfeed2.atman.pl!newsfeed.
atman.pl!.POSTED!not-for-mail
From: bartekltg <b...@g...com>
Newsgroups: pl.comp.programming
Subject: Re: Pętla FOR (w sam raz na poziom FIR'a)
Date: Sun, 28 Apr 2013 23:31:57 +0200
Organization: ATMAN - ATM S.A.
Lines: 116
Message-ID: <klk4ge$pli$1@node1.news.atman.pl>
References: <517bf604$0$1250$65785112@news.neostrada.pl>
<kljt4d$mod$1@mx1.internetia.pl>
NNTP-Posting-Host: 89-73-65-59.dynamic.chello.pl
Mime-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 8bit
X-Trace: node1.news.atman.pl 1367184718 26290 89.73.65.59 (28 Apr 2013 21:31:58 GMT)
X-Complaints-To: u...@a...pl
NNTP-Posting-Date: Sun, 28 Apr 2013 21:31:58 +0000 (UTC)
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:17.0) Gecko/20130328
Thunderbird/17.0.5
In-Reply-To: <kljt4d$mod$1@mx1.internetia.pl>
Xref: news-archive.icm.edu.pl pl.comp.programming:202938
[ ukryj nagłówki ]W dniu 2013-04-28 21:17, Michoo pisze:
> On 27.04.2013 18:00, slawek wrote:
>> Takie głupie pytanie - która pętla jest lepsza:
>>
>> 1: for i = 0 to n do call subroutine();
>> 2: for i = n downto 0 call subroutine();
>>
>> Na zdrowy rozum, obie są takie same. Ale chwila - pierwsza rozwija się
>> (przynajmniej w niektórych językach) do
>
> Ogólnie to gcc (icc też, nie wiem jak kompilator MS i inne) robią
> transformacje niezmienników - czyli jeżeli wykryją, że i ma za zadanie
> tylko kontrolę iteracji to zamienią to w zjazd do zera, i to nawet w
> bardziej złożonych przypadkach jak:
> for(int i=5;i<10;i++)
> foo();
> zostanie zamienione w:
> for(int i=5;i;i--)
> foo();
VC2010
double d;
cin>>d;
for(int i=5;i<10;i++)
d = 4*d*(1-d);
cout<<d;
na domyślnych ustawieniach (/O2) rozwija na 5 powtórzeń.
Po załączeniu opcji Favor small code (/Os)
***
; 31 : for(int i=5;i<10;i++)
dec eax
; 32 : d = 4*d*(1-d);
fld1
fsub QWORD PTR _d$[ebp]
fld QWORD PTR _d$[ebp]
fmul QWORD PTR __real@4010000000000000
fmulp ST(1), ST(0)
fstp QWORD PTR _d$[ebp]
jne SHORT $LL3@wmain
***
Czyli tak, jak chcemy.
Ale dalej. Zmieńmy 10 na 100 i wyłączny /Os.
mov eax, 19 ; 00000013H
...
$LN3@wmain:
; 31 : for(int i=5;i<100;i++)
dec eax
; 32 : d = 4*d*(1-d);
fld ST(2)
fsub ST(0), ST(1)
fxch ST(1)
fmul ST(0), ST(2)
fmulp ST(1), ST(0)
....powtórzone jeszcze 4 razy....
jne SHORT $LN3@wmain
Bardziej złośliwe liczby? for(int i=5;i<102;i++)
97 jest pierwsza.
Więc mamy 12 razy wykonywaną pętlę po 8 powtórzeń + jedno
na koniec.
Też odliczamy do zera.
To może coś oczko trudnijszego:
double d;
int k;
cin>>d;
cin>>k;
for(int i=5;i<k+10;i++)
d = 4*d*(1-d);
cout<<d;
***
; 33 : for(int i=5;i<k+10;i++)
mov eax, DWORD PTR _k$[ebp]
add eax, 10 ; 0000000aH
cmp eax, 5
jle SHORT $LN1@wmain
; 29 : double d;
; 30 : int k;
; 31 : cin>>d;
add eax, -5 ; fffffffbH
$LL3@wmain:
; 33 : for(int i=5;i<k+10;i++)
dec eax
; 34 : d = 4*d*(1-d);
fld1
fsub QWORD PTR _d$[ebp]
fld QWORD PTR _d$[ebp]
fmul QWORD PTR __real@4010000000000000
fmulp ST(1), ST(0)
fstp QWORD PTR _d$[ebp]
jne SHORT $LL3@wmain
***
Wersja bez Favor small code (/Os) to pętla po 8 ++ pętla pojedyncza.
Jest dobrze.
Jeszcze paręnaście lat i dogonimy gcc ;-)
pzdr
bartekltg
Następne wpisy z tego wątku
- 29.04.13 10:28 slawek
- 29.04.13 18:53 identyfikator: 20040501
- 30.04.13 07:32 Paweł Kierski
- 01.05.13 20:26 Michoo
Najnowsze wątki z tej grupy
- Can you activate BMW 48V 10Ah Li-Ion battery, connecting to CAN-USB laptop interface ?
- We Wrocławiu ruszyła Odra 5, pierwszy w Polsce komputer kwantowy z nadprzewodzącymi kubitami
- Ada-Europe - AEiC 2025 early registration deadline imminent
- John Carmack twierdzi, że gdyby gry były optymalizowane, to wystarczyły by stare kompy
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2025
- Linuks od wer. 6.15 przestanie wspierać procesory 486 i będzie wymagać min. Pentium
- ,,Polski przemysł jest w stanie agonalnym" - podkreślił dobitnie, wskazując na brak zamówień.
- Rewolucja w debugowaniu!!! SI analizuje zrzuty pamięci systemu M$ Windows!!!
- Brednie w wiki - hasło Dehomag
- Perfidne ataki krakerów z KRLD na skrypciarzy JS i Pajton
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- U nas propagują modę na SI, a w Chinach naukowcy SI po kolei umierają w wieku 40-50lat
- C++. Podróż Po Języku - komentarz
Najnowsze wątki
- 2025-07-12 Warszawa => PC Hardware Expert / Specjalista PC <=
- 2025-07-12 Warszawa => Account Manager - Usługi rekrutacyjne <=
- 2025-07-12 Warszawa => Administrator IT <=
- 2025-07-12 Warszawa => IT Administrator <=
- 2025-07-12 Warszawa => Asystent/tka ds. Administracji <=
- 2025-07-12 Warszawa => Specjalista/stka ds. Organizacji <=
- 2025-07-12 Warszawa => MENA New Business Manager <=
- 2025-07-12 Gdynia => Controlling systems Consultant <=
- 2025-07-12 Warszawa => Developer Microsoft Dynamics 365 Finance & Operations (D36
- 2025-07-12 Warszawa => Programista Microsoft Dynamics 365 Finance & Operations (D
- 2025-07-12 Warszawa => Dyrektor IT <=
- 2025-07-12 Warszawa => IT Director <=
- 2025-07-12 Czy wypowiedź Kaczyńskiego o Braunie jest skarżalna? ["działa z OBCEJ inspiracji"]
- 2025-07-11 Rejestrator temperatur - termopara, siec
- 2025-07-11 DPD, przeniesienie numerów z a2mobile i z Orange