/* * immer: immutable data structures for C++ * Copyright (C) 2016, 2017, 2018 Juan Pedro Bolivar Puente * * This software is distributed under the Boost Software License, Version 1.0. * See accompanying file LICENSE or copy at http://boost.org/LICENSE_1_0.txt */ var immer = Module var N = 1000 var suite = new Benchmark.Suite('push') .add('Immutable.List', function(){ var v = new Immutable.List for (var x = 0; x < N; ++x) v = v.push(x) }) .add('mori.vector', function(){ var v = mori.vector() for (var x = 0; x < N; ++x) v = mori.conj.f2(v, x) }) .add('mori.vector-Transient', function(){ var v = mori.mutable.thaw(mori.vector()) for (var x = 0; x < N; ++x) v = mori.mutable.conj.f2(v, x) return mori.mutable.freeze(v) }) .add('immer.Vector', function(){ var v = new immer.Vector for (var x = 0; x < N; ++x) { var v_ = v v = v.push(x) v_.delete() } }) .add('immer.VectorInt', function(){ var v = new immer.VectorInt for (var x = 0; x < N; ++x) { var v_ = v v = v.push(x) v_.delete() } v.delete() }) .add('immer.VectorNumber', function(){ var v = new immer.VectorNumber for (var x = 0; x < N; ++x) { var v_ = v v = v.push(x) v_.delete() } v.delete() }) .add('immer.VectorInt-Native', function(){ immer.rangeSlow_int(0, N).delete() }) .add('immer.VectorInt-NativeTransient', function(){ immer.range_int(0, N).delete() }) .add('immer.VectorDouble-Native', function(){ immer.rangeSlow_double(0, N).delete() }) .add('immer.VectorDouble-NativeTransient', function(){ immer.range_double(0, N).delete() }) .on('cycle', function(event) { console.log(String(event.target)); }) .on('complete', function() { console.log('Fastest is ' + this.filter('fastest').map('name')); }) .run({ 'async': true })