74 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			74 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
/*
 | 
						|
 * 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 })
 |