diff options
author | Araq <rumpf_a@web.de> | 2014-11-07 00:27:31 +0100 |
---|---|---|
committer | Araq <rumpf_a@web.de> | 2014-11-07 00:27:31 +0100 |
commit | b5586264a0e0515f88f7ad4944bb987930fbd7b9 (patch) | |
tree | aed2e14820214783049e9a4366f06e975b91222b /tests/parallel | |
parent | 9500dfcc2e7b56a626744eff3000612b13c79575 (diff) | |
download | Nim-b5586264a0e0515f88f7ad4944bb987930fbd7b9.tar.gz |
broken attempt to fix queue exhaustion
Diffstat (limited to 'tests/parallel')
-rw-r--r-- | tests/parallel/tconvexhull.nim | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/tests/parallel/tconvexhull.nim b/tests/parallel/tconvexhull.nim new file mode 100644 index 000000000..c97fed39b --- /dev/null +++ b/tests/parallel/tconvexhull.nim @@ -0,0 +1,62 @@ +discard """ + output: '''true +true +true +true +true +true''' +""" + +# parallel convex hull for Nim bigbreak +# nim c --threads:on -d:release pconvex_hull.nim +import algorithm, sequtils, threadpool + +type Point = tuple[x, y: float] + +proc cmpPoint(a, b: Point): int = + result = cmp(a.x, b.x) + if result == 0: + result = cmp(a.y, b.y) + +template cross[T](o, a, b: T): expr = + (a.x - o.x) * (b.y - o.y) - (a.y - o.y) * (b.x - o.x) + +template pro(): expr = + while lr1 > 0 and cross(result[lr1 - 1], result[lr1], p[i]) <= 0: + discard result.pop + lr1 -= 1 + result.add(p[i]) + lr1 += 1 + +proc half[T](p: seq[T]; upper: bool): seq[T] = + var i, lr1: int + result = @[] + lr1 = -1 + if upper: + i = 0 + while i <= high(p): + pro() + i += 1 + else: + i = high(p) + while i >= low(p): + pro() + i -= 1 + discard result.pop + +proc convex_hull[T](points: var seq[T], cmp: proc(x, y: T): int {.closure.}) : seq[T] = + if len(points) < 2: return points + points.sort(cmp) + var ul: array[2, FlowVar[seq[T]]] + parallel: + for k in 0..ul.high: + ul[k] = spawn half[T](points, k == 0) + result = concat(^ul[0], ^ul[1]) + +var s = map(toSeq(0..999999), proc(x: int): Point = (float(x div 1000), float(x mod 1000))) +setMaxPoolSize 2 + +#echo convex_hull[Point](s, cmpPoint) +for i in 0..5: + echo convex_hull[Point](s, cmpPoint) == + @[(0.0, 0.0), (999.0, 0.0), (999.0, 999.0), (0.0, 999.0)] |