Analyze the dataset and save a result#
import lamindb as ln
import lnschema_bionty as lb
ln.track()
💡 lamindb instance: testuser1/test-facs
💡 notebook imports: lamindb==0.64.2 lnschema_bionty==0.36.1 scanpy==1.9.6
💡 saved: Transform(uid='zzJzdgJ763Dyz8', name='Analyze the dataset and save a result', short_name='facs4', version='0', type=notebook, updated_at=2023-12-22 16:57:29 UTC, created_by_id=1)
💡 saved: Run(uid='DARLtjf4yB3zHnR8SCug', run_at=2023-12-22 16:57:29 UTC, transform_id=4, created_by_id=1)
ln.Dataset.filter().df()
uid | name | description | version | hash | reference | reference_type | transform_id | run_id | artifact_id | initial_version_id | visibility | updated_at | created_by_id | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
id | ||||||||||||||
1 | yT92kbllQWRGstFEV78R | My versioned cytometry dataset | None | 1 | VsTnnzHN63ovNESaJtlRUQ | None | None | 1 | 1 | 1.0 | NaN | 1 | 2023-12-22 16:57:08.782443+00:00 | 1 |
2 | O9ayv7zCop9accQoOZ4C | My versioned cytometry dataset | None | 2 | ZKQxIw0uAvtMtdZk8SAj | None | None | 2 | 2 | NaN | 1.0 | 1 | 2023-12-22 16:57:19.013486+00:00 | 1 |
dataset = ln.Dataset.filter(name="My versioned cytometry dataset", version="2").one()
adata = dataset.load(join="inner")
/opt/hostedtoolcache/Python/3.10.13/x64/lib/python3.10/site-packages/anndata/_core/anndata.py:1838: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.
utils.warn_names_duplicates("obs")
The AnnData
has the reference to the individual files in the .obs
annotations:
adata.obs.artifact_uid.cat.categories
Index(['yT92kbllQWRGstFEV78R', 'K57mz7XrXIXRKY8j96Gz'], dtype='object')
By default, the intersection of features is used:
adata.var.index
Index(['Cd4', 'CD8', 'CD3', 'CD27', 'Ccr7', 'CD45RA'], dtype='object')
Let us create a plot:
markers = lb.CellMarker.lookup()
import scanpy as sc
sc.pp.pca(adata)
sc.pl.pca(adata, color=markers.cd8.name, save="_cd8")
WARNING: saving figure to file figures/pca_cd8.pdf
artifact = ln.Artifact("./figures/pca_cd8.pdf", description="My result on CD8")
artifact.save()
artifact.view_flow()
Given the image is part of the notebook, there isn’t an actual need to save it and you can also rely on the report that you’ll create when saving the notebook via the command line via:
lamin save <notebook_path>
# clean up test instance
!lamin delete --force test-facs
!rm -r test-flow
💡 deleting instance testuser1/test-facs
✅ deleted instance settings file: /home/runner/.lamin/instance--testuser1--test-facs.env
✅ instance cache deleted
✅ deleted '.lndb' sqlite file
❗ consider manually deleting your stored data: /home/runner/work/lamin-usecases/lamin-usecases/docs/test-facs
rm: cannot remove 'test-flow': No such file or directory