Pi10K Pseudo-Random Number Generator Algorithm Test.
by William Donnelly
Additional information, description, and explanation below-bottom.
This page was coded for Firefox 3.x+, but should work on any modern browser.
Pi 10K PRNG
var gnPiLength = gsPiDigits.length; // see below-bottom for gsPiDigits string
var gnPiOffset = 0;
function Pi10K()
{
var sNumber = "";
var nLength = parseInt (gsPiDigits[gnPiOffset++]);
if (gnPiOffset >= gnPiLength)
gnPiOffset = 0;
for (var ii = 0; ii < nLength; ++ii) {
sNumber += gsPiDigits[gnPiOffset++];
if (gnPiOffset >= gnPiLength)
gnPiOffset = 0;
} // for
return parseInt (sNumber) & 0xFF;
} // Pi10K
More information, description and explanation.
Test of a PRNG created from choosing digit-values from the first 10,000 digits of the Pi constant.
You can see by the reported results that this a VERY poor PRNG algorithm.
Min Times a Rand# was Chosen = 35 Max Times a Rand# was Chosen = 8828 Average Times a Rand# was Chosen = 256 Average Distance between Rand# Chosen Again = 439.70993631558287 Min Average Distance = 6.422632532850023 Max Average Distance = 1852.857142857143 Min Distance = 0 Max Distance = 1853
Min and Max Times a Rand# was Chosen should be near 256 (+/- 50?), as should be Min and Max Average Distance, as should be Average Distance between Rand# Chosen Again. The rough Plot clearly shows weird, extreme anomalies. (and is "blown out" with the very high values of some number chosen counts because it is expected that each number will be chosen about 256 times and not more or less than about half (+/-) that value)
var gsPiDigits = "3" +
"14159265358979323846264338327950288419716939937510" +
"58209749445923078164062862089986280348253421170679" +
"82148086513282306647093844609550582231725359408128" +
"48111745028410270193852110555964462294895493038196" +
"44288109756659334461284756482337867831652712019091" +
"45648566923460348610454326648213393607260249141273" +
"72458700660631558817488152092096282925409171536436" +
"78925903600113305305488204665213841469519415116094" +
"33057270365759591953092186117381932611793105118548" +
"07446237996274956735188575272489122793818301194912" +
"98336733624406566430860213949463952247371907021798" +
"60943702770539217176293176752384674818467669405132" +
"00056812714526356082778577134275778960917363717872" +
"14684409012249534301465495853710507922796892589235" +
"42019956112129021960864034418159813629774771309960" +
"51870721134999999837297804995105973173281609631859" +
"50244594553469083026425223082533446850352619311881" +
"71010003137838752886587533208381420617177669147303" +
"59825349042875546873115956286388235378759375195778" +
"18577805321712268066130019278766111959092164201989" +
"38095257201065485863278865936153381827968230301952" +
"03530185296899577362259941389124972177528347913151" +
"55748572424541506959508295331168617278558890750983" +
"81754637464939319255060400927701671139009848824012" +
"85836160356370766010471018194295559619894676783744" +
"94482553797747268471040475346462080466842590694912" +
"93313677028989152104752162056966024058038150193511" +
"25338243003558764024749647326391419927260426992279" +
"67823547816360093417216412199245863150302861829745" +
"55706749838505494588586926995690927210797509302955" +
"32116534498720275596023648066549911988183479775356" +
"63698074265425278625518184175746728909777727938000" +
"81647060016145249192173217214772350141441973568548" +
"16136115735255213347574184946843852332390739414333" +
"45477624168625189835694855620992192221842725502542" +
"56887671790494601653466804988627232791786085784383" +
"82796797668145410095388378636095068006422512520511" +
"73929848960841284886269456042419652850222106611863" +
"06744278622039194945047123713786960956364371917287" +
"46776465757396241389086583264599581339047802759009" +
"94657640789512694683983525957098258226205224894077" +
"26719478268482601476990902640136394437455305068203" +
"49625245174939965143142980919065925093722169646151" +
"57098583874105978859597729754989301617539284681382" +
"68683868942774155991855925245953959431049972524680" +
"84598727364469584865383673622262609912460805124388" +
"43904512441365497627807977156914359977001296160894" +
"41694868555848406353422072225828488648158456028506" +
"01684273945226746767889525213852254995466672782398" +
"64565961163548862305774564980355936345681743241125" +
"15076069479451096596094025228879710893145669136867" +
"22874894056010150330861792868092087476091782493858" +
"90097149096759852613655497818931297848216829989487" +
"22658804857564014270477555132379641451523746234364" +
"54285844479526586782105114135473573952311342716610" +
"21359695362314429524849371871101457654035902799344" +
"03742007310578539062198387447808478489683321445713" +
"86875194350643021845319104848100537061468067491927" +
"81911979399520614196634287544406437451237181921799" +
"98391015919561814675142691239748940907186494231961" +
"56794520809514655022523160388193014209376213785595" +
"66389377870830390697920773467221825625996615014215" +
"03068038447734549202605414665925201497442850732518" +
"66600213243408819071048633173464965145390579626856" +
"10055081066587969981635747363840525714591028970641" +
"40110971206280439039759515677157700420337869936007" +
"23055876317635942187312514712053292819182618612586" +
"73215791984148488291644706095752706957220917567116" +
"72291098169091528017350671274858322287183520935396" +
"57251210835791513698820914442100675103346711031412" +
"67111369908658516398315019701651511685171437657618" +
"35155650884909989859982387345528331635507647918535" +
"89322618548963213293308985706420467525907091548141" +
"65498594616371802709819943099244889575712828905923" +
"23326097299712084433573265489382391193259746366730" +
"58360414281388303203824903758985243744170291327656" +
"18093773444030707469211201913020330380197621101100" +
"44929321516084244485963766983895228684783123552658" +
"21314495768572624334418930396864262434107732269780" +
"28073189154411010446823252716201052652272111660396" +
"66557309254711055785376346682065310989652691862056" +
"47693125705863566201855810072936065987648611791045" +
"33488503461136576867532494416680396265797877185560" +
"84552965412665408530614344431858676975145661406800" +
"70023787765913440171274947042056223053899456131407" +
"11270004078547332699390814546646458807972708266830" +
"63432858785698305235808933065757406795457163775254" +
"20211495576158140025012622859413021647155097925923" +
"09907965473761255176567513575178296664547791745011" +
"29961489030463994713296210734043751895735961458901" +
"93897131117904297828564750320319869151402870808599" +
"04801094121472213179476477726224142548545403321571" +
"85306142288137585043063321751829798662237172159160" +
"77166925474873898665494945011465406284336639379003" +
"97692656721463853067360965712091807638327166416274" +
"88880078692560290228472104031721186082041900042296" +
"61711963779213375751149595015660496318629472654736" +
"42523081770367515906735023507283540567040386743513" +
"62222477158915049530984448933309634087807693259939" +
"78054193414473774418426312986080998886874132604721" +
"56951623965864573021631598193195167353812974167729" +
"47867242292465436680098067692823828068996400482435" +
"40370141631496589794092432378969070697794223625082" +
"21688957383798623001593776471651228935786015881617" +
"55782973523344604281512627203734314653197777416031" +
"99066554187639792933441952154134189948544473456738" +
"31624993419131814809277771038638773431772075456545" +
"32207770921201905166096280490926360197598828161332" +
"31666365286193266863360627356763035447762803504507" +
"77235547105859548702790814356240145171806246436267" +
"94561275318134078330336254232783944975382437205835" +
"31147711992606381334677687969597030983391307710987" +
"04085913374641442822772634659470474587847787201927" +
"71528073176790770715721344473060570073349243693113" +
"83504931631284042512192565179806941135280131470130" +
"47816437885185290928545201165839341965621349143415" +
"95625865865570552690496520985803385072242648293972" +
"85847831630577775606888764462482468579260395352773" +
"48030480290058760758251047470916439613626760449256" +
"27420420832085661190625454337213153595845068772460" +
"29016187667952406163425225771954291629919306455377" +
"99140373404328752628889639958794757291746426357455" +
"25407909145135711136941091193932519107602082520261" +
"87985318877058429725916778131496990090192116971737" +
"27847684726860849003377024242916513005005168323364" +
"35038951702989392233451722013812806965011784408745" +
"19601212285993716231301711444846409038906449544400" +
"61986907548516026327505298349187407866808818338510" +
"22833450850486082503930213321971551843063545500766" +
"82829493041377655279397517546139539846833936383047" +
"46119966538581538420568533862186725233402830871123" +
"28278921250771262946322956398989893582116745627010" +
"21835646220134967151881909730381198004973407239610" +
"36854066431939509790190699639552453005450580685501" +
"95673022921913933918568034490398205955100226353536" +
"19204199474553859381023439554495977837790237421617" +
"27111723643435439478221818528624085140066604433258" +
"88569867054315470696574745855033232334210730154594" +
"05165537906866273337995851156257843229882737231989" +
"87571415957811196358330059408730681216028764962867" +
"44604774649159950549737425626901049037781986835938" +
"14657412680492564879855614537234786733039046883834" +
"36346553794986419270563872931748723320837601123029" +
"91136793862708943879936201629515413371424892830722" +
"01269014754668476535761647737946752004907571555278" +
"19653621323926406160136358155907422020203187277605" +
"27721900556148425551879253034351398442532234157623" +
"36106425063904975008656271095359194658975141310348" +
"22769306247435363256916078154781811528436679570611" +
"08615331504452127473924544945423682886061340841486" +
"37767009612071512491404302725386076482363414334623" +
"51897576645216413767969031495019108575984423919862" +
"91642193994907236234646844117394032659184044378051" +
"33389452574239950829659122850855582157250310712570" +
"12668302402929525220118726767562204154205161841634" +
"84756516999811614101002996078386909291603028840026" +
"91041407928862150784245167090870006992821206604183" +
"71806535567252532567532861291042487761825829765157" +
"95984703562226293486003415872298053498965022629174" +
"87882027342092222453398562647669149055628425039127" +
"57710284027998066365825488926488025456610172967026" +
"64076559042909945681506526530537182941270336931378" +
"51786090407086671149655834343476933857817113864558" +
"73678123014587687126603489139095620099393610310291" +
"61615288138437909904231747336394804575931493140529" +
"76347574811935670911013775172100803155902485309066" +
"92037671922033229094334676851422144773793937517034" +
"43661991040337511173547191855046449026365512816228" +
"82446257591633303910722538374218214088350865739177" +
"15096828874782656995995744906617583441375223970968" +
"34080053559849175417381883999446974867626551658276" +
"58483588453142775687900290951702835297163445621296" +
"40435231176006651012412006597558512761785838292041" +
"97484423608007193045761893234922927965019875187212" +
"72675079812554709589045563579212210333466974992356" +
"30254947802490114195212382815309114079073860251522" +
"74299581807247162591668545133312394804947079119153" +
"26734302824418604142636395480004480026704962482017" +
"92896476697583183271314251702969234889627668440323" +
"26092752496035799646925650493681836090032380929345" +
"95889706953653494060340216654437558900456328822505" +
"45255640564482465151875471196218443965825337543885" +
"69094113031509526179378002974120766514793942590298" +
"96959469955657612186561967337862362561252163208628" +
"69222103274889218654364802296780705765615144632046" +
"92790682120738837781423356282360896320806822246801" +
"22482611771858963814091839036736722208883215137556" +
"00372798394004152970028783076670944474560134556417" +
"25437090697939612257142989467154357846878861444581" +
"23145935719849225284716050492212424701412147805734" +
"55105008019086996033027634787081081754501193071412" +
"23390866393833952942578690507643100638351983438934" +
"15961318543475464955697810382930971646514384070070" +
"73604112373599843452251610507027056235266012764848" +
"30840761183013052793205427462865403603674532865105" +
"70658748822569815793678976697422057505968344086973" +
"50201410206723585020072452256326513410559240190274" +
"21624843914035998953539459094407046912091409387001" +
"26456001623742880210927645793106579229552498872758" +
"4610126483699989225695968815920560010165525637568";
# END #
E-mail the author / creator / programmer: Contact William Donnelly