gdstats currently provides a small set of common distributions all implemented in fast forms usually via inversion techniques:
-
randi_bernoulli(p)
, return 1 or 0 based on probability pexample: Whether a specific die value was rolled or not
-
randi_binomial(p, n)
, return the number of 1s on n many Bernoulli Trials probability p.example: Number of times a specific value is rolled on a die in n many trials
-
randi_geometric(p)
, return the number of Bernoulli Trials with probability p until a result of 1.example: The number of rolls on a die until a specific value shows.
-
randi_poisson(lambda)
, a binomial where p->0 and n->inf but n*p = lambda.example: Number of phone calls in a given amount of time. p is very low and n is very large.
-
randv_histogram(values, probabilities)
, provide a list of return values and probabilities and return a value fitting the distribution.example: Use for distributions of own choosing such as marbles in a bag.
-
randi_pseudo(c)
, mimics the Warcraft3/Dota style of "fair" number generators. Gives the number of actions until an event occurs where upon a failure, the probability increases by c.example: Use to determine the number of attacks until the next critical occurs.
Table of Nominal Probabilities to c Values
The following table gives values of c to approximate a given event's probability of occuring.
Nominal Probability | c | Nominal Probability | c |
---|---|---|---|
5% | 0.00380 | 45% | 0.20155 |
10% | 0.01475 | 50% | 0.24931 |
15% | 0.03222 | 55% | 0.36040 |
20% | 0.05570 | 60% | 0.42265 |
25% | 0.08474 | 65% | 0.48113 |
30% | 0.11895 | 70% | 0.57143 |
40% | 0.15798 |
-
randf_uniform(a, b)
, return a uniformly random value in range a to bexample: Same as rand_range
-
randf_exponential(lambda)
, return a value fitting the exponential distributionexample: Time between independant events which occur at a constant average rate. Memoryless
-
randf_erlang(k, lambda)
, Sum of k many exponentials of 1/lambda.example: The distribution of time between k many incoming telephone calls modelled by a poisson process. k = 1 is the exponential.
-
randf_gaussian()/randf_normal()
, return a value from the normal distribution.example: Useful in modeling realistic scenarious which use the distribution, i.e. Harmonic Oscilator ground state, position of a diffused particle.