Skip to main content

Parallel multiradial LBP features

Project description

fastLBP

Highly parallel LBP implementation

Installation

Note: it is not recommended to proceed on a head node; consider starting an ijob or a jupyter instance.

  • Activate a Python 3.11 environment (e.g. using conda create -y -n p11 python=3.11 && conda activate p11)
  • Verify you are using the right env
    • python --version та pip --version
  • Install a stable version from PyPI
    • pip install fastlbp-imbg
  • Or build the latest version from sources
git clone git@github.com:imbg-ua/fastLBP.git
cd fastLBP
# git checkout <branchname> # if you need a specific branch
pip install . # this will install the fastlbp_imbg package in the current env
  • You can use import fastlbp_imbg now

Testing

# in repo root
conda activate fastlbp
pip install -e .
python -m unittest

Implemented modules

run_skimage

Computes multiradial LBP of a single multichannel image in a parallel fashion.
This is a quick sample implementation that could be a baseline for further benchmarking.

Features:

  • Powered by skimage.feature.local_binary_pattern
  • Concurrency is managed by Python's multiprocessing module
  • Parallel computation via multiprocessing.Pool of size ncpus
  • Efficient memory usage via multiprocessing.shared_memory to make sure processes do not create redundant copies of data
  • It computes everything in RAM, no filesystem usage

TODO:

  • Use max_ram parameter to estimate optimal number of sub-processes and collect memory stats. Now max_ram is ignored.

Planned modules

run_chunked_skimage

Similar to 1. run_skimage, but each subprocess should compute LBP for its image chunk, not the whole image.

run_dask and run_chunked_dask

Similar to 1. run_skimage, but use Dask and dask.array.map_overlap for parallelisation instead of multiprocessing and manual data wrangling

Other notable things to try

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fastlbp_imbg-0.1.4.tar.gz (210.0 kB view details)

Uploaded Source

Built Distribution

fastlbp_imbg-0.1.4-cp311-cp311-win_amd64.whl (123.0 kB view details)

Uploaded CPython 3.11 Windows x86-64

File details

Details for the file fastlbp_imbg-0.1.4.tar.gz.

File metadata

  • Download URL: fastlbp_imbg-0.1.4.tar.gz
  • Upload date:
  • Size: 210.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.11.5

File hashes

Hashes for fastlbp_imbg-0.1.4.tar.gz
Algorithm Hash digest
SHA256 a7a2aaaa3119391de893f7c9d3512346eee36c512a40057a7dd74932ec5d20ad
MD5 2fc64e182c945b3bdb6d3e6696156fb4
BLAKE2b-256 649a8ee6d042ef169cd8bfefa6ca922a49353733016b05439338b6e5a6fdad22

See more details on using hashes here.

File details

Details for the file fastlbp_imbg-0.1.4-cp311-cp311-win_amd64.whl.

File metadata

File hashes

Hashes for fastlbp_imbg-0.1.4-cp311-cp311-win_amd64.whl
Algorithm Hash digest
SHA256 9a97553f497a0e0d1e9300f9142a801c6713295b53a94505076f449857670f26
MD5 6b088d16aa1ce83046938562f63ef8d6
BLAKE2b-256 d449a19d8c819b7089609599dc73230c45b9d140041c4bce6335cea6a916d070

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page