-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpseudoRandom.php
130 lines (121 loc) · 4.18 KB
/
pseudoRandom.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
<?php
/*
* Universal Cross-Platform Multi-Language Pseudo Random Number Generator (pseudoRandom) v0.9
*
* A Set of libraries for Pseudo-Random Number Generation across environments
*
* X-PRNG is an advanced set of libraries designed to provide developers with tools
* for generating pseudo-random numbers across various computing environments. It
* supports a wide range of applications, from statistical analysis and data simulation
* to secure cryptographic functions. These libraries offer a simple yet powerful
* interface for incorporating high-quality, pseudo-random numbers into applications
* written in different programming languages, ensuring consistency and reliability
* across platforms.
*
* Copyright (C) 2024 under GPL v. 2 license
* 18 March 2024
*
* @author Luca Soltoggio
* https://www.lucasoltoggio.it
* https://github.com/toggio/X-PRNG
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
/*
*
* PseudoRandom Number Generator PHP Class
*
* This class implements a pseudo-random number generator (PRNG) using a linear
* congruential generator (LCG) algorithm.
*
*/
class pseudoRandom {
// Static variables to hold the seed, coefficients, and counter for the LCG algorithm.
private static $savedRSeed;
private static $RSeed = 0;
private static $a = 1664525;
private static $c = 1013904223;
private static $m = 4294967296; // 2^32
private static $counter = 0;
/**
* Constructor to initialize the PRNG with an optional seed.
* If a string is provided as a seed, it uses crc32 to convert it into an integer.
* If no seed is provided, it uses the current time.
*
* @param mixed $seed Optional seed for the PRNG.
*/
public function __construct($seed = NULL) {
if (is_string($seed)) {
self::$RSeed=crc32($seed);
} elseif ($seed != NULL) {
self::$RSeed = abs(intval($seed));
} else {
self::$RSeed = time();
}
self::$counter = 0;
self::$c = 1013904223;
}
/**
* Function to re-seed the PRNG. This can be used to reset the generator's state.
*
* @param mixed $seed Optional new seed for the PRNG.
*/
public function reSeed($seed = NULL) {
self::__construct($seed);
}
/**
* Saves the current state of the PRNG for later restoration. This is useful
* for applications that need to backtrack or repeat a sequence of generated numbers.
*/
public function saveState() {
self::$savedRSeed = self::$RSeed;
}
/**
* Restores the PRNG to a previously saved state. This allows the sequence of
* generated numbers to be replicated by rolling back to an earlier state.
*/
public function restoreState() {
if (self::$savedRSeed !== null) {
self::$RSeed = self::$savedRSeed;
}
}
/**
* Generates a pseudo-random integer within a specified range.
*
* @param int $min The lower bound of the range (inclusive).
* @param int $max The upper bound of the range (inclusive).
* @return int A pseudo-random integer between $min and $max.
*/
public function randInt($min = 0, $max = 255) {
self::$c = crc32(self::$counter. self::$RSeed . self::$counter);
self::$RSeed = (self::$RSeed * self::$a + self::$c) % self::$m;
self::$counter += 1;
return (int)floor((self::$RSeed / self::$m) * ($max - $min + 1) + $min);
}
/**
* Generates a string of pseudo-random bytes of a specified length.
*
* @param int $len The length of the byte string.
* @param bool $readable If true, ensures the generated bytes are in the readable ASCII range.
* @return string A string or an array of pseudo-random bytes.
*/
public function randBytes($len = 1, $readable = false) {
$char = '';
for ($i=0; $i<$len; $i++) {
if ($readable) $n = $this->randInt(32,126); else $n = $this->randInt();
$char.= chr($n);
}
return $char;
}
}
?>