-
Data: 2021-08-24 16:20:24
Temat: Re: Jak zrobić test za pomocą PractRand?
Od: "o...@g...com" <o...@g...com> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]wtorek, 24 sierpnia 2021 o 11:46:47 UTC+2 M.M. napisał(a):
> On Tuesday, August 24, 2021 at 1:43:54 AM UTC+2, o...@g...com wrote:
> > To też nie działa:
> >
> > def to_bytes(num, size):
> > x = num if num >= 0 else 256**size + num
> > h = hex(x)[2:].rstrip("L")
> > return binascii.unhexlify("0"*((2*size)-len(h))+h)
> >
> > Wyniki, które otrzymuję są podobne do tego, który podano w przykładzie:
> >
> > \x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00
\x00\x00\x00'
> >
> > Oznacza, to, że prawie na pewno konwertuję dane dobrze. Problem jest nadal z
przekazaniem tego do PractRand. Nie wiem, czy używam poprawnie:
> >
> > sys.stdout.buffer.write(binary)
> >
> > Skoro nie działa, ale z tego co widzę może tam być po prostu zmienna w nawiasach,
więc nie powinno być problemu. Standardowy print zarówno ze znakami nowej linii, jak
i bez nie działa. Nie sądzę, że tutaj też jest nadal jakiś błąd. Wydaje mi się, że
dane są wciąż źle podawane.
> >
> > Jak podaje dane program:
> >
> > #include <cstdio>
> > #include <cstdint>
> >
> > #include <random>
> >
> > int main()
> > {
> > freopen(NULL, "wb", stdout); // Only necessary on Windows, but harmless.
> >
> > std::mt19937 rng(42);
> >
> > while (1) {
> > uint32_t value = rng();
> > fwrite((void*) &value, sizeof(value), 1, stdout);
> > }
> > }
> >
> > https://www.pcg-random.org/posts/how-to-test-with-pr
actrand.html
> >
> > I czym to się różni od mojego sposobu?
> Nie wiem, ale u mnie działa:
>
> cat test.py
> import sys
> import struct
>
> class SimpPRNG:
> x = 0
> A = 79908886691
> B = 8143076871913
> def __init__( self, seed ):
> self.x = seed
> for i in range(1,100):
> self.g()
>
> def g(self):
> self.x = (self.x * self.A + self.B) & (2**128-1)
> return self.x >> 123
>
> r = SimpPRNG( 1 )
> buf = 0
> s = 0
> while True:
> t = r.g()
> for i in range(1,5):
> buf = buf << 1
> buf = buf | (t & 1)
> t = t >> 1
> s = s + 1
> if s == 32:
> sys.stdout.write( struct.pack('I', buf) )
> s = 0
> buf = 0
>
>
> python test.py | ../c/PractRand/RNG_test stdin
> RNG_test using PractRand version 0.94
> RNG = RNG_stdin, seed = unknown
> test set = core, folding = standard(unknown format)
>
> rng=RNG_stdin, seed=unknown
> length= 512 kilobytes (2^19 bytes), time= 2.7 seconds
> no anomalies in 84 test result(s)
>
> rng=RNG_stdin, seed=unknown
> length= 1 megabyte (2^20 bytes), time= 5.8 seconds
> no anomalies in 94 test result(s)
>
> rng=RNG_stdin, seed=unknown
> length= 2 megabytes (2^21 bytes), time= 11.5 seconds
> no anomalies in 109 test result(s)
>
> rng=RNG_stdin, seed=unknown
> length= 4 megabytes (2^22 bytes), time= 22.7 seconds
> no anomalies in 124 test result(s)
>
> rng=RNG_stdin, seed=unknown
> length= 8 megabytes (2^23 bytes), time= 44.5 seconds
> no anomalies in 135 test result(s)
>
> rng=RNG_stdin, seed=unknown
> length= 16 megabytes (2^24 bytes), time= 87.8 seconds
> no anomalies in 151 test result(s)
> ^CTraceback (most recent call last):
> File "test.py", line 30, in <module>
> t = t >> 1
> KeyboardInterrupt
>
> Pozdrawim
U mnie sys.stdout.write(struct.pack('I', buf)) od razu podświetla się jako błąd. Po
uruchomieniu:
TypeError: write() argument must be str, not bytes
Gdy zrobię z argumentu stringa sys.stdout.write(str(struct.pack('I', buf))), to
oczywiście oblewa. Trzeba tam jeszcze coś prawdopodobnie dodać, żeby to write
działało w trybie binarnym.
Następne wpisy z tego wątku
- 24.08.21 17:49 o...@g...com
- 25.08.21 04:15 o...@g...com
- 25.08.21 04:24 o...@g...com
- 27.08.21 00:52 o...@g...com
- 29.08.21 16:29 o...@g...com
- 31.08.21 00:57 o...@g...com
- 31.08.21 02:36 M.M.
- 31.08.21 10:04 o...@g...com
- 23.09.21 02:28 o...@g...com
- 23.09.21 02:55 o...@g...com
- 16.06.23 13:32 o...@g...com
- 16.06.23 14:05 o...@g...com
- 16.06.23 14:07 o...@g...com
- 16.06.23 14:11 o...@g...com
- 21.06.23 05:48 o...@g...com
Najnowsze wątki z tej grupy
- U nas propagują modę na SI, a w Chinach naukowcy SI po kolei umierają w wieku 40-50lat
- C++. Podróż Po Języku - komentarz
- "Wuj dobra rada" z KDAB rozważa: Choosing the Right Programming Language for Your Embedded Linux Device
- Nowa ustawa o ochronie praw autorskich - opis problemu i szkic ustawy
- Alg. kompresji LZW
- Popr. 14. Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- Arch. Prog. Nieuprzywilejowanych w pełnej wer. na nowej s. WWW energokod.pl
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
Najnowsze wątki
- 2025-04-17 Warszawa => Team Lead Data Engineer (obszar Snowflake) <=
- 2025-04-17 Cła Trumpa już w sądzie federalnym USA
- 2025-04-16 Jaki trojfazowy licznik tuya lub podobny?
- 2025-04-16 co ile czasu rysa?
- 2025-04-16 co ile czasu rysa?
- 2025-04-16 cytat: "Za prezydentury Władimira Putina co najmniej 37 dziennikarzy zostało zamordowanych z powodu swojej pracy."
- 2025-04-16 Przyczyny
- 2025-04-16 Re: "Wazelina": Donald Tusk trzęsie giełdą jak mały Donald Trump [do -9%]
- 2025-04-16 Motodziennik #322 Audi Q9, Omoda 3, MG Cyber X - oraz koniec Leapmotor, Citana oraz auto od Amazona
- 2025-04-16 Do sądu trafił pozew zbiorowy przeciw Google'owi - oskarżenie o praktyki monopolistyczne na rynku reklamy internetowej
- 2025-04-16 Francja: "Za mało pracujemy, za dużo wydajemy" - a pierwsi chcieli pracować 4/7 !!!
- 2025-04-16 To już koniec 30letniej firmy Ekolot z Krosna - to kolejna ofiara urzędników
- 2025-04-16 To już koniec 30letniej firmy Ekolot z Krosna - to kolejna ofiara urzędników
- 2025-04-16 Francja: "Za mało pracujemy, za dużo wydajemy" - a pierwsi chcieli pracować 4/7 !!!
- 2025-04-16 Polska na 3 miejscu pod względem inflacji w UE!!!