Skip to main content

Interactive, reproducible and efficient data analytics

Project description

Quibbler

Interactive, reproducible and efficient data analytics

GitHub GitHub release (latest by date)

https://user-images.githubusercontent.com/62783755/209929327-67766771-f271-40f0-8f3a-76deb88310b7.mp4

What is it?

Quibbler is a toolset for building highly interactive, yet reproducible, transparent and efficient data analysis pipelines. Quibbler allows using standard Python syntax to process data through any series of analysis steps, while automatically maintaining connectivity between downstream results and upstream raw data sources. Quibbler facilitates and embraces human interventions as an inherent part of the analysis pipeline: input parameters, as well as exceptions and overrides, can be specified and adjusted either programmatically, or by interacting with "live" graphics, and all such interventions are automatically recorded in well-documented human-machine readable files. Changes to such parameters propagate downstream, pinpointing which specific data items, or even specific elements thereof, are affected, thereby vastly saving unnecessary recalculations. Quibbler, therefore, facilitates hands-on interactions with data in ways that are not only flexible, fun and interactive, but also traceable, reproducible, and computationally efficient.

Check out our "Best Quibble" competition!

We just launched Quibbler in PyData Tel-Aviv. We are seeking engagement from users and developers and are also eager to learn of the range of applications for Quibbler. To get it fun and going, we are announcing a competition for the best "Quibble" - a short elegant quib-based code that demonstrates fun interactive graphics and/or hints to ideas of applications.

The competition is open to everyone. For details (and prizes!) see: Best Quibble Award

Main Features

  • Interactivity

    • Creating interactive graphics is as simple as calling standard Matplotlib graphics functions with arguments that represent your parameter values.

    • Any data presented graphically is automatically live and interactive (no need for the tedious programming of callback functions).

  • Traceability and Reproducibility

  • Computational efficiency

    • Upon parameter changes, Quibbler pinpoints and only recalculates the specifically affected array elements of downstream analysis steps (here).
  • Very little to learn: your standard-syntax code automatically comes to life.

    • To get started with Quibbler, you do not need to learn any new syntax or new functions. Just encapsulate your input parameters with iquib and your analysis and graphics automatically become live and interactive.
    • Quibbler supports standard coding syntax with all Python operators, slicing, getitem, Numpy functions, Matplotlib graphics functions, Matplotlib widgets, and ipywidgets. It further provides an easy way to incorporate any user functions or functions from any other non-graphics packages (here). Support for other graphics packages, besides Matplotlib, will be offered in future releases.

Minimal app

from pyquibbler import initialize_quibbler, iquib
initialize_quibbler()
import matplotlib.pyplot as plt

x = iquib(0.5)
y = 1 - x
plt.plot([0, 1], [1, 0], '-')
plt.plot([0, x, x], [y, y, 0], '--', marker='D')
plt.title(x, fontsize=20)

Documentation and Examples

For complete documentation and a getting-started tour, see readthedocs.

For simple demos and small apps, see our Examples.

Installation

We recommend installing Quibbler in a new virtual environment (see creating a new environment).

To install run:

pip install pyquibbler

If you are using Quibbler within Jupyter lab, you can also add the pyquibbler Jupyter Lab extension:

pip install pyquibbler_labextension

Development

To install for developers, see our guide here.

Credit

Quibbler was created by Roy Kishony, initially implemented as a Matlab toolbox.

The first release of Quibbler for Python, pyquibbler, was developed at the Kishony lab, Technion - Israel Institute of Technology, by Maor Kern, Maor Kleinberger and Roy Kishony.

We very much welcome any thoughts, suggestions and ideas and of course welcome PR contributions (for some proposed directions, see our pending issues).

Related packages

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

pyquibbler-0.2.7-py3-none-any.whl (268.7 kB view details)

Uploaded Python 3

File details

Details for the file pyquibbler-0.2.7-py3-none-any.whl.

File metadata

  • Download URL: pyquibbler-0.2.7-py3-none-any.whl
  • Upload date:
  • Size: 268.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.16

File hashes

Hashes for pyquibbler-0.2.7-py3-none-any.whl
Algorithm Hash digest
SHA256 d37996f1e8d684ef1980e51688ac9e65860fd689c8cc26a2601f3a42290e8287
MD5 774e7a450efc7d22295c781123c272ae
BLAKE2b-256 e5795920972f5c6fe599a9db9921107dd96d19316bf2d4bf095c88adf97e0db5

See more details on using hashes here.

Supported by

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