eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.comp.programmingNiezmienniki pętliRe: Niezmienniki pętli
  • X-Received: by 2002:a37:a2ca:: with SMTP id l193mr17116qke.2.1542707160986; Tue, 20
    Nov 2018 01:46:00 -0800 (PST)
    X-Received: by 2002:a37:a2ca:: with SMTP id l193mr17116qke.2.1542707160986; Tue, 20
    Nov 2018 01:46:00 -0800 (PST)
    Path: news-archive.icm.edu.pl!news.icm.edu.pl!news.nask.pl!news.nask.org.pl!news.unit
    0.net!weretis.net!feeder6.news.weretis.net!feeder.usenetexpress.com!feeder-in1.
    iad1.usenetexpress.com!border1.nntp.dca1.giganews.com!nntp.giganews.com!z5-v6no
    246143ite.0!news-out.google.com!y103-v6ni116ita.0!nntp.google.com!q69no247703it
    b.0!postnews.google.com!glegroupsg2000goo.googlegroups.com!not-for-mail
    Newsgroups: pl.comp.programming
    Date: Tue, 20 Nov 2018 01:46:00 -0800 (PST)
    In-Reply-To: <a...@g...com>
    Complaints-To: g...@g...com
    Injection-Info: glegroupsg2000goo.googlegroups.com;
    posting-host=2a00:f41:1cb5:1b23:981e:4f13:9498:4677;
    posting-account=Sb6m8goAAABbWsBL7gouk3bfLsuxwMgN
    NNTP-Posting-Host: 2a00:f41:1cb5:1b23:981e:4f13:9498:4677
    References: <8...@g...com>
    <7...@g...com>
    <d...@g...com>
    <psp6q7$97o$1@node2.news.atman.pl>
    <6...@g...com>
    <pss4d0$14n$1@node2.news.atman.pl>
    <3...@g...com>
    <8...@g...com>
    <a...@g...com>
    <a...@g...com>
    User-Agent: G2/1.0
    MIME-Version: 1.0
    Message-ID: <4...@g...com>
    Subject: Re: Niezmienniki pętli
    From: fir <p...@g...com>
    Injection-Date: Tue, 20 Nov 2018 09:46:01 +0000
    Content-Type: text/plain; charset="UTF-8"
    Content-Transfer-Encoding: quoted-printable
    Lines: 70
    Xref: news-archive.icm.edu.pl pl.comp.programming:212946
    [ ukryj nagłówki ]

    W dniu poniedziałek, 19 listopada 2018 23:12:21 UTC+1 użytkownik g...@g...com
    napisał:
    > Jak będziecie używać mojej funkcji memmove, to może nawet zadziała
    > o ćwierć promila szybciej na niektórych procesorach.

    takie teksty nie brzmia za madrze (pominawszy fakt ze tego typu spory/dyskusje (tego
    okreslonego typu) wogole nie sa za madre) (z trzeciej stony wlaczanie sie w takie
    logiczne podejscie
    (typu wypowiadanie zdan i rozrtrzasanie co jest rpawda a co nie) jest ok)

    ile to jest cwierc promila? 0.025 %,
    cos tu nie gra, wygladami na to ze
    ktos kto to pisze ma bardzo osobliwe podejscie do optymalizacji i robil to albo jakos
    dziwnie albo zupelnie zle
    albo wogole

    ja optymalizowalem relatywnie sporo i

    1)
    takie wartosci jak 0.025% nie wchodza
    tam wogole w gre bo te czasy wogole nie sa tak stabilne by moc to zauwazyc i zmierzyc
    (aq czas czystego memcopy to juz wogole gdy ja to mierzylem niezle oscylowal)
    2)
    samego memcopy raczej sie nie optymalizuje bo przestrzen by tu poprawic jest mala ale
    juz cale okolice bliskie
    memcopy - jak najbardziej
    3) czynniki jakimi mozesz przyoptymalizowac juz calkiem dobrze ale zwyczajnie
    napisany kod w c czy tam c++ moga byc naprawde spore, i wtedy nie wyrazasz tez tego
    raczej w procentach tylko w 'x' ile razy, to ilemozesz osiagnac zalezy od natury
    zagadnienia i od tego jak wstepnie przyoptymalizowany byl kod oraz od tego jak bardzo
    daleko chesz isc w ta optymalizacje

    ale moje przykladowe casy jakie ja znam

    1) kiepsko napisany kod 60 ms na ramke
    2) pobawianie sie z flagami kompilacji
    (ale takie ktore polega na tym ze po roznych zmianach patrzysz na wplyw a nie tylko
    na pale wlaczysz kilka) oraz wogole
    wyodrebnienie petli i przepisanie jaj tak by bylo jasne co tam sie dzieje (jelsi ktos
    napisal bez wiekszej uwagi) 30 ms na ramke

    (dla mnie to pow punkt startoway bo jzu na starcie zwracam na to uwage)

    3) poprzepisywanie, porozwijanie wyrazen, zredukowanie dzielen, poprzepisywanie na
    inline (choc to malo pomaga raczej chodzi o to by miec wglad co tam sie dzieje),
    ogolne poupraszczanie tak ze kod bardziej jest przyjazny podejsciu optymalizacyjnemu
    - 16 ms

    4) tabelaryzowanie kawalkow kodu, porozbijanie kodu na specjalne casy pod wzgledem
    optymalizacji, dorobienie skomplikowanych algorytmow 'odrzucania roboty', zagladanie
    do generowanego asma, ew wwalenie paru intrinsincow sse... przerobienie niektorych
    czesci na kod ktory dzial w sposob lekko przyblizony (zlinearyzowany) (strata jakosc
    wzgl szybkosci) - 1.6- 1.2 ms

    5) zejscie na poziom asma i robienie jakiegos hardkoru w mikrokodzie razem ew jeszcze
    z dorobieniem jeszcze wiekszych rewolucji w algorytmach odrzucania - prawdopodobnie
    jeszcze mozna przyspieszyc 2 razy (i zejsc ponizej milisekundy ale to juz hardkor i
    tego nie robie za duzo roboty i nei znam az takl asma


    slowem jak ktos mowi ze optymalizacja to walka o promile to raczej nie wie co mowi,
    wg mopich doswiadczen optymalizacja to raczej 'srednio' czynnik 10x 15x jeslis ie
    nawet zaczyna z calkiem poprawnego kodu w c

    nie widze przypadku w ktorych mowienie o promilach mialoby sens - bo to chyab
    musialobybyc w wypadku potwznie przyoptymalizowanego kodu a taki kod ma juz wtedy
    procentowo spoore fluktuacje wiec gadanie o promilach nie ma sensu

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: