From da2f7771873177bb1751537677b543eadf9aba49 Mon Sep 17 00:00:00 2001 From: Philipp Schlegel Date: Tue, 22 Nov 2022 15:43:15 +0000 Subject: [PATCH] write_precomputed: fix skeleton edges --- navis/io/precomputed_io.py | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/navis/io/precomputed_io.py b/navis/io/precomputed_io.py index 18b25956..b637da6f 100644 --- a/navis/io/precomputed_io.py +++ b/navis/io/precomputed_io.py @@ -500,7 +500,7 @@ def write_info_file(data, filepath, add_props={}): u = 1 tr = np.zeros((4, 3), dtype=int) tr[:3, :3] = np.diag([u, u, u]) - info['transform'] = tr.flatten().tolist() + info['transform'] = tr.T.flatten().tolist() else: raise TypeError(f'Unable to write info file for data of type "{type(data)}"') @@ -539,14 +539,15 @@ def _write_skeleton(x, filename, radius=False): # Below code modified from: # https://github.com/google/neuroglancer/blob/master/python/neuroglancer/skeleton.py#L34 result = io.BytesIO() - vertex_positions = x.nodes[['x', 'y', 'z']].values.astype('float32') + vertex_positions = x.nodes[['x', 'y', 'z']].values.astype('float32', order='C') # Map edges node IDs to node indices node_ix = pd.Series(x.nodes.reset_index(drop=True).index, index=x.nodes.node_id) - edges = x.edges.copy().astype('uint32') + edges = x.edges.copy().astype('uint32', order='C') edges[:, 0] = node_ix.loc[edges[:, 0]].values edges[:, 1] = node_ix.loc[edges[:, 1]].values + edges = edges[:, [1, 0]] # For some reason we have to switch direction - result.write(struct.pack('