Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/droxpopuli/gdstats
gdstats provides common statistical distributions in Godot 3.0
https://github.com/droxpopuli/gdstats
Last synced: 6 days ago
JSON representation
gdstats provides common statistical distributions in Godot 3.0
- Host: GitHub
- URL: https://github.com/droxpopuli/gdstats
- Owner: droxpopuli
- License: mit
- Created: 2018-07-17T22:15:07.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2018-07-19T03:50:16.000Z (over 6 years ago)
- Last Synced: 2024-08-02T06:17:41.222Z (3 months ago)
- Language: GDScript
- Size: 15.6 KB
- Stars: 36
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-godot - gdstats - A library of pseudorandom number generators for common statistical distributions. (Plugins and scripts / 3D)
- awesome-godot-3 - gdstats - A library of pseudorandom number generators for common statistical distributions. (Plugins and scripts / 3D)
- awesome-godot-3 - gdstats - A library of pseudorandom number generators for common statistical distributions. (Plugins and scripts / 3D)
README
# gdstats
gdstats currently provides a small set of common distributions all implemented in fast forms usually via inversion techniques:
![Image of Example Project](https://i.imgur.com/39pPFmh.png)
Discrete (integers)
--------- `randi_bernoulli(p)`, return 1 or 0 based on probability p
`example: 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 | | |Continuous (floats)
----------- `randf_uniform(a, b)`, return a uniformly random value in range a to b
`example: Same as rand_range`
- `randf_exponential(lambda)`, return a value fitting the exponential distribution
`example: 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.`