about summary refs log tree commit diff
path: root/extra/js/index.js
diff options
context:
space:
mode:
authorVincent Ambo <mail@tazj.in>2020-07-15T07·20+0100
committerVincent Ambo <mail@tazj.in>2020-07-15T07·20+0100
commit7f19d641647ac4ef313ed88d6b5c140983ce5436 (patch)
tree31b66c81465293da5c093c5dde3e419758c0d6cc /extra/js/index.js
Squashed 'third_party/immer/' content from commit ad3e3556d
git-subtree-dir: third_party/immer
git-subtree-split: ad3e3556d38bb75966dd24c61a774970a7c7957e
Diffstat (limited to 'extra/js/index.js')
-rw-r--r--extra/js/index.js74
1 files changed, 74 insertions, 0 deletions
diff --git a/extra/js/index.js b/extra/js/index.js
new file mode 100644
index 000000000000..6da994164f8e
--- /dev/null
+++ b/extra/js/index.js
@@ -0,0 +1,74 @@
+/*
+ * 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 })