mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-01 09:49:45 +00:00
Optimized vnf_add_face() and vnf_add_faces()
This commit is contained in:
parent
1e2995fcf7
commit
258e162f98
2 changed files with 26 additions and 27 deletions
|
@ -8,7 +8,7 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
BOSL_VERSION = [2,0,248];
|
BOSL_VERSION = [2,0,249];
|
||||||
|
|
||||||
|
|
||||||
// Section: BOSL Library Version Functions
|
// Section: BOSL Library Version Functions
|
||||||
|
|
51
vnf.scad
51
vnf.scad
|
@ -81,26 +81,11 @@ function vnf_quantize(vnf,q=pow(2,-12)) =
|
||||||
// vnf3 = vnf_get_vertex(vnf2, p=[3,5,8]); // Returns: [0, [[[3,5,8],[3,2,1]],[]]]
|
// vnf3 = vnf_get_vertex(vnf2, p=[3,5,8]); // Returns: [0, [[[3,5,8],[3,2,1]],[]]]
|
||||||
// vnf4 = vnf_get_vertex(vnf3, p=[[1,3,2],[3,2,1]]); // Returns: [[1,2], [[[3,5,8],[3,2,1],[1,3,2]],[]]]
|
// vnf4 = vnf_get_vertex(vnf3, p=[[1,3,2],[3,2,1]]); // Returns: [[1,2], [[[3,5,8],[3,2,1],[1,3,2]],[]]]
|
||||||
function vnf_get_vertex(vnf=EMPTY_VNF, p) =
|
function vnf_get_vertex(vnf=EMPTY_VNF, p) =
|
||||||
is_path(p)? _vnf_get_vertices(vnf, p) :
|
|
||||||
assert(is_list(vnf) && len(vnf)==2 && is_list(vnf[0]) && is_list(vnf[1]), "Argument vnf should contain a VNF structure.")
|
|
||||||
assert(is_vector(p))
|
|
||||||
let(
|
let(
|
||||||
v = search([p], vnf[0])[0]
|
p = is_vector(p)? [p] : p,
|
||||||
) [
|
res = set_union(vnf[0], p, get_indices=true)
|
||||||
v != []? v : len(vnf[0]),
|
)
|
||||||
[
|
[res[0], [res[1],vnf[1]]];
|
||||||
concat(vnf[0], v != []? [] : [p]),
|
|
||||||
vnf[1]
|
|
||||||
]
|
|
||||||
];
|
|
||||||
|
|
||||||
|
|
||||||
// Internal use only
|
|
||||||
function _vnf_get_vertices(vnf=EMPTY_VNF, pts, _i=0, _idxs=[]) =
|
|
||||||
_i>=len(pts)? [_idxs, vnf] :
|
|
||||||
let(
|
|
||||||
vvnf = vnf_get_vertex(vnf, pts[_i])
|
|
||||||
) _vnf_get_vertices(vvnf[1], pts, _i=_i+1, _idxs=concat(_idxs,[vvnf[0]]));
|
|
||||||
|
|
||||||
|
|
||||||
// Function: vnf_add_face()
|
// Function: vnf_add_face()
|
||||||
|
@ -117,12 +102,11 @@ function vnf_add_face(vnf=EMPTY_VNF, pts) =
|
||||||
assert(is_vnf(vnf))
|
assert(is_vnf(vnf))
|
||||||
assert(is_path(pts))
|
assert(is_path(pts))
|
||||||
let(
|
let(
|
||||||
vvnf = vnf_get_vertex(vnf, pts),
|
res = set_union(vnf[0], pts, get_indices=true),
|
||||||
face = deduplicate(vvnf[0], closed=true),
|
face = deduplicate(res[0], closed=true)
|
||||||
vnf2 = vvnf[1]
|
|
||||||
) [
|
) [
|
||||||
vnf_vertices(vnf2),
|
res[1],
|
||||||
concat(vnf_faces(vnf2), len(face)>2? [face] : [])
|
concat(vnf[1], len(face)>2? [face] : [])
|
||||||
];
|
];
|
||||||
|
|
||||||
|
|
||||||
|
@ -138,8 +122,23 @@ function vnf_add_face(vnf=EMPTY_VNF, pts) =
|
||||||
// vnf = The VNF structure to add a face to.
|
// vnf = The VNF structure to add a face to.
|
||||||
// faces = The list of faces, where each face is given as a list of vertex points.
|
// faces = The list of faces, where each face is given as a list of vertex points.
|
||||||
function vnf_add_faces(vnf=EMPTY_VNF, faces, _i=0) =
|
function vnf_add_faces(vnf=EMPTY_VNF, faces, _i=0) =
|
||||||
(assert(is_vnf(vnf)) assert(is_list(faces)) _i>=len(faces))? vnf :
|
assert(is_vnf(vnf))
|
||||||
vnf_add_faces(vnf_add_face(vnf, faces[_i]), faces, _i=_i+1);
|
assert(is_list(faces))
|
||||||
|
let(
|
||||||
|
res = set_union(vnf[0],flatten(faces), get_indices=true),
|
||||||
|
idxs = res[0],
|
||||||
|
nverts = res[1],
|
||||||
|
offs = cumsum([for (face=faces) len(face)]),
|
||||||
|
ifaces = [
|
||||||
|
for (i=idx(faces)) [
|
||||||
|
for (j=idx(faces[i]))
|
||||||
|
idxs[offs[i]+j]
|
||||||
|
]
|
||||||
|
]
|
||||||
|
) [
|
||||||
|
nverts,
|
||||||
|
concat(vnf[1],ifaces)
|
||||||
|
];
|
||||||
|
|
||||||
|
|
||||||
// Function: vnf_merge()
|
// Function: vnf_merge()
|
||||||
|
|
Loading…
Reference in a new issue