(function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.ngraphRandom = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o= 1 || r === 0); return x * Math.sqrt(-2 * Math.log(r)/r); } /** * See https://twitter.com/anvaka/status/1296182534150135808 */ Generator.prototype.levy = levy; function levy() { var beta = 3 / 2; var sigma = Math.pow( gamma( 1 + beta ) * Math.sin(Math.PI * beta / 2) / (gamma((1 + beta) / 2) * beta * Math.pow(2, (beta - 1) / 2)), 1/beta ); return this.gaussian() * sigma / Math.pow(Math.abs(this.gaussian()), 1/beta); } // gamma function approximation function gamma(z) { return Math.sqrt(2 * Math.PI / z) * Math.pow((1 / Math.E) * (z + 1 / (12 * z - 1 / (10 * z))), z); } function nextDouble() { var seed = this.seed; // Robert Jenkins' 32 bit integer hash function. seed = ((seed + 0x7ed55d16) + (seed << 12)) & 0xffffffff; seed = ((seed ^ 0xc761c23c) ^ (seed >>> 19)) & 0xffffffff; seed = ((seed + 0x165667b1) + (seed << 5)) & 0xffffffff; seed = ((seed + 0xd3a2646c) ^ (seed << 9)) & 0xffffffff; seed = ((seed + 0xfd7046c5) + (seed << 3)) & 0xffffffff; seed = ((seed ^ 0xb55a4f09) ^ (seed >>> 16)) & 0xffffffff; this.seed = seed; return (seed & 0xfffffff) / 0x10000000; } function next(maxValue) { return Math.floor(this.nextDouble() * maxValue); } /* * Creates iterator over array, which returns items of array in random order * Time complexity is guaranteed to be O(n); */ function randomIterator(array, customRandom) { var localRandom = customRandom || random(); if (typeof localRandom.next !== 'function') { throw new Error('customRandom does not match expected API: next() function is missing'); } return { forEach: forEach, /** * Shuffles array randomly, in place. */ shuffle: shuffle }; function shuffle() { var i, j, t; for (i = array.length - 1; i > 0; --i) { j = localRandom.next(i + 1); // i inclusive t = array[j]; array[j] = array[i]; array[i] = t; } return array; } function forEach(callback) { var i, j, t; for (i = array.length - 1; i > 0; --i) { j = localRandom.next(i + 1); // i inclusive t = array[j]; array[j] = array[i]; array[i] = t; callback(t); } if (array.length) { callback(array[0]); } } } },{}]},{},[1])(1) });