slide2vec 4.0.3__tar.gz → 4.0.4__tar.gz
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.
- {slide2vec-4.0.3 → slide2vec-4.0.4}/PKG-INFO +1 -1
- {slide2vec-4.0.3 → slide2vec-4.0.4}/pyproject.toml +2 -2
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/__init__.py +1 -1
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/inference.py +3 -2
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec.egg-info/PKG-INFO +1 -1
- {slide2vec-4.0.3 → slide2vec-4.0.4}/tests/test_regression_inference.py +6 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/LICENSE +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/README.md +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/setup.cfg +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/__main__.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/api.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/artifacts.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/cli.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/configs/__init__.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/configs/default.yaml +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/data/__init__.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/data/dataset.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/data/tile_reader.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/data/tile_store.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/distributed/__init__.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/distributed/direct_embed_worker.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/distributed/pipeline_worker.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/encoders/__init__.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/encoders/base.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/encoders/models/__init__.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/encoders/models/conch.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/encoders/models/gigapath.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/encoders/models/hibou.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/encoders/models/hoptimus.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/encoders/models/midnight.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/encoders/models/musk.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/encoders/models/phikon.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/encoders/models/prism.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/encoders/models/prost40m.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/encoders/models/titan.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/encoders/models/uni.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/encoders/models/virchow.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/encoders/registry.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/encoders/validation.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/main.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/model_settings.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/progress.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/registry.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/resources.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/runtime_types.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/utils/__init__.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/utils/config.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/utils/coordinates.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/utils/log_utils.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/utils/tiling_io.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec/utils/utils.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec.egg-info/SOURCES.txt +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec.egg-info/dependency_links.txt +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec.egg-info/entry_points.txt +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec.egg-info/not-zip-safe +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec.egg-info/requires.txt +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/slide2vec.egg-info/top_level.txt +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/tests/test_batch_collator_timing.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/tests/test_encoder_registry.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/tests/test_hs2p_package_cutover.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/tests/test_output_consistency.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/tests/test_packaging_metadata.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/tests/test_progress.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/tests/test_regression_core.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/tests/test_regression_models.py +0 -0
- {slide2vec-4.0.3 → slide2vec-4.0.4}/tests/test_tile_store.py +0 -0
|
@@ -4,7 +4,7 @@ build-backend = "setuptools.build_meta"
|
|
|
4
4
|
|
|
5
5
|
[project]
|
|
6
6
|
name = "slide2vec"
|
|
7
|
-
version = "4.0.
|
|
7
|
+
version = "4.0.4"
|
|
8
8
|
description = "Embedding of whole slide images with Foundation Models"
|
|
9
9
|
readme = "README.md"
|
|
10
10
|
requires-python = ">=3.10"
|
|
@@ -154,7 +154,7 @@ no_implicit_reexport = true
|
|
|
154
154
|
max-line-length = 160
|
|
155
155
|
|
|
156
156
|
[tool.bumpver]
|
|
157
|
-
current_version = "4.0.
|
|
157
|
+
current_version = "4.0.4"
|
|
158
158
|
version_pattern = "MAJOR.MINOR.PATCH"
|
|
159
159
|
commit = false # We do version bumping in CI, not as a commit
|
|
160
160
|
tag = false # Git tag already exists — we don't auto-tag
|
|
@@ -2,7 +2,7 @@ from slide2vec.api import EmbeddedSlide, ExecutionOptions, Model, Pipeline, Prep
|
|
|
2
2
|
from slide2vec.artifacts import HierarchicalEmbeddingArtifact, SlideEmbeddingArtifact, TileEmbeddingArtifact
|
|
3
3
|
|
|
4
4
|
|
|
5
|
-
__version__ = "4.0.
|
|
5
|
+
__version__ = "4.0.4"
|
|
6
6
|
|
|
7
7
|
__all__ = [
|
|
8
8
|
"Model",
|
|
@@ -2261,11 +2261,12 @@ def _should_persist_tile_embeddings(model, execution: ExecutionOptions) -> bool:
|
|
|
2261
2261
|
|
|
2262
2262
|
|
|
2263
2263
|
def _resolved_process_list_output_variant(model) -> str | None:
|
|
2264
|
+
requested_output_variant = getattr(model, "_output_variant", None)
|
|
2264
2265
|
if not hasattr(model, "name") or model.name not in encoder_registry:
|
|
2265
|
-
return
|
|
2266
|
+
return requested_output_variant
|
|
2266
2267
|
resolved = resolve_encoder_output(
|
|
2267
2268
|
model.name,
|
|
2268
|
-
requested_output_variant=
|
|
2269
|
+
requested_output_variant=requested_output_variant,
|
|
2269
2270
|
)
|
|
2270
2271
|
return str(resolved["output_variant"])
|
|
2271
2272
|
|
|
@@ -176,6 +176,8 @@ def test_collect_distributed_pipeline_artifacts_runs_stage_collects_and_updates(
|
|
|
176
176
|
persist_tile_embeddings,
|
|
177
177
|
persist_hierarchical_embeddings,
|
|
178
178
|
include_slide_embeddings,
|
|
179
|
+
encoder_name,
|
|
180
|
+
output_variant,
|
|
179
181
|
tile_artifacts,
|
|
180
182
|
hierarchical_artifacts,
|
|
181
183
|
slide_artifacts,
|
|
@@ -186,6 +188,8 @@ def test_collect_distributed_pipeline_artifacts_runs_stage_collects_and_updates(
|
|
|
186
188
|
"persist_tile_embeddings": persist_tile_embeddings,
|
|
187
189
|
"persist_hierarchical_embeddings": persist_hierarchical_embeddings,
|
|
188
190
|
"include_slide_embeddings": include_slide_embeddings,
|
|
191
|
+
"encoder_name": encoder_name,
|
|
192
|
+
"output_variant": output_variant,
|
|
189
193
|
"tile_artifacts": tile_artifacts,
|
|
190
194
|
"hierarchical_artifacts": hierarchical_artifacts,
|
|
191
195
|
"slide_artifacts": slide_artifacts,
|
|
@@ -220,6 +224,8 @@ def test_collect_distributed_pipeline_artifacts_runs_stage_collects_and_updates(
|
|
|
220
224
|
assert captured["update"]["persist_tile_embeddings"] is True
|
|
221
225
|
assert captured["update"]["persist_hierarchical_embeddings"] is False
|
|
222
226
|
assert captured["update"]["include_slide_embeddings"] is True
|
|
227
|
+
assert captured["update"]["encoder_name"] == "prism"
|
|
228
|
+
assert captured["update"]["output_variant"] == "default"
|
|
223
229
|
assert captured["update"]["tile_artifacts"] == ["tile-artifact"]
|
|
224
230
|
assert captured["update"]["hierarchical_artifacts"] == []
|
|
225
231
|
assert captured["update"]["slide_artifacts"] == ["slide-artifact"]
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|