mirror of
https://github.com/JustinSDK/dotSCAD.git
synced 2025-01-17 14:18:13 +01:00
refactor
This commit is contained in:
parent
193f38d531
commit
42fa6df7cc
@ -1,4 +1,3 @@
|
||||
use <../../util/sorted.scad>;
|
||||
use <../../util/sum.scad>;
|
||||
|
||||
function _manhattan(v) = sum([for(d = v) abs(d)]);
|
||||
@ -6,27 +5,33 @@ function _manhattan(v) = sum([for(d = v) abs(d)]);
|
||||
function _chebyshev(p1, p2) =
|
||||
max([for(i = [0:len(p1) - 1]) abs(p1[i] - p2[i])]);
|
||||
|
||||
function _nz_cell_classic(cells, p, dist) =
|
||||
let(
|
||||
dists =
|
||||
dist == "euclidean" ? [for(cell = cells) norm(cell - p)] :
|
||||
dist == "manhattan" ? [for(cell = cells) _manhattan(cell - p)] :
|
||||
dist == "chebyshev" ? [for(cell = cells) _chebyshev(cell, p)] :
|
||||
assert("Unknown distance option")
|
||||
)
|
||||
min(dists);
|
||||
function _nz_worley_euclidean(p, cells) =
|
||||
_nz_worley_from(cells, [for(cell = cells) norm(cell - p)]);
|
||||
|
||||
function _nz_cell_border(cells, p) =
|
||||
function _nz_worley_manhattan(p, cells) =
|
||||
_nz_worley_from(cells, [for(cell = cells) _manhattan(cell - p)]);
|
||||
|
||||
function _nz_worley_chebyshev(p, cells) =
|
||||
_nz_worley_from(cells, [for(cell = cells) _chebyshev(cell, p)]);
|
||||
|
||||
function _nz_worley_from(cells, dists) =
|
||||
let(
|
||||
m = min(dists),
|
||||
i = search(m, dists)[0]
|
||||
)
|
||||
m;
|
||||
|
||||
function _nz_worley_border(p, cells) =
|
||||
let(
|
||||
dists = [for(cell = cells) norm(cell - p)],
|
||||
m1 = min(dists),
|
||||
i1 = search(m1, dists)[0],
|
||||
dists2 = [for(i = [0:len(dists) - 1]) if(i != i1) dists[i]],
|
||||
cells2 = [for(i = [0:len(cells) - 1]) if(i != i1) cells[i]],
|
||||
nbrs2 = [for(i = [0:len(cells) - 1]) if(i != i1) cells[i]],
|
||||
m2 = min(dists2),
|
||||
i2 = search(m2, dists2)[0],
|
||||
fst = cells[i1],
|
||||
snd = cells2[i2],
|
||||
snd = nbrs2[i2],
|
||||
m = (fst + snd) / 2
|
||||
)
|
||||
(p - m) * (fst - m);
|
@ -11,5 +11,8 @@
|
||||
use <_impl/_nz_cell_impl.scad>;
|
||||
|
||||
function nz_cell(points, p, dist = "euclidean") =
|
||||
dist == "border" ? _nz_cell_border(points, p) :
|
||||
_nz_cell_classic(points, p, dist);
|
||||
dist == "euclidean" ? _nz_worley_euclidean(p, points) :
|
||||
dist == "manhattan" ? _nz_worley_manhattan(p, points) :
|
||||
dist == "chebyshev" ? _nz_worley_chebyshev(p, points) :
|
||||
dist == "border" ? _nz_worley_border(p, points) :
|
||||
assert("Unknown distance option");
|
Loading…
x
Reference in New Issue
Block a user