eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.comp.programmingProsty generator pseudolosowy 8bit z limitemRe: Prosty generator pseudolosowy 8bit z limitem
  • X-Received: by 10.31.189.69 with SMTP id n66mr304116vkf.6.1512108254494; Thu, 30 Nov
    2017 22:04:14 -0800 (PST)
    X-Received: by 10.31.189.69 with SMTP id n66mr304116vkf.6.1512108254494; Thu, 30 Nov
    2017 22:04:14 -0800 (PST)
    Path: news-archive.icm.edu.pl!news.icm.edu.pl!news.nask.pl!news.nask.org.pl!news.unit
    0.net!peer02.am4!peer.am4.highwinds-media.com!peer01.iad!feed-me.highwinds-medi
    a.com!news.highwinds-media.com!m31no12357qtf.0!news-out.google.com!t48ni55qtc.1
    !nntp.google.com!g35no12188qtk.1!postnews.google.com!glegroupsg2000goo.googlegr
    oups.com!not-for-mail
    Newsgroups: pl.comp.programming
    Date: Thu, 30 Nov 2017 22:04:14 -0800 (PST)
    In-Reply-To: <f...@g...com>
    Complaints-To: g...@g...com
    Injection-Info: glegroupsg2000goo.googlegroups.com; posting-host=89.77.34.118;
    posting-account=mvBzhgoAAADiziO82aLj4VEpjexQv3Cn
    NNTP-Posting-Host: 89.77.34.118
    References: <a...@g...com>
    <f...@g...com>
    User-Agent: G2/1.0
    MIME-Version: 1.0
    Message-ID: <1...@g...com>
    Subject: Re: Prosty generator pseudolosowy 8bit z limitem
    From: Adam Klobukowski <a...@g...com>
    Injection-Date: Fri, 01 Dec 2017 06:04:14 +0000
    Content-Type: text/plain; charset="UTF-8"
    Content-Transfer-Encoding: quoted-printable
    X-Received-Body-CRC: 492935150
    X-Received-Bytes: 3461
    Xref: news-archive.icm.edu.pl pl.comp.programming:211808
    [ ukryj nagłówki ]

    W dniu czwartek, 30 listopada 2017 05:42:24 UTC+1 użytkownik bartekltg napisał:
    > On Tuesday, November 28, 2017 at 9:48:28 AM UTC+1, Adam Klobukowski wrote:
    > > Poszukuję prostego (szybkiego) generatora pseudolosowego liczb 8bitowych z górnym
    limitem, tj. jak bym chciał sobie wylosować liczbę z zakresu 0-44. Możecie coś
    polecić?
    >
    > Dalej piszesz, że chcesz zmieniać w trakcie, to jedynym rozwiązaniem jest
    > generator o zakresie pełnych 8 bitów i obcinanie-odrzucanie*) w lepszej
    > werjsi, a modulo jak checsz mieć liczby ujowe.
    >
    > *) masz M liczb losowych, a chesz N, bierzesz największe k, takie, że
    > N*k<M. Losujesz x, jeśli x/k <N x/k jest wynikiem, jeśli nie - repeta.
    >
    > No to czym generować te 8 bitów? Weź najprostszy generator kongruencyjny
    > i bierz 8 bitów w miarę z góry.
    > Co bardzije znane generatorki:
    > (x * 48271) % 2147483647
    > (x * 16807) % 2147483647
    >
    > Modulo 2^31-1. Ciut upierdliwe.
    > Tu możesz sobie znaleść takie, które są mod 2^k (poza RANDU!)
    > https://en.wikipedia.org/wiki/Linear_congruential_ge
    nerator#Parameters_in_common_use
    >
    > Dlaczego taki duży stan, mimo, że chcesz tylko 8 bitów?
    > Bo jeśli stan miałby tylko 8 bitów, generatorek miałby
    > okres co nauwyżej 256. Dla 16 bitów co najwyżęj 65536. Mało.
    > Poza i tak rzadko więcej niż połowa bitów takiej liczby zachowuje
    > się ładnie.
    >
    > Ładną alternatywą jest też xorshift*.
    >
    >
    > BTW. Coś mi mówi, że zadałeś nie to pytanie, które chciałeś.
    > Czy przypadkiem nie istotniejsze jest to, że ma to szybko
    > banglać na 8 lub 16 bitowym urządzeniu? ;->
    > Wtedy to zupełnie inny problem.
    >
    > pzdr
    > bartekltg

    O, dzieki, o coś takiego mi chodziło :D

    AdamK

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: