# BioPII
BioPII (Biology Parallel Integral Image) is a Python package for performing sliding window analysis (SWA) on biological images. This package makes use of the integral image technique to drastically speedup SWA, enabling SWA analysis of images that would have been too large for previous SWA implementations.
To use the package include the following statement at the top of your file: `from BioPII import PII`
To cite this package, cite our [IEEE CIBCB 2023 short paper](https://www.researchgate.net/publication/382174274_Accelerating_Biological_Spatial_Cluster_Analysis_with_the_Parallel_Integral_Image_Technique).
This code and package is under the MIT License - copyright (c) Seth Ockerman
The package name is prounounced bio-pie :)
## Performance Numbers
We tested our summing SWA to determine its performance relative to past methods. We created a C++ SWA (referred to as DP-Naive) script which used dynamic programming to reduce the number of additions needed to be performed. DP-Naive SWA was already 400x faster than a naive approach (a simple four for loop approach) on small images and is used as the baseline for comparison to our integral-image-based methods.
| | 30k by 30k | 30k by 30k Speedup | 40k by 50k | 40k by 50k Speedup | 60k by 60k | 60k by 60k Speedup |
|-------------------|------------|--------------------|------------|--------------------|------------|--------------------|
| **DP-Naive** | 211,381,433| N/A | 491,374,150| N/A | 943,858,845 | N/A |
| **Integral Image** | 56,693 | 3728x | 253,082 | 1942x | 319,666 | 2953x |
| **Parallel Integral Image** | 20,137 | 10,497x | 46,532 | 10,559x | 86,583 | 10,901x |
*Note: SWA runtime in milliseconds on different image sizes; speedups relative to DP-Naive Solution*
## Features
- Efficient computation for various biological image analysis tasks.
- Supports different types of SWA (Sliding Window Analysis) algorithms.
- Flexible window size selection for analyzing different cellular features.
- GPU acceleration option for faster computations.
- Works with numpy arrays for easy integration into existing workflows.
## Installation
You can install BioPII using pip:
``` pip3 install BioPII ```
## Documentation
Documentation can be found internally within our code and in the [documentation file](./documentation.md).
### Note
The average-SWA-algorithm and std-deviation-SWA algorithm have not been as tested as extensively as the sum-SWA-algorithm. If you discover a bug, please reach out to [sockerman@cs.wisc.edu](mailto:sockerman@cs.wisc.edu).
Raw data
{
"_id": null,
"home_page": "https://github.com/OckermanSethGVSU/BioPII",
"name": "BioPII",
"maintainer": null,
"docs_url": null,
"requires_python": null,
"maintainer_email": null,
"keywords": "Biology, Integral Image, Sliding Window, HPC",
"author": "Seth Ockerman",
"author_email": "ockermas@mail.gvsu.edu",
"download_url": "https://files.pythonhosted.org/packages/12/12/36c6b153e0b8535bbf84506d81e43c627072cad117a97e8990772455187a/biopii-0.2.4.tar.gz",
"platform": null,
"description": "# BioPII\n\nBioPII (Biology Parallel Integral Image) is a Python package for performing sliding window analysis (SWA) on biological images. This package makes use of the integral image technique to drastically speedup SWA, enabling SWA analysis of images that would have been too large for previous SWA implementations. \n\nTo use the package include the following statement at the top of your file: `from BioPII import PII`\n\nTo cite this package, cite our [IEEE CIBCB 2023 short paper](https://www.researchgate.net/publication/382174274_Accelerating_Biological_Spatial_Cluster_Analysis_with_the_Parallel_Integral_Image_Technique).\n\nThis code and package is under the MIT License - copyright (c) Seth Ockerman\n\nThe package name is prounounced bio-pie :)\n\n## Performance Numbers\nWe tested our summing SWA to determine its performance relative to past methods. We created a C++ SWA (referred to as DP-Naive) script which used dynamic programming to reduce the number of additions needed to be performed. DP-Naive SWA was already 400x faster than a naive approach (a simple four for loop approach) on small images and is used as the baseline for comparison to our integral-image-based methods. \n\n| | 30k by 30k | 30k by 30k Speedup | 40k by 50k | 40k by 50k Speedup | 60k by 60k | 60k by 60k Speedup |\n|-------------------|------------|--------------------|------------|--------------------|------------|--------------------|\n| **DP-Naive** | 211,381,433| N/A | 491,374,150| N/A | 943,858,845 | N/A |\n| **Integral Image** | 56,693 | 3728x | 253,082 | 1942x | 319,666 | 2953x |\n| **Parallel Integral Image** | 20,137 | 10,497x | 46,532 | 10,559x | 86,583 | 10,901x |\n\n*Note: SWA runtime in milliseconds on different image sizes; speedups relative to DP-Naive Solution*\n\n\n## Features\n\n- Efficient computation for various biological image analysis tasks.\n- Supports different types of SWA (Sliding Window Analysis) algorithms.\n- Flexible window size selection for analyzing different cellular features.\n- GPU acceleration option for faster computations.\n- Works with numpy arrays for easy integration into existing workflows.\n\n## Installation\n\nYou can install BioPII using pip:\n\n``` pip3 install BioPII ```\n\n## Documentation\nDocumentation can be found internally within our code and in the [documentation file](./documentation.md). \n\n\n### Note\nThe average-SWA-algorithm and std-deviation-SWA algorithm have not been as tested as extensively as the sum-SWA-algorithm. If you discover a bug, please reach out to [sockerman@cs.wisc.edu](mailto:sockerman@cs.wisc.edu).\n",
"bugtrack_url": null,
"license": null,
"summary": "BioPII (Biology Parallel Integral Image) is a Python package for performing sliding window analysis (SWA) on biological images.",
"version": "0.2.4",
"project_urls": {
"Homepage": "https://github.com/OckermanSethGVSU/BioPII"
},
"split_keywords": [
"biology",
" integral image",
" sliding window",
" hpc"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "a13e2f4df41730a1c0db32d912414128e151ea84df595d0d74ce63a620a9dbfe",
"md5": "36ff08200831844938f2d82317e438e5",
"sha256": "b881d537886023bc8592fccd7d201993a62dbfd137c36aa5e7062d47b575b29a"
},
"downloads": -1,
"filename": "BioPII-0.2.4-py3-none-any.whl",
"has_sig": false,
"md5_digest": "36ff08200831844938f2d82317e438e5",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": null,
"size": 6632,
"upload_time": "2024-07-11T18:22:31",
"upload_time_iso_8601": "2024-07-11T18:22:31.687895Z",
"url": "https://files.pythonhosted.org/packages/a1/3e/2f4df41730a1c0db32d912414128e151ea84df595d0d74ce63a620a9dbfe/BioPII-0.2.4-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "121236c6b153e0b8535bbf84506d81e43c627072cad117a97e8990772455187a",
"md5": "85749d21a86f56fa20a0f8d56cab2f80",
"sha256": "5ba04e724969dc90600e79ba6b61fdea630bbe6725f6f2b6681632ba1178cdfb"
},
"downloads": -1,
"filename": "biopii-0.2.4.tar.gz",
"has_sig": false,
"md5_digest": "85749d21a86f56fa20a0f8d56cab2f80",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 8358,
"upload_time": "2024-07-11T18:22:33",
"upload_time_iso_8601": "2024-07-11T18:22:33.220897Z",
"url": "https://files.pythonhosted.org/packages/12/12/36c6b153e0b8535bbf84506d81e43c627072cad117a97e8990772455187a/biopii-0.2.4.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-07-11 18:22:33",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "OckermanSethGVSU",
"github_project": "BioPII",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"lcname": "biopii"
}