- planning.py shows how to use this graph with graph_search.
- graph_sparsification.py shows how to sparsify a graph
- batch_sparsification.py efficiently sparsify a graph with as a batch
- incremental_api.py shows how to extend with sparsity
To instantiate a graph:
graph = AsymMesh(n=10_000, k=6, dim=2, img_dim=[2], kernel_fn=l2, embed_fn=id2D, d_max=20) graph.extend(xys, images=xys, meta=xys) graph.update_zs() graph.update_edges()
Most of the time it is better to enforce sparsity of the graph by only adding new vertices when there is no existing vertex that is close-by. The new dedupe API allows us to do this in a batch fashion:
spots = graph.dedupe(images=xys, r_min=r_min) xys = xys[spots] ds = graph.to_goal(zs_2=xys) if ds.size == 0: graph.extend(xys, images=xys, meta=xys) else: m = ds.min(axis=-1) >= r_min if m.sum() > 0: graph.extend(xys[m], images=xys[m], meta=xys[m]) graph.update_edges()
Dense | Sparse | Details |
---|---|---|
![]() | ![]() | 10x more edges in the dense graph in comparison to the sparse graph. |
Import this module in the method module.