Merge pull request #607 from atomiks/utils

Add mostPerformant snippet
This commit is contained in:
Angelos Chalaris
2018-02-14 13:53:21 +02:00
committed by GitHub
2 changed files with 32 additions and 0 deletions

View File

@ -0,0 +1,31 @@
### mostPerformant
Returns the index of the function in an array of functions which executed the fastest.
Use `Array.map()` to generate an array where each value is the total time taken to execute the function after `iterations` times. Use the difference in `performance.now()` values before and after to get the total time in milliseconds to a high degree of accuracy.
Use `Math.min()` to find the minimum execution time, and return the index of that shortest time which corresponds to the index of the most performant function.
Omit the second argument, `iterations`, to use a default of 10,000 iterations. The more iterations, the more reliable the result but the longer it will take.
```js
const mostPerformant = (fns, iterations = 10000) => {
const times = fns.map(fn => {
const before = performance.now();
for (let i = 0; i < iterations; i++) fn();
return performance.now() - before;
});
return times.indexOf(Math.min(...times));
};
```
```js
mostPerformant([
() => {
// Loops through the entire array before returning `false`
[1, 2, 3, 4, 5, 6, 7, 8, 9, '10'].every(el => typeof el === 'number')
},
() => {
// Only needs to reach index `1` before returning false
[1, '2', 3, 4, 5, 6, 7, 8, 9, 10].every(el => typeof el === 'number')
}
]); // 1
```

View File

@ -162,6 +162,7 @@ memoize:function
merge:object,array merge:object,array
minBy:math,array,function minBy:math,array,function
minN:array,math minN:array,math
mostPerformant:utility,function
negate:function negate:function
none:array none:array
noneBy:array,function noneBy:array,function