Script Preparation code:
x
 
  var nums = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10];
  
  function sum_recurse(arr, i) {
   i = i || 0;
   if (i > arr.length)
     return 0;
   else
     return arr[i] + sum_recurse(arr, i + 1);
  }
 function sum_recurse_tail(arr, i, sum = 0) {
   i = i || 0;
   if (i > arr.length)
     return 0;
   else
     return sum_recurse(arr, i + 1, sum + arr[i]);
  }
  
  function sum_while(arr) {
   var total = 0,
       i = 0,
       len = arr.length;
  
   while (i < len) {
    total += arr[i++];
   }
  
   return total;
  }
  
  function sum_for(arr) {
   var total = 0,
       len = arr.length;
  
   for (var i = 0; i < len; i++) {
    total += arr[i];
   }
  
   return total;
  }
Tests:
  • recursion

     
    sum_recurse(nums)
  • while loop

     
    sum_while(nums)
  • for loop

     
    sum_for(nums)
  • recurse (tail)

     
    sum_recurse_tail(nums)
Rendered benchmark preparation results:

Suite status: <idle, ready to run>

Previous results

Experimental features:

  • Test case name Result
    recursion
    while loop
    for loop
    recurse (tail)

    Fastest: N/A

    Slowest: N/A

Latest run results:
Run details: (Test run date: 9 months ago)
Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/123.0.0.0 Safari/537.36 OPR/109.0.0.0
Opera 109 on Windows
View result in a separate tab
Test name Executions per second
recursion 548839.1 Ops/sec
while loop 3232907.8 Ops/sec
for loop 3647159.5 Ops/sec
recurse (tail) 569380.4 Ops/sec