summaryrefslogtreecommitdiff
path: root/test/benchmarking/ParCtrie-nums.scala
diff options
context:
space:
mode:
authorAleksandar Prokopec <axel22@gmail.com>2012-02-22 15:59:37 +0100
committerAleksandar Prokopec <axel22@gmail.com>2012-02-22 15:59:37 +0100
commit4c9b2b930d3ce7a0301a8c680eb8be494574fd3c (patch)
treecdbba56a3064699556630e5422162765b8214362 /test/benchmarking/ParCtrie-nums.scala
parent14f3135368b923a1f5d14d1b4f7424db22fd7f79 (diff)
downloadscala-4c9b2b930d3ce7a0301a8c680eb8be494574fd3c.tar.gz
scala-4c9b2b930d3ce7a0301a8c680eb8be494574fd3c.tar.bz2
scala-4c9b2b930d3ce7a0301a8c680eb8be494574fd3c.zip
Add 2 benchmarks for Ctries.
Diffstat (limited to 'test/benchmarking/ParCtrie-nums.scala')
-rw-r--r--test/benchmarking/ParCtrie-nums.scala39
1 files changed, 39 insertions, 0 deletions
diff --git a/test/benchmarking/ParCtrie-nums.scala b/test/benchmarking/ParCtrie-nums.scala
new file mode 100644
index 0000000000..76d1966d1f
--- /dev/null
+++ b/test/benchmarking/ParCtrie-nums.scala
@@ -0,0 +1,39 @@
+
+
+
+
+
+import collection.parallel.mutable.ParCtrie
+
+
+case class Entry(num: Double) {
+ var sqrt = num
+}
+
+
+object Nums extends testing.Benchmark {
+ val length = sys.props("length").toInt
+ val par = sys.props("par").toInt
+ var entries: Seq[Entry] = null
+ var results: ParCtrie[Double, Entry] = null
+
+ collection.parallel.ForkJoinTasks.defaultForkJoinPool.setParallelism(par)
+
+ override def setUp() {
+ entries = (1 until length) map { num => Entry(num.toDouble) }
+ results = ParCtrie()
+ for (e <- entries) results += ((e.num, e))
+ }
+
+ def run() = {
+ while (results.nonEmpty) {
+ for ((num, e) <- results) {
+ val nsqrt = 0.5 * (e.sqrt + e.num / e.sqrt)
+ if (math.abs(nsqrt - e.sqrt) < 0.01) {
+ results.remove(num)
+ } else e.sqrt = nsqrt
+ }
+ }
+ }
+}
+