Typed array iteration (v13)

Revision 13 of this benchmark created by vjeux on


Preparation HTML

<canvas width="512" height="512" id="canvas" style="border: 1px dashed black;"></canvas>
<script>
  var classic = new Array(1048576);
  var context = document.getElementById("canvas").getContext("2d");
  var imageData = context.getImageData(0, 0, 512, 512);
  var canvas = imageData.data;
  if (typeof Uint8Array !== 'undefined') {
   var typed8 = new Uint8Array(1048576);
   var typed32 = new Uint32Array(1048576);
  }
  
  for (var i = 0; i < 1048576; ++i) {
   var number = ~~ (Math.random() * 254)
   classic[i] = number;
   canvas[i] = number;
   if (typeof Uint8Array !== 'undefined') {
    typed8[i] = number;
    typed32[i] = number;
   }
  }
  
  context.putImageData(imageData, 0, 0);
</script>

Test runner

Ready to run.

Testing in
TestOps/sec
Classic
for (var ii = 0; ii < 1048576; ++ii) {
 classic[ii] += 1;
}
ready
Canvas
for (var ii = 0; ii < 1048576; ++ii) {
 canvas[ii] += 1;
}
ready
Typed 8
if (typeof Uint8Array === 'undefined') {
 throw "Error";
}

for (var ii = 0; ii < 1048576; ++ii) {
 typed8[ii] += 1;
}
ready
Typed 32
if (typeof Uint8Array === 'undefined') {
 throw "Error";
}

for (var ii = 0; ii < 1048576; ++ii) {
 typed32[ii] += 1;
}
ready

Revisions

You can edit these tests or add more tests to this page by appending /edit to the URL.