From a2baebef8c7c6c89ed9f1aa007b834a2c22b9c2a Mon Sep 17 00:00:00 2001 From: Dealga McArdle Date: Thu, 7 Jul 2022 12:16:15 +0200 Subject: [PATCH 1/5] rip out function into a utility file --- nodes/modifier_change/mesh_separate.py | 51 ++++---------------------- 1 file changed, 7 insertions(+), 44 deletions(-) diff --git a/nodes/modifier_change/mesh_separate.py b/nodes/modifier_change/mesh_separate.py index f0794e2025..7fe076c64f 100644 --- a/nodes/modifier_change/mesh_separate.py +++ b/nodes/modifier_change/mesh_separate.py @@ -23,7 +23,7 @@ from sverchok.node_tree import SverchCustomTreeNode from sverchok.data_structure import zip_long_repeat from sverchok.utils.nodes_mixins.sockets_config import ModifierLiteNode - +from sverchok.utils.modules.topology_utils import separate_loose class SvSeparateMeshNode(ModifierLiteNode, bpy.types.Node, SverchCustomTreeNode): '''Separate Loose mesh parts''' @@ -42,54 +42,17 @@ def sv_init(self, context): def process(self): if not any(s.is_linked for s in self.outputs): return + verts = self.inputs['Vertices'].sv_get(deepcopy=False) poly = self.inputs['Poly Egde'].sv_get(deepcopy=False) + verts_out = [] poly_edge_out = [] - for ve, pe in zip_long_repeat(verts, poly): - # build links - node_links = {} - for edge_face in pe: - for i in edge_face: - if i not in node_links: - node_links[i] = set() - node_links[i].update(edge_face) - nodes = set(node_links.keys()) - n = nodes.pop() - node_set_list = [set([n])] - node_stack = collections.deque() - node_stack_append = node_stack.append - node_stack_pop = node_stack.pop - node_set = node_set_list[-1] - # find separate sets - while nodes: - for node in node_links[n]: - if node not in node_set: - node_stack_append(node) - if not node_stack: # new mesh part - n = nodes.pop() - node_set_list.append(set([n])) - node_set = node_set_list[-1] - else: - while node_stack and n in node_set: - n = node_stack_pop() - nodes.discard(n) - node_set.add(n) - # create new meshes from sets, new_pe is the slow line. - if len(node_set_list) > 1: - for node_set in node_set_list: - mesh_index = sorted(node_set) - vert_dict = {j: i for i, j in enumerate(mesh_index)} - new_vert = [ve[i] for i in mesh_index] - new_pe = [[vert_dict[n] for n in fe] - for fe in pe - if fe[0] in node_set] - verts_out.append(new_vert) - poly_edge_out.append(new_pe) - elif node_set_list: # no reprocessing needed - verts_out.append(ve) - poly_edge_out.append(pe) + for ve, pe in zip_long_repeat(verts, poly): + nve, npe = separate_loose(ve, pe) + verts_out.extend(nve) + poly_edge_out.extend(npe) self.outputs['Vertices'].sv_set(verts_out) self.outputs['Poly Egde'].sv_set(poly_edge_out) From 2e3123033a811454da3acca8e352d43ca2b2c2e7 Mon Sep 17 00:00:00 2001 From: Dealga McArdle Date: Thu, 7 Jul 2022 12:18:13 +0200 Subject: [PATCH 2/5] add file --- utils/modules/topology_utils.py | 62 +++++++++++++++++++++++++++++++++ 1 file changed, 62 insertions(+) create mode 100644 utils/modules/topology_utils.py diff --git a/utils/modules/topology_utils.py b/utils/modules/topology_utils.py new file mode 100644 index 0000000000..47b66d1acc --- /dev/null +++ b/utils/modules/topology_utils.py @@ -0,0 +1,62 @@ +# This file is part of project Sverchok. It's copyrighted by the contributors +# recorded in the version control history of the file, available from +# its original location https://github.com/nortikin/sverchok/commit/master +# +# SPDX-License-Identifier: GPL3 +# License-Filename: LICENSE + +import collections + +def separate_loose(ve, pe): + verts, poly_edges = [], [] + + # build links + node_links = {} + for edge_face in pe: + for i in edge_face: + if i not in node_links: + node_links[i] = set() + node_links[i].update(edge_face) + + nodes = set(node_links.keys()) + n = nodes.pop() + node_set_list = [set([n])] + node_stack = collections.deque() + node_stack_append = node_stack.append + node_stack_pop = node_stack.pop + node_set = node_set_list[-1] + + # find separate sets + while nodes: + for node in node_links[n]: + if node not in node_set: + node_stack_append(node) + if not node_stack: # new mesh part + n = nodes.pop() + node_set_list.append(set([n])) + node_set = node_set_list[-1] + else: + while node_stack and n in node_set: + n = node_stack_pop() + nodes.discard(n) + node_set.add(n) + + # create new meshes from sets, new_pe is the slow line. + if len(node_set_list) > 1: + + for node_set in node_set_list: + mesh_index = sorted(node_set) + vert_dict = {j: i for i, j in enumerate(mesh_index)} + new_vert = [ve[i] for i in mesh_index] + new_pe = [[vert_dict[n] for n in fe] + for fe in pe + if fe[0] in node_set] + verts.append(new_vert) + poly_edges.append(new_pe) + + elif node_set_list: # no reprocessing needed + + verts.append(ve) + poly_edges.append(pe) + + return verts, poly_edges From 626a4e250ffcccf34207cea88d347bd945819380 Mon Sep 17 00:00:00 2001 From: Dealga McArdle Date: Fri, 8 Jul 2022 10:29:52 +0200 Subject: [PATCH 3/5] is it parity? --- utils/modules/topology_utils.py | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/utils/modules/topology_utils.py b/utils/modules/topology_utils.py index 47b66d1acc..931e35a3d3 100644 --- a/utils/modules/topology_utils.py +++ b/utils/modules/topology_utils.py @@ -8,7 +8,7 @@ import collections def separate_loose(ve, pe): - verts, poly_edges = [], [] + # verts, poly_edges = [], [] # build links node_links = {} @@ -42,6 +42,8 @@ def separate_loose(ve, pe): node_set.add(n) # create new meshes from sets, new_pe is the slow line. + verts = [] + poly_edges = [] if len(node_set_list) > 1: for node_set in node_set_list: @@ -51,12 +53,10 @@ def separate_loose(ve, pe): new_pe = [[vert_dict[n] for n in fe] for fe in pe if fe[0] in node_set] + verts.append(new_vert) poly_edges.append(new_pe) + return verts, poly_edges elif node_set_list: # no reprocessing needed - - verts.append(ve) - poly_edges.append(pe) - - return verts, poly_edges + return [ve], [pe] \ No newline at end of file From d4fc065f7e0a5d13a74b536afab7220be310e374 Mon Sep 17 00:00:00 2001 From: Dealga McArdle Date: Fri, 8 Jul 2022 10:30:50 +0200 Subject: [PATCH 4/5] whitespace --- utils/modules/topology_utils.py | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/utils/modules/topology_utils.py b/utils/modules/topology_utils.py index 931e35a3d3..a3f03a57a5 100644 --- a/utils/modules/topology_utils.py +++ b/utils/modules/topology_utils.py @@ -42,10 +42,10 @@ def separate_loose(ve, pe): node_set.add(n) # create new meshes from sets, new_pe is the slow line. - verts = [] - poly_edges = [] if len(node_set_list) > 1: + verts = [] + poly_edges = [] for node_set in node_set_list: mesh_index = sorted(node_set) vert_dict = {j: i for i, j in enumerate(mesh_index)} @@ -56,6 +56,7 @@ def separate_loose(ve, pe): verts.append(new_vert) poly_edges.append(new_pe) + return verts, poly_edges elif node_set_list: # no reprocessing needed From 78dd813521d755663a04a0b2514345069722e7d4 Mon Sep 17 00:00:00 2001 From: Dealga McArdle Date: Sun, 10 Jul 2022 12:41:42 +0200 Subject: [PATCH 5/5] save changes --- utils/modules/topology_utils.py | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/utils/modules/topology_utils.py b/utils/modules/topology_utils.py index a3f03a57a5..a53c06b4fc 100644 --- a/utils/modules/topology_utils.py +++ b/utils/modules/topology_utils.py @@ -8,7 +8,12 @@ import collections def separate_loose(ve, pe): - # verts, poly_edges = [], [] + """ + this function will take verts and polygons or edges. + if you pass it verts and edges/polygons it will return the individual mesh islands + if you pass it verts and boundary edges it will return the separate boundaries per object. + + """ # build links node_links = {} @@ -42,10 +47,10 @@ def separate_loose(ve, pe): node_set.add(n) # create new meshes from sets, new_pe is the slow line. + verts = [] + poly_edges = [] if len(node_set_list) > 1: - verts = [] - poly_edges = [] for node_set in node_set_list: mesh_index = sorted(node_set) vert_dict = {j: i for i, j in enumerate(mesh_index)} @@ -57,7 +62,9 @@ def separate_loose(ve, pe): verts.append(new_vert) poly_edges.append(new_pe) - return verts, poly_edges elif node_set_list: # no reprocessing needed - return [ve], [pe] \ No newline at end of file + verts.append(ve) + poly_edges.append(pe) + + return verts, poly_edges \ No newline at end of file