summaryrefslogtreecommitdiffstats
path: root/core/math/pcg.cpp
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2017-01-16 20:06:54 +0100
committerGitHub <noreply@github.com>2017-01-16 20:06:54 +0100
commitbf05dab74f5c0fc19663dce05b462be2aba581a5 (patch)
tree837c11d04a76437e69d43744487cedf1bb5ec1f0 /core/math/pcg.cpp
parent0a9aee6b1d20f29e0e7a3bc8990f807144b62f74 (diff)
parent4c9004671af455a03acb4e2750b12d62b2b3c917 (diff)
downloadredot-engine-bf05dab74f5c0fc19663dce05b462be2aba581a5.tar.gz
Merge pull request #7532 from tagcup/pcg_prng
Replace the existing PRNG (Xorshift31) with (minimal) PCG-32.
Diffstat (limited to 'core/math/pcg.cpp')
-rw-r--r--core/math/pcg.cpp15
1 files changed, 15 insertions, 0 deletions
diff --git a/core/math/pcg.cpp b/core/math/pcg.cpp
new file mode 100644
index 0000000000..eac3b36d36
--- /dev/null
+++ b/core/math/pcg.cpp
@@ -0,0 +1,15 @@
+// *Really* minimal PCG32 code / (c) 2014 M.E. O'Neill / pcg-random.org
+// Licensed under Apache License 2.0 (NO WARRANTY, etc. see website)
+
+#include "pcg.h"
+
+uint32_t pcg32_random_r(pcg32_random_t* rng)
+{
+ uint64_t oldstate = rng->state;
+ // Advance internal state
+ rng->state = oldstate * 6364136223846793005ULL + (rng->inc|1);
+ // Calculate output function (XSH RR), uses old state for max ILP
+ uint32_t xorshifted = ((oldstate >> 18u) ^ oldstate) >> 27u;
+ uint32_t rot = oldstate >> 59u;
+ return (xorshifted >> rot) | (xorshifted << ((-rot) & 31));
+}