Skip to content

Commit

Permalink
fix(edits/split): filter out inactive cross edges AT EACH LAYER
Browse files Browse the repository at this point in the history
  • Loading branch information
akhileshh committed Jul 17, 2024
1 parent ba69c9d commit a75a95e
Show file tree
Hide file tree
Showing 3 changed files with 27 additions and 11 deletions.
2 changes: 1 addition & 1 deletion pychunkedgraph/__init__.py
Original file line number Diff line number Diff line change
@@ -1 +1 @@
__version__ = "3.0.3"
__version__ = "3.0.0"
14 changes: 5 additions & 9 deletions pychunkedgraph/graph/chunkedgraph.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@
import time
import typing
import datetime
from itertools import chain
from functools import reduce

import numpy as np
from pychunkedgraph import __version__
Expand Down Expand Up @@ -667,8 +669,6 @@ def get_l2_agglomerations(
Children of Level 2 Node IDs and edges.
Edges are read from cloud storage.
"""
from itertools import chain
from functools import reduce
from .misc import get_agglomerations

chunk_ids = np.unique(self.get_chunk_ids_from_node_ids(level2_ids))
Expand Down Expand Up @@ -708,13 +708,9 @@ def get_l2_agglomerations(
sv_parent_d.update(dict(zip(svs.tolist(), [l2id] * len(svs))))

if active:
n1, n2 = all_chunk_edges.node_ids1, all_chunk_edges.node_ids2
layers = self.get_cross_chunk_edges_layer(all_chunk_edges.get_pairs())
max_layer = np.max(layers) + 1
parents1 = self.get_roots(n1, stop_layer=max_layer, time_stamp=time_stamp)
parents2 = self.get_roots(n2, stop_layer=max_layer, time_stamp=time_stamp)
mask = parents1 == parents2
all_chunk_edges = all_chunk_edges[mask]
all_chunk_edges = edge_utils.filter_inactive_cross_edges(
self, all_chunk_edges, time_stamp=time_stamp
)

in_edges, out_edges, cross_edges = edge_utils.categorize_edges_v2(
self.meta, all_chunk_edges, sv_parent_d
Expand Down
22 changes: 21 additions & 1 deletion pychunkedgraph/graph/edges/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@
from typing import Iterable
from typing import Optional
from collections import defaultdict
from functools import reduce

import fastremap
import numpy as np
Expand Down Expand Up @@ -46,7 +47,9 @@ def concatenate_chunk_edges(chunk_edge_dicts: Iterable) -> Dict:
return edges_dict


def concatenate_cross_edge_dicts(edges_ds: Iterable[Dict], unique: bool = False) -> Dict:
def concatenate_cross_edge_dicts(
edges_ds: Iterable[Dict], unique: bool = False
) -> Dict:
"""Combines cross chunk edge dicts of form {layer id : edge list}."""
result_d = defaultdict(list)
for edges_d in edges_ds:
Expand Down Expand Up @@ -182,3 +185,20 @@ def get_edges_status(cg, edges: Iterable, time_stamp: Optional[float] = None):
active_status.extend(mask)
active_status = np.array(active_status, dtype=bool)
return existence_status, active_status


def filter_inactive_cross_edges(
cg, all_chunk_edges: Edges, time_stamp: Optional[float] = None
):
result = []
layers = cg.get_cross_chunk_edges_layer(all_chunk_edges.get_pairs())
for layer in np.unique(layers):
layer_mask = layers == layer
parent_layer = layer + 1
layer_edges = all_chunk_edges[layer_mask]
n1, n2 = layer_edges.node_ids1, layer_edges.node_ids2
parents1 = cg.get_roots(n1, stop_layer=parent_layer, time_stamp=time_stamp)
parents2 = cg.get_roots(n2, stop_layer=parent_layer, time_stamp=time_stamp)
mask = parents1 == parents2
result.append(layer_edges[mask])
return reduce(lambda x, y: x + y, result, Edges([], []))

0 comments on commit a75a95e

Please sign in to comment.