fastmath.random
Various random and noise functions.
Namespace defines various random number generators (RNGs), different types of random functions, sequence generators and noise functions.
RNGs
You can use a selection of various RNGs defined in Apache Commons Math library.
Currently supported RNGs:
:jdk
- default java.util.Random:mersenne
- MersenneTwister:isaac
- ISAAC:well512a
,:well1024a
,:well19937a
,:well19937c
,:well44497a
,:well44497b
- several WELL variants
To create your RNG use rng multimethod. Pass RNG name and (optional) seed. Returned RNG is equipped with RNGProto protocol with methods: irandom, lrandom, frandom drandom, grandom, brandom which return random primitive value with given RNG.
(let [rng (rng :isaac 1337)]
(irandom rng))
For conveniency default RNG (:jdk
) with following functions are created: irand, lrand, frand, drand, grand, brand.
Each prefix denotes returned type:
- i - int
- l - long
- f - float
- d - double
- g - gaussian (double)
- b - boolean
Check individual function for parameters description.
Random Vector Sequences
Couple of functions to generate sequences of numbers or vectors.
To create generator call sequence-generator with generator name and vector size. Following generators are available:
:halton
- Halton low-discrepancy sequence; range 0,1:sobol
- Sobol low-discrepancy sequence; range 0,1:r2
- R2 low-discrepancy sequence; range 0,1, moreā¦:sphere
- uniformly random distributed on unit sphere:ball
- uniformly random distributed from unit ball:gaussian
- gaussian distributed (mean=0, stddev=1):default
- uniformly random; range:0,1
:halton
, :sobol
and :r2
can be also randomly jittered according to this article. Call jittered-sequence-generator.
After creation you get lazy sequence
Noise
List of continuous noise functions (1d, 2d and 3d):
:value
- value noise:gradient
- gradient noise (improved Ken Perlin version):simplex
- simplex noise
First two (:value
and :gradient
) can use 4 different interpolation types: :none
, :linear
, :hermite
(cubic) and :quintic
.
All can be combined in following variants:
- Noise - pure noise value, create with single-noise
- FBM - fractal brownian motion, create with fbm-noise
- Billow - billow noise, billow-noise
- RidgedMulti - ridged multi, ridgedmulti-noise
Noise creation requires detailed configuration which is simple map of following keys:
:seed
- seed as integer:noise-type
- type of noise::value
,:gradient
(default),:simplex
:interpolation
- type of interpolation (for value and gradient)::none
,:linear
,:hermite
(default) or:quintic
:octaves
- number of octaves for combined noise (like FBM), default: 6:lacunarity
- scaling factor for combined noise, default: 2.00:gain
- amplitude scaling factor for combined noise, default: 0.5:normalize?
- should be normalized to[0,1]
range (true, default) or to[-1,1]
range (false)
For usage convenience 3 ready to use functions are prepared. Returning value from [0,1]
range:
- noise - Perlin Noise (gradient noise, 6 octaves, quintic interpolation)
- vnoise - Value Noise (as in Processing, 6 octaves, hermite interpolation)
- simplex - Simplex Noise (6 octaves)
For random noise generation you can use random-noise-cfg and random-noise-fn. Both can be feed with configuration. Additional configuration:
:generator
can be set to one of the noise variants, defaults to:fbm
:warp-scale
- 0.0 - do not warp, >0.0 warp:warp-depth
- depth for warp (default 1.0, if warp-scale is positive)
Discrete Noise
discrete-noise is a 1d or 2d hash function for given integers. Returns double from [0,1]
range.
Distribution
Various real and integer distributions. See DistributionProto and RNGProto for functions.
To create distribution call distribution multimethod with name as a keyword and map as parameters.
Categories
Other vars: ->seq ball-random billow-noise brand brandom ccdf cdf continuous? covariance default-normal default-rng dimensions discrete-noise distribution distribution-id distribution-parameters distribution? distributions-list drand drandom fbm-noise flip flip-rng flipb flipb-rng frand frandom grand grandom icdf integrate-pdf irand irandom jittered-sequence-generator likelihood log-likelihood lower-bound lpdf lrand lrandom mean means noise noise-generators noise-interpolations noise-types observe observe1 pdf probability random-noise-cfg random-noise-fn randval randval-rng ridgedmulti-noise rng rngs-list roll-a-dice roll-a-dice-rng sample sequence-generator sequence-generators-list set-seed set-seed! simplex single-noise source-object synced-rng upper-bound variance vnoise warp-noise-fn
->seq
(->seq)
(->seq rng)
(->seq rng n)
(->seq rng n sampling-method)
Returns lazy sequence of random samples (can be limited to optional n
values).
Additionally one of the sampling methods can be provided, ie: :uniform
, :antithetic
, :systematic
and :stratified
.
Examples
Sequence of random values from distribution
(->seq (distribution :gamma) 5)
;;=> (4.1687630473847435
;;=> 0.11489652782773863
;;=> 3.5038148440291073
;;=> 3.6810345721073534
;;=> 1.6948726884788454)
(->seq (distribution :gamma) 5 :stratified)
;;=> (1.600601368607516
;;=> 2.7030326250022294
;;=> 3.9802593653442395
;;=> 5.874946153835131
;;=> 13.600897944977005)
(->seq default-rng 5 :systematic)
;;=> (0.009986363810732058
;;=> 0.2099863638107321
;;=> 0.4099863638107321
;;=> 0.6099863638107321
;;=> 0.8099863638107321)
billow-noise
(billow-noise)
(billow-noise cfg__22233__auto__)
Create billow-noise function with optional configuration.
Examples
Usage
(let [n (billow-noise {:seed 12345, :interpolation :none})]
(n 0.5 1.1 -1.3))
;;=> 0.16031746031746036
2d noise
data:image/s3,"s3://crabby-images/e9502/e95021201e31741536cb6a2349f627e1c4dd8b3c" alt=""
brand
Random boolean with default RNG.
Returns true or false with equal probability. You can set p
probability for true
Examples
Usage
(brand)
;;=> true
(brand 0.1)
;;=> false
Count number of
true
values with probability 0.15
(count (filter true? (repeatedly 100000 (fn* [] (brand 0.15)))))
;;=> 15085
brandom
(brandom rng)
(brandom rng p)
Random boolean with provided RNG
Examples
boolean
(rngproto-snippet brandom ...)
;;=> false
cdf
(cdf d v)
(cdf d v1 v2)
Cumulative probability.
Examples
Usage
(cdf (distribution :gamma) 1)
;;=> 0.09020401043104985
(cdf (distribution :gamma) 1 4)
;;=> 0.5037901398591113
continuous?
(continuous? d)
Does distribution support continuous domain?
Examples
Usage
(continuous? (distribution :gamma))
;;=> true
(continuous? (distribution :pascal))
;;=> false
;; Test: ok.
covariance
(covariance d)
Distribution covariance matrix (for multivariate distributions)
Examples
Usage
(covariance (distribution :multi-normal))
;;=> ((1.0 0.0) (0.0 1.0))
(covariance (distribution :dirichlet {:alpha [2 2]}))
;;=> [[0.05 -0.05] [-0.05 0.05]]
;; Test: ok.
default-normal
Default normal distribution (u=0.0, sigma=1.0).
Examples
Usage
(sample default-normal)
;;=> 1.3545645038826972
(set-seed! default-normal 1234)
;;=> org.apache.commons.math3.distribution.NormalDistribution@4f0ac32c
(sample default-normal)
;;=> 0.14115907833078006
(irandom default-normal)
;;=> 0
(mean default-normal)
;;=> 0.0
(variance default-normal)
;;=> 1.0
default-rng
Default RNG - JDK
Examples
Usage
(set-seed! default-rng 111)
;;=> org.apache.commons.math3.random.JDKRandomGenerator@75f84e75
(irandom default-rng)
;;=> -1196652709
(set-seed! default-rng 999)
;;=> org.apache.commons.math3.random.JDKRandomGenerator@75f84e75
(irandom default-rng)
;;=> -1242822577
(set-seed! default-rng 111)
;;=> org.apache.commons.math3.random.JDKRandomGenerator@75f84e75
(irandom default-rng)
;;=> -1196652709
dimensions
(dimensions d)
Distribution dimensionality
Examples
Usage
(dimensions (distribution :gamma))
;;=> 1
(dimensions (distribution :dirichlet {:alpha (repeat 30 2.0)}))
;;=> 30
;; Test: ok.
discrete-noise
(discrete-noise X Y)
(discrete-noise X)
Examples
Example calls
(discrete-noise 123 444)
;;=> 0.8660251823561383
(discrete-noise 123 444)
;;=> 0.8660251823561383
(discrete-noise 123 445)
;;=> 0.4702831345937602
(discrete-noise 123)
;;=> 0.28831296287864117
Draw noise for 0-180 range.
data:image/s3,"s3://crabby-images/7861b/7861bf9c2b2de2e4a7dbae7b397584ace16c9061" alt=""
distribution
multimethod
Create distribution object.
- First parameter is distribution as a
:key
. - Second parameter is a map with configuration.
All distributions accept rng
under :rng
key (default: default-rng) and some of them accept inverse-cumm-accuracy
(default set to 1e-9
).
Examples
Usage
(distribution :beta)
;;=> org.apache.commons.math3.distribution.BetaDistribution@5e2a0361
(distribution :beta {:alpha 1.0, :beta 1.0})
;;=> org.apache.commons.math3.distribution.BetaDistribution@10fa8f92
All parameters
(into (sorted-map)
(map (fn* [p1__36077#]
(vector p1__36077#
(sort (distribution-parameters (distribution
p1__36077#)))))
(keys (methods distribution))))
;;=> {:anderson-darling ({:n 1.0}),
;;=> :bb (:bd :mu :sigma),
;;=> :bernoulli (:p :trials),
;;=> :beta (:alpha :beta),
;;=> :binomial (:p :trials),
;;=> :categorical-distribution (:data :probabilities),
;;=> :cauchy (:median :scale),
;;=> :chi ({:nu 1.0}),
;;=> :chi-squared (:degrees-of-freedom),
;;=> :chi-squared-noncentral ({:lambda 1.0, :nu 1.0}),
;;=> :continuous-distribution (:bandwidth :data :kde :steps),
;;=> :cramer-von-mises ({:n 1.0}),
;;=> :dirichlet (:alpha),
;;=> :empirical (:bin-count :data),
;;=> :enumerated-int (:data :probabilities),
;;=> :enumerated-real (:data :probabilities),
;;=> :erlang ({:k 1, :lambda 1}),
;;=> :exgaus (:mu :nu :sigma),
;;=> :exponential (:mean),
;;=> :f (:denominator-degrees-of-freedom :numerator-degrees-of-freedom),
;;=> :fatigue-life ({:beta 1.0, :gamma 1.0, :mu 0.0}),
;;=> :fishers-noncentral-hypergeometric (:n :nf :ns :omega),
;;=> :folded-normal ({:mu 0.0, :sigma 1.0}),
;;=> :frechet ({:alpha 1.0, :beta 1.0, :delta 0.0}),
;;=> :gamma (:scale :shape),
;;=> :geometric (:p),
;;=> :gumbel (:beta :mu),
;;=> :half-cauchy (:scale),
;;=> :half-normal (:sigma),
;;=> :hyperbolic-secant ({:mu 0.0, :sigma 1.0}),
;;=> :hypergeometric (:number-of-successes :population-size :sample-size),
;;=> :hypoexponential (:lambdas),
;;=> :hypoexponential-equal ({:h 1.0, :k 1.0, :n 1.0}),
;;=> :integer-discrete-distribution (:data :probabilities),
;;=> :inverse-gamma ({:alpha 2.0, :beta 1.0}),
;;=> :inverse-gaussian ({:lambda 1.0, :mu 1.0}),
;;=> :johnson-sb ({:delta 1.0, :gamma 0.0, :lambda 1.0, :xi 0.0}),
;;=> :johnson-sl ({:delta 1.0, :gamma 0.0, :lambda 1.0, :xi 0.0}),
;;=> :johnson-su ({:delta 1.0, :gamma 0.0, :lambda 1.0, :xi 0.0}),
;;=> :kde (:bandwidth :data :kde :steps),
;;=> :kolmogorov (),
;;=> :kolmogorov-smirnov ({:n 1.0}),
;;=> :kolmogorov-smirnov+ ({:n 1.0}),
;;=> :laplace (:beta :mu),
;;=> :levy (:c :mu),
;;=> :log-logistic ({:alpha 3.0, :beta 1.0}),
;;=> :log-normal (:scale :shape),
;;=> :logarithmic (:theta),
;;=> :logistic (:mu :s),
;;=> :mixture (:distrs :weights),
;;=> :multi-normal (:covariances :means),
;;=> :multinomial (:n :ps),
;;=> :nakagami (:mu :omega),
;;=> :nbi (:mu :sigma),
;;=> :negative-binomial (:p :r),
;;=> :normal (:mu :sd),
;;=> :normal-inverse-gaussian
;;=> ({:alpha 1.0, :beta 0.0, :delta 1.0, :mu 0.0}),
;;=> :pareto (:scale :shape),
;;=> :pascal (:p :r),
;;=> :pearson-6 ({:alpha1 1.0, :alpha2 1.0, :beta 1.0}),
;;=> :poisson (:p),
;;=> :power ({:a 0.0, :b 1.0, :c 2.0}),
;;=> :rayleigh ({:a 0.0, :beta 1.0}),
;;=> :real-discrete-distribution (:data :probabilities),
;;=> :reciprocal-sqrt (:a),
;;=> :t (:degrees-of-freedom),
;;=> :triangular (:a :b :c),
;;=> :truncated (:distr :left :right),
;;=> :uniform-int (:lower :upper),
;;=> :uniform-real (:lower :upper),
;;=> :watson-g ({:n 2.0}),
;;=> :watson-u ({:n 2.0}),
;;=> :weibull (:alpha :beta),
;;=> :zabb (:bd :mu :nu :sigma),
;;=> :zabi (:bd :mu :sigma),
;;=> :zaga (:lower-tail? :mu :nu :sigma),
;;=> :zanbi (:mu :nu :sigma),
;;=> :zibb (:bd :mu :nu :sigma),
;;=> :zibi (:bd :mu :sigma),
;;=> :zinbi (:mu :nu :sigma),
;;=> :zip (:mu :sigma),
;;=> :zip2 (:mu :sigma),
;;=> :zipf (:exponent :number-of-elements)}
PDFs of anderson-darling
data:image/s3,"s3://crabby-images/913c7/913c718b64d41af8f59e7fb620e45558cb5e1b0c" alt=""
CDFs of anderson-darling
data:image/s3,"s3://crabby-images/be71e/be71ef4fc20b6c96cf2ef55232d91e018580294c" alt=""
ICDFs of anderson-darling
data:image/s3,"s3://crabby-images/3c5d2/3c5d26d6a9d87b7576f395efce33fd0053ff7cca" alt=""
PDFs of bb
data:image/s3,"s3://crabby-images/2494b/2494bf0ff84ca23ce15744283b81bf7d5eb46638" alt=""
CDFs of bb
data:image/s3,"s3://crabby-images/4cdce/4cdce24cf83eb3baaead1d6104e0a9ed7038ece8" alt=""
ICDFs of bb
data:image/s3,"s3://crabby-images/29230/292302437ab3b923a084053701251b6589556d23" alt=""
PDFs of bernoulli
data:image/s3,"s3://crabby-images/a2aa1/a2aa133e9c472f3500dc89ee8c1fcefbb058a3e6" alt=""
CDFs of bernoulli
data:image/s3,"s3://crabby-images/0232c/0232c160d76e5996b45ebb2ee473d6cbc2ad923f" alt=""
ICDFs of bernoulli
data:image/s3,"s3://crabby-images/5449e/5449ea1c26d073b14d8e9cf57e2874df6027b666" alt=""
PDFs of beta
data:image/s3,"s3://crabby-images/710fb/710fb1b56c6becff448d8353ddcaf45e085be5f7" alt=""
CDFs of beta
data:image/s3,"s3://crabby-images/9da41/9da41c5c4819becd6c9182b7ce10403bca01f646" alt=""
ICDFs of beta
data:image/s3,"s3://crabby-images/23d8c/23d8c2cf6852393b17ac56fa7b3ad742deb6fc7f" alt=""
PDFs of binomial
data:image/s3,"s3://crabby-images/86d88/86d887b1ed7d9b4ce096def799431365b27c29f2" alt=""
CDFs of binomial
data:image/s3,"s3://crabby-images/062ca/062caad953bd5f170f13990b141b7d4814e26627" alt=""
ICDFs of binomial
data:image/s3,"s3://crabby-images/e9813/e98130f436203c5b792c5822c597ff7d45535fdf" alt=""
PDFs of cauchy
data:image/s3,"s3://crabby-images/57283/572835aec12ee5836f128cdfe586e87077c568a0" alt=""
CDFs of cauchy
data:image/s3,"s3://crabby-images/6114f/6114f27775fa78ba9a3185b1eb317ac8b3a3c877" alt=""
ICDFs of cauchy
data:image/s3,"s3://crabby-images/210ea/210ea4bd2bee0f21f86677cb9d877688d22259c1" alt=""
PDFs of chi
data:image/s3,"s3://crabby-images/07d57/07d573f9f21eca44c78f05321e886bafaaa63b56" alt=""
CDFs of chi
data:image/s3,"s3://crabby-images/365e3/365e356a3e443508bb353ab23099d5c73152538b" alt=""
ICDFs of chi
data:image/s3,"s3://crabby-images/b6739/b6739587820ac981bc95223542da961bceff085c" alt=""
PDFs of chi-squared
data:image/s3,"s3://crabby-images/83820/83820c6e4800cb5a298e4f166b568f379817a530" alt=""
CDFs of chi-squared
data:image/s3,"s3://crabby-images/d8774/d8774d5197571b234a322fc2e366cc423a864a1d" alt=""
ICDFs of chi-squared
data:image/s3,"s3://crabby-images/0c492/0c49283a5f864c366263b9da8491805a6c47f09a" alt=""
PDFs of chi-squared-noncentral
data:image/s3,"s3://crabby-images/26531/2653100b104c29507fde1eed5e12d8f5bfcafe0f" alt=""
CDFs of chi-squared-noncentral
data:image/s3,"s3://crabby-images/1dc43/1dc4312e504bf19747a3bf4f48fac7d366ff0d51" alt=""
ICDFs of chi-squared-noncentral
data:image/s3,"s3://crabby-images/59a98/59a98b40aeb99266876e418e7f57420bf51d2f67" alt=""
PDFs of continuous-distribution
data:image/s3,"s3://crabby-images/61711/61711b7c1b667a4db821e42c30a8326f6b4f54e2" alt=""
CDFs of continuous-distribution
data:image/s3,"s3://crabby-images/a8828/a8828e164a5108dfb21d038719cf02d80e4eaf5d" alt=""
ICDFs of continuous-distribution
data:image/s3,"s3://crabby-images/2e078/2e07812573b3a2154493f6ba29f3ecd2a86462c7" alt=""
PDFs of empirical
data:image/s3,"s3://crabby-images/5fd92/5fd92d614cef9a8f7160d610e4ac9e419c06c9ca" alt=""
CDFs of empirical
data:image/s3,"s3://crabby-images/3b4b0/3b4b0ce54dddfe1780f05d2f6b73cd277315c416" alt=""
ICDFs of empirical
data:image/s3,"s3://crabby-images/82b06/82b0608a16af9d417a46117c50c9e7dc83d40b38" alt=""
PDFs of enumerated-int
data:image/s3,"s3://crabby-images/be304/be30423c5624cf1bf26cf5b0780434788f86f826" alt=""
CDFs of enumerated-int
data:image/s3,"s3://crabby-images/7e453/7e453ed68616b3a9c9412d8cf7f83552ef29edb3" alt=""
ICDFs of enumerated-int
data:image/s3,"s3://crabby-images/e9f65/e9f65fcf58e6e4a06fe601de99916927c11a7cd8" alt=""
PDFs of enumerated-real
data:image/s3,"s3://crabby-images/3531c/3531c43b25a4d567d61c5a1f7e3dab22a5e6a1e8" alt=""
CDFs of enumerated-real
data:image/s3,"s3://crabby-images/9dc31/9dc315ce1cb9931c9f2074b2dc9e0d3b76e6f168" alt=""
ICDFs of enumerated-real
data:image/s3,"s3://crabby-images/7c870/7c8709c61e8925b30decf2ed61313c8fc84818d3" alt=""
PDFs of erlang
data:image/s3,"s3://crabby-images/952c1/952c1534b9502426165bb08443cc636f0743cdbe" alt=""
CDFs of erlang
data:image/s3,"s3://crabby-images/78afc/78afcca2e597872b4bc2ac673d63b862d22701b7" alt=""
ICDFs of erlang
data:image/s3,"s3://crabby-images/d9812/d98126ad6b82f6abc7398e1d75cdb332c49e7dc7" alt=""
PDFs of exgaus
data:image/s3,"s3://crabby-images/15a23/15a23aebe350e69c3a9fa3d02dd6c37d141fa44f" alt=""
CDFs of exgaus
data:image/s3,"s3://crabby-images/a27d3/a27d339c203ea9890c96e58e04cf0cae713bb192" alt=""
ICDFs of exgaus
data:image/s3,"s3://crabby-images/7e53e/7e53e0f7bf85c214a54dbc44b259e0fc8e8ac0d9" alt=""
PDFs of exponential
data:image/s3,"s3://crabby-images/5f953/5f9536e169cad5491f945adfec5f150c9f9ae2a2" alt=""
CDFs of exponential
data:image/s3,"s3://crabby-images/50838/508380b7cdb1a2b728d808eebcc4a082277c70fd" alt=""
ICDFs of exponential
data:image/s3,"s3://crabby-images/45707/45707845eb309d3d85db878300147c940a8472e5" alt=""
PDFs of f
data:image/s3,"s3://crabby-images/638c2/638c204405df4fea532709e45ca74d9a6b0d3c20" alt=""
CDFs of f
data:image/s3,"s3://crabby-images/e799d/e799def0d70f45d350e1a4fea4718f3f503d65d6" alt=""
ICDFs of f
data:image/s3,"s3://crabby-images/3e181/3e181d13167cc377f29e0c881c93c53d4c9beb10" alt=""
PDFs of fatigue-life
data:image/s3,"s3://crabby-images/13ffa/13ffa6e9c450b0af9a0141ba3ca6880725d5ea21" alt=""
CDFs of fatigue-life
data:image/s3,"s3://crabby-images/0455c/0455cdb8e6c1cf0b96b127b33dae0792738cfc7e" alt=""
ICDFs of fatigue-life
data:image/s3,"s3://crabby-images/ba58a/ba58a05e10f47dea30ad26590979973a9cb89e2d" alt=""
PDFs of fishers-noncentral-hypergeometric
data:image/s3,"s3://crabby-images/74442/74442d14713068cfe402f0d87f5c802877d51c64" alt=""
CDFs of fishers-noncentral-hypergeometric
data:image/s3,"s3://crabby-images/a5290/a52908e0e68a70ddb5c54d55d821b126ee1186e3" alt=""
ICDFs of fishers-noncentral-hypergeometric
data:image/s3,"s3://crabby-images/c08ef/c08efe471fdd3a9e1ee2fc08714d47f8a3bc74c2" alt=""
PDFs of folded-normal
data:image/s3,"s3://crabby-images/89018/8901896a36ed29b66fcc6c9d5e635095f6acf28c" alt=""
CDFs of folded-normal
data:image/s3,"s3://crabby-images/004f7/004f75975cc1c45fa3825328a456bee2b94465ce" alt=""
ICDFs of folded-normal
data:image/s3,"s3://crabby-images/61fae/61fae560441e3ad3b266c9118f7c8fc3c5dbf5fc" alt=""
PDFs of frechet
data:image/s3,"s3://crabby-images/fb090/fb0908faaa5457067a8d21b323bfc6285100c035" alt=""
CDFs of frechet
data:image/s3,"s3://crabby-images/b2e1a/b2e1a72ea905955edf0d420c098bc77be3d04d20" alt=""
ICDFs of frechet
data:image/s3,"s3://crabby-images/3e83f/3e83f17ceafd4dcf2b6aade527b981a3541bfbe7" alt=""
PDFs of gamma
data:image/s3,"s3://crabby-images/0c448/0c448df6b4827ff2b8cd0a3c91fbee33e6133c5a" alt=""
CDFs of gamma
data:image/s3,"s3://crabby-images/1c647/1c6473f234ac95d82b30ff6e4b7c2a7a2dc58b0b" alt=""
ICDFs of gamma
data:image/s3,"s3://crabby-images/14224/14224f860e6b591f15e58dc8c1adc8df3216ac7a" alt=""
PDFs of geometric
data:image/s3,"s3://crabby-images/9e861/9e861545b3d375bdf97b2b5e7988c1b150f11039" alt=""
CDFs of geometric
data:image/s3,"s3://crabby-images/a0c8b/a0c8b8f73f435a993c638c8e17cab077851464ab" alt=""
ICDFs of geometric
data:image/s3,"s3://crabby-images/0bf6d/0bf6db464327c46729ed3445ce652f9fa7867463" alt=""
PDFs of gumbel
data:image/s3,"s3://crabby-images/52784/52784b6b42e362c1f44cc2bb85f9aef88dc39856" alt=""
CDFs of gumbel
data:image/s3,"s3://crabby-images/423e9/423e9b9181b0019d5da30806c0ae734b9326bd43" alt=""
ICDFs of gumbel
data:image/s3,"s3://crabby-images/c54eb/c54ebc81b7e2050caf73444f5a073b33ed1f16d9" alt=""
PDFs of half-cauchy
data:image/s3,"s3://crabby-images/3c11d/3c11d84af9bc6cbe0f149d643e8b0c918f0a7dbe" alt=""
CDFs of half-cauchy
data:image/s3,"s3://crabby-images/c4e5a/c4e5ab202f801b61ff6f40cbdced923f32095cd2" alt=""
ICDFs of half-cauchy
data:image/s3,"s3://crabby-images/a9149/a91494606fe91f236b8bc16f6cd453c17c41fa13" alt=""
PDFs of half-normal
data:image/s3,"s3://crabby-images/8ddf6/8ddf6f0c0d4587b41808076c2b293be4783c02d5" alt=""
CDFs of half-normal
data:image/s3,"s3://crabby-images/ca260/ca260b169b6b4f59f283d53f6bd3240817c412a3" alt=""
ICDFs of half-normal
data:image/s3,"s3://crabby-images/0c856/0c8568fa5079b2f492ce51862fed303b89bca432" alt=""
PDFs of hyperbolic-secant
data:image/s3,"s3://crabby-images/f2d98/f2d989b6ba0f85f862cce8af68be56bce300675f" alt=""
CDFs of hyperbolic-secant
data:image/s3,"s3://crabby-images/d2262/d2262f001a339ff8cfd33f2403667bc2e2483c2e" alt=""
ICDFs of hyperbolic-secant
data:image/s3,"s3://crabby-images/586f7/586f72a83e165e1074fd14c2c78480bdac2c42c2" alt=""
PDFs of hypergeometric
data:image/s3,"s3://crabby-images/2d16d/2d16d7ed12970d8d40f0be263d53ee600b24e4d5" alt=""
CDFs of hypergeometric
data:image/s3,"s3://crabby-images/0c145/0c1453b6eb4e676b409d949ed3376f0e7869a91c" alt=""
ICDFs of hypergeometric
data:image/s3,"s3://crabby-images/927c4/927c4e4ef160e3ded95f9a64224e465f111730e4" alt=""
PDFs of hypoexponential
data:image/s3,"s3://crabby-images/e51ed/e51ed5006eb728e8e41ee8e721a615bf84da7237" alt=""
CDFs of hypoexponential
data:image/s3,"s3://crabby-images/5c4b8/5c4b8c24234b464ad5f3bd1dbcb0a2f46351658c" alt=""
ICDFs of hypoexponential
data:image/s3,"s3://crabby-images/521d9/521d90348a4ec4248b583236eeca240b3d5748d4" alt=""
PDFs of hypoexponential-equal
data:image/s3,"s3://crabby-images/c3c43/c3c439c9d6e132244608a60e0d82d903c6e9c68f" alt=""
CDFs of hypoexponential-equal
data:image/s3,"s3://crabby-images/8f0c3/8f0c3516d8f157b30206886c5375d5696d05a670" alt=""
ICDFs of hypoexponential-equal
data:image/s3,"s3://crabby-images/ce9c7/ce9c7ee7ed0a309ad8ed9374c7b13d4731bc7a0d" alt=""
PDFs of integer-discrete-distribution
data:image/s3,"s3://crabby-images/bea05/bea05d3300d88ced4782d8fcaaf282d07bafe970" alt=""
CDFs of integer-discrete-distribution
data:image/s3,"s3://crabby-images/4ef4d/4ef4d71a0a790e0e43c71aad6d7634845f00c68f" alt=""
ICDFs of integer-discrete-distribution
data:image/s3,"s3://crabby-images/5726d/5726d05e71583c27830b1006cad75157cebaa5f1" alt=""
PDFs of inverse-gamma
data:image/s3,"s3://crabby-images/b77a0/b77a0b4c30ad583cd7976a1b0ae97ee05ac2a7f9" alt=""
CDFs of inverse-gamma
data:image/s3,"s3://crabby-images/15296/15296b8ddff6335b3d8dab9cfd4290b1e6d22e56" alt=""
ICDFs of inverse-gamma
data:image/s3,"s3://crabby-images/4546a/4546a5194a3601790745f4cbac79c686ab1433cb" alt=""
PDFs of inverse-gaussian
data:image/s3,"s3://crabby-images/3e3f3/3e3f3906caf804e87123b26325641fc1ae319727" alt=""
CDFs of inverse-gaussian
data:image/s3,"s3://crabby-images/19ce1/19ce1736d9c6bdaf2eb39d02c50668cae7cffe57" alt=""
ICDFs of inverse-gaussian
data:image/s3,"s3://crabby-images/1112f/1112f3e94cae9f79cf837c34ba4a672a49487fd6" alt=""
PDFs of johnson-sb
data:image/s3,"s3://crabby-images/3e86b/3e86b9d49e00d3b4e18f2afad12fcd6008ae8e77" alt=""
CDFs of johnson-sb
data:image/s3,"s3://crabby-images/4afe7/4afe7b68acd7a213a9433c7ac4aeab6f137e0ee3" alt=""
ICDFs of johnson-sb
data:image/s3,"s3://crabby-images/82613/82613ccc18accefd1f396346f29377cc767eee93" alt=""
PDFs of johnson-sl
data:image/s3,"s3://crabby-images/eb33c/eb33cfd6675357df956472a2aebd61be01b2d996" alt=""
CDFs of johnson-sl
data:image/s3,"s3://crabby-images/98566/98566c0abe4ddcfda79a8ccc4a041e02c29a6e68" alt=""
ICDFs of johnson-sl
data:image/s3,"s3://crabby-images/f622a/f622ac727f856d4f4f27a1749569c50600af4ace" alt=""
PDFs of johnson-su
data:image/s3,"s3://crabby-images/def9c/def9c7f4297b3da4d573ef929c0ffce1f1fc5bf4" alt=""
CDFs of johnson-su
data:image/s3,"s3://crabby-images/d7cc7/d7cc762fcc8cc62ff86f5245cf116fa0ac235b60" alt=""
ICDFs of johnson-su
data:image/s3,"s3://crabby-images/f53dd/f53dd17414fd542c707d22fab2a1678f9c8ad192" alt=""
PDFs of kolmogorov
data:image/s3,"s3://crabby-images/d51f3/d51f3ecb0da6a9d6ae40a6f1b0fe636dab43bc91" alt=""
CDFs of kolmogorov
data:image/s3,"s3://crabby-images/df398/df3985cd41e53059e26e7f9417784122010bbdf0" alt=""
ICDFs of kolmogorov
data:image/s3,"s3://crabby-images/d6678/d667882b53981734e91663d7de4a4595d63c0634" alt=""
PDFs of kolmogorov-smirnov
data:image/s3,"s3://crabby-images/d6da5/d6da5e5413dc58fa130f6ba20773f7f4f474b893" alt=""
CDFs of kolmogorov-smirnov
data:image/s3,"s3://crabby-images/fd6ca/fd6caca2d6c6717c82a07bdeedd4fcf146851eba" alt=""
ICDFs of kolmogorov-smirnov
data:image/s3,"s3://crabby-images/5cd6a/5cd6ae0d0fced53c5436bbb23d6a40ff4a1fa59b" alt=""
PDFs of kolmogorov-smirnov+
data:image/s3,"s3://crabby-images/afcbc/afcbc2799c7a20b35d2e2b0afbce378e7b4f1aab" alt=""
CDFs of kolmogorov-smirnov+
data:image/s3,"s3://crabby-images/a1e0e/a1e0e97a65c69e1f3442495fa75db160e288bc93" alt=""
ICDFs of kolmogorov-smirnov+
data:image/s3,"s3://crabby-images/43231/43231441f72400812e34aaa6ac13a03cbdde1ac1" alt=""
PDFs of laplace
data:image/s3,"s3://crabby-images/654e6/654e6f4b705f63e813cacdd4cf744531a5ce5e74" alt=""
CDFs of laplace
data:image/s3,"s3://crabby-images/ae2da/ae2da67f8ab986a23ba5515b11a2bf28f71a1f8d" alt=""
ICDFs of laplace
data:image/s3,"s3://crabby-images/81249/812499b92a62d300abb77e3cb9e6cb26df8fc46c" alt=""
PDFs of levy
data:image/s3,"s3://crabby-images/1b9cd/1b9cd4aab49bd6e4c91340084ef9c462c29f4469" alt=""
CDFs of levy
data:image/s3,"s3://crabby-images/3dd08/3dd0875726b60a91012c843d9317f855cb5c6416" alt=""
ICDFs of levy
data:image/s3,"s3://crabby-images/c1f53/c1f53a4c1495fdf3e5b73abb9e3893195ccd97da" alt=""
PDFs of log-logistic
data:image/s3,"s3://crabby-images/5da45/5da456c9b1011f5514eb3b2508275e6a99491a92" alt=""
CDFs of log-logistic
data:image/s3,"s3://crabby-images/a44a3/a44a3d50fb6cbc101674b4e7754ecfc407fddffe" alt=""
ICDFs of log-logistic
data:image/s3,"s3://crabby-images/7382c/7382ccb0ad0d86140a69813b22eb73d1ce2d33b3" alt=""
PDFs of log-normal
data:image/s3,"s3://crabby-images/5eadd/5eadd84a281cc71a6d092b25f83e695344c99dae" alt=""
CDFs of log-normal
data:image/s3,"s3://crabby-images/d2514/d2514199d4d65b30987ffc798847a686697890fc" alt=""
ICDFs of log-normal
data:image/s3,"s3://crabby-images/2993f/2993f65d945ac3c66b1c8f3dd35e82ed4f9065e0" alt=""
PDFs of logistic
data:image/s3,"s3://crabby-images/25988/25988fdb2cc5ff86c4545e1d689cc288e06b260e" alt=""
CDFs of logistic
data:image/s3,"s3://crabby-images/a5327/a5327f1ef9b42693b20364969ca031bc83682ad2" alt=""
ICDFs of logistic
data:image/s3,"s3://crabby-images/5855c/5855c0b196d5eae7579ee457867bad4b0deb66b2" alt=""
PDFs of mixture
data:image/s3,"s3://crabby-images/73a18/73a18ce73e0fdb019692a17278720d2739164364" alt=""
CDFs of mixture
data:image/s3,"s3://crabby-images/83ec9/83ec963ba9e76c1778ad693d8b62c44753498ba5" alt=""
ICDFs of mixture
data:image/s3,"s3://crabby-images/65064/65064514382ad69d506c21f042592fb2b67cbc50" alt=""
PDFs of multinomial
data:image/s3,"s3://crabby-images/65e4a/65e4a18ba1766b7cbc7325e8b6e54aee125091ab" alt=""
CDFs of multinomial
data:image/s3,"s3://crabby-images/ca1c2/ca1c259bd1b3ba081862f825d5851569e63d2b39" alt=""
ICDFs of multinomial
data:image/s3,"s3://crabby-images/2079f/2079f797e963808a0955391a21e6f4f658405963" alt=""
PDFs of nakagami
data:image/s3,"s3://crabby-images/d077f/d077f19bee3dd33debc63d8c95e3230346816ac5" alt=""
CDFs of nakagami
data:image/s3,"s3://crabby-images/5c82f/5c82fa4d0597f3b4e782a5d0c0d40094dbf01968" alt=""
ICDFs of nakagami
data:image/s3,"s3://crabby-images/5c362/5c362d0a7cd373adba0bce47f03356b1995e3802" alt=""
PDFs of nbi
data:image/s3,"s3://crabby-images/ec86e/ec86ef7c6b8e97d6c9ecb749bd24861b1755eda2" alt=""
CDFs of nbi
data:image/s3,"s3://crabby-images/b8827/b8827d3f56a00544bbf134d3dd6339578c00fa18" alt=""
ICDFs of nbi
data:image/s3,"s3://crabby-images/d406c/d406ca241e4cc9779aef5d71e6253d966fc05145" alt=""
PDFs of negative-binomial
data:image/s3,"s3://crabby-images/927e6/927e6b5f7174404f495bdeb217f9ef21e2c2890a" alt=""
CDFs of negative-binomial
data:image/s3,"s3://crabby-images/57035/57035ded97487283104fc0ca7b45fe6b9a58ce46" alt=""
ICDFs of negative-binomial
data:image/s3,"s3://crabby-images/8a5a6/8a5a6a669279a7761b1a768f96d9d2f167d85a39" alt=""
PDFs of normal
data:image/s3,"s3://crabby-images/b33ca/b33cab4c2edbaee825b5949820c82e5cfae76c87" alt=""
CDFs of normal
data:image/s3,"s3://crabby-images/a32fb/a32fb80bd3e7affb20509f30d3cde299fc222be4" alt=""
ICDFs of normal
data:image/s3,"s3://crabby-images/6412f/6412f7dc8292eb3f5646984aaf908e74d9b6892c" alt=""
PDFs of pareto
data:image/s3,"s3://crabby-images/4ac33/4ac33b7e21418d2a46182b4651f1fb86c5f0ddbc" alt=""
CDFs of pareto
data:image/s3,"s3://crabby-images/0ad3f/0ad3fb5a18ed033f18f297aa828cd6302aea5927" alt=""
ICDFs of pareto
data:image/s3,"s3://crabby-images/c48d7/c48d7b5a4445aa1a6ecc2ba3f9d372e828874098" alt=""
PDFs of pascal
data:image/s3,"s3://crabby-images/d99eb/d99ebba1cddca3052230a2846ef90c2418190365" alt=""
CDFs of pascal
data:image/s3,"s3://crabby-images/1419d/1419d717de1049ee2beac27661ce3ec98a066d1c" alt=""
ICDFs of pascal
data:image/s3,"s3://crabby-images/07435/07435b06b412ed1dcf8ba1bf45c5fa744765969d" alt=""
PDFs of pearson-6
data:image/s3,"s3://crabby-images/91194/911945d78aaebc6e2dba2e4f78086421a2f469ea" alt=""
CDFs of pearson-6
data:image/s3,"s3://crabby-images/69c21/69c210c1c2da04df0cc15bb49b9d4d65419fdd12" alt=""
ICDFs of pearson-6
data:image/s3,"s3://crabby-images/cef18/cef18d562140144be316b61a44cdddc0ec9fb868" alt=""
PDFs of poisson
data:image/s3,"s3://crabby-images/66a27/66a2713a5393fe299a8caed7816f5cc4b78707c7" alt=""
CDFs of poisson
data:image/s3,"s3://crabby-images/7c1a5/7c1a54f9c49090dff1b812e8445f31c9cc685942" alt=""
ICDFs of poisson
data:image/s3,"s3://crabby-images/e9502/e95026433ae26b24cde87c04c766835a859077da" alt=""
PDFs of power
data:image/s3,"s3://crabby-images/85f1c/85f1c9fc963e21820f2a07444c823cd28f0b8f77" alt=""
CDFs of power
data:image/s3,"s3://crabby-images/d0710/d07109ff37a06adfa8f4345f4b8456e6f692e0c9" alt=""
ICDFs of power
data:image/s3,"s3://crabby-images/ecc22/ecc2265db8a9f7feb786868b6f4329db40bdb962" alt=""
PDFs of rayleigh
data:image/s3,"s3://crabby-images/1a35c/1a35ccf5967683f2c31919daf6d92725f0b5c08c" alt=""
CDFs of rayleigh
data:image/s3,"s3://crabby-images/924a1/924a1e15c6deb9c1c38bad4b0b4924cda3f93820" alt=""
ICDFs of rayleigh
data:image/s3,"s3://crabby-images/c2a2a/c2a2af2b6861f1da66bdb661ff31d57ab563a21e" alt=""
PDFs of real-discrete-distribution
data:image/s3,"s3://crabby-images/8ae82/8ae827624159e0525e5ff0878a5ef8cf124eca95" alt=""
CDFs of real-discrete-distribution
data:image/s3,"s3://crabby-images/3c241/3c24150b72659cbcaf2c16a9bdf9fe9258b08bf4" alt=""
ICDFs of real-discrete-distribution
data:image/s3,"s3://crabby-images/e42bf/e42bfb0498739f0fb8b7ee9d2698ce450d9190c6" alt=""
PDFs of reciprocal-sqrt
data:image/s3,"s3://crabby-images/ae9ff/ae9ff6c3eec6c5d52a1843fafc6b0cf5bd82d73e" alt=""
CDFs of reciprocal-sqrt
data:image/s3,"s3://crabby-images/e5bd7/e5bd715784e7fecf8a743ee82b5818945ec1c940" alt=""
ICDFs of reciprocal-sqrt
data:image/s3,"s3://crabby-images/bde18/bde18146d6f2528f6f8c0879d12879e27d4d758a" alt=""
PDFs of t
data:image/s3,"s3://crabby-images/f5f31/f5f31e22919141f136a72e93a9aa9c40fd581a82" alt=""
CDFs of t
data:image/s3,"s3://crabby-images/01f46/01f464caa89a5e0c1434bb2f6018156260bfd0a7" alt=""
ICDFs of t
data:image/s3,"s3://crabby-images/fcebf/fcebfd9e8fcfab68e3e909fca34400395d467dd8" alt=""
PDFs of triangular
data:image/s3,"s3://crabby-images/f2579/f2579977a26bd4a594dabbb302306305ac142dc4" alt=""
CDFs of triangular
data:image/s3,"s3://crabby-images/2ef9c/2ef9c4a496c6361424ce3ca3d571b49fd639f85d" alt=""
ICDFs of triangular
data:image/s3,"s3://crabby-images/43377/4337796127a0ce05e7b0f8b515f9be749ced0906" alt=""
PDFs of truncated
data:image/s3,"s3://crabby-images/297fd/297fdf076534238cc542f7fefe7f25ebce9522d0" alt=""
CDFs of truncated
data:image/s3,"s3://crabby-images/df60f/df60f5777eafbf2c41b80ade20c1473f5280f4b1" alt=""
ICDFs of truncated
data:image/s3,"s3://crabby-images/e3442/e3442301121fa2be0bbf863692effc9edbb8c60e" alt=""
PDFs of uniform-int
data:image/s3,"s3://crabby-images/507c1/507c1db70e73a87c0d8a934df5630eebbc733a08" alt=""
CDFs of uniform-int
data:image/s3,"s3://crabby-images/1d69d/1d69d3e347696df8b7e59c5ec0b20ae8c7477f51" alt=""
ICDFs of uniform-int
data:image/s3,"s3://crabby-images/e85a9/e85a9441b073ae50352f51faee3afe332125faa6" alt=""
PDFs of uniform-real
data:image/s3,"s3://crabby-images/c3a12/c3a121ccca264742a82f32db6b591d722702b98e" alt=""
CDFs of uniform-real
data:image/s3,"s3://crabby-images/cca23/cca23a187c098c637c876acf6d2b3e81e31354b4" alt=""
ICDFs of uniform-real
data:image/s3,"s3://crabby-images/5b0ec/5b0ec76fe526568946e5dbca70bbc7012a91d9ac" alt=""
PDFs of watson-g
data:image/s3,"s3://crabby-images/5cf60/5cf607040f563d7d4f17c02c4b4c259fa95e079a" alt=""
CDFs of watson-g
data:image/s3,"s3://crabby-images/8d32c/8d32cf160d1a9829e8b6599dfcd8e58fde1321d3" alt=""
ICDFs of watson-g
data:image/s3,"s3://crabby-images/0c301/0c30141b2958165e56854dbc6fcb531eefe217cf" alt=""
PDFs of watson-u
data:image/s3,"s3://crabby-images/62bea/62bea9bc74174d06f5834166e5b5ac6a32f0279e" alt=""
CDFs of watson-u
data:image/s3,"s3://crabby-images/d633f/d633f2c7df4d36683fe429af3285a157bc2bbc04" alt=""
ICDFs of watson-u
data:image/s3,"s3://crabby-images/b4fac/b4facbc054d4205f8a84cb5c7b29debb452b8c31" alt=""
PDFs of weibull
data:image/s3,"s3://crabby-images/db777/db7776b0311697de6a1bf8114b9580bc84ba36b8" alt=""
CDFs of weibull
data:image/s3,"s3://crabby-images/3d78d/3d78d41ac571b915ca81b6ac055051b9ebb64012" alt=""
ICDFs of weibull
data:image/s3,"s3://crabby-images/91f0e/91f0e5106dc811cf10d3b373797b5ad02689c3eb" alt=""
PDFs of zabb
data:image/s3,"s3://crabby-images/6fa7d/6fa7d855f573673bc7a8b42bddde5c34991e5ca0" alt=""
CDFs of zabb
data:image/s3,"s3://crabby-images/46612/4661235c20b5a91eaf0d9c892b641c0c17b40951" alt=""
ICDFs of zabb
data:image/s3,"s3://crabby-images/cb853/cb853328ae1745523f11b2290bb6d46c0c599d76" alt=""
PDFs of zabi
data:image/s3,"s3://crabby-images/0c9e9/0c9e97a3f1918aea3599b592d74f2b0569e292e2" alt=""
CDFs of zabi
data:image/s3,"s3://crabby-images/47155/47155b78034706edc02c6e3faf9d472a0a164864" alt=""
ICDFs of zabi
data:image/s3,"s3://crabby-images/0e907/0e907f797bd110bbcd2ea1dfb26028ec011bc318" alt=""
PDFs of zaga
data:image/s3,"s3://crabby-images/5aaed/5aaed11add9ca7be30ca6b640d1102ac23842331" alt=""
CDFs of zaga
data:image/s3,"s3://crabby-images/8736a/8736a69c6f8703a98e0b7605c1c13d737fc8644f" alt=""
ICDFs of zaga
data:image/s3,"s3://crabby-images/c479d/c479d0b5791daedbe6f9a546f3b939e4b40ff630" alt=""
PDFs of zanbi
data:image/s3,"s3://crabby-images/8a5a9/8a5a916e7d27b05365e6f03b95656d5a32c927bd" alt=""
CDFs of zanbi
data:image/s3,"s3://crabby-images/1b5b8/1b5b81d09a9b037bb0dea1662648ecb218197127" alt=""
ICDFs of zanbi
data:image/s3,"s3://crabby-images/602d0/602d0e1df546c1db99ca4993ab266eba481355b4" alt=""
PDFs of zibb
data:image/s3,"s3://crabby-images/52f3a/52f3a401f00d5c14104c6522bbbe257370f68986" alt=""
CDFs of zibb
data:image/s3,"s3://crabby-images/d1f4d/d1f4d8dc80957bb1c7eb9a42c7638ba7e646f10d" alt=""
ICDFs of zibb
data:image/s3,"s3://crabby-images/64738/64738c92116e6023c5d3387d5b00388611493d0d" alt=""
PDFs of zibi
data:image/s3,"s3://crabby-images/34328/34328b761b78486db2f828becf73c25878bcbb25" alt=""
CDFs of zibi
data:image/s3,"s3://crabby-images/619e0/619e0dc3cf427262a22bbf1805f9107f95a30ede" alt=""
ICDFs of zibi
data:image/s3,"s3://crabby-images/49dba/49dba9de5c1e84ca4497f84f9e578e8d6a715c3c" alt=""
PDFs of zinbi
data:image/s3,"s3://crabby-images/892ab/892abf5c608373402b9898cb5499b345d0f83a51" alt=""
CDFs of zinbi
data:image/s3,"s3://crabby-images/3221a/3221a5253413f2acc01fba9d8e3285d63f51285b" alt=""
ICDFs of zinbi
data:image/s3,"s3://crabby-images/7ba96/7ba969f5e3afe2cd2e7d44fb1bcaab877ef6941b" alt=""
PDFs of zip
data:image/s3,"s3://crabby-images/f557c/f557c2b8b004f78e83e908786a4d60bd454d6195" alt=""
CDFs of zip
data:image/s3,"s3://crabby-images/e148a/e148afe6ecd82b6d372eac371c065a6c9f1662b2" alt=""
ICDFs of zip
data:image/s3,"s3://crabby-images/3513e/3513e8983e02a01d3b7cc6445866bb8669f795e0" alt=""
PDFs of zip2
data:image/s3,"s3://crabby-images/4a6f4/4a6f402a2f0fc6998ac204967c82062ed57342ef" alt=""
CDFs of zip2
data:image/s3,"s3://crabby-images/e51e2/e51e271a5856062ea719ad2bb56573a522b7b948" alt=""
ICDFs of zip2
data:image/s3,"s3://crabby-images/a808b/a808b0ac469e124be6dd055f99ff2d957db8abd2" alt=""
PDFs of zipf
data:image/s3,"s3://crabby-images/f60f5/f60f5e58a9a6d7dbed59e08a96644461f902ab26" alt=""
CDFs of zipf
data:image/s3,"s3://crabby-images/31b62/31b624b890ca05b7bf20720bef15e553a93df045" alt=""
ICDFs of zipf
data:image/s3,"s3://crabby-images/641b7/641b744f72efa76e1414476e8b4c5b4044de7b26" alt=""
2d multidimensional normal (mean=0,0, covariances=I)
data:image/s3,"s3://crabby-images/74ed2/74ed2ec4a732e8bde67612b77b8a742abf28fc84" alt=""
2d dirichlet (alpha=2,0.8)
data:image/s3,"s3://crabby-images/8918d/8918d5ed75137c7e67ea1c7cf1580cbb879cac9c" alt=""
distribution-id
(distribution-id d)
Distribution identifier as keyword.
Examples
Usage
(distribution-id (distribution :gamma))
;;=> :gamma
(distribution-id default-normal)
;;=> :normal
;; Test: ok.
distribution-parameters
(distribution-parameters d)
(distribution-parameters d all?)
Distribution highest supported value.
When all?
is true, technical parameters are included, ie: :rng
and :inverser-cumm-accuracy
.
Examples
Usage
(distribution-parameters (distribution :gamma))
;;=> [:scale :shape]
(distribution-parameters (distribution :gamma) true)
;;=> [:rng :shape :scale :inverse-cumm-accuracy]
(distribution-parameters default-normal)
;;=> [:sd :mu]
;; Test: ok.
distributions-list
List of distributions.
Examples
Number and list of distributions
distributions-list
;;=> #{:anderson-darling :bb :bernoulli :beta :binomial
;;=> :categorical-distribution :cauchy :chi :chi-squared
;;=> :chi-squared-noncentral :continuous-distribution :cramer-von-mises
;;=> :dirichlet :empirical :enumerated-int :enumerated-real :erlang :exgaus
;;=> :exponential :f :fatigue-life :fishers-noncentral-hypergeometric
;;=> :folded-normal :frechet :gamma :geometric :gumbel :half-cauchy
;;=> :half-normal :hyperbolic-secant :hypergeometric :hypoexponential
;;=> :hypoexponential-equal :integer-discrete-distribution :inverse-gamma
;;=> :inverse-gaussian :johnson-sb :johnson-sl :johnson-su :kde :kolmogorov
;;=> :kolmogorov-smirnov :kolmogorov-smirnov+ :laplace :levy :log-logistic
;;=> :log-normal :logarithmic :logistic :mixture :multi-normal :multinomial
;;=> :nakagami :nbi :negative-binomial :normal :normal-inverse-gaussian
;;=> :pareto :pascal :pearson-6 :poisson :power :rayleigh
;;=> :real-discrete-distribution :reciprocal-sqrt :t :triangular :truncated
;;=> :uniform-int :uniform-real :watson-g :watson-u :weibull :zabb :zabi
;;=> :zaga :zanbi :zibb :zibi :zinbi :zip :zip2 :zipf}
(count distributions-list)
;;=> 83
drand
(drand)
(drand mx)
(drand mn mx)
Random double number with default RNG.
As default returns random double from [0,1)
range. When mx
is passed, range is set to [0, mx)
. When mn
is passed, range is set to [mn, mx)
.
Examples
Usage
(drand)
;;=> 0.6178882774976912
(drand 10)
;;=> 3.234654167181481
(drand 10 20)
;;=> 11.178257652282884
drandom
(drandom rng)
(drandom rng mx)
(drandom rng mn mx)
Random double number with provided RNG
Examples
double
(rngproto-snippet drandom ...)
;;=> 0.12887351924500923
Double random value from distribution
(drandom (distribution :gamma))
;;=> 4.477314503655649
fbm-noise
(fbm-noise)
(fbm-noise cfg__22233__auto__)
Create fbm-noise function with optional configuration.
Examples
Usage
(let [n (fbm-noise {:interpolation :linear, :noise-type :value})]
(n 0.5 1.1 -1.3))
;;=> 0.3596888698390143
2d noise
data:image/s3,"s3://crabby-images/1c69b/1c69b2a61c5d2f401ec4373892392bc09a133211" alt=""
flip
(flip p)
(flip)
Returns 1 with given probability, 0 otherwise
Examples
Usage
(flip)
;;=> 1
(flip 0.2)
;;=> 0
(repeatedly 10 (fn* [] (flip 0.1)))
;;=> (0 1 0 1 0 0 1 0 0 0)
flip-rng
(flip-rng rng p)
(flip-rng rng)
Returns 1 with given probability, 0 otherwise, for given rng
flipb
(flipb p)
(flipb)
Returns true with given probability, false otherwise
Examples
Usage
(flipb)
;;=> true
(flipb 0.2)
;;=> false
(repeatedly 10 (fn* [] (flipb 0.1)))
;;=> (false false false false false false false false false false)
flipb-rng
(flipb-rng rng p)
(flipb-rng rng)
Returns true with given probability, false otherwise, for given rng
frand
(frand)
(frand mx)
(frand mn mx)
Random double number with default RNG.
As default returns random float from [0,1)
range. When mx
is passed, range is set to [0, mx)
. When mn
is passed, range is set to [mn, mx)
.
Examples
Usage
(frand)
;;=> 0.93785393
(frand 10)
;;=> 9.578358
(frand 10 20)
;;=> 15.521044
frandom
(frandom rng)
(frandom rng mx)
(frandom rng mn mx)
Random double number with provided RNG
Examples
float
(rngproto-snippet frandom ...)
;;=> 0.28929412
Float random value from distribution (sample cast to
float
)
(frandom (distribution :gamma))
;;=> 6.0880103
grand
(grand)
(grand stddev)
(grand mean stddev)
Random gaussian double number with default RNG.
As default returns random double from N(0,1)
. When std
is passed, N(0,std)
is used. When mean
is passed, distribution is set to N(mean, std)
.
Examples
Usage
(grand)
;;=> -1.5236953146011685
(grand 10)
;;=> 7.944277491488467
(grand 10 20)
;;=> 8.045099200233572
grandom
(grandom rng)
(grandom rng stddev)
(grandom rng mean stddev)
Random gaussian double number with provided RNG
Examples
gaussian double
(rngproto-snippet grandom ...)
;;=> -1.2620959490529822
icdf
(icdf d v)
Inverse cumulative probability
Examples
Usage
(icdf (distribution :gamma) 0.5)
;;=> 3.3566939800333233
integrate-pdf
(integrate-pdf pdf-func mn mx steps)
(integrate-pdf pdf-func {:keys [mn mx steps interpolator min-iterations], :or {mn 0.0, mx 1.0, steps 1000, min-iterations 3, interpolator :linear}})
Integrate PDF function, returns CDF and iCDF
Parameters: * pdf-func
- univariate function * mn
- lower bound for integration, value of pdf-func should be 0.0 at this point * mx
- upper bound for integration * steps
- how much subintervals to integrate (default 1000) * min-iterations
- minimum iterations for RombergIntegrator (default 3) * interpolator
- interpolation method between integrated points (default :spline)
Possible interpolation methods: :linear
(default), :spline
, :monotone
or any function from fastmath.interpolation
irand
(irand)
(irand mx)
(irand mn mx)
Random integer number with default RNG.
As default returns random integer from full integer range. When mx
is passed, range is set to [0, mx)
. When mn
is passed, range is set to [mn, mx)
.
Examples
Usage
(irand)
;;=> 403368085
(irand 10)
;;=> 7
(irand 10 20)
;;=> 16
irandom
(irandom rng)
(irandom rng mx)
(irandom rng mn mx)
Random integer number with provided RNG
Examples
integer
(rngproto-snippet irandom ...)
;;=> -870209046
Integer random value from distribution (sample cast to
int
)
(irandom (distribution :gamma))
;;=> 4
jittered-sequence-generator
(jittered-sequence-generator seq-generator dimensions)
(jittered-sequence-generator seq-generator dimensions jitter)
Create jittered sequence generator.
Suitable for :r2
, :sobol
and :halton
sequences.
jitter
parameter range is from 0
(no jitter) to 1
(full jitter). Default: 0.25.
See also sequence-generator.
Examples
Usage
(let [gen1 (jittered-sequence-generator :r2 2 0.5)
gen2 (jittered-sequence-generator :r2 2 0.5)]
[(first gen1) (first gen2)])
;;=> [[0.3349098031447362 0.3632196608626955]
;;=> [0.46362255181031453 0.23019358923493558]]
Jittered (0.5) R2 plot (500 samples)
data:image/s3,"s3://crabby-images/ecd01/ecd01ded291575f39a9de29beb67e0294832f0f7" alt=""
Jittered (0.5) Halton plot (500 samples)
data:image/s3,"s3://crabby-images/b2850/b28508f2e0a88fd23fb3ad54afd08797abf111e2" alt=""
Jittered (0.5) Sobol plot (500 samples)
data:image/s3,"s3://crabby-images/47084/47084965975ed6971a509c06f2fb6be0cd06164e" alt=""
Jittered (0.5) Sphere plot (500 samples)
data:image/s3,"s3://crabby-images/023d2/023d2e70ba823317cf0d15a311ef0388c0445721" alt=""
Jittered (0.5) Gaussian plot (500 samples)
data:image/s3,"s3://crabby-images/052d9/052d90e3f5e627cd74c88c77b91ea65cadc5679b" alt=""
Jittered (0.5) Default plot (500 samples)
data:image/s3,"s3://crabby-images/64ff0/64ff007b75a62efe37dcf271d546eb884f81b476" alt=""
likelihood
(likelihood d vs)
Likelihood of samples
Examples
Usage
(likelihood (distribution :gamma) [10 0.5 0.5 1 2])
;;=> 4.452548659934162E-6
log-likelihood
(log-likelihood d vs)
Log likelihood of samples
Examples
Usage
(log-likelihood (distribution :gamma) [10 0.5 0.5 1 2])
;;=> -12.322033893165353
lower-bound
(lower-bound d)
Distribution lowest supported value
Examples
Usage
(lower-bound (distribution :gamma))
;;=> 0.0
;; Test: ok.
lpdf
(lpdf d v)
Log density
Examples
Usage
(lpdf (distribution :gamma) 1)
;;=> -1.8862943611198908
lrand
(lrand)
(lrand mx)
(lrand mn mx)
Random long number with default RNG.
As default returns random long from full integer range. When mx
is passed, range is set to [0, mx)
. When mn
is passed, range is set to [mn, mx)
.
Examples
Usage
(lrand)
;;=> -6983603299110100805
(lrand 10)
;;=> 1
(lrand 10 20)
;;=> 19
lrandom
(lrandom rng)
(lrandom rng mx)
(lrandom rng mn mx)
Random long number with provided RNG
Examples
long
(rngproto-snippet lrandom ...)
;;=> -2549412008922664795
Long random value from distribution (sample cast to
long
)
(lrandom (distribution :gamma))
;;=> 2
mean
(mean d)
Distribution mean
Examples
Usage
(mean (distribution :gamma))
;;=> 4.0
;; Test: ok.
means
(means d)
Distribution means (for multivariate distributions)
Examples
Usage
(means (distribution :multi-normal))
;;=> [0.0 0.0]
(means (distribution :dirichlet {:alpha [2 2]}))
;;=> (0.5 0.5)
;; Test: ok.
noise
(noise x)
(noise x y)
(noise x y z)
Improved Perlin Noise.
6 octaves, quintic interpolation.
Examples
Usage
(noise 3.3)
;;=> 0.5733724444444446
(noise 3.3 1.1)
;;=> 0.5240146679060318
(noise 3.3 0.0 -0.1)
;;=> 0.598906850336508
2d noise
data:image/s3,"s3://crabby-images/a7126/a71265295c5221698efc0f9361587a762764b932" alt=""
noise-generators
List of possible noise generators as a map of names and functions.
Examples
List of names (keys)
(keys noise-generators)
;;=> (:fbm :single :billow :ridgemulti)
noise-interpolations
List of possible noise interpolations as a map of names and values.
Examples
List of names (keys)
(keys noise-interpolations)
;;=> (:none :linear :hermite :quintic)
noise-types
List of possible noise types as a map of names and values.
Examples
List of names (keys)
(keys noise-types)
;;=> (:value :gradient :simplex)
observe
macro
(observe d vs)
Log likelihood of samples. Alias for log-likelihood.
Examples
Usage
(observe (distribution :gamma) [10 0.5 0.5 1 2])
;;=> -12.322033893165353
observe1
(observe1 d v)
Log of probability/density of the value. Alias for lpdf.
Examples
Usage
(observe1 (distribution :gamma) 10)
;;=> -4.083709268125845
(pdf d v)
Density
Examples
Usage
(pdf (distribution :gamma) 1)
;;=> 0.15163266492815838
(pdf (distribution :pascal) 1)
;;=> 9.5367431640625E-6
probability
(probability d v)
Probability (PMF)
Examples
Usage
(probability (distribution :gamma) 1)
;;=> 0.15163266492815838
(probability (distribution :pascal) 1)
;;=> 9.5367431640625E-6
random-noise-cfg
(random-noise-cfg pre-config)
(random-noise-cfg)
Create random noise configuration.
Optional map with fixed values.
Examples
Random configuration
(random-noise-cfg)
;;=> {:gain 0.5470770409714059,
;;=> :generator :ridgemulti,
;;=> :interpolation :linear,
;;=> :lacunarity 2.276291258543873,
;;=> :noise-type :gradient,
;;=> :normalize? true,
;;=> :octaves 6,
;;=> :seed -1748984410,
;;=> :warp-depth 1,
;;=> :warp-scale 0.0}
random-noise-fn
(random-noise-fn cfg)
(random-noise-fn)
Create random noise function from all possible options.
Optionally provide own configuration cfg
. In this case one of 4 different blending methods will be selected.
Examples
Create function
(random-noise-fn)
;;=> fastmath.random$billow_noise$fn__22251@597a247
(random-noise-fn (random-noise-cfg))
;;=> fastmath.random$fbm_noise$fn__22247@494f5bd
One
data:image/s3,"s3://crabby-images/a8190/a81908a0fca6185c941a31719a58dbf66fcce115" alt=""
Two
data:image/s3,"s3://crabby-images/330c0/330c0915a4efa70c6bb8e99561dddc326140e223" alt=""
Three
data:image/s3,"s3://crabby-images/70484/704846c80e233b9633867434e5480beb15800cbb" alt=""
randval
macro
(randval v1 v2)
(randval prob v1 v2)
(randval prob)
(randval)
Return value with given probability (default 0.5)
Examples
Usage
(randval :val-one :val-two)
;;=> :val-one
(randval 0.001 :low-probability :high-probability)
;;=> :high-probability
Check probability of nil (should return value around 1000).
(count (filter nil?
(repeatedly 1000000 (fn* [] (randval 0.001 nil 101)))))
;;=> 1019
randval-rng
macro
(randval-rng rng v1 v2)
(randval-rng rng prob v1 v2)
(randval-rng rng prob)
(randval-rng rng)
Return value with given probability (default 0.5), for given rng
ridgedmulti-noise
(ridgedmulti-noise)
(ridgedmulti-noise cfg__22233__auto__)
Create ridgedmulti-noise function with optional configuration.
Examples
Usage
(let [n
(ridgedmulti-noise
{:octaves 3, :lacunarity 2.1, :gain 0.7, :noise-type :simplex})]
(n 0.5 1.1 -1.3))
;;=> 0.6151828850470207
2d noise
data:image/s3,"s3://crabby-images/ec2ee/ec2ee096c73bb34d651e93da20e1fd1da9f26cab" alt=""
rng
multimethod
Examples
Creation
(rng :mersenne)
;;=> org.apache.commons.math3.random.MersenneTwister@6b009752
(rng :isaac 1234)
;;=> org.apache.commons.math3.random.ISAACRandom@7d5b7023
Usage
(irandom (rng :mersenne 999) 15 25)
;;=> 24
rngs-list
List of all possible RNGs.
Examples
Contains
(sort rngs-list)
;;=> (:isaac :jdk :mersenne
;;=> :well1024a :well19937a
;;=> :well19937c :well44497a
;;=> :well44497b :well512a)
roll-a-dice-rng
(roll-a-dice-rng rng sides)
(roll-a-dice-rng rng dices sides)
Roll a dice with given sides and given rng
sample
(sample d)
Random sample
Examples
Random value from distribution
(sample (distribution :gamma))
;;=> 3.8220900629270256
sequence-generator
multimethod
Create Sequence generator. See sequence-generators-list for names.
Values:
:r2
,:halton
,:sobol
,:default
/:uniform
- range[0-1] for each dimension
:gaussian
- fromN(0,1)
distribution:sphere
- from surface of unit sphere (ie. euclidean distance from origin equals 1.0):ball
- from an unit ball
Possible dimensions:
:r2
- 1-15:halton
- 1-40:sobol
- 1-1000- the rest - 1+
See also jittered-sequence-generator.
Examples
Usage (2d)
(let [gen (sequence-generator :halton 2)] (take 5 gen))
;;=> ([0.0 0.0]
;;=> [0.5 0.6666666666666666]
;;=> [0.25 0.3333333333333333]
;;=> [0.75 0.2222222222222222]
;;=> [0.125 0.8888888888888888])
Usage (1d)
(let [gen (sequence-generator :sobol 1)] (take 5 gen))
;;=> (0.0 0.5 0.75 0.25 0.375)
Usage (10d)
(second (sequence-generator :halton 10))
;;=> [0.5 0.6666666666666666 0.6000000000000001 0.42857142857142855
;;=> 0.7272727272727273 0.8461538461538463 0.7058823529411764
;;=> 0.7368421052631579 0.30434782608695654 0.6206896551724138]
Usage, R2 sequence
(take 5 (sequence-generator :r2 3))
;;=> ([0.3191725133961645 0.17104360670378926 0.0497004779019703]
;;=> [0.13834502679232896 0.8420872134075785 0.5994009558039406]
;;=> [0.9575175401884934 0.5131308201113678 0.1491014337059109]
;;=> [0.7766900535846579 0.18417442681515706 0.6988019116078812]
;;=> [0.5958625669808224 0.8552180335189463 0.24850238950985148])
R2 plot (500 samples)
data:image/s3,"s3://crabby-images/fb1ed/fb1ed60ca35ce63bc5fe9ff7c0a76c5491fb2327" alt=""
Halton plot (500 samples)
data:image/s3,"s3://crabby-images/a9388/a93881424b7e691395d9e5ff49d6ec0cd68c9eaa" alt=""
Sobol plot (500 samples)
data:image/s3,"s3://crabby-images/1a24a/1a24adfb6867955cdad3d4961066ef95a4c1392a" alt=""
Sphere plot (500 samples)
data:image/s3,"s3://crabby-images/45338/45338c8a22c59beea5066857324b9e3c18f36281" alt=""
Gaussian plot (500 samples)
data:image/s3,"s3://crabby-images/ec5cb/ec5cb26054986636a215a655407f87744e82b71c" alt=""
Default plot (500 samples)
data:image/s3,"s3://crabby-images/0129b/0129bccbe8fa2efd7511d6b52e2a55b28836e0bf" alt=""
sequence-generators-list
List of random sequence generator. See sequence-generator.
Examples
Generator names.
(sort sequence-generators-list)
;;=> (:ball :default :gaussian :halton :r2 :sobol :sphere)
set-seed!
(set-seed!)
(set-seed! v)
(set-seed! rng v)
Sets seed.
If rng
is :smile
calls smile.math.MathEx/setSeed()
.
Without rng
sets both :smile
and default-rng
Examples
Set seed for the RNG object
(let [rng (rng :isaac)]
(set-seed! rng 1234)
(irandom rng 10 15))
;;=> 10
;; Test: ok.
Set seed for the distribution object
(let [d (distribution :enumerated-int {:data [1 1 1 2 3]})]
(set-seed! d 1234)
(irandom d))
;;=> 2
;; Test: ok.
Set seed to SMILE (global) RNG
(set-seed! :smile 1234)
;;=> nil
Set seed to both SMILE and fastmath default RNGs
(set-seed! 1234)
;;=> org.apache.commons.math3.random.JDKRandomGenerator@75f84e75
Set to random seed both default RNGs
(set-seed!)
;;=> org.apache.commons.math3.random.JDKRandomGenerator@75f84e75
simplex
(simplex x)
(simplex x y)
(simplex x y z)
Simplex noise. 6 octaves.
Examples
Usage
(simplex 3.3)
;;=> 0.5333568931885713
(simplex 3.3 1.1)
;;=> 0.5337502464278872
(simplex 3.3 0.0 -0.1)
;;=> 0.39681219935985423
2d noise
data:image/s3,"s3://crabby-images/9f443/9f4437d289b3a61eac03d1806339fb3ab084bf7d" alt=""
single-noise
(single-noise)
(single-noise cfg__22233__auto__)
Create single-noise function with optional configuration.
Examples
Usage
(let [n (single-noise {:interpolation :linear})] (n 0.5 1.1 -1.3))
;;=> 0.5405
2d noise
data:image/s3,"s3://crabby-images/008cc/008cce918a04d9965c2b657865b673521c90d40f" alt=""
source-object
(source-object d)
Returns Java or proxy object from backend library (if available)
Examples
Usage
(source-object default-normal)
;;=> org.apache.commons.math3.distribution.NormalDistribution@4f0ac32c
synced-rng
(synced-rng m)
(synced-rng m seed)
Create synchronized RNG for given name and optional seed. Wraps rng method.
Examples
Usage
(drandom (synced-rng :mersenne 1234))
;;=> 0.0685985404954157
upper-bound
(upper-bound d)
Distribution highest supported value
Examples
Usage
(upper-bound (distribution :gamma))
;;=> Infinity
;; Test: ok.
variance
(variance d)
Distribution variance
Examples
Usage
(variance (distribution :gamma))
;;=> 8.0
;; Test: ok.
vnoise
(vnoise x)
(vnoise x y)
(vnoise x y z)
Value Noise.
6 octaves, Hermite interpolation (cubic, h01).
Examples
Usage
(vnoise 3.3)
;;=> 0.3685741220739981
(vnoise 3.3 1.1)
;;=> 0.32606184202712973
(vnoise 3.3 0.0 -0.1)
;;=> 0.4377780763909749
2d noise
data:image/s3,"s3://crabby-images/28b9d/28b9d6587781aead1ff451908b7692a61e25a25d" alt=""
warp-noise-fn
(warp-noise-fn noise scale depth)
(warp-noise-fn noise scale)
(warp-noise-fn noise)
(warp-noise-fn)
Create warp noise (see Inigo Quilez article).
Parameters:
- noise function, default: vnoise
- scale factor, default: 4.0
- depth (1 or 2), default 1
Normalization of warp noise depends on normalization of noise function.
Examples
Usage
(let [n (warp-noise-fn simplex 2.0 2.0)]
[(n 0.0) (n 1.0 0.5) (n 2 2 2)])
;;=> [0.40098715790712897 0.46270697250804094 0.6131643768058173]
Default warp (noise=vnoise, scale=4.0, depth=1.0).
data:image/s3,"s3://crabby-images/3d397/3d397d25cacadd111bc1e82f4915d85a80ce0734" alt=""