knn-normalization 0.1.0__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 (48) hide show
  1. knn_normalization-0.1.0/.README.md.swp +0 -0
  2. knn_normalization-0.1.0/.codecov.yaml +17 -0
  3. knn_normalization-0.1.0/.cruft.json +42 -0
  4. knn_normalization-0.1.0/.editorconfig +15 -0
  5. knn_normalization-0.1.0/.github/ISSUE_TEMPLATE/bug_report.yml +94 -0
  6. knn_normalization-0.1.0/.github/ISSUE_TEMPLATE/config.yml +5 -0
  7. knn_normalization-0.1.0/.github/ISSUE_TEMPLATE/feature_request.yml +11 -0
  8. knn_normalization-0.1.0/.github/workflows/build.yaml +33 -0
  9. knn_normalization-0.1.0/.github/workflows/release.yaml +34 -0
  10. knn_normalization-0.1.0/.github/workflows/test.yaml +99 -0
  11. knn_normalization-0.1.0/.gitignore +20 -0
  12. knn_normalization-0.1.0/.pre-commit-config.yaml +47 -0
  13. knn_normalization-0.1.0/.python-version +1 -0
  14. knn_normalization-0.1.0/.readthedocs.yaml +16 -0
  15. knn_normalization-0.1.0/.vscode/extensions.json +18 -0
  16. knn_normalization-0.1.0/.vscode/launch.json +33 -0
  17. knn_normalization-0.1.0/.vscode/settings.json +18 -0
  18. knn_normalization-0.1.0/CHANGELOG.md +14 -0
  19. knn_normalization-0.1.0/LICENSE +21 -0
  20. knn_normalization-0.1.0/PKG-INFO +122 -0
  21. knn_normalization-0.1.0/README.md +55 -0
  22. knn_normalization-0.1.0/biome.jsonc +16 -0
  23. knn_normalization-0.1.0/docs/_static/.gitkeep +0 -0
  24. knn_normalization-0.1.0/docs/_static/css/custom.css +4 -0
  25. knn_normalization-0.1.0/docs/_templates/.gitkeep +0 -0
  26. knn_normalization-0.1.0/docs/_templates/autosummary/class.rst +61 -0
  27. knn_normalization-0.1.0/docs/api.md +14 -0
  28. knn_normalization-0.1.0/docs/changelog.md +3 -0
  29. knn_normalization-0.1.0/docs/conf.py +132 -0
  30. knn_normalization-0.1.0/docs/extensions/typed_returns.py +33 -0
  31. knn_normalization-0.1.0/docs/index.md +15 -0
  32. knn_normalization-0.1.0/docs/notebooks/.ipynb_checkpoints/example-checkpoint.ipynb +106 -0
  33. knn_normalization-0.1.0/docs/notebooks/example.ipynb +105 -0
  34. knn_normalization-0.1.0/docs/references.bib +10 -0
  35. knn_normalization-0.1.0/docs/references.md +5 -0
  36. knn_normalization-0.1.0/images/KNN_normalization_logo.png +0 -0
  37. knn_normalization-0.1.0/pyproject.toml +154 -0
  38. knn_normalization-0.1.0/src/knn_normalization/__init__.py +7 -0
  39. knn_normalization-0.1.0/src/knn_normalization/pl/__init__.py +0 -0
  40. knn_normalization-0.1.0/src/knn_normalization/pl/plotting.py +0 -0
  41. knn_normalization-0.1.0/src/knn_normalization/pp/__init__.py +1 -0
  42. knn_normalization-0.1.0/src/knn_normalization/pp/preprocessing.py +60 -0
  43. knn_normalization-0.1.0/src/knn_normalization/tl/__init__.py +1 -0
  44. knn_normalization-0.1.0/src/knn_normalization/tl/tools.py +505 -0
  45. knn_normalization-0.1.0/tests/.ipynb_checkpoints/conftest-checkpoint.py +23 -0
  46. knn_normalization-0.1.0/tests/.ipynb_checkpoints/test_basic-checkpoint.py +57 -0
  47. knn_normalization-0.1.0/tests/conftest.py +24 -0
  48. knn_normalization-0.1.0/tests/test_basic.py +51 -0
Binary file
@@ -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,42 @@
1
+ {
2
+ "template": "https://github.com/scverse/cookiecutter-scverse",
3
+ "commit": "d4bdfc5ec4c5029aebf7c0cba65609e20358144d",
4
+ "checkout": null,
5
+ "context": {
6
+ "cookiecutter": {
7
+ "project_name": "KNN_normalization",
8
+ "package_name": "knn_normalization",
9
+ "project_description": "Neighbor-based normalization of CITE-seq data",
10
+ "author_full_name": "Javier Marchena Hurtado",
11
+ "author_email": "javier.marchena.hurtado@gmail.com",
12
+ "github_user": "javier-marchena-hurtado",
13
+ "github_repo": "KNN_normalization",
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
+ }
40
+ },
41
+ "directory": null
42
+ }
@@ -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 KNN_normalization
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/knn_normalization
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,99 @@
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 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 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 run ${{ matrix.env.name }}:run-cov
82
+ - name: generate coverage report
83
+ run: uvx hatch run ${{ matrix.env.name }}:coverage xml
84
+ - name: Upload coverage
85
+ uses: codecov/codecov-action@v4
86
+
87
+ # Check that all tests defined above pass. This makes it easy to set a single "required" test in branch
88
+ # protection instead of having to update it frequently. See https://github.com/re-actors/alls-green#why.
89
+ check:
90
+ name: Tests pass in all hatch environments
91
+ if: always()
92
+ needs:
93
+ - get-environments
94
+ - test
95
+ runs-on: ubuntu-latest
96
+ steps:
97
+ - uses: re-actors/alls-green@release/v1
98
+ with:
99
+ jobs: ${{ toJSON(needs) }}
@@ -0,0 +1,20 @@
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/
@@ -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.23.0
16
+ hooks:
17
+ - id: pyproject-fmt
18
+ - repo: https://github.com/astral-sh/ruff-pre-commit
19
+ rev: v0.11.6
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 @@
1
+ 3.9.18
@@ -0,0 +1,16 @@
1
+ # https://docs.readthedocs.io/en/stable/config-file/v2.html
2
+ version: 2
3
+ build:
4
+ os: ubuntu-20.04
5
+ tools:
6
+ python: "3.10"
7
+ sphinx:
8
+ configuration: docs/conf.py
9
+ # disable this for more lenient docs builds
10
+ fail_on_warning: true
11
+ python:
12
+ install:
13
+ - method: pip
14
+ path: .
15
+ extra_requirements:
16
+ - doc
@@ -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,14 @@
1
+ # Changelog
2
+
3
+ All notable changes to this project will be documented in this file.
4
+
5
+
6
+ ## [Unreleased]
7
+
8
+ ## [0.1.0] - 2026-06-15
9
+
10
+ ### Added
11
+
12
+ - Initial public release
13
+ - Neighbor-based normalization of CITE-seq
14
+ - Basic preprocessing and tool functions, especially the main function knn.tl.knn_normalize()
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2025, Javier Marchena Hurtado
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.
@@ -0,0 +1,122 @@
1
+ Metadata-Version: 2.4
2
+ Name: knn-normalization
3
+ Version: 0.1.0
4
+ Summary: Neighbor-based normalization of CITE-seq data
5
+ Project-URL: Documentation, https://knn-normalization.readthedocs.io/
6
+ Project-URL: Homepage, https://github.com/javier-marchena-hurtado/KNN_normalization
7
+ Project-URL: Source, https://github.com/javier-marchena-hurtado/KNN_normalization
8
+ Author: Javier Marchena Hurtado
9
+ Maintainer-email: Javier Marchena Hurtado <javier.marchena.hurtado@gmail.com>
10
+ License: MIT License
11
+
12
+ Copyright (c) 2025, Javier Marchena Hurtado
13
+
14
+ Permission is hereby granted, free of charge, to any person obtaining a copy
15
+ of this software and associated documentation files (the "Software"), to deal
16
+ in the Software without restriction, including without limitation the rights
17
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
18
+ copies of the Software, and to permit persons to whom the Software is
19
+ furnished to do so, subject to the following conditions:
20
+
21
+ The above copyright notice and this permission notice shall be included in all
22
+ copies or substantial portions of the Software.
23
+
24
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
25
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
26
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
27
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
28
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
29
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
30
+ SOFTWARE.
31
+ License-File: LICENSE
32
+ Classifier: Programming Language :: Python :: 3 :: Only
33
+ Classifier: Programming Language :: Python :: 3.10
34
+ Classifier: Programming Language :: Python :: 3.11
35
+ Classifier: Programming Language :: Python :: 3.12
36
+ Classifier: Programming Language :: Python :: 3.13
37
+ Classifier: Programming Language :: Python :: 3.14
38
+ Requires-Python: >=3.10
39
+ Requires-Dist: anndata
40
+ Requires-Dist: mudata
41
+ Requires-Dist: numpy
42
+ Requires-Dist: scanpy
43
+ Requires-Dist: scipy
44
+ Requires-Dist: session-info2
45
+ Provides-Extra: dev
46
+ Requires-Dist: build; extra == 'dev'
47
+ Requires-Dist: pre-commit; extra == 'dev'
48
+ Requires-Dist: twine>=4.0.2; extra == 'dev'
49
+ Provides-Extra: doc
50
+ Requires-Dist: docutils!=0.18.*,!=0.19.*,>=0.8; extra == 'doc'
51
+ Requires-Dist: ipykernel; extra == 'doc'
52
+ Requires-Dist: ipython; extra == 'doc'
53
+ Requires-Dist: myst-nb>=1.1; extra == 'doc'
54
+ Requires-Dist: pandas; extra == 'doc'
55
+ Requires-Dist: setuptools; extra == 'doc'
56
+ Requires-Dist: sphinx-autodoc-typehints; extra == 'doc'
57
+ Requires-Dist: sphinx-book-theme>=1; extra == 'doc'
58
+ Requires-Dist: sphinx-copybutton; extra == 'doc'
59
+ Requires-Dist: sphinx-tabs; extra == 'doc'
60
+ Requires-Dist: sphinx>=4; extra == 'doc'
61
+ Requires-Dist: sphinxcontrib-bibtex>=1; extra == 'doc'
62
+ Requires-Dist: sphinxext-opengraph; extra == 'doc'
63
+ Provides-Extra: test
64
+ Requires-Dist: coverage; extra == 'test'
65
+ Requires-Dist: pytest; extra == 'test'
66
+ Description-Content-Type: text/markdown
67
+
68
+ # KNN normalization
69
+
70
+ [![Tests][badge-tests]][tests]
71
+ [![Documentation][badge-docs]][documentation]
72
+
73
+ [badge-tests]: https://img.shields.io/github/actions/workflow/status/javier-marchena-hurtado/KNN_normalization/test.yaml?branch=main
74
+ [badge-docs]: https://img.shields.io/readthedocs/KNN_normalization
75
+
76
+ <img src="https://raw.githubusercontent.com/javier-marchena-hurtado/KNN_normalization/main/images/KNN_normalization_logo.png" width="250">
77
+
78
+ ## Background and motivation
79
+
80
+ KNN normalization is a normalization method for protein counts in CITE-seq data. KNN normalization learns from neighbor cells in a KNN graph in order to estimate the appropriate total protein counts in each cell. KNN normalization accurately estimates total protein counts while preserving biological information.
81
+
82
+ ## Getting started
83
+
84
+ Please refer to the [documentation][],
85
+ in particular, the [API documentation][].
86
+
87
+ ## Installation
88
+
89
+
90
+ <!--
91
+ 1) Install the latest release of `KNN_normalization` from [PyPI][]:
92
+
93
+ ```bash
94
+ pip install KNN_normalization
95
+ ```
96
+ -->
97
+ Install the latest development version:
98
+
99
+ ```bash
100
+ pip install git+https://github.com/javier-marchena-hurtado/KNN_normalization.git@main
101
+ ```
102
+
103
+ ## Release notes
104
+
105
+ See the [changelog][].
106
+
107
+ ## Contact
108
+
109
+ For questions and help requests, please open a [discussion][] on GitHub.
110
+ If you found a bug, please use the [issue tracker][].
111
+
112
+ ## Citation
113
+
114
+ > t.b.a
115
+
116
+ [issue tracker]: https://github.com/javier-marchena-hurtado/KNN_normalization/issues
117
+ [tests]: https://github.com/javier-marchena-hurtado/KNN_normalization/actions/workflows/test.yaml
118
+ [documentation]: https://knn-normalization.readthedocs.io
119
+ [changelog]: https://knn-normalization.readthedocs.io/en/latest/changelog.html
120
+ [api documentation]: https://knn-normalization.readthedocs.io/en/latest/api.html
121
+ [pypi]: https://pypi.org/project/KNN_normalization
122
+ [discussion]: https://github.com/javier-marchena-hurtado/KNN_normalization/discussions