hoa-tools 1.0.2b1__py3-none-any.whl → 1.0.3__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of hoa-tools might be problematic. Click here for more details.

hoa_tools/_version.py CHANGED
@@ -17,5 +17,5 @@ __version__: str
17
17
  __version_tuple__: VERSION_TUPLE
18
18
  version_tuple: VERSION_TUPLE
19
19
 
20
- __version__ = version = '1.0.2b1'
21
- __version_tuple__ = version_tuple = (1, 0, 2, 'b1')
20
+ __version__ = version = '1.0.3'
21
+ __version_tuple__ = version_tuple = (1, 0, 3)
hoa_tools/dataset.py CHANGED
@@ -17,6 +17,7 @@ from typing import Literal
17
17
 
18
18
  import dask.array.core
19
19
  import gcsfs
20
+ import networkx as nx
20
21
  import numpy as np
21
22
  import xarray as xr
22
23
  import zarr.core
@@ -41,6 +42,9 @@ class Dataset(HOAMetadata):
41
42
  def __str__(self) -> str:
42
43
  return f"Dataset(name={self.name})"
43
44
 
45
+ def __hash__(self) -> int:
46
+ return hash(self.name)
47
+
44
48
  def _organ_str(self) -> str:
45
49
  """
46
50
  Get name of organ, with organ context appended if present.
@@ -114,6 +118,18 @@ class Dataset(HOAMetadata):
114
118
  ]
115
119
  return sorted(parents, key=lambda c: c.name)
116
120
 
121
+ def get_registered(self) -> set["Dataset"]:
122
+ """
123
+ Get a set of all datasets that are registered (even indirectly) to this dataset.
124
+ """
125
+ import hoa_tools.registration
126
+
127
+ dataset_names = nx.node_connected_component(
128
+ hoa_tools.registration.Inventory._graph.to_undirected(), # noqa: SLF001
129
+ self.name,
130
+ )
131
+ return {get_dataset(name) for name in dataset_names}
132
+
117
133
  @property
118
134
  def _remote_fmt(self) -> Literal["n5", "zarr"]:
119
135
  if self.data.gcs_url.startswith("n5://"):
hoa_tools/registration.py CHANGED
@@ -8,6 +8,10 @@ in units of micro-meters (μm).
8
8
  Transforms are defined using the `SimpleITK` library.
9
9
  """
10
10
 
11
+ import itertools
12
+ from typing import Any
13
+
14
+ import networkx as nx
11
15
  import numpy as np
12
16
  import SimpleITK as sitk
13
17
 
@@ -28,13 +32,13 @@ class RegistrationInventory:
28
32
  """
29
33
  Create registration inventory.
30
34
  """
31
- self._registrations: dict[tuple[str, str], sitk.Transform] = {}
35
+ self._graph: nx.DiGraph[Any] = nx.DiGraph()
32
36
 
33
37
  def __contains__(self, item: tuple[Dataset, Dataset]) -> bool:
34
38
  """
35
39
  Check for existence of registration between two datasets.
36
40
  """
37
- return (item[0].name, item[1].name) in self._registrations
41
+ return (item[0].name, item[1].name) in self._graph.edges
38
42
 
39
43
  def get_registration(
40
44
  self, *, source_dataset: Dataset, target_dataset: Dataset
@@ -42,7 +46,28 @@ class RegistrationInventory:
42
46
  """
43
47
  Get a registration.
44
48
  """
45
- return self._registrations[(source_dataset.name, target_dataset.name)]
49
+ try:
50
+ path = nx.shortest_path(
51
+ self._graph, source_dataset.name, target_dataset.name
52
+ )
53
+ except nx.exception.NetworkXNoPath:
54
+ msg = (
55
+ f"No registration path between {source_dataset.name} and "
56
+ f"{target_dataset.name}"
57
+ )
58
+ raise ValueError(msg) from None
59
+
60
+ transforms: list[sitk.Transform] = [
61
+ self._graph[p1][p2]["transform"] for p1, p2 in itertools.pairwise(path)
62
+ ]
63
+ if len(transforms) == 1:
64
+ return transforms[0]
65
+
66
+ ndim = 3
67
+ t = sitk.CompositeTransform(ndim) # type: ignore[no-untyped-call]
68
+ for transform in transforms:
69
+ t.AddTransform(transform) # type: ignore[no-untyped-call]
70
+ return t
46
71
 
47
72
  def add_registration(
48
73
  self,
@@ -59,16 +84,20 @@ class RegistrationInventory:
59
84
  This will override any already defined transforms for these two datasets.
60
85
 
61
86
  """
62
- self._registrations[(source_dataset.name, target_dataset.name)] = transform
63
- self._registrations[(target_dataset.name, source_dataset.name)] = (
64
- transform.GetInverse() # type: ignore[no-untyped-call]
87
+ self._graph.add_edge(
88
+ source_dataset.name, target_dataset.name, transform=transform
89
+ )
90
+ self._graph.add_edge(
91
+ target_dataset.name,
92
+ source_dataset.name,
93
+ transform=transform.GetInverse(), # type: ignore[no-untyped-call]
65
94
  )
66
95
 
67
96
  def _clear(self) -> None:
68
97
  """
69
98
  Remove all registrations.
70
99
  """
71
- self._registrations = {}
100
+ self._graph = nx.DiGraph()
72
101
 
73
102
 
74
103
  def build_transform(
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: hoa-tools
3
- Version: 1.0.2b1
3
+ Version: 1.0.3
4
4
  Summary: Tools for working with the Human Organ Atlas
5
5
  Author-email: David Stansby <d.stansby@ucl.ac.uk>
6
6
  License: Copyright (c) 2024, David Stansby
@@ -44,6 +44,7 @@ Description-Content-Type: text/markdown
44
44
  License-File: LICENSE.md
45
45
  Requires-Dist: dask[array]
46
46
  Requires-Dist: gcsfs>2023
47
+ Requires-Dist: networkx>=3
47
48
  Requires-Dist: pandas>=2
48
49
  Requires-Dist: pydantic>=2
49
50
  Requires-Dist: simpleitk
@@ -56,6 +57,7 @@ Requires-Dist: pre-commit; extra == "dev"
56
57
  Requires-Dist: ruff; extra == "dev"
57
58
  Requires-Dist: jupyterlab; extra == "dev"
58
59
  Requires-Dist: jupytext; extra == "dev"
60
+ Requires-Dist: types-networkx; extra == "dev"
59
61
  Requires-Dist: pandas-stubs; extra == "dev"
60
62
  Requires-Dist: datamodel-code-generator; extra == "dev"
61
63
  Provides-Extra: docs
@@ -1,11 +1,11 @@
1
1
  hoa_tools/__init__.py,sha256=wc7Yn5CXR3hxr2JyV3eEyCx3p8UZdknXDFJPSthKE_g,87
2
2
  hoa_tools/_n5.py,sha256=NGDJBbuyp1scGZ9fjuH7QqAQBpax9nxg2MhwhnV698M,310
3
- hoa_tools/_version.py,sha256=w7r5zi_L5eXXI6Dl3_kMp_3jBUG5p94YT5f5H78ZElY,519
4
- hoa_tools/dataset.py,sha256=tZtC-DhFTptzo8F_LkMgcoW0EIHnMEe1I3zW-pJOEEk,9086
3
+ hoa_tools/_version.py,sha256=jWOT7x0QtPxvOokiMtAg9lJ_WkkL0NXT4lwG0yqXne0,511
4
+ hoa_tools/dataset.py,sha256=0pIuht5wePO0OXxRhj8ylgncf9PcwsfJJsl5uYXLcNo,9604
5
5
  hoa_tools/inventory.py,sha256=44IbE1eLFTetAeCadpBFYXXIwcX5fagq76zSMLWBOmE,613
6
6
  hoa_tools/metadata.py,sha256=HGdhjoaUZ2oW9EguO7iuoSU22XLPvPZyIUPvvjoNtbE,22851
7
7
  hoa_tools/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
8
- hoa_tools/registration.py,sha256=EXnSrwLgxm5fpxTqCKWXNV0fbKOLWHP-Dt8Yb0-v4oY,2535
8
+ hoa_tools/registration.py,sha256=6BWscCF_SUcn7l1_NJLr4eUH0pbn7PizEWqZpQsSGYU,3356
9
9
  hoa_tools/types.py,sha256=X8GzZXknwgmtTLWR2d_JxEfoavXAQ1zVrf8BaNdevSw,1452
10
10
  hoa_tools/voi.py,sha256=t6XAPMpS70W5OphWr3U4j8eXMVElR1OuuzJCoDLs7zc,7868
11
11
  hoa_tools/data/metadata/metadata/A186_lung_right_VOI-3_4.26um_bm18.json,sha256=XsMNYpnxvwqUt0h56gfhoXW5XCgBOXdiWzaIxJ_qov8,7550
@@ -191,8 +191,8 @@ hoa_tools/data/metadata/metadata/S-20-29_lung_left_VOI-02_6.5um_bm05.json,sha256
191
191
  hoa_tools/data/metadata/metadata/S-20-29_lung_left_VOI-04_6.5um_bm05.json,sha256=BncVFzcPaqrGiBWSEo46L_xbkr-od21Vr7j4XqZUEE8,6116
192
192
  hoa_tools/data/metadata/metadata/S-20-29_lung_left_VOI-05_6.5um_bm05.json,sha256=iseb551Vq9B-sHCYWprmbso4XXeb-o2-bFsMlyTyjE8,6118
193
193
  hoa_tools/data/metadata/metadata/S-20-29_lung_left_complete-organ_25.31um_bm05.json,sha256=sjNcr9XX7aDDjFMf8yScq4CU53mudSwsExZV7pqXBxQ,5875
194
- hoa_tools-1.0.2b1.dist-info/licenses/LICENSE.md,sha256=CU-KGODbkoeDUXYPeLgpicDrFTffLQECao-wTKJrXFU,1480
195
- hoa_tools-1.0.2b1.dist-info/METADATA,sha256=LLBx6e9uTgSjJfWvrVcbbvno3V7EBSx5Rr--hYE2_lw,5065
196
- hoa_tools-1.0.2b1.dist-info/WHEEL,sha256=0CuiUZ_p9E4cD6NyLD6UG80LBXYyiSYZOKDm5lp32xk,91
197
- hoa_tools-1.0.2b1.dist-info/top_level.txt,sha256=NkWbNX-2byZN6hcVyowOVv0aiRNdH0uXpOkA0SFHDgY,10
198
- hoa_tools-1.0.2b1.dist-info/RECORD,,
194
+ hoa_tools-1.0.3.dist-info/licenses/LICENSE.md,sha256=CU-KGODbkoeDUXYPeLgpicDrFTffLQECao-wTKJrXFU,1480
195
+ hoa_tools-1.0.3.dist-info/METADATA,sha256=I2BI3MrUOAO4HIMrNs-vcOUEkh35vsTTsr6PXpuP7zM,5136
196
+ hoa_tools-1.0.3.dist-info/WHEEL,sha256=DnLRTWE75wApRYVsjgc6wsVswC54sMSJhAEd4xhDpBk,91
197
+ hoa_tools-1.0.3.dist-info/top_level.txt,sha256=NkWbNX-2byZN6hcVyowOVv0aiRNdH0uXpOkA0SFHDgY,10
198
+ hoa_tools-1.0.3.dist-info/RECORD,,
@@ -1,5 +1,5 @@
1
1
  Wheel-Version: 1.0
2
- Generator: setuptools (80.3.1)
2
+ Generator: setuptools (80.4.0)
3
3
  Root-Is-Purelib: true
4
4
  Tag: py3-none-any
5
5