Skip to main content

a simple tool to compute arbitrary generator in a background thread

Project description

Based on http://stackoverflow.com/questions/7323664/python-generator-pre-fetch

This is a single-function package that makes it possible to transform any generator into a BackgroundGenerator which computes any number of elements from the generator ahead, in a background thread.

It is quite lightweight, but not entirely weightless.

The BackgroundGenerator is most useful when you have a GIL releasing task which might take a long time to complete (e.g. Disk I/O, Web Requests, pure C functions, GPU processing, …), and another task which takes a similar amount of time, but is dependent on the results of the first task (e.g. Computationally intensive processing of data loaded from disk).

Normally these two tasks will constantly wait for one another to finish. If you make one of these tasks a BackgroundGenerator (see examples below), they will work in parallel, potentially saving up to 50% of execution time (definitely less in practice).

We personally use the BackgroundGenerator when iterating over minibatches of data for deep learning with tensorflow and theano ( lasagne, blocks, raw, etc.).

Quick usage example (ipython notebook) - https://github.com/justheuristic/prefetch_generator/blob/master/example.ipynb

This package contains two objects:
  • The Class BackgroundGenerator(generator [,max_prefetch=1])

  • The decorator @prefetch([max_prefetch=1])

the usage is either

#for item in BackgroundGenerator(my_generator): # do_stuff(item)

or

#@prefetch() #def my_generator(some_param): # while True: # X = read_heavy_file() # y = wget_from_cornhub() # do_pretty_much_anything(some_param) # yield X, y

More details are written in the BackgroundGenerator doc: See help(BackgroundGenerator)

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

prefetch_generator-1.0.3.tar.gz (4.6 kB view details)

Uploaded Source

File details

Details for the file prefetch_generator-1.0.3.tar.gz.

File metadata

  • Download URL: prefetch_generator-1.0.3.tar.gz
  • Upload date:
  • Size: 4.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.25.1 requests-toolbelt/0.9.1 urllib3/1.26.12 tqdm/4.64.0 importlib-metadata/4.11.4 keyring/22.3.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.8.8

File hashes

Hashes for prefetch_generator-1.0.3.tar.gz
Algorithm Hash digest
SHA256 cefabd51c7ff3cdc1c885e22d287592219fe1ca25623322806370a0ce9acd32b
MD5 9a9956a6ced74f63cd7c55db4038d32d
BLAKE2b-256 28cff6c148289fd87832e9f20428b7e842921efac5313cb3ac5920a424543760

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