0
$\begingroup$

As programmer i find many solutions that generates pseudo-random values and surfaces, i'm always wondering how they can do that from a mathematical viewpoint.

For example i can generate a terrain from algorithms, i can input some parameters like the bottom and maximum height of the terrain and a seed to get the terrain that i want; i can't understand that from a mathematical viewpoint, if someone would explain this to me it would be great.

  • 1
    what is a seed?2012-09-12
  • 0
    the number that you can use to rebuild and obtain the same placement in space, for example if say that the seed is 459593 and input this number you should be able to generate the same map as everybody else that are using this number. It's a "mathematical root" in some ways that parametrize everything.2012-09-12
  • 0
    what is a terrain?2012-09-12

1 Answers 1

1

A pseudorandom number generator (PRNG) is a function that takes a seed and outputs a long sequence of seemingly random numbers. The algorithms you mention use a large quantity of random numbers to run. Using a PRNG, instead of specifying all of them, it is enough to specify a seed. In other words, a PRNG is a way of parametrizing a large number of random-looking sequences of numbers.

  • 0
    ok, so the "property" is that 1 function do the work for N values ?2012-09-12
  • 0
    Yes; you *iterate* that one function as many times as you need, to generate as many values as you need. Starting with the seed $x_0$, and a function $f$, you produce $x_1,x_2,\dots$ via the formula $x_{n+1}=f(x_n)$.2012-09-13
  • 0
    @Gerry, this is not an accurate description of a PRNG: it has an internal state, and you only get to see part of it. And you have a seeding function. So what happens is that you have a seed function $i$, a transition function $m$, and an output function $o$, and the outputs, under seed $s$, are $(o \circ m^{(t)} \circ i)(s)$, for $t \in \mathbb{N}$.2012-09-14
  • 0
    I was thinking of the kind of PRNG based on $x_{n+1}=ax_n+b$ reduced modulo $m$; you plug in an $x_0$, and it churns out $x_1,x_2,\dots$. Anyway, what's important is whether OP has an answer he/she can understand and use.2012-09-14
  • 0
    For anyone who's reading this, don't use the PRNG $x_{n+1} = ax_n + b \pmod{m}$, your programs might produce the wrong results!2012-09-14