Dutch PHP Conference 2025 - Call For Papers

Random\Engine\Mt19937::__construct

(PHP 8 >= 8.2.0)

Random\Engine\Mt19937::__constructConstructs a new Mt19937 engine

Опис

public Random\Engine\Mt19937::__construct(?int $seed = null, int $mode = MT_RAND_MT19937)

Застереження

Оскільки рушій Mt19937 (“Mersenne Twister”) приймає тільки одне 32-бітне ціле число як сід, кількість можливих випадкових послідовностей обмежена до лише 232 (тобто 4ʼ294ʼ967ʼ296), не зважаючи на величезний період Mt19937 у 219937-1.

Якщо покладатися на неявний чи явний випадковий сід, дуплікати зʼявляться набагато швидше. Однакові сіди очікуються з імовірністю у 50% менше ніж через 80ʼ000 випадково згенерованих сідів, відповідно до парадоксу днів народжень. Імовірність у 10% настає після 30ʼ000 сідів, згенерованих випадковим чином.

Через це Mt19937 непридатний для застосунків, де повторювані послідовності не повинні виникати з більш ніж незначною ймовірністю. Якщо потрібне відтворюване сідування, обидва рушії Random\Engine\Xoshiro256StarStar і Random\Engine\PcgOneseq128XslRr64 підтримують набагато довші сіди, які навряд випадково співпадуть. Якщо відтворюваність не потрібна, то для цього є рушій Random\Engine\Secure, який надає криптографічно безпечну випадковість.

Увага

Наразі ця функція не документована. Доступний лише список її параметрів.

Параметри

seed

Fills the state with values generated with a linear congruential generator that was seeded with seed interpreted as an unsigned 32 bit integer.

If seed is omitted or null, a random unsigned 32 bit integer will be used.

mode

Use one of the following constants to specify the implementation of the algorithm to use.

Увага

Цей функціонал ЗАСТАРІВ, починаючи з PHP 8.3.0. Вкрай не рекомендується на нього покладатися.

Приклади

Приклад #1 Random\Engine\Mt19937::__construct() example

<?php
// Uses a random 32 Bit seed.
$e = new \Random\Engine\Mt19937();

$r = new \Random\Randomizer($e);
?>
add a note

User Contributed Notes

There are no user contributed notes for this page.
To Top