# Overview
This is a Python implementation of the [SOMA API specification](https://github.com/single-cell-data/SOMA/blob/main/abstract_specification.md) for interacting with the [Unified Single-cell Data Model](https://github.com/single-cell-data/SOMA).
# Installation
TileDB-SOMA is available on [PyPI](https://pypi.org/project/tiledbsoma/) and [Conda](https://anaconda.org/tiledb/tiledbsoma-py), and can be installed via `pip` or `mamba` as indicated below.
```bash
python -m pip install tiledbsoma
```
```bash
mamba install -c conda-forge -c tiledb tiledbsoma-py
```
To install a specific version:
```shell
$ python -m pip install git+https://github.com/single-cell-data/TileDB-SOMA.git@0.0.6#subdirectory=apis/python
```
To update to the latest version:
```shell
$ python -m pip install --upgrade tiledbsoma
```
In case of `illegal instruction` errors when running on older architectures --- e.g. Opteron, non-AVX2 --- the issue is that the pre-compiled binaries available at Conda or PyPI aren't targeted for all processor variants over time. You can install from source, as shown below.
To see if this is the issue, on Linux:
```
grep avx2 /proc/cpuinfo
```
If this comes up empty for your system, you'll definitely need to build from source to run TileDB-SOMA on that system.
## From source
* Clone [this repo](https://github.com/single-cell-data/TileDB-SOMA)
* `cd` into your checkout and then `cd apis/python`
* `python -m pip install .`
* Or, if you wish to modify the code and run it, `python -m pip install -v -e .`
* If the TileDB and TileDB-SOMA libraries are locally installed to a custom directory, such as `/usr/local`, set the path with environment variables `TILEDB_PATH` and `TILEDBSOMA_PATH`, `TILEDB_PATH=/usr/local python -m pip install -v -e .`
* Optionally, if you prefer, you can run that inside `venv`:
```shell
$ python -m venv venv
$ . ./venv/bin/activate
$ python -m pip install -v -e .
```
* In either case:
```shell
make data
python -m pytest tests
```
* A note about the `spdlog` package: If you encounter an install-time error like `fatal error: spdlog/spdlog.h: No such file or directory` you should additionally recursively remove `/usr/local/lib/cmake/spdlog `, since the system uninstall of `spdlog` fails to remove this properly.
# Status
Please see [https://github.com/single-cell-data/TileDB-SOMA/issues](https://github.com/single-cell-data/TileDB-SOMA/issues).
# `platform_config` format
When accessing SOMA APIs, TileDB-specific settings can be configured with the [`platform_config`](https://github.com/single-cell-data/SOMA/blob/main/abstract_specification.md#platform-specific-configuration) parameter.
The options accepted by TileDB SOMA are described here, using [TypeScript interface syntax](https://www.typescriptlang.org/docs/handbook/2/objects.html):
```typescript
interface PlatformConfig {
tiledb?: TDBConfig;
}
interface TDBConfig {
create?: TDBCreateOptions;
}
interface TDBCreateOptions {
dims?: { [dim: string]: TDBDimension };
attrs?: { [attr: string]: TDBAttr };
allows_duplicates?: bool;
offsets_filters?: TDBFilter[];
validity_filters?: TDBFilter[];
capacity?: number;
cell_order?: string;
tile_order?: string;
}
interface TDBDimension {
filters?: TDBFilter[];
tile?: number;
}
interface TDBAttr {
filters?: TDBFilter[];
}
/**
* Either the name of a filter (in which case it will use
* the default arguments) or a specification with filter args.
*/
type TDBFilter = string | TDBFilterSpec;
interface TDBFilterSpec {
/** The name of the filter. */
_name: string;
/** kwargs that are passed when constructing the filter. */
[kwarg: string]: any;
}
```
# Information for developers
Please see the [TileDB-SOMA wiki](https://github.com/single-cell-data/TileDB-SOMA/wiki).
<!-- temp for readthedocs testing -->
Raw data
{
"_id": null,
"home_page": "https://github.com/single-cell-data/TileDB-SOMA/tree/main/apis/python",
"name": "tiledbsoma",
"maintainer": "TileDB, Inc.",
"docs_url": null,
"requires_python": ">=3.9",
"maintainer_email": "help@tiledb.io",
"keywords": null,
"author": "TileDB, Inc.",
"author_email": "help@tiledb.io",
"download_url": "https://files.pythonhosted.org/packages/28/5f/935aa811dd78a4a26a4584c53923efeb63c36bd546049159d94e91149618/tiledbsoma-1.15.4.tar.gz",
"platform": null,
"description": "# Overview\n\nThis is a Python implementation of the [SOMA API specification](https://github.com/single-cell-data/SOMA/blob/main/abstract_specification.md) for interacting with the [Unified Single-cell Data Model](https://github.com/single-cell-data/SOMA).\n\n# Installation\n\nTileDB-SOMA is available on [PyPI](https://pypi.org/project/tiledbsoma/) and [Conda](https://anaconda.org/tiledb/tiledbsoma-py), and can be installed via `pip` or `mamba` as indicated below.\n\n```bash\npython -m pip install tiledbsoma\n```\n\n```bash\nmamba install -c conda-forge -c tiledb tiledbsoma-py\n```\n\nTo install a specific version:\n\n```shell\n$ python -m pip install git+https://github.com/single-cell-data/TileDB-SOMA.git@0.0.6#subdirectory=apis/python\n```\n\nTo update to the latest version:\n\n```shell\n$ python -m pip install --upgrade tiledbsoma\n```\n\nIn case of `illegal instruction` errors when running on older architectures --- e.g. Opteron, non-AVX2 --- the issue is that the pre-compiled binaries available at Conda or PyPI aren't targeted for all processor variants over time. You can install from source, as shown below.\n\nTo see if this is the issue, on Linux:\n\n```\ngrep avx2 /proc/cpuinfo\n```\n\nIf this comes up empty for your system, you'll definitely need to build from source to run TileDB-SOMA on that system.\n\n## From source\n\n* Clone [this repo](https://github.com/single-cell-data/TileDB-SOMA)\n* `cd` into your checkout and then `cd apis/python`\n* `python -m pip install .`\n* Or, if you wish to modify the code and run it, `python -m pip install -v -e .`\n* If the TileDB and TileDB-SOMA libraries are locally installed to a custom directory, such as `/usr/local`, set the path with environment variables `TILEDB_PATH` and `TILEDBSOMA_PATH`, `TILEDB_PATH=/usr/local python -m pip install -v -e .`\n* Optionally, if you prefer, you can run that inside `venv`:\n ```shell\n $ python -m venv venv\n $ . ./venv/bin/activate\n $ python -m pip install -v -e .\n ```\n* In either case:\n ```shell\n make data\n python -m pytest tests\n ```\n* A note about the `spdlog` package: If you encounter an install-time error like `fatal error: spdlog/spdlog.h: No such file or directory` you should additionally recursively remove `/usr/local/lib/cmake/spdlog `, since the system uninstall of `spdlog` fails to remove this properly.\n\n# Status\n\nPlease see [https://github.com/single-cell-data/TileDB-SOMA/issues](https://github.com/single-cell-data/TileDB-SOMA/issues).\n\n# `platform_config` format\n\nWhen accessing SOMA APIs, TileDB-specific settings can be configured with the [`platform_config`](https://github.com/single-cell-data/SOMA/blob/main/abstract_specification.md#platform-specific-configuration) parameter.\nThe options accepted by TileDB SOMA are described here, using [TypeScript interface syntax](https://www.typescriptlang.org/docs/handbook/2/objects.html):\n\n```typescript\ninterface PlatformConfig {\n tiledb?: TDBConfig;\n}\n\ninterface TDBConfig {\n create?: TDBCreateOptions;\n}\n\ninterface TDBCreateOptions {\n dims?: { [dim: string]: TDBDimension };\n attrs?: { [attr: string]: TDBAttr };\n allows_duplicates?: bool;\n\n offsets_filters?: TDBFilter[];\n validity_filters?: TDBFilter[];\n\n capacity?: number;\n cell_order?: string;\n tile_order?: string;\n}\n\ninterface TDBDimension {\n filters?: TDBFilter[];\n tile?: number;\n}\n\ninterface TDBAttr {\n filters?: TDBFilter[];\n}\n\n/**\n * Either the name of a filter (in which case it will use\n * the default arguments) or a specification with filter args.\n */\ntype TDBFilter = string | TDBFilterSpec;\n\ninterface TDBFilterSpec {\n /** The name of the filter. */\n _name: string;\n /** kwargs that are passed when constructing the filter. */\n [kwarg: string]: any;\n}\n```\n\n# Information for developers\n\nPlease see the [TileDB-SOMA wiki](https://github.com/single-cell-data/TileDB-SOMA/wiki).\n\n<!-- temp for readthedocs testing -->\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "Python API for efficient storage and retrieval of single-cell data using TileDB",
"version": "1.15.4",
"project_urls": {
"Homepage": "https://github.com/single-cell-data/TileDB-SOMA/tree/main/apis/python"
},
"split_keywords": [],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "57c1387dd30977d60c80abc996d3d1c02c509f7a21b4605460898a17d94b9834",
"md5": "663d07e0e6c2b20dc5eef90c2c6b0d4e",
"sha256": "99dff1dd59d4925faa32b2f5300365fffe6bc35697119d4ba9670f1bff8ab5ec"
},
"downloads": -1,
"filename": "tiledbsoma-1.15.4-cp310-cp310-macosx_11_0_arm64.whl",
"has_sig": false,
"md5_digest": "663d07e0e6c2b20dc5eef90c2c6b0d4e",
"packagetype": "bdist_wheel",
"python_version": "cp310",
"requires_python": ">=3.9",
"size": 25935518,
"upload_time": "2025-01-22T23:02:07",
"upload_time_iso_8601": "2025-01-22T23:02:07.372587Z",
"url": "https://files.pythonhosted.org/packages/57/c1/387dd30977d60c80abc996d3d1c02c509f7a21b4605460898a17d94b9834/tiledbsoma-1.15.4-cp310-cp310-macosx_11_0_arm64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "92750f9be4edb362da4273e99206040406ddcbcb8f08fcdcd324582c51a0c115",
"md5": "6f23b262297bdc086a33ccfc24c8586b",
"sha256": "f33a19c8c353a1bab21639e77c6abff705bb2e7b3392f1b693367c92b998ceca"
},
"downloads": -1,
"filename": "tiledbsoma-1.15.4-cp310-cp310-macosx_11_0_x86_64.whl",
"has_sig": false,
"md5_digest": "6f23b262297bdc086a33ccfc24c8586b",
"packagetype": "bdist_wheel",
"python_version": "cp310",
"requires_python": ">=3.9",
"size": 27753549,
"upload_time": "2025-01-22T23:02:12",
"upload_time_iso_8601": "2025-01-22T23:02:12.105620Z",
"url": "https://files.pythonhosted.org/packages/92/75/0f9be4edb362da4273e99206040406ddcbcb8f08fcdcd324582c51a0c115/tiledbsoma-1.15.4-cp310-cp310-macosx_11_0_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "1f3cdacde742463bd44d63bfb56b6b2587e1cdb735eda61d6923ed4a9544e1c2",
"md5": "a4e1732cb61e835489ac7e6bc0cd38fa",
"sha256": "3b53dbbbe39fae184b2cd49aca787127290805c1077ee8696623b1a12d7fbb1a"
},
"downloads": -1,
"filename": "tiledbsoma-1.15.4-cp310-cp310-manylinux_2_28_x86_64.whl",
"has_sig": false,
"md5_digest": "a4e1732cb61e835489ac7e6bc0cd38fa",
"packagetype": "bdist_wheel",
"python_version": "cp310",
"requires_python": ">=3.9",
"size": 19163986,
"upload_time": "2025-01-22T23:02:16",
"upload_time_iso_8601": "2025-01-22T23:02:16.508604Z",
"url": "https://files.pythonhosted.org/packages/1f/3c/dacde742463bd44d63bfb56b6b2587e1cdb735eda61d6923ed4a9544e1c2/tiledbsoma-1.15.4-cp310-cp310-manylinux_2_28_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "e52f2e70c90a5785a5952fc59d5e5b617007ef0f5054b09c905384c5026b98e1",
"md5": "b7829de290e7df380e0790bb0a26669d",
"sha256": "68dc48547e187460d5c37d3f8184019ae8268be5a0f96f1db2a4a4a4a0aaf672"
},
"downloads": -1,
"filename": "tiledbsoma-1.15.4-cp311-cp311-macosx_11_0_arm64.whl",
"has_sig": false,
"md5_digest": "b7829de290e7df380e0790bb0a26669d",
"packagetype": "bdist_wheel",
"python_version": "cp311",
"requires_python": ">=3.9",
"size": 25938247,
"upload_time": "2025-01-22T23:02:20",
"upload_time_iso_8601": "2025-01-22T23:02:20.465774Z",
"url": "https://files.pythonhosted.org/packages/e5/2f/2e70c90a5785a5952fc59d5e5b617007ef0f5054b09c905384c5026b98e1/tiledbsoma-1.15.4-cp311-cp311-macosx_11_0_arm64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "0aa0f453c6d2b72abd50fb4d302fe8d63b95c0dcb48f08f82ea0eed3a88d0238",
"md5": "4a46739a501d886bd3f8ab4b4d028c6d",
"sha256": "030ca9c341d4a502bdb5a4c1f0f202d2a22d94ac585e3bc3ae2e35ec6ed2d1d7"
},
"downloads": -1,
"filename": "tiledbsoma-1.15.4-cp311-cp311-macosx_11_0_x86_64.whl",
"has_sig": false,
"md5_digest": "4a46739a501d886bd3f8ab4b4d028c6d",
"packagetype": "bdist_wheel",
"python_version": "cp311",
"requires_python": ">=3.9",
"size": 27756144,
"upload_time": "2025-01-22T23:02:26",
"upload_time_iso_8601": "2025-01-22T23:02:26.896084Z",
"url": "https://files.pythonhosted.org/packages/0a/a0/f453c6d2b72abd50fb4d302fe8d63b95c0dcb48f08f82ea0eed3a88d0238/tiledbsoma-1.15.4-cp311-cp311-macosx_11_0_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "342fa87d2ef0c8623ce14e45be8c5df788bafd8e9d3184928449d6e11c7a647e",
"md5": "62e0c44e54f4e62f3dfcdc0530ab5f9d",
"sha256": "103190cae886edac53c9427b751cd9941dfd21e1195c73094b437e93649c4afc"
},
"downloads": -1,
"filename": "tiledbsoma-1.15.4-cp311-cp311-manylinux_2_28_x86_64.whl",
"has_sig": false,
"md5_digest": "62e0c44e54f4e62f3dfcdc0530ab5f9d",
"packagetype": "bdist_wheel",
"python_version": "cp311",
"requires_python": ">=3.9",
"size": 19166116,
"upload_time": "2025-01-22T23:02:31",
"upload_time_iso_8601": "2025-01-22T23:02:31.406919Z",
"url": "https://files.pythonhosted.org/packages/34/2f/a87d2ef0c8623ce14e45be8c5df788bafd8e9d3184928449d6e11c7a647e/tiledbsoma-1.15.4-cp311-cp311-manylinux_2_28_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "718b7ad1c4d1ef262aa3d3149ac4d783af53cb66a523fd0da6de905fe436f91e",
"md5": "a5f5b25fa2f242f99fd4b2b908198065",
"sha256": "2c17399a31a93b1862b5681b83a262e962e9e37d30d2424c147ac486e826b51d"
},
"downloads": -1,
"filename": "tiledbsoma-1.15.4-cp312-cp312-macosx_11_0_arm64.whl",
"has_sig": false,
"md5_digest": "a5f5b25fa2f242f99fd4b2b908198065",
"packagetype": "bdist_wheel",
"python_version": "cp312",
"requires_python": ">=3.9",
"size": 25953457,
"upload_time": "2025-01-22T23:02:35",
"upload_time_iso_8601": "2025-01-22T23:02:35.376601Z",
"url": "https://files.pythonhosted.org/packages/71/8b/7ad1c4d1ef262aa3d3149ac4d783af53cb66a523fd0da6de905fe436f91e/tiledbsoma-1.15.4-cp312-cp312-macosx_11_0_arm64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "eff884030dc95f04711cdba75d239c25e6359ae26312b0c2525f94769dd67c1c",
"md5": "a44c52bb87549a14fdbc34b8e2b40394",
"sha256": "dec8cd8a9cca0a0c98da4495cede2ab6f6f6efedd61181855318611937d61a12"
},
"downloads": -1,
"filename": "tiledbsoma-1.15.4-cp312-cp312-macosx_11_0_x86_64.whl",
"has_sig": false,
"md5_digest": "a44c52bb87549a14fdbc34b8e2b40394",
"packagetype": "bdist_wheel",
"python_version": "cp312",
"requires_python": ">=3.9",
"size": 27780374,
"upload_time": "2025-01-22T23:02:40",
"upload_time_iso_8601": "2025-01-22T23:02:40.201946Z",
"url": "https://files.pythonhosted.org/packages/ef/f8/84030dc95f04711cdba75d239c25e6359ae26312b0c2525f94769dd67c1c/tiledbsoma-1.15.4-cp312-cp312-macosx_11_0_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "8ca638f34f01c6d2b4f45ce65c8940aa0c32c3071afb575cba9f086675a1f3f7",
"md5": "36cf4780bc1bc95e9577c0ed95f2a74f",
"sha256": "04a71619ba3092b2077421e2d6b3ace1eaa63f82158430a7a51f338b9e90f93a"
},
"downloads": -1,
"filename": "tiledbsoma-1.15.4-cp312-cp312-manylinux_2_28_x86_64.whl",
"has_sig": false,
"md5_digest": "36cf4780bc1bc95e9577c0ed95f2a74f",
"packagetype": "bdist_wheel",
"python_version": "cp312",
"requires_python": ">=3.9",
"size": 19175375,
"upload_time": "2025-01-22T23:02:44",
"upload_time_iso_8601": "2025-01-22T23:02:44.504630Z",
"url": "https://files.pythonhosted.org/packages/8c/a6/38f34f01c6d2b4f45ce65c8940aa0c32c3071afb575cba9f086675a1f3f7/tiledbsoma-1.15.4-cp312-cp312-manylinux_2_28_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "638b4a405007ffbbac7aede884427538aa76e0cfb104a0bdf14553be7070fc40",
"md5": "3fbba646eb46182cca8c99c6ecfbaa46",
"sha256": "655630508ed793a077854b4ea1f81ba7c2906796beab83ee03caafa6d2b99029"
},
"downloads": -1,
"filename": "tiledbsoma-1.15.4-cp39-cp39-macosx_11_0_arm64.whl",
"has_sig": false,
"md5_digest": "3fbba646eb46182cca8c99c6ecfbaa46",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": ">=3.9",
"size": 25935894,
"upload_time": "2025-01-22T23:02:48",
"upload_time_iso_8601": "2025-01-22T23:02:48.780582Z",
"url": "https://files.pythonhosted.org/packages/63/8b/4a405007ffbbac7aede884427538aa76e0cfb104a0bdf14553be7070fc40/tiledbsoma-1.15.4-cp39-cp39-macosx_11_0_arm64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "a8028e5e98bfe501696a8d15c433edafb65b22c1597e7ae152e174a1cdf9d040",
"md5": "93035e2f684f878718d7f4cb7b89d9ce",
"sha256": "1fab3e325c0a619cfe2ba0420703f02a74d5db63b7308f91842f19dab22d7f51"
},
"downloads": -1,
"filename": "tiledbsoma-1.15.4-cp39-cp39-macosx_11_0_x86_64.whl",
"has_sig": false,
"md5_digest": "93035e2f684f878718d7f4cb7b89d9ce",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": ">=3.9",
"size": 27753598,
"upload_time": "2025-01-22T23:02:53",
"upload_time_iso_8601": "2025-01-22T23:02:53.495559Z",
"url": "https://files.pythonhosted.org/packages/a8/02/8e5e98bfe501696a8d15c433edafb65b22c1597e7ae152e174a1cdf9d040/tiledbsoma-1.15.4-cp39-cp39-macosx_11_0_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "390a0cf3f8b6bb429418c336b6b8ceace44e4a7d19ecc4e972f0cdcbd3546806",
"md5": "f0acdfcca85528f99bb8be14d03cc32b",
"sha256": "1164a8f49232dae03da6c2f47c3f6eb10910e47af2aab6ea6cac5b630641f631"
},
"downloads": -1,
"filename": "tiledbsoma-1.15.4-cp39-cp39-manylinux_2_28_x86_64.whl",
"has_sig": false,
"md5_digest": "f0acdfcca85528f99bb8be14d03cc32b",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": ">=3.9",
"size": 19162855,
"upload_time": "2025-01-22T23:02:57",
"upload_time_iso_8601": "2025-01-22T23:02:57.609849Z",
"url": "https://files.pythonhosted.org/packages/39/0a/0cf3f8b6bb429418c336b6b8ceace44e4a7d19ecc4e972f0cdcbd3546806/tiledbsoma-1.15.4-cp39-cp39-manylinux_2_28_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "285f935aa811dd78a4a26a4584c53923efeb63c36bd546049159d94e91149618",
"md5": "89a2e95a0117e4b309db79ca51e501c8",
"sha256": "aaf30fffb3843b99e6b4ecd093b210107c1438b69edfce7d8dccfbf44445e82c"
},
"downloads": -1,
"filename": "tiledbsoma-1.15.4.tar.gz",
"has_sig": false,
"md5_digest": "89a2e95a0117e4b309db79ca51e501c8",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.9",
"size": 693642,
"upload_time": "2025-01-22T23:02:59",
"upload_time_iso_8601": "2025-01-22T23:02:59.959303Z",
"url": "https://files.pythonhosted.org/packages/28/5f/935aa811dd78a4a26a4584c53923efeb63c36bd546049159d94e91149618/tiledbsoma-1.15.4.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-01-22 23:02:59",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "single-cell-data",
"github_project": "TileDB-SOMA",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "tiledbsoma"
}