Random Number Generator in Arbitrary Probability Distribution Fashion
Random Number Generation
data:image/s3,"s3://crabby-images/ab6d5/ab6d53eb344455a69c9ffe971fa38cf9d59876e1" alt=""
Random Numbers
RandomReal[ ] | give a pseudorandom real number in the range 0 to 1 |
RandomReal[ { x min , x max } ] | give a pseudorandom real number in the range x min to x max |
RandomReal[ x max ] | give a pseudorandom real number in the range 0 to ten max |
RandomReal[ domain , n ] | give a list of n pseudorandom reals |
RandomReal[ domain , { n 1 , northward two , … } ] | give an n 1 × n 2 × … array of pseudorandom reals |
RandomInteger[ { i min , i max } ] | give a pseudorandom integer in the range { i min , … , i max } |
RandomInteger[ i max ] | give a pseudorandom integer in the range { 0 , … , i max } |
RandomInteger[ ] | pseudorandomly give 0 or one with probability ![]() |
RandomInteger[ domain , due north ] | give a list of n pseudorandom integers |
RandomInteger[ domain , { n 1 , n 2 , … } ] | requite an north 1 × n 2 × … array of pseudorandom integers |
RandomComplex[ ] | give a pseudorandom complex number in the unit foursquare |
RandomComplex[ { z min , z max } ] | requite a pseudorandom complex number in the rectangle bounded past z min and z max |
RandomComplex[ z max ] | requite a pseudorandom complex number in the rectangle divisional by 0 and z max |
RandomComplex[ domain , n ] | requite a listing of n pseudorandom complex numbers |
RandomComplex[ domain , { n 1 , n 2 , … } ] | give an n i × north 2 × … assortment of pseudorandom complex numbers |
RandomVariate[ dist ] | requite a pseudorandom value from the distribution dist |
RandomVariate[ dist , n ] | give a list of n pseudorandom values from dist |
RandomVariate[ dist , { north i , n ii , … } ] | give an due north 1 × due north 2 × … assortment of pseudorandom values from dist |
RandomPrime[ { i min , i max } ] | give a pseudorandom prime number in the range { i min , … , i max } |
RandomPrime[ i max ] | give a pseudorandom prime number in the range two to i max |
RandomPrime[ domain , n ] | give a list of due north pseudorandom primes |
RandomPrime[ domain , { n 1 , north two , … } ] | give an north 1 × northward 2 × … assortment of pseudorandom primes |
data:image/s3,"s3://crabby-images/24fa5/24fa5b547768a1eb06216153c819ec687162eeec" alt=""
data:image/s3,"s3://crabby-images/eb772/eb772e5efa27d8632273d232ee2cd87e9a28b31f" alt=""
Arbitrary-Precision Reals and Complexes
data:image/s3,"s3://crabby-images/62784/627847d50439e9882a080fba8fa17c24050c4268" alt=""
data:image/s3,"s3://crabby-images/ef383/ef383a2fe2e652024a1b30ff0389407799061fa9" alt=""
data:image/s3,"s3://crabby-images/a684c/a684c2f60d66c5f7534000afac933786b1bac2ec" alt=""
data:image/s3,"s3://crabby-images/2dcdd/2dcdd5d70d14fc3b344d8381193957a0fef13ee5" alt=""
Random Elements
RandomChoice[ { due east 1 , e 2 , … } ] | give a pseudorandom selection of one of the due east i |
RandomChoice[ list , n ] | requite a list of n pseudorandom choices from list |
RandomChoice[ list , { n ane , n 2 , … } ] | requite n 1 × n 2 × … pseudorandom choices from list |
RandomChoice[ { w ane , west 2 , … }->{ e 1 , east 2 , … } ] | |
give a pseudorandom choice weighted past the westward i | |
RandomChoice[ wlist->elist , due north ] | requite a list of due north weighted choices |
RandomChoice[ wlist->elist , { north ane , due north two , … } ] | |
give an array of northward i × n 2 × … assortment of weighted choices |
RandomSample[ { due east 1 , east 2 , … } , n ] | give a pseudorandom sample of north of the eastward i |
RandomSample[ { westward 1 , w 2 , … }->{ e 1 , e 2 , … } , north ] | |
give a pseudorandom sample of due north of the e i called using weights w i | |
RandomSample[ { e one , eastward 2 , … } ] | requite a pseudorandom permutation of the e i |
RandomSample[ wlist->elist ] | requite a pseudorandom permutation of elist using initial weights wlist |
data:image/s3,"s3://crabby-images/6b4a5/6b4a5324b160883874496306059e73cd1f662336" alt=""
BlockRandom[ expr ] | evaluate expr with all pseudorandom generators localized |
SeedRandom[ due north ] | reset the pseudorandom generator using north as a seed |
SeedRandom[ ] | reset the generator using every bit a seed the time of day and sure attributes of the current Wolfram Language session |
SeedRandom and BlockRandom in Parallel Computations
command | series | parallel |
SeedRandom[ seed ] | seed all current series random generators with seed and the parallel generators with with seed + i , where i is the index for the parallel thread | seed but the random generator for the current thread with seed |
SeedRandom[ seed ,Method->"ParallelGenerator"] | seed the parallel generators with seed + i , where i is the alphabetize for the parallel thread | no effect |
SeedRandom[Method->method ] | modify the method for the serial random generator to method | change the method for only the random generator for the current thread to method |
BlockRandom[ expr ] | evaluate expr with all pseudorandom generators localized | evaluate expr with merely the pseudorandom generator for the current thread localized |
data:image/s3,"s3://crabby-images/ff792/ff792c56335171a688f4ad113607feff89a4cbc4" alt=""
data:image/s3,"s3://crabby-images/c54cb/c54cbecbef62d02eb43d51c72dcfb0bb7d237371" alt=""
data:image/s3,"s3://crabby-images/a9de2/a9de23d6fe1ed96ea156360f279ff9c278ec457d" alt=""
data:image/s3,"s3://crabby-images/697f8/697f8e395787ad04b94e616fba1eecaa26e6b806" alt=""
"Congruential" | linear congruential generator (low ‐ quality randomness) |
"ExtendedCA" | extended cellular automaton generator (default) |
"Legacy" | default generators prior to Mathematica 6.0 |
"MersenneTwister" | Mersenne Twister shift register generator |
"MKL" | Intel MKL generator (Intel ‐ based systems) |
"ParallelGenerator" | used for initializing and seeding generators for parallel computations. |
"ParallelMersenneTwister" | set of 1024 Mersenne Twister generators of period ![]() |
"Rule30CA" | Wolfram rule thirty generator |
Congruential
data:image/s3,"s3://crabby-images/297da/297da6c642bc9cbb910bb75349a3600260ecf0dc" alt=""
pick name | default value | |
"Bits" | Automated | specify range of bits to use for numbers constructed from $.25 |
"Multiplier" | 1283839219676404755 | multiplier value |
"Increment" | 0 | increment value |
"Modulus" | 2305843009213693951 | modulus value |
"ConvertToRealsDirectly" | True | whether reals should be constructed straight from the congruence relation |
data:image/s3,"s3://crabby-images/ee908/ee908d816bbbc923d55bd996c32063e600713b6a" alt=""
ExtendedCA
selection proper noun | default value | |
"Size" | 80 | state vector size every bit a multiplier of 64 |
"Skip" | 4 | number of cells to skip |
"First" | 0 | which cell to showtime from |
data:image/s3,"s3://crabby-images/a983d/a983d52afe3c58020dd297bd4635f32329437b3f" alt=""
Legacy
MersenneTwister
data:image/s3,"s3://crabby-images/91995/91995cb92c6667b670d3c4891b0d84a5690274f1" alt=""
MKL
"MCG31" | 31-flake multiplicative congruential generator |
"MCG59" | 59-bit multiplicative congruential generator |
"MRG32K3A" | combined multiple recursive generators with two components of order three |
"MersenneTwister" | Mersenne Twister shift register generator |
"R250" | generalized feedback shift register generator |
"WichmannHill" | Wichmann–Hill combined multiplicative congruential generators |
"Niederreiter" | Niederreiter low-discrepancy sequence |
"Sobol" | Sobol depression-discrepancy sequence |
Rule30CA
data:image/s3,"s3://crabby-images/14f33/14f33eb709095a2dfecc2850938635af3e708cd7" alt=""
choice proper noun | default value | |
"Size" | nine | state vector size every bit a multiplier of 29 |
data:image/s3,"s3://crabby-images/849a3/849a3038a48343b982b7ef024efabd85dca2c56e" alt=""
ParallelMersenneTwister
data:image/s3,"s3://crabby-images/76e14/76e1401e85bd13229c48969d6ce83d14c53e872b" alt=""
pick proper name | default value | |
"Alphabetize" | 0 | which generator to use from 0 to 1023 |
ParallelGenerator
option name | default value | |
Method | Automatic | which contained generators to use |
"ParallelMersenneTwister" | parallel Mersenne twister generators with period ![]() |
"ExtendedCA" | extended CA generators with dissimilar starting positions |
f | generator f [ i ] used for the i thursday thread |
"Default" | restores the default method |
Defining Your Own Generator
Random`InitializeGenerator[ gsym , opts ] | |
initialize the generator gsym with options opts |
GeneratesBitsQ | set to Truthful if the method generates bits |
GeneratesIntegersQ | fix to Truthful if the method generates integers for a given range |
GeneratesRealsQ | set to True if the method generates reals for a given range and precision |
data:image/s3,"s3://crabby-images/02e9b/02e9ba9095547f34d5a996499e8b5a4b7a6deab2" alt=""
data:image/s3,"s3://crabby-images/d8991/d899112f2984e1eb58a2adeb6ec5da4833aae27b" alt=""
Example: Multiplicative Congruential Generator
data:image/s3,"s3://crabby-images/560dd/560dd74be07432239ca70f586c0cce16b6255d52" alt=""
data:image/s3,"s3://crabby-images/06314/06314897256620777d2d3d2ccf31fc41583b2980" alt=""
Example: Blum–Blum–Shub Generator
RandomVariate[ dist ] | requite a random number from the continuous distribution dist |
RandomVariate[ dist , n ] | give a list of due north pseudorandom reals from dist |
RandomVariate[ dist , { n 1 , n ii , … } ] | give an due north 1 × n 2 × … array of pseudorandom reals from dist |
Continuous Distributions
data:image/s3,"s3://crabby-images/cf4ea/cf4ea3ea9fc3fd4fde4d9cd78b1c854048cc797a" alt=""
data:image/s3,"s3://crabby-images/d35bf/d35bf206ad0b369ca299ba7f98df34c15b8ea238" alt=""
data:image/s3,"s3://crabby-images/f01fe/f01fe8476fec01399d0fc6482224c2bb9b36fa91" alt=""
data:image/s3,"s3://crabby-images/99d64/99d645a47f6a9f510e383e922db5aae8898687cc" alt=""
data:image/s3,"s3://crabby-images/376b7/376b79fde7b55bc5c4b3a48e0c401b139a50e5af" alt=""
data:image/s3,"s3://crabby-images/f1a53/f1a53c5ae961f6a70fcb910c66be73f452ec1a7d" alt=""
data:image/s3,"s3://crabby-images/b23f7/b23f7bda2a9f49521c34d9138fe6889dffa5c38a" alt=""
data:image/s3,"s3://crabby-images/93dc5/93dc52fd843cb6bd6451fe0a528dcec6cab5f1a4" alt=""
data:image/s3,"s3://crabby-images/480ba/480ba007e19360260dad1abe5c2b6e23dfd090ce" alt=""
data:image/s3,"s3://crabby-images/41d45/41d45981905254d48f2426d86fa731548cdba65e" alt=""
data:image/s3,"s3://crabby-images/c88f1/c88f158b59fb79974fab1a8e79df54fa1203f703" alt=""
data:image/s3,"s3://crabby-images/8d651/8d651f9fed9aba608c7463bdea3783a8b102b37e" alt=""
data:image/s3,"s3://crabby-images/73655/736558959e8a8f6bb71b72cf113bfeef778c847d" alt=""
data:image/s3,"s3://crabby-images/6925b/6925b7b1e56b97d227518e86d11387cce92fdea2" alt=""
data:image/s3,"s3://crabby-images/814d1/814d1226c0cfa1aadba71729b6283dfe21ae52cf" alt=""
data:image/s3,"s3://crabby-images/4444c/4444c885701b2d106cf78d7bff6e5e5bc6d92b78" alt=""
data:image/s3,"s3://crabby-images/5dbf0/5dbf07042b4e2255b9c9eeb82d38212b6d33ba62" alt=""
data:image/s3,"s3://crabby-images/63282/6328263931e2c26ada702b2438c4f06fd6a37e25" alt=""
data:image/s3,"s3://crabby-images/fc147/fc1473c8e99e47ca95208f87ecb0ad41959bed83" alt=""
data:image/s3,"s3://crabby-images/d1ce8/d1ce8913048f87c292dca632caa968bda67d4536" alt=""
data:image/s3,"s3://crabby-images/b47a8/b47a835a91b8a3e9ae865d93bf974c52bedb4b92" alt=""
data:image/s3,"s3://crabby-images/edb5e/edb5e78b16fc5918c57c51e314353393fd381621" alt=""
data:image/s3,"s3://crabby-images/a7b2a/a7b2a8e94043fa7cd7c64bb95aeaafa049d1e610" alt=""
data:image/s3,"s3://crabby-images/650e8/650e8ccea8b4ecbadfbcb68066d6ebab776e8b78" alt=""
data:image/s3,"s3://crabby-images/6b608/6b6082c3457abd5336098fee5d08b49cec8a1369" alt=""
data:image/s3,"s3://crabby-images/837d0/837d0a0b77ae2fd53c7d3e3f8c327d331d8abd0e" alt=""
Discrete Distributions
data:image/s3,"s3://crabby-images/3208f/3208f39fa99b7e710778a659898d01d51f59333a" alt=""
Defining Distributional Generators
Random`DistributionVector[ expr , northward , prec ] | |
defines rules for generating northward observations from expr with precision prec |
data:image/s3,"s3://crabby-images/326cb/326cbf6d6109dfe6153e37f100d2878d65aa0bb0" alt=""
data:image/s3,"s3://crabby-images/965cd/965cd653d32650a4af46374d0c8ddd727f3c9dc5" alt=""
Case: Normal Distribution by Inversion
Example: Uniform Distribution on a Disk
Example: Gibbs Sampler
[1] Geman, Due south. and D. Geman. "Stochastic Relaxation, Gibbs Distributions, and the Bayesian Restoration of Images." IEEE Transactions on Pattern Analysis and Automobile Intelligence 6, no. 6 (1984): 721–741.
[2] Casella, Chiliad. and E. I. George. "Explaining the Gibbs Sampler." The American Statistician 46, no. iii (1992): 167–174.
[3] Matsumoto, Thou. and T. Nishimura. "Mersenne Twister: A 623-Dimensionally Equidistributed Compatible Pseudorandom Number Generator." ACM Transactions on Modeling and Computer Simulation eight, no. 1 (1998): 3–thirty.
[four] Nishimura, T. "Tables of 64-Bit Mersenne Twisters." ACM Transactions on Modeling and Computer Simulation 10, no. 4 (2000): 348–357.
[5] Junod, P. "Cryptographic Secure Pseudo-Random Bits Generation: The Blum–Blum–Shub Generator." August 1999. http://crypto.junod.info/bbs.pdf
[half-dozen] Gentle, J. E. Random Number Generation and Monte Carlo Methods, 2d ed. Springer-Verlag, 2003.
[7] Johnson, N. L., S. Kotz, and N. Balakrishnan. Continuous Univariate Distributions, Volume 2, 2nd ed. John Wiley & Sons, 1995.
[8] Smith, Due west. B. and R. R. Hocking. "Algorithm AS 53: Wishart Variate Generator." Applied Statistics 21, no. iii (1972): 341–345.
[9] Cheng, R. C. H. and G. K. Feast. "Some Simple Gamma Variate Generators." Applied Statistics 28, no. 3 (1979): 290–295.
[10] Johnson, M. East. Multivariate Statistical Simulation. John Wiley & Sons, 1987.
[11] Jöhnk, Chiliad. D. "Erzeugung von Betaverteilten und Gammaverteilten Zufallszahlen." Metrika eight (1964): 5–15.
[12] Cheng, R. C. H. "Generating Beta Variables with Nonintegral Shape Parameters." Communications of the ACM 21, no. 4 (1978): 317–322.
[xiii] Atkinson, A. C. "A Family of Switching Algorithms for the Computer Generation of Beta Random Variables." Biometrika 66, no. one (1979): 141–145.
[xiv] Bailey, R. W. "Polar Generation of Random Variates with the t-Distribution." Mathematics of Ciphering 62, no. 206 (1994): 779–781.
[15] Devroye, 50. Non-Uniform Random Variate Generation. Springer-Verlag, 1986.
[xvi] Kachitvichyanukul, V. and B. W. Schmeiser. "Binomial Random Variate Generation." Communications of the ACM 31, no. 2 (1988): 216–223.
[17] Kachitvichyanukul, V. and B. Due west. Schmeiser. "Computer Generation of Hypergeometric Random Variates." Journal of Statistical Computation and Simulation 22, no. ii (1985): 127–145.
[18] Ahrens, J. H. and U. Dieter. "Computer Generation of Poisson Deviates from Modified Normal Distributions." ACM Transactions on Mathematical Software 8, no. 2 (1982): 163–179.
[19] Matsumoto, M. and T. Nishimura. "Dynamic Creation of Pseudorandom Number Generators." In Proceedings of the Third International Conference on Monte Carlo and Quasi-Monte Carlo Methods in Scientific Calculating: Monte Carlo and Quasi‐Monte Carlo Methods 1998, 56–69, 2000.
0 Response to "Random Number Generator in Arbitrary Probability Distribution Fashion"
Post a Comment