Skip to content

Commit

Permalink
Use Scene in visium ingestion
Browse files Browse the repository at this point in the history
  • Loading branch information
jp-dark committed Apr 25, 2024
1 parent 2723c4b commit b717006
Show file tree
Hide file tree
Showing 2 changed files with 63 additions and 33 deletions.
83 changes: 50 additions & 33 deletions apis/python/src/tiledbsoma/experimental/ingest.py
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down Expand Up @@ -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(
Expand Down
13 changes: 13 additions & 0 deletions apis/python/src/tiledbsoma/io/ingest.py
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,7 @@
DenseNDArray,
Experiment,
Measurement,
Scene,
SparseNDArray,
_factory,
_util,
Expand Down Expand Up @@ -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]],
Expand Down

0 comments on commit b717006

Please sign in to comment.