eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.comp.programmingSzukam benchmarkówRe: Szukam benchmarków
  • 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: Szukam benchmarków
    Date: Wed, 17 Dec 2014 17:15:59 +0100
    Organization: ATMAN - ATM S.A.
    Lines: 55
    Message-ID: <m6sa80$49n$1@node1.news.atman.pl>
    References: <lq5a1e$7rk$1@node1.news.atman.pl>
    <9...@g...com>
    <e...@g...com>
    <lqadk9$kg7$1@node1.news.atman.pl>
    <s...@4...com>
    <6...@g...com>
    <lqalcn$65n$1@node2.news.atman.pl>
    <3...@g...com>
    <4...@g...com>
    <f...@g...com>
    <m6qo5d$fqd$1@node1.news.atman.pl>
    <9...@g...com>
    <7...@g...com>
    NNTP-Posting-Host: 89-73-81-145.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 1418832960 4407 89.73.81.145 (17 Dec 2014 16:16:00 GMT)
    X-Complaints-To: u...@a...pl
    NNTP-Posting-Date: Wed, 17 Dec 2014 16:16:00 +0000 (UTC)
    User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:31.0) Gecko/20100101
    Thunderbird/31.2.0
    In-Reply-To: <7...@g...com>
    Xref: news-archive.icm.edu.pl pl.comp.programming:207229
    [ ukryj nagłówki ]

    On 17.12.2014 15:27, M.M. wrote:
    > On Wednesday, December 17, 2014 2:24:57 PM UTC+1, g...@g...com wrote:
    >> Jezeli dana procedura (taka jak np. liczenie sinusa) gwarantuje,
    >> ze dla tego samego argumentu zawsze uzyskamy ten sam wynik
    > Wystarczy ze gwarantuje taką samą dokładność dla określonego zbioru
    > argumentów.
    >
    >
    > Swoją drogą, szkoda że w C++ nie można przy argumencie procedury
    > napisać, że dany argument będzie przyjmował wartości tylko z małego
    > zbioru. Wtedy kompilator miałbym lepsze możliwości optymalizacji.
    >
    >
    > np.
    > f( int x@{1:50%,0:20%,2:10%,other} ) {
    > return sin(x);
    > }
    >
    > Kompilator mógłby stablicować dla sin dla 1, 0 i 2, a że 1
    > przychodzi statystycznie w 50%, to mógłby 'górnym ifem' sprawdzać,
    > czy x==1.

    Nie, tablicowanie to inny sposób działania programu.
    Chcesz tablicowania, zrób to ręcznie (ile to, 10 linijak jak się
    rozpiszesz).

    >
    > if( x==1 ) return sin(1);
    > if( x==0 ) return sin(0);
    > if( x==2 ) return sin(2);
    > return sin(x);


    > Z kolei gdy się nie poda statystyki wystąpień, to kompilator mógłby
    > wziąć wartości z pgo.
    >
    > Dalej, gdy nie ma other, to w ogóle kompilator mógłby wygenerować
    > ultra zoptymalizowany kod:
    >
    > f( int x@{1:60%,0:40%} ) {
    > return x==1 ? sin(1) : sin(0);
    > }

    Kompilator musiałby mieć gwarancje, że innej liczby nie będzie.
    Przykładowe uruchomiania przy -fprofile-generate to za mało.
    A skoro wpisujesz to ręcznie, to możesz wpisać sam, jak powyżej.

    Kompilator ma wykonywać za programistę mechzniczne czynności,
    nie myśleć ;-)

    pzdr
    bartekltg



Podziel się

Poleć ten post znajomemu poleć

Wydrukuj ten post drukuj


Następne wpisy z tego wątku

Najnowsze wątki z tej grupy


Najnowsze wątki

Szukaj w grupach

Eksperci egospodarka.pl

1 1 1

Wpisz nazwę miasta, dla którego chcesz znaleźć jednostkę ZUS.

Wzory dokumentów

Bezpłatne wzory dokumentów i formularzy.
Wyszukaj i pobierz za darmo: