topomics 0.0.1__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.
Files changed (120) hide show
  1. topomics-0.0.1/.codecov.yaml +17 -0
  2. topomics-0.0.1/.cruft.json +43 -0
  3. topomics-0.0.1/.editorconfig +15 -0
  4. topomics-0.0.1/.github/ISSUE_TEMPLATE/bug_report.yml +94 -0
  5. topomics-0.0.1/.github/ISSUE_TEMPLATE/config.yml +5 -0
  6. topomics-0.0.1/.github/ISSUE_TEMPLATE/feature_request.yml +11 -0
  7. topomics-0.0.1/.github/workflows/build.yaml +33 -0
  8. topomics-0.0.1/.github/workflows/release.yaml +34 -0
  9. topomics-0.0.1/.github/workflows/test.yaml +101 -0
  10. topomics-0.0.1/.gitignore +29 -0
  11. topomics-0.0.1/.pre-commit-config.yaml +47 -0
  12. topomics-0.0.1/.readthedocs.yaml +15 -0
  13. topomics-0.0.1/.vscode/extensions.json +18 -0
  14. topomics-0.0.1/.vscode/launch.json +33 -0
  15. topomics-0.0.1/.vscode/settings.json +18 -0
  16. topomics-0.0.1/CHANGELOG.md +16 -0
  17. topomics-0.0.1/LICENSE +21 -0
  18. topomics-0.0.1/PKG-INFO +138 -0
  19. topomics-0.0.1/README.md +67 -0
  20. topomics-0.0.1/ROADMAP.md +238 -0
  21. topomics-0.0.1/biome.jsonc +16 -0
  22. topomics-0.0.1/docs/_static/.gitkeep +0 -0
  23. topomics-0.0.1/docs/_static/css/custom.css +4 -0
  24. topomics-0.0.1/docs/_templates/.gitkeep +0 -0
  25. topomics-0.0.1/docs/_templates/autosummary/class.rst +61 -0
  26. topomics-0.0.1/docs/api.md +60 -0
  27. topomics-0.0.1/docs/changelog.md +2 -0
  28. topomics-0.0.1/docs/conf.py +152 -0
  29. topomics-0.0.1/docs/contributing.md +216 -0
  30. topomics-0.0.1/docs/examples/atac_rna.ipynb +1051 -0
  31. topomics-0.0.1/docs/examples/config.example.yml +34 -0
  32. topomics-0.0.1/docs/examples/scvelo_gastrulation_erythroid.ipynb +836 -0
  33. topomics-0.0.1/docs/examples/tea_seq.ipynb +888 -0
  34. topomics-0.0.1/docs/examples/teaseq.ipynb +1005 -0
  35. topomics-0.0.1/docs/extensions/typed_returns.py +32 -0
  36. topomics-0.0.1/docs/index.md +24 -0
  37. topomics-0.0.1/docs/notebooks/example.ipynb +171 -0
  38. topomics-0.0.1/docs/notebooks/example_SVEM.ipynb +596 -0
  39. topomics-0.0.1/docs/notebooks/example_amortized.ipynb +572 -0
  40. topomics-0.0.1/docs/notebooks/example_gibbs.ipynb +455 -0
  41. topomics-0.0.1/docs/references.bib +10 -0
  42. topomics-0.0.1/paper/Snakefile +62 -0
  43. topomics-0.0.1/paper/config.yaml +225 -0
  44. topomics-0.0.1/paper/notebooks/gastrulation_comparison.ipynb +1827 -0
  45. topomics-0.0.1/paper/notebooks/retina_batch_correction_comparison.ipynb +1324 -0
  46. topomics-0.0.1/paper/notebooks/retina_batch_correction_figures.py +314 -0
  47. topomics-0.0.1/paper/notebooks/visium_comparison.ipynb +906 -0
  48. topomics-0.0.1/paper/notebooks/visium_umap_gallery.ipynb +147 -0
  49. topomics-0.0.1/paper/scripts/annotate_teaseq_celltypist.py +234 -0
  50. topomics-0.0.1/paper/scripts/train_atac_rna.py +289 -0
  51. topomics-0.0.1/paper/scripts/train_baselines_atac_rna.py +504 -0
  52. topomics-0.0.1/paper/scripts/train_baselines_mouse_brain.py +614 -0
  53. topomics-0.0.1/paper/scripts/train_baselines_teaseq.py +734 -0
  54. topomics-0.0.1/paper/scripts/train_baselines_visium.py +330 -0
  55. topomics-0.0.1/paper/scripts/train_gastrulation.py +279 -0
  56. topomics-0.0.1/paper/scripts/train_mouse_brain_gaussian.py +333 -0
  57. topomics-0.0.1/paper/scripts/train_mouse_brain_spatial.py +388 -0
  58. topomics-0.0.1/paper/scripts/train_retina_linear_scvi.py +174 -0
  59. topomics-0.0.1/paper/scripts/train_retina_scvi.py +185 -0
  60. topomics-0.0.1/paper/scripts/train_retina_topomics.py +281 -0
  61. topomics-0.0.1/paper/scripts/train_teaseq.py +341 -0
  62. topomics-0.0.1/paper/scripts/train_visium.py +259 -0
  63. topomics-0.0.1/paper/workflow/rules/baselines.smk +172 -0
  64. topomics-0.0.1/paper/workflow/rules/retina.smk +47 -0
  65. topomics-0.0.1/paper/workflow/rules/scaling.smk +26 -0
  66. topomics-0.0.1/paper/workflow/rules/topomics.smk +26 -0
  67. topomics-0.0.1/paper/workflow/scripts/preprocess_data.py +311 -0
  68. topomics-0.0.1/paper/workflow/scripts/scaling_multimodal_cells.py +277 -0
  69. topomics-0.0.1/paper/workflow/scripts/scaling_multimodal_features.py +213 -0
  70. topomics-0.0.1/paper/workflow/scripts/train_amortized_lda.py +70 -0
  71. topomics-0.0.1/paper/workflow/scripts/train_cosmos.py +115 -0
  72. topomics-0.0.1/paper/workflow/scripts/train_glue.py +105 -0
  73. topomics-0.0.1/paper/workflow/scripts/train_linear_scvi.py +60 -0
  74. topomics-0.0.1/paper/workflow/scripts/train_mofa.py +58 -0
  75. topomics-0.0.1/paper/workflow/scripts/train_multivi.py +80 -0
  76. topomics-0.0.1/paper/workflow/scripts/train_scvi.py +89 -0
  77. topomics-0.0.1/paper/workflow/scripts/train_spatialglue.py +92 -0
  78. topomics-0.0.1/paper/workflow/scripts/train_stamp.py +91 -0
  79. topomics-0.0.1/paper/workflow/scripts/train_topomics.py +203 -0
  80. topomics-0.0.1/paper/workflow/scripts/train_topomics_retina.py +98 -0
  81. topomics-0.0.1/paper/workflow/scripts/train_totalvi.py +71 -0
  82. topomics-0.0.1/pyproject.toml +169 -0
  83. topomics-0.0.1/src/topomics/__init__.py +24 -0
  84. topomics-0.0.1/src/topomics/data/__init__.py +18 -0
  85. topomics-0.0.1/src/topomics/data/data_extraction.py +354 -0
  86. topomics-0.0.1/src/topomics/data/data_type_detection.py +91 -0
  87. topomics-0.0.1/src/topomics/models/SVEM.py +437 -0
  88. topomics-0.0.1/src/topomics/models/__init__.py +5 -0
  89. topomics-0.0.1/src/topomics/models/amortizedLDA.py +2003 -0
  90. topomics-0.0.1/src/topomics/models/base_model.py +492 -0
  91. topomics-0.0.1/src/topomics/models/gibbs.py +458 -0
  92. topomics-0.0.1/src/topomics/models/hBSM.py +0 -0
  93. topomics-0.0.1/src/topomics/models/share_topic.py +539 -0
  94. topomics-0.0.1/src/topomics/module/_amortizedLDA.py +1832 -0
  95. topomics-0.0.1/src/topomics/module/_share_topic.py +759 -0
  96. topomics-0.0.1/src/topomics/pl/__init__.py +2 -0
  97. topomics-0.0.1/src/topomics/pl/basic.py +48 -0
  98. topomics-0.0.1/src/topomics/pl/plot_topic_loc.py +75 -0
  99. topomics-0.0.1/src/topomics/pp/__init__.py +1 -0
  100. topomics-0.0.1/src/topomics/pp/basic.py +90 -0
  101. topomics-0.0.1/src/topomics/tl/__init__.py +1 -0
  102. topomics-0.0.1/src/topomics/tl/basic.py +17 -0
  103. topomics-0.0.1/src/topomics/utils/__init__.py +3 -0
  104. topomics-0.0.1/src/topomics/utils/_amortized_utils.py +239 -0
  105. topomics-0.0.1/src/topomics/utils/_encoders.py +561 -0
  106. topomics-0.0.1/src/topomics/utils/amortized_utils.py +137 -0
  107. topomics-0.0.1/src/topomics/utils/neighbor_sampler.py +209 -0
  108. topomics-0.0.1/src/topomics/utils/training_plan.py +216 -0
  109. topomics-0.0.1/tests/conftest.py +11 -0
  110. topomics-0.0.1/tests/test_basic.py +33 -0
  111. topomics-0.0.1/tests/test_bernoulli.py +519 -0
  112. topomics-0.0.1/tests/test_covariates.py +615 -0
  113. topomics-0.0.1/tests/test_data_import.py +478 -0
  114. topomics-0.0.1/tests/test_gaussian.py +503 -0
  115. topomics-0.0.1/tests/test_gibbs.py +111 -0
  116. topomics-0.0.1/tests/test_new_features.py +261 -0
  117. topomics-0.0.1/tests/test_perplexity.py +139 -0
  118. topomics-0.0.1/tests/test_sgc_stamp.py +184 -0
  119. topomics-0.0.1/tests/test_svem.py +90 -0
  120. topomics-0.0.1/uv.lock +4562 -0
@@ -0,0 +1,17 @@
1
+ # Based on pydata/xarray
2
+ codecov:
3
+ require_ci_to_pass: no
4
+
5
+ coverage:
6
+ status:
7
+ project:
8
+ default:
9
+ # Require 1% coverage, i.e., always succeed
10
+ target: 1
11
+ patch: false
12
+ changes: false
13
+
14
+ comment:
15
+ layout: diff, flags, files
16
+ behavior: once
17
+ require_base: no
@@ -0,0 +1,43 @@
1
+ {
2
+ "template": "https://github.com/scverse/cookiecutter-scverse",
3
+ "commit": "a2255cdaa3c5590777a276a1768f420099f162be",
4
+ "checkout": null,
5
+ "context": {
6
+ "cookiecutter": {
7
+ "project_name": "topomics",
8
+ "package_name": "topomics",
9
+ "project_description": "Single-cell multiomics topic modeling",
10
+ "author_full_name": "Federico Caretti",
11
+ "author_email": "fcaretti@sissa.it",
12
+ "github_user": "fcaretti",
13
+ "github_repo": "topomics",
14
+ "license": "MIT License",
15
+ "ide_integration": true,
16
+ "_copy_without_render": [
17
+ ".github/workflows/build.yaml",
18
+ ".github/workflows/test.yaml",
19
+ "docs/_templates/autosummary/**.rst"
20
+ ],
21
+ "_exclude_on_template_update": [
22
+ "CHANGELOG.md",
23
+ "LICENSE",
24
+ "README.md",
25
+ "docs/api.md",
26
+ "docs/index.md",
27
+ "docs/notebooks/example.ipynb",
28
+ "docs/references.bib",
29
+ "docs/references.md",
30
+ "src/**",
31
+ "tests/**"
32
+ ],
33
+ "_render_devdocs": false,
34
+ "_jinja2_env_vars": {
35
+ "lstrip_blocks": true,
36
+ "trim_blocks": true
37
+ },
38
+ "_template": "https://github.com/scverse/cookiecutter-scverse",
39
+ "_commit": "a2255cdaa3c5590777a276a1768f420099f162be"
40
+ }
41
+ },
42
+ "directory": null
43
+ }
@@ -0,0 +1,15 @@
1
+ root = true
2
+
3
+ [*]
4
+ indent_style = space
5
+ indent_size = 4
6
+ end_of_line = lf
7
+ charset = utf-8
8
+ trim_trailing_whitespace = true
9
+ insert_final_newline = true
10
+
11
+ [{*.{yml,yaml,toml},.cruft.json}]
12
+ indent_size = 2
13
+
14
+ [Makefile]
15
+ indent_style = tab
@@ -0,0 +1,94 @@
1
+ name: Bug report
2
+ description: Report something that is broken or incorrect
3
+ labels: bug
4
+ body:
5
+ - type: markdown
6
+ attributes:
7
+ value: |
8
+ **Note**: Please read [this guide](https://matthewrocklin.com/blog/work/2018/02/28/minimal-bug-reports)
9
+ detailing how to provide the necessary information for us to reproduce your bug. In brief:
10
+ * Please provide exact steps how to reproduce the bug in a clean Python environment.
11
+ * In case it's not clear what's causing this bug, please provide the data or the data generation procedure.
12
+ * Sometimes it is not possible to share the data, but usually it is possible to replicate problems on publicly
13
+ available datasets or to share a subset of your data.
14
+
15
+ - type: textarea
16
+ id: report
17
+ attributes:
18
+ label: Report
19
+ description: A clear and concise description of what the bug is.
20
+ validations:
21
+ required: true
22
+
23
+ - type: textarea
24
+ id: versions
25
+ attributes:
26
+ label: Versions
27
+ description: |
28
+ Which version of packages.
29
+
30
+ Please install `session-info2`, run the following command in a notebook,
31
+ click the “Copy as Markdown” button, then paste the results into the text box below.
32
+
33
+ ```python
34
+ In[1]: import session_info2; session_info2.session_info(dependencies=True)
35
+ ```
36
+
37
+ Alternatively, run this in a console:
38
+
39
+ ```python
40
+ >>> import session_info2; print(session_info2.session_info(dependencies=True)._repr_mimebundle_()["text/markdown"])
41
+ ```
42
+ render: python
43
+ placeholder: |
44
+ anndata 0.11.3
45
+ ---- ----
46
+ charset-normalizer 3.4.1
47
+ coverage 7.7.0
48
+ psutil 7.0.0
49
+ dask 2024.7.1
50
+ jaraco.context 5.3.0
51
+ numcodecs 0.15.1
52
+ jaraco.functools 4.0.1
53
+ Jinja2 3.1.6
54
+ sphinxcontrib-jsmath 1.0.1
55
+ sphinxcontrib-htmlhelp 2.1.0
56
+ toolz 1.0.0
57
+ session-info2 0.1.2
58
+ PyYAML 6.0.2
59
+ llvmlite 0.44.0
60
+ scipy 1.15.2
61
+ pandas 2.2.3
62
+ sphinxcontrib-devhelp 2.0.0
63
+ h5py 3.13.0
64
+ tblib 3.0.0
65
+ setuptools-scm 8.2.0
66
+ more-itertools 10.3.0
67
+ msgpack 1.1.0
68
+ sparse 0.15.5
69
+ wrapt 1.17.2
70
+ jaraco.collections 5.1.0
71
+ numba 0.61.0
72
+ pyarrow 19.0.1
73
+ pytz 2025.1
74
+ MarkupSafe 3.0.2
75
+ crc32c 2.7.1
76
+ sphinxcontrib-qthelp 2.0.0
77
+ sphinxcontrib-serializinghtml 2.0.0
78
+ zarr 2.18.4
79
+ asciitree 0.3.3
80
+ six 1.17.0
81
+ sphinxcontrib-applehelp 2.0.0
82
+ numpy 2.1.3
83
+ cloudpickle 3.1.1
84
+ sphinxcontrib-bibtex 2.6.3
85
+ natsort 8.4.0
86
+ jaraco.text 3.12.1
87
+ setuptools 76.1.0
88
+ Deprecated 1.2.18
89
+ packaging 24.2
90
+ python-dateutil 2.9.0.post0
91
+ ---- ----
92
+ Python 3.13.2 | packaged by conda-forge | (main, Feb 17 2025, 14:10:22) [GCC 13.3.0]
93
+ OS Linux-6.11.0-109019-tuxedo-x86_64-with-glibc2.39
94
+ Updated 2025-03-18 15:47
@@ -0,0 +1,5 @@
1
+ blank_issues_enabled: false
2
+ contact_links:
3
+ - name: Scverse Community Forum
4
+ url: https://discourse.scverse.org/
5
+ about: If you have questions about “How to do X”, please ask them here.
@@ -0,0 +1,11 @@
1
+ name: Feature request
2
+ description: Propose a new feature for topomics
3
+ labels: enhancement
4
+ body:
5
+ - type: textarea
6
+ id: description
7
+ attributes:
8
+ label: Description of feature
9
+ description: Please describe your suggestion for a new feature. It might help to describe a problem or use case, plus any alternatives that you have considered.
10
+ validations:
11
+ required: true
@@ -0,0 +1,33 @@
1
+ name: Check Build
2
+
3
+ on:
4
+ push:
5
+ branches: [main]
6
+ pull_request:
7
+ branches: [main]
8
+
9
+ concurrency:
10
+ group: ${{ github.workflow }}-${{ github.ref }}
11
+ cancel-in-progress: true
12
+
13
+ defaults:
14
+ run:
15
+ # to fail on error in multiline statements (-e), in pipes (-o pipefail), and on unset variables (-u).
16
+ shell: bash -euo pipefail {0}
17
+
18
+ jobs:
19
+ package:
20
+ runs-on: ubuntu-latest
21
+ steps:
22
+ - uses: actions/checkout@v4
23
+ with:
24
+ filter: blob:none
25
+ fetch-depth: 0
26
+ - name: Install uv
27
+ uses: astral-sh/setup-uv@v5
28
+ with:
29
+ cache-dependency-glob: pyproject.toml
30
+ - name: Build package
31
+ run: uv build
32
+ - name: Check package
33
+ run: uvx twine check --strict dist/*.whl
@@ -0,0 +1,34 @@
1
+ name: Release
2
+
3
+ on:
4
+ release:
5
+ types: [published]
6
+
7
+ defaults:
8
+ run:
9
+ # to fail on error in multiline statements (-e), in pipes (-o pipefail), and on unset variables (-u).
10
+ shell: bash -euo pipefail {0}
11
+
12
+ # Use "trusted publishing", see https://docs.pypi.org/trusted-publishers/
13
+ jobs:
14
+ release:
15
+ name: Upload release to PyPI
16
+ runs-on: ubuntu-latest
17
+ environment:
18
+ name: pypi
19
+ url: https://pypi.org/p/topomics
20
+ permissions:
21
+ id-token: write # IMPORTANT: this permission is mandatory for trusted publishing
22
+ steps:
23
+ - uses: actions/checkout@v4
24
+ with:
25
+ filter: blob:none
26
+ fetch-depth: 0
27
+ - name: Install uv
28
+ uses: astral-sh/setup-uv@v5
29
+ with:
30
+ cache-dependency-glob: pyproject.toml
31
+ - name: Build package
32
+ run: uv build
33
+ - name: Publish package distributions to PyPI
34
+ uses: pypa/gh-action-pypi-publish@release/v1
@@ -0,0 +1,101 @@
1
+ name: Test
2
+
3
+ on:
4
+ push:
5
+ branches: [main]
6
+ pull_request:
7
+ branches: [main]
8
+ schedule:
9
+ - cron: "0 5 1,15 * *"
10
+
11
+ concurrency:
12
+ group: ${{ github.workflow }}-${{ github.ref }}
13
+ cancel-in-progress: true
14
+
15
+ defaults:
16
+ run:
17
+ # to fail on error in multiline statements (-e), in pipes (-o pipefail), and on unset variables (-u).
18
+ shell: bash -euo pipefail {0}
19
+
20
+ jobs:
21
+ # Get the test environment from hatch as defined in pyproject.toml.
22
+ # This ensures that the pyproject.toml is the single point of truth for test definitions and the same tests are
23
+ # run locally and on continuous integration.
24
+ # Check [[tool.hatch.envs.hatch-test.matrix]] in pyproject.toml and https://hatch.pypa.io/latest/environment/ for
25
+ # more details.
26
+ get-environments:
27
+ runs-on: ubuntu-latest
28
+ outputs:
29
+ envs: ${{ steps.get-envs.outputs.envs }}
30
+ steps:
31
+ - uses: actions/checkout@v4
32
+ with:
33
+ filter: blob:none
34
+ fetch-depth: 0
35
+ - name: Install uv
36
+ uses: astral-sh/setup-uv@v5
37
+ - name: Get test environments
38
+ id: get-envs
39
+ run: |
40
+ ENVS_JSON=$(uvx hatch==1.16.5 env show --json | jq -c 'to_entries
41
+ | map(
42
+ select(.key | startswith("hatch-test"))
43
+ | {
44
+ name: .key,
45
+ label: (if (.key | contains("pre")) then .key + " (PRE-RELEASE DEPENDENCIES)" else .key end),
46
+ python: .value.python
47
+ }
48
+ )')
49
+ echo "envs=${ENVS_JSON}" | tee $GITHUB_OUTPUT
50
+
51
+ # Run tests through hatch. Spawns a separate runner for each environment defined in the hatch matrix obtained above.
52
+ test:
53
+ needs: get-environments
54
+
55
+ strategy:
56
+ fail-fast: false
57
+ matrix:
58
+ os: [ubuntu-latest]
59
+ env: ${{ fromJSON(needs.get-environments.outputs.envs) }}
60
+
61
+ name: ${{ matrix.env.label }}
62
+ runs-on: ${{ matrix.os }}
63
+
64
+ steps:
65
+ - uses: actions/checkout@v4
66
+ with:
67
+ filter: blob:none
68
+ fetch-depth: 0
69
+ - name: Install uv
70
+ uses: astral-sh/setup-uv@v5
71
+ with:
72
+ python-version: ${{ matrix.env.python }}
73
+ cache-dependency-glob: pyproject.toml
74
+ - name: create hatch environment
75
+ run: uvx hatch==1.16.5 env create ${{ matrix.env.name }}
76
+ - name: run tests using hatch
77
+ env:
78
+ MPLBACKEND: agg
79
+ PLATFORM: ${{ matrix.os }}
80
+ DISPLAY: :42
81
+ run: uvx hatch==1.16.5 run ${{ matrix.env.name }}:run-cov
82
+ - name: generate coverage report
83
+ run: uvx hatch==1.16.5 run ${{ matrix.env.name }}:coverage xml
84
+ - name: Upload coverage
85
+ uses: codecov/codecov-action@v4
86
+ with:
87
+ token: ${{ secrets.CODECOV_TOKEN }}
88
+
89
+ # Check that all tests defined above pass. This makes it easy to set a single "required" test in branch
90
+ # protection instead of having to update it frequently. See https://github.com/re-actors/alls-green#why.
91
+ check:
92
+ name: Tests pass in all hatch environments
93
+ if: always()
94
+ needs:
95
+ - get-environments
96
+ - test
97
+ runs-on: ubuntu-latest
98
+ steps:
99
+ - uses: re-actors/alls-green@release/v1
100
+ with:
101
+ jobs: ${{ toJSON(needs) }}
@@ -0,0 +1,29 @@
1
+ # Temp files
2
+ .DS_Store
3
+ *~
4
+ buck-out/
5
+
6
+ # Compiled files
7
+ .venv/
8
+ __pycache__/
9
+ .*cache/
10
+
11
+ # Distribution / packaging
12
+ /dist/
13
+
14
+ # Tests and coverage
15
+ /data/
16
+ /node_modules/
17
+
18
+ # docs
19
+ /docs/generated/
20
+ /docs/_build/
21
+
22
+ examples/*.png
23
+ *.pdf
24
+ paper/.snakemake/*
25
+ paper/plots/*
26
+ *.csv
27
+ *.npy
28
+ # Tutorial config with private dataset/model paths (keep out of git)
29
+ docs/examples/config.yml
@@ -0,0 +1,47 @@
1
+ fail_fast: false
2
+ default_language_version:
3
+ python: python3
4
+ default_stages:
5
+ - pre-commit
6
+ - pre-push
7
+ minimum_pre_commit_version: 2.16.0
8
+ repos:
9
+ - repo: https://github.com/biomejs/pre-commit
10
+ rev: v1.9.4
11
+ hooks:
12
+ - id: biome-format
13
+ exclude: ^\.cruft\.json$ # inconsistent indentation with cruft - file never to be modified manually.
14
+ - repo: https://github.com/tox-dev/pyproject-fmt
15
+ rev: v2.6.0
16
+ hooks:
17
+ - id: pyproject-fmt
18
+ - repo: https://github.com/astral-sh/ruff-pre-commit
19
+ rev: v0.11.13
20
+ hooks:
21
+ - id: ruff
22
+ types_or: [python, pyi, jupyter]
23
+ args: [--fix, --exit-non-zero-on-fix]
24
+ - id: ruff-format
25
+ types_or: [python, pyi, jupyter]
26
+ - repo: https://github.com/pre-commit/pre-commit-hooks
27
+ rev: v5.0.0
28
+ hooks:
29
+ - id: detect-private-key
30
+ - id: check-ast
31
+ - id: end-of-file-fixer
32
+ - id: mixed-line-ending
33
+ args: [--fix=lf]
34
+ - id: trailing-whitespace
35
+ - id: check-case-conflict
36
+ # Check that there are no merge conflicts (could be generated by template sync)
37
+ - id: check-merge-conflict
38
+ args: [--assume-in-merge]
39
+ - repo: local
40
+ hooks:
41
+ - id: forbid-to-commit
42
+ name: Don't commit rej files
43
+ entry: |
44
+ Cannot commit .rej files. These indicate merge conflicts that arise during automated template updates.
45
+ Fix the merge conflicts manually and remove the .rej files.
46
+ language: fail
47
+ files: '.*\.rej$'
@@ -0,0 +1,15 @@
1
+ # https://docs.readthedocs.io/en/stable/config-file/v2.html
2
+ version: 2
3
+ build:
4
+ os: ubuntu-24.04
5
+ tools:
6
+ python: "3.12"
7
+ jobs:
8
+ create_environment:
9
+ - asdf plugin add uv
10
+ - asdf install uv latest
11
+ - asdf global uv latest
12
+ build:
13
+ html:
14
+ - uvx hatch run docs:build
15
+ - mv docs/_build $READTHEDOCS_OUTPUT
@@ -0,0 +1,18 @@
1
+ {
2
+ "recommendations": [
3
+ // GitHub integration
4
+ "github.vscode-github-actions",
5
+ "github.vscode-pull-request-github",
6
+ // Language support
7
+ "ms-python.python",
8
+ "ms-python.vscode-pylance",
9
+ "ms-toolsai.jupyter",
10
+ "tamasfe.even-better-toml",
11
+ // Dependency management
12
+ "ninoseki.vscode-mogami",
13
+ // Linting and formatting
14
+ "editorconfig.editorconfig",
15
+ "charliermarsh.ruff",
16
+ "biomejs.biome",
17
+ ],
18
+ }
@@ -0,0 +1,33 @@
1
+ {
2
+ // Use IntelliSense to learn about possible attributes.
3
+ // Hover to view descriptions of existing attributes.
4
+ // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
5
+ "version": "0.2.0",
6
+ "configurations": [
7
+ {
8
+ "name": "Python: Build Documentation",
9
+ "type": "debugpy",
10
+ "request": "launch",
11
+ "module": "sphinx",
12
+ "args": ["-M", "html", ".", "_build"],
13
+ "cwd": "${workspaceFolder}/docs",
14
+ "console": "internalConsole",
15
+ "justMyCode": false,
16
+ },
17
+ {
18
+ "name": "Python: Debug Test",
19
+ "type": "debugpy",
20
+ "request": "launch",
21
+ "program": "${file}",
22
+ "purpose": ["debug-test"],
23
+ "console": "internalConsole",
24
+ "justMyCode": false,
25
+ "env": {
26
+ "PYTEST_ADDOPTS": "--color=yes",
27
+ },
28
+ "presentation": {
29
+ "hidden": true,
30
+ },
31
+ },
32
+ ],
33
+ }
@@ -0,0 +1,18 @@
1
+ {
2
+ "[python][json][jsonc]": {
3
+ "editor.formatOnSave": true,
4
+ },
5
+ "[python]": {
6
+ "editor.defaultFormatter": "charliermarsh.ruff",
7
+ "editor.codeActionsOnSave": {
8
+ "source.fixAll": "always",
9
+ "source.organizeImports": "always",
10
+ },
11
+ },
12
+ "[json][jsonc]": {
13
+ "editor.defaultFormatter": "biomejs.biome",
14
+ },
15
+ "python.analysis.typeCheckingMode": "basic",
16
+ "python.testing.pytestEnabled": true,
17
+ "python.testing.pytestArgs": ["-vv", "--color=yes"],
18
+ }
@@ -0,0 +1,16 @@
1
+ # Changelog
2
+
3
+ All notable changes to this project will be documented in this file.
4
+
5
+ The format is based on [Keep a Changelog][],
6
+ and this project adheres to [Semantic Versioning][].
7
+
8
+ [keep a changelog]: https://keepachangelog.com/en/1.0.0/
9
+ [semantic versioning]: https://semver.org/spec/v2.0.0.html
10
+
11
+ ## [Unreleased]
12
+
13
+ ### Added
14
+
15
+ - Basic tool, preprocessing and plotting functions
16
+ - Class MultimodalAmortizedLDA, with support for
topomics-0.0.1/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2025, Federico Caretti
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.