From eef0ba246cba9287991443ae1065b0b22cabe998 Mon Sep 17 00:00:00 2001 From: Julia Dark Date: Wed, 24 Apr 2024 16:09:30 -0400 Subject: [PATCH] Use Scene in visium ingestion --- .../src/tiledbsoma/experimental/ingest.py | 83 +++++++++++-------- apis/python/src/tiledbsoma/io/ingest.py | 13 +++ 2 files changed, 63 insertions(+), 33 deletions(-) diff --git a/apis/python/src/tiledbsoma/experimental/ingest.py b/apis/python/src/tiledbsoma/experimental/ingest.py index 77075f9ceb..db147020a5 100644 --- a/apis/python/src/tiledbsoma/experimental/ingest.py +++ b/apis/python/src/tiledbsoma/experimental/ingest.py @@ -30,7 +30,7 @@ import scanpy from PIL import Image -from .. import Collection, DataFrame, DenseNDArray, Experiment, SparseNDArray +from .. import Collection, DataFrame, DenseNDArray, Experiment, Scene, SparseNDArray from .._constants import SOMA_JOINID from .._tiledb_object import AnyTileDBObject from .._types import IngestMode @@ -147,52 +147,69 @@ def from_visium( with Experiment.open(uri, mode="w", context=context) as experiment: spatial_uri = f"{uri}/spatial" with _create_or_open_collection( - Collection[Collection[AnyTileDBObject]], spatial_uri, **ingest_ctx + Collection[Union[DataFrame, Scene]], spatial_uri, **ingest_ctx ) as spatial: _maybe_set( experiment, "spatial", spatial, use_relative_uri=use_relative_uri ) scene_uri = f"{spatial_uri}/{scene_name}" with _create_or_open_collection( - Collection[AnyTileDBObject], scene_uri, **ingest_ctx + Collection[Collection[AnyTileDBObject]], scene_uri, **ingest_ctx ) as scene: _maybe_set( spatial, scene_name, scene, use_relative_uri=use_relative_uri ) - obs_locations_uri = f"{scene_uri}/obs_locations" - - # Write spot data and add to the scene. - with _write_visium_spot_dataframe( - obs_locations_uri, - input_tissue_positions, - scale_factors, - obs_df, - obs_id_name, - **ingest_ctx, - ) as obs_locations: + scene_exp_uri = f"{scene_uri}/exp" + with _create_or_open_collection( + Collection[AnyTileDBObject], scene_exp_uri, **ingest_ctx + ) as scene_exp: _maybe_set( - scene, - "obs_locations", - obs_locations, - use_relative_uri=use_relative_uri, + scene, "exp", scene_exp, use_relative_uri=use_relative_uri ) - # Write image data and add to the scene. - images_uri = f"{scene_uri}/images" - with _write_visium_images( - images_uri, - scale_factors, - input_hires=input_hires, - input_lowres=input_lowres, - input_fullres=input_fullres, - use_relative_uri=use_relative_uri, - **ingest_ctx, - ) as images: - _maybe_set( - scene, "images", images, use_relative_uri=use_relative_uri - ) - return uri + obs_locations_uri = f"{scene_exp_uri}/obs_locations" + + # Write spot data and add to the scene. + with _write_visium_spot_dataframe( + obs_locations_uri, + input_tissue_positions, + scale_factors, + obs_df, + obs_id_name, + **ingest_ctx, + ) as obs_locations: + _maybe_set( + scene_exp, + "obs_locations", + obs_locations, + use_relative_uri=use_relative_uri, + ) + + # Write image data and add to the scene. + images_uri = f"{scene_exp_uri}/images" + with _write_visium_images( + images_uri, + scale_factors, + input_hires=input_hires, + input_lowres=input_lowres, + input_fullres=input_fullres, + use_relative_uri=use_relative_uri, + **ingest_ctx, + ) as images: + _maybe_set( + scene_exp, + "images", + images, + use_relative_uri=use_relative_uri, + ) + + scene_ms_uri = f"{scene_uri}/ms" + with _create_or_open_collection( + Collection[Collection[AnyTileDBObject]], scene_ms_uri, **ingest_ctx + ) as scene_ms: + _maybe_set(scene, "ms", scene_ms, use_relative_uri=use_relative_uri) + return uri def _write_visium_spot_dataframe( diff --git a/apis/python/src/tiledbsoma/io/ingest.py b/apis/python/src/tiledbsoma/io/ingest.py index 4e6203f1bd..814b41d42c 100644 --- a/apis/python/src/tiledbsoma/io/ingest.py +++ b/apis/python/src/tiledbsoma/io/ingest.py @@ -48,6 +48,7 @@ DenseNDArray, Experiment, Measurement, + Scene, SparseNDArray, _factory, _util, @@ -979,6 +980,18 @@ def _create_or_open_collection( ... +@overload +def _create_or_open_collection( + cls: Type[Scene], + uri: str, + *, + ingestion_params: IngestionParams, + context: Optional["SOMATileDBContext"], + additional_metadata: "AdditionalMetadata" = None, +) -> Scene: + ... + + @no_type_check def _create_or_open_collection( cls: Type[CollectionBase[_TDBO]],