General genetics/genomics utilities.
Project description
genetools: single-cell analysis recipes (work in progress)
Plot gallery
Other features
- Compare clustering results by computing co-clustering percentage.
- Map marker genes against reference lists to find names for your clusters.
- pandas shotrcuts:
- Split single cell barcodes conveniently.
- Defensive pandas merging and concatenation methods with strict correctness checks.
Full documentation: https://genetools.maximz.com.
Install
Run pip install --upgrade 'genetools[scanpy]'.
Or if you don't use scanpy: pip install --upgrade genetools.
Usage
To use genetools in a project, add import genetools. Review the documentation and the tests for examples.
Development
Setup:
git clone git://github.com/maximz/genetools
cd genetools
pip install --upgrade pip wheel
pip install -r requirements_dev.txt
pre-commit install
Common commands:
# lint
make lint
# one-time: generate test anndata, and commit so we have reproducible tests in CI
rm -r data
make regen-test-data
# run tests locally
# this is done in a debian-based docker image to ensure image style matches what Github Actions CI will produce
# failing image snapshot tests are recorded in tests/results/
make build-docker-test-image # whenever requirements_dev.txt change
make test
# generate baseline figures (also happens in docker)
make regen-snapshot-figures
# regenerate test data, and baseline figures (also happens in docker)
make regen-test-data
# run tests locally without docker, therefore omitting the snapshot tests
# (the @snapshot_image tests are still executed but the images are not compared. the @pytest.mark.snapshot_custom are skipped altogether.)
make test-without-figures
# docs
make docs
# bump version before submitting a PR against master (all master commits are deployed)
bump2version patch # possible: major / minor / patch
# also ensure CHANGELOG.md updated
CI:
- Main: Github Actions
- Docs: https://app.netlify.com/sites/genetools
Changelog
0.7.0
0.6.0
- Two new functions to customize tick labels on any existing plot:
wrap_tick_labels: add text wrappingadd_sample_size_to_labels: add group sample sizes with a(n=N)suffix
- Make writing PDF figures a deterministic process and make the PDF text editable.
- Scatterplot improvements:
- Adjust default marker shape and size to work better for most plots.
- Adjust HueValueStyle so that an explicit marker size is not specified there, only a marker size scaling factor. The scatterplot itself is responsible for defining the base marker size, while the palette of HueValueStyles should be drawable at any marker size.
- Change legends so that only one marker is drawn to indicate a group's style.
0.5.0 (2022-01-10)
- Improve scatter plots and stacked bar plots.
- Introduce
HueValueStylefor granular styling of each hue.
0.4.0 (2020-07-22)
- Centered log ratio (CLR) normalization for Cite-seq protein data.
0.3.0 (2020-06-03)
- Pandas helpers for easier normalization
0.2.0 (2020-06-03)
- Far faster implementation of
stats.coclustering - Introducing
helpers.make_slurm_command - Global submodule import (no longer need to import submodules individually)
0.1.0 (2020-03-06)
- First release on PyPI.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file genetools-0.7.5.tar.gz.
File metadata
- Download URL: genetools-0.7.5.tar.gz
- Upload date:
- Size: 1.8 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.9.20
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
abe71d77ca936bcfc3f513502f93a1cc3b2b091f316c11da46face2da3799b4f
|
|
| MD5 |
f5a6f21b4c81a091e1bd14d260a7fe92
|
|
| BLAKE2b-256 |
7533a13a69adc54cf5a7757d06665d014e4b6955feec92f45bbeff6f2a739dcf
|
File details
Details for the file genetools-0.7.5-py2.py3-none-any.whl.
File metadata
- Download URL: genetools-0.7.5-py2.py3-none-any.whl
- Upload date:
- Size: 45.5 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.9.20
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c25ecdd26d47ed76372051317c242e36294177db492272c29fcb3add4285d0b7
|
|
| MD5 |
a46114da4726d026d3ddf91ca0c1399b
|
|
| BLAKE2b-256 |
951c592d53e6b3dacd6cf93389e4a78be1ae2d24b01b4e97692974abbcd7e989
|