• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Czy ktoś ma pomysł na przyspieszenie mojego kodu?

VPS Starter Arubacloud
+1 głos
282 wizyt
pytanie zadane 24 maja 2021 w Python przez osobliwy nick Użytkownik (900 p.)

Cześć. Interesuje mnie zaprogramowanie generatora liczb losowych PCG o nazwie XSL-RR-RR:

https://en.wikipedia.org/wiki/Permuted_congruential_generator

Napisałem kod, który z tego co sprawdzałem działa poprawnie:

def PCG(x):
    count1 = x >> 122
    x1 = (x ^ (x >> 64)) % (1 << 64)
    low64 = (((1 << (64 - count1)) * ((x1 % (1 << count1)) + (1 << count1))) ^ (1 << 64)) + (x1 >> count1)
    x2 = (x >> 64) % (1 << 64)
    count2 = low64 & 63
    high64 = (((1 << (64 - count2)) * ((x2 % (1 << count2)) + (1 << count2))) ^ (1 << 64)) + (x2 >> count2)
    x = (high64 << 64) | low64
    return x

Pytanie, czy da się to zrobić szybciej? Nie jestem zbyt dobrym programistą, napisałem swoją funkcję do rotacji bitowej, a może istnieje jakaś szybka w Pythonie? Czy to jest przyzwoicie napisany kod, czy może można to napisać prościej i szybciej? Zależy mi przede wszystkim na przyspieszeniu tego. Myślę, że ta ręcznie napisana rotacja bitowa (używana do obliczenia low64 i high64) zajmuje najwięcej czasu, gdyby istniała jakaś funkcja wbudowana w Pythonie do rotacji, można byłoby to uprościć.

1 odpowiedź

0 głosów
odpowiedź 24 maja 2021 przez Benek Szeryf (90,690 p.)

Ja bym wziął gotowca i nie wynajdował koła na nowo. Moduł numpy jest zoptymalizowany, jeśli chodzi wydajność obliczeń, więc raczej nie uda Ci się zaimplementować szybszej wersji.

komentarz 24 maja 2021 przez osobliwy nick Użytkownik (900 p.)
Ale gdzie można ten generator znaleźć w numpy?
komentarz 24 maja 2021 przez Benek Szeryf (90,690 p.)
Kliknij w link w moim poście.
komentarz 24 maja 2021 przez osobliwy nick Użytkownik (900 p.)

Nie o ten generator mi chodzi. Chcę mieć generator, który przekształca 128 bitów w 128 bitów, jak wersja XSL-RR-RR:

https://en.wikipedia.org/wiki/Permuted_congruential_generator

Znalazłem szybszy bitowy rotr na Pythonie:

https://www.geeksforgeeks.org/rotate-bits-of-an-integer/

Przyspieszyło to kod o 25%. Więcej chyba nic się nie da zrobić.

komentarz 24 maja 2021 przez mokrowski Mędrzec (155,460 p.)
Hmm.. a profilowałeś ten kod linia po linii czy "tak sobie strzelasz"?
komentarz 25 maja 2021 przez osobliwy nick Użytkownik (900 p.)

Raczej linia po linii. Tyle ile mogłem przyspieszyć, to przyspieszyłem. Mam to obecnie:

def PCG(x):
    count1 = x >> 122
    x1 = (x ^ (x >> 64)) & 18446744073709551615
    low64 = (x1 >> count1)|(x1 << (64 - count1)) & 18446744073709551615
    x2 = (x >> 64) & 18446744073709551615
    count2 = low64 & 63
    high64 = (x2 >> count2)|(x2 << (64 - count2)) & 18446744073709551615
    x = (high64 << 64) | low64
    return x

Liczyłem przede wszystkim na jakąś lepszą bitową rotację, myślałem, że może coś jest wbudowanego w Pythonie. Jeśli nie ma, to wiele więcej pewnie nie da się tu zrobić.

komentarz 19 czerwca 2021 przez reaktywny Nałogowiec (40,650 p.)
Jak zależy Tobie na wydajności, przyspieszeniu kodu, to zainteresuj się raczej innym językiem, jak Rust, Go czy C++. Python nie jest demonem szybkości.

Podobne pytania

0 głosów
1 odpowiedź 109 wizyt
pytanie zadane 20 stycznia 2023 w JavaScript przez pazo1313 Nowicjusz (140 p.)
0 głosów
0 odpowiedzi 862 wizyt
pytanie zadane 2 lipca 2021 w Python przez Nalesniolek Nowicjusz (180 p.)
–4 głosów
0 odpowiedzi 799 wizyt
pytanie zadane 12 czerwca 2021 w Python przez Nalesniolek Nowicjusz (180 p.)

92,454 zapytań

141,263 odpowiedzi

319,099 komentarzy

61,854 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...