Slide 1

Slide 1 text

lol im so random! @markwunsch

Slide 2

Slide 2 text

Math.random()

Slide 3

Slide 3 text

https://xkcd.com/221/

Slide 4

Slide 4 text

George Raft
 Scarface, 1932

Slide 5

Slide 5 text

http://www.rand.org/pubs/monograph_reports/MR1418.html

Slide 6

Slide 6 text

No content

Slide 7

Slide 7 text

John von Neumann Various Techniques Used in Connection With Random Digits “Any one who considers arithmetical methods of producing random digits is, of course, in a state of sin. For, as has been pointed out several times, there is no such thing as a random number — there are only methods to produce random numbers, and a strict arithmetic procedure of course is not such a method.”

Slide 8

Slide 8 text

Pseudorandom Number Generator (PRNG)

Slide 9

Slide 9 text

Animate[ListPlot[BlockRandom[ SeedRandom[seed, Method ! “MersenneTwister”]; RandomReal[1, 10000]]], {seed, 1, 100, 1}]

Slide 10

Slide 10 text

(rand)

Slide 11

Slide 11 text

(defn rand “Returns a random floating point number between 0 (inclusive) and n (default 1) (exclusive).” ([] (. Math (random))) ([n] (* n (rand)))) clojure.core

Slide 12

Slide 12 text

public static double random() Returns a double value with a positive sign, greater than or equal to 0.0 and less than 1.0. Returned values are chosen pseudorandomly with (approximately) uniform distribution from that range. When this method is first called, it creates a single new pseudorandom-number generator, exactly as if by the expression new java.util.Random() This new pseudorandom-number generator is used thereafter for all calls to this method and is used nowhere else. java.lang.Math

Slide 13

Slide 13 text

Mary Rose Cook A practical introduction to functional programming https://maryrosecook.com/blog/post/a-practical-introduction-to-functional-programming “Functional code is characterized by one thing: the absence of side effects. It doesn’t rely on data outside the current function, and it doesn’t change data that exists outside the current function.”

Slide 14

Slide 14 text

random :: (RandomGen g, Random a) => g -> (a, g)

Slide 15

Slide 15 text

> import System.Random > random (mkStdGen 42) :: (Int, StdGen) (-3900021226967401631,2060101257 2103410263)

Slide 16

Slide 16 text

Tell’s Knabe From the Schiller Gallery, 1859

Slide 17

Slide 17 text

Property-Based Testing QuickCheck & its scions
 http://www.cse.chalmers.se/~rjmh/QuickCheck/ Gary Fredericks — Purely Random
 from Clojure/West 2015
 https://www.youtube.com/watch?v=u0t-6lUvXHo

Slide 18

Slide 18 text

The
 Mersenne 
 Twister

Slide 19

Slide 19 text

219937-1

Slide 20

Slide 20 text

219937-1 the period

Slide 21

Slide 21 text

“PRNGs are currently implemented as a modified Mersenne Twister with a period of 2**19937-1” 
 http://ruby-doc.org/core-2.2.2/Random.html “Python uses the Mersenne Twister as the core generator. It produces 53-bit precision floats and has a period of 2**19937-1.” 
 https://docs.python.org/3/library/random.html “Random number generation in Julia uses the Mersenne Twister library via MersenneTwister objects.” 
 http://docs.julialang.org/en/release-0.4/stdlib/numbers#random-numbers

Slide 22

Slide 22 text

TIFU by using Math.random()
 https://medium.com/@betable/tifu-by-using-math-random-f1c308c4fd9d There’s Math.random(), and then there’s Math.random()
 http://v8project.blogspot.com/2015/12/theres-mathrandom-and-then-theres.html

Slide 23

Slide 23 text

http://stat.fsu.edu/pub/diehard/

Slide 24

Slide 24 text

cf. TestU01
 http://simul.iro.umontreal.ca/testu01/tu01.html dieharder
 https://www.phy.duke.edu/~rgb/General/dieharder.php

Slide 25

Slide 25 text

“The Mersenne Twister … is completely unsuitable for cryptographic purposes.” https://docs.python.org/3/library/random.html

Slide 26

Slide 26 text

“Mersenne Twister is not cryptographically secure.” http://www.math.sci.hiroshima-u.ac.jp/~m-mat/MT/emt.html

Slide 27

Slide 27 text

cryptographically secure

Slide 28

Slide 28 text

Cryptographically Secure Pseudorandom Number Generator (CSPRNG)

Slide 29

Slide 29 text

Achillea millefolium Köhler’s Medizinal-Pflanzen, 1887

Slide 30

Slide 30 text

Yarrow Bruce Schneier and John Kelsey https://www.schneier.com/cryptography/yarrow/

Slide 31

Slide 31 text

The
 Entropy Device

Slide 32

Slide 32 text

/dev/random man 4 random

Slide 33

Slide 33 text

function lookbusy() { cat /dev/urandom | od -An; }

Slide 34

Slide 34 text

101262 024567 163231 107002 047500 141110 112373 100363 141204 177347 033443 153461 150705 005261 075113 041430 057531 072242 066770 001374 110052 004716 160523 064356 127045 113127 072433 031735 146001 040647 105205 104464 010021 174056 072621 047566 041173 074062 063702 142662 012703 064566 004331 124752 002455 051065 171176 014151 024462 007765 036437 057554 111072 070733 014741 102411 117460 057656 073073 127016 124774 015743 013005 153673 171613 152444 166643 141710 150477 054502 150175 055630 045701 024774 074654 021546 164660 127465 075035 027547 032112 110437 170726 052324 112261 011234 163423 053520 042643 123732 016343 143734 003171 047752 161731 104761 106311 014712 162121 020272 150470 046124 156427 104625 172660 135352 034330 164771 076535 031660 146333 030455 041511 072500 017333 102715 074317 065237 075131 054032 001217 044045 046220 073062 021534 060345 065446 034237 130226 034734 061603 022274 133362 066144 103771 055055 073664 162725 013732 123243 144705 061310 106532 161743 002362 002610 111577 071633 124030 024525 146333 101235 160420 030052 002761 175720 125564 017030 007503 120511 124152 032335 041561 057646 177455 030002 010667 074013

Slide 35

Slide 35 text

$ expr $RANDOM % 6 + 1 $ awk ‘BEGIN { srand(); print 1 + int(rand() * 6); }’ $ cat /dev/urandom | hexdump -v -e '/1 "%u\n"' | awk '{ split("0,2,4,5,7,9,11,12",a,","); for (i = 0; i < 1; i+= 0.0001) printf("%08X\n", 100*sin(1382*exp((a[$1 % 8]/12)*log(2))*i)) }' | xxd -r -p | aplay -c 2 -f S32_LE -r 16000 http://blog.robertelder.org/bash-one-liner-compose-music/

Slide 36

Slide 36 text

10 PRINT CHR$(205.5+RND(1)); : GOTO 10 http://10print.org

Slide 37

Slide 37 text

Allegory of Chance Frans Francken the Younger, 1627

Slide 38

Slide 38 text

^D