Improve random number array generation
authorJérôme Benoit <jerome.benoit@sap.com>
Mon, 24 Oct 2022 12:18:08 +0000 (14:18 +0200)
committerJérôme Benoit <jerome.benoit@sap.com>
Mon, 24 Oct 2022 12:18:08 +0000 (14:18 +0200)
Signed-off-by: Jérôme Benoit <jerome.benoit@sap.com>
benchmark-utils.js
empty-array.js
max.js

index 50aa39ce19f25d5cc2639c3d541dd914f63b66c7..961043b03ca0d233295607608356d33ebb61ea65 100644 (file)
@@ -33,13 +33,33 @@ function generateRandomInteger (max = Number.MAX_SAFE_INTEGER, min = 0) {
  *
  * @param size
  * @param max
+ * @param numberGenerator
  */
-function generateRandomIntegerArray (size, max = Number.MAX_SAFE_INTEGER) {
-  const integerArray = []
+function generateRandomNumberArray (
+  size,
+  max = Number.MAX_VALUE,
+  numberGenerator = generateRandomFloat
+) {
+  const array = []
   for (let i = 0; i < size; i++) {
-    integerArray.push(generateRandomInteger(max))
+    array.push(numberGenerator(max))
   }
-  return integerArray
+  return array
+}
+
+/**
+ *
+ * @param max
+ * @param min
+ * @param negative
+ */
+function generateRandomFloat (max = Number.MAX_VALUE, min = 0, negative = true) {
+  if (max < min || min < 0 || max < 0) {
+    throw new RangeError('Invalid interval')
+  }
+  const randomPositiveFloat = crypto.randomBytes(4).readUInt32LE() / 0xffffffff
+  const sign = negative && randomPositiveFloat < 0.5 ? -1 : 1
+  return sign * (randomPositiveFloat * (max - min) + min)
 }
 
 /**
@@ -57,7 +77,8 @@ const LIST_FORMATTER = new Intl.ListFormat('en-US', {
 
 module.exports = {
   generateRandomInteger,
-  generateRandomIntegerArray,
+  generateRandomFloat,
+  generateRandomNumberArray,
   sleep,
   secureRandom,
   LIST_FORMATTER
index 52f836e5f474b31f6c578291e9920a89d1f9df6a..a6a8acd84daa66c81fcdc5fa93c93d76e60841e2 100644 (file)
@@ -1,7 +1,7 @@
 const Benchmark = require('benny')
-const { generateRandomIntegerArray } = require('./benchmark-utils')
+const { generateRandomNumberArray } = require('./benchmark-utils')
 
-let testArray = generateRandomIntegerArray(10000)
+let testArray = generateRandomNumberArray(10000)
 
 Benchmark.suite(
   'Empty array',
diff --git a/max.js b/max.js
index 367a859126e91b8f2b70a04a41422f31f2951a22..bfa521cce36722fc35f72dc991d48fd9413b2e4a 100644 (file)
--- a/max.js
+++ b/max.js
@@ -1,7 +1,7 @@
 const Benchmark = require('benny')
-const { generateRandomIntegerArray } = require('./benchmark-utils')
+const { generateRandomNumberArray } = require('./benchmark-utils')
 
-const testArray = generateRandomIntegerArray(10000)
+const testArray = generateRandomNumberArray(10000)
 
 /**
  *