eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.comp.programmingIle zajmie komputerowi mnożenie liczb rzędu 2^128Re: Ile zajmie komputerowi mnożenie liczb rzędu 2^128
  • Path: news-archive.icm.edu.pl!news.icm.edu.pl!newsfeed.pionier.net.pl!news-1.dfn.de!n
    ews.dfn.de!feeder.erje.net!2.eu.feeder.erje.net!news.uzoreto.com!eternal-septem
    ber.org!feeder.eternal-september.org!reader01.eternal-september.org!.POSTED!not
    -for-mail
    From: Piotr Chamera <p...@p...onet.pl>
    Newsgroups: pl.comp.programming
    Subject: Re: Ile zajmie komputerowi mnożenie liczb rzędu 2^128
    Date: Fri, 13 Dec 2019 08:34:34 +0100
    Organization: A noiseless patient Spider
    Lines: 19
    Message-ID: <qsveui$eop$1@dont-email.me>
    References: <b...@g...com>
    <qs878c$luk$1@dont-email.me>
    <5...@g...com>
    <d...@g...com>
    <8...@g...com>
    <8...@g...com>
    <6...@g...com>
    <2...@g...com>
    <e...@g...com>
    <0...@g...com>
    <a...@g...com>
    Mime-Version: 1.0
    Content-Type: text/plain; charset=utf-8; format=flowed
    Content-Transfer-Encoding: 8bit
    Injection-Date: Fri, 13 Dec 2019 07:34:42 -0000 (UTC)
    Injection-Info: reader02.eternal-september.org;
    posting-host="82ef82f9b20f891106c6da5bffbd903e";
    logging-data="15129";
    mail-complaints-to="a...@e...org";
    posting-account="U2FsdGVkX1/+Bm3i5jaS3m55siwnGuVV"
    User-Agent: Mozilla/5.0 (Windows NT 6.3; WOW64; rv:60.0) Gecko/20100101
    Thunderbird/60.9.1
    Cancel-Lock: sha1:KsAa6gXDaHjjexrVcPLOLtSks7k=
    In-Reply-To: <a...@g...com>
    Content-Language: pl
    Xref: news-archive.icm.edu.pl pl.comp.programming:214541
    [ ukryj nagłówki ]

    W dniu 2019-12-13 o 06:42, osobliwy nick pisze:
    > 166 mikrosekund wziąłem z wyliczeń Piotra Chamera. Z tego co Ty napisałeś wynika
    zaś, że można to zrobić 50 razy szybciej. 10 nanosekund dla 64-bitowych liczb na
    iterację, dla 128-bitowych - 3 razy wolniej, czyli 30 nanosekund. To daje 128*30=3840
    nanosekund na 128 iteracji (czyli 3,84 mikrosekund). Wówczas wychodzi:
    >
    > 1000000/3,84*128/20*1/2^20 = 1,59 MB/s
    >
    > Nie rozumiem w takim razie tylko skąd taka rozbieżność pomiędzy tym co piszesz Ty,
    a tym co policzył Piotra Chamera.

    Muszę się odezwać, bo tu jakieś absurdy wychodzą. Napisałem na szybko
    zupełnie niezoptymalizowany program, który policzył przykładowy algorytm
    w 166 ms. O czym to świadczy? Tylko o tym, że bez wysiłku można taki
    czas uzyskać. Trzeba też wziąć pod uwagę, że jest to program zupełnie
    bez ograniczeń na to jak duże są liczby, czy są całkowite itp.

    Kolega fir oszacował, że ten sam algorytm można policzyć wielokrotnie
    szybciej i to też prawda. Szczególnie jeśli da się ustalić, że wszystko
    da się np. policzyć na 128 bitowych liczbach całkowitych bez znaku :)
    O ile to będzie szybciej okaże się kiedy ktoś to napisze w konkretnym
    języku, skompiluje i uruchomi na konkretnym procesorze (50 razy szybciej
    względem mojego przykładu jest jak najbardziej realne :).

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: