Skip to main content

Turn a function into an interactive plot with a single line of code

Project description

sliderplot

PyPI - Downloads

Turn a function into an interactive plot with a single line of code.

It is very similar to Holoviews DynamicMap but with multiple lines and plots capabilities, and with only sliders as interactive elements.

Demo

demo

from sliderplot import sliderplot
import numpy as np


def f(amplitude=1, frequency=np.pi, phase=np.pi / 2):
    x = np.linspace(0, 10, 1000)
    y = amplitude * np.sin(frequency * x + phase)
    return x, y, "Hey"


sliderplot(
    f,
    params_bounds=((0, 1),),
    titles=("Minimal example",),
    page_title="Minimal example",
)

Features

Single line

To create a sliderplot with a single line, pass into sliderplot() a function that returns same-length x and y vectors.

Example

def f(amplitude, frequency, phase):
    x = np.linspace(0, 10, 1000)
    y = amplitude * np.sin(frequency * x + phase)
    return x, y


sliderplot(f)

Multiple lines

To create a sliderplot with multiple lines, pass into sliderplot() a function that returns multiple pairs of same-length x and y vectors.

Example

def f(amplitude, frequency, phase):
    x = np.linspace(0, 10, 1000)
    y = amplitude * np.sin(frequency * x + phase)
    return (x, y), (x, 2 * y), (x, 3 * y)


sliderplot(f)

Multiple subplots

To create a sliderplot with multiple subplots, pass into sliderplot() a function that returns a list with the following levels, top to bottom:

  1. List of subplots.
  2. List of lines.
  3. Line: (x, y) pair of same-length vectors, or (x, y, label: str) to add a line label.

Example

def f(amplitude, frequency, phase):
    x = np.linspace(0, 10, 1000)
    y = amplitude * np.sin(frequency * x + phase)
    return ((x, y), (x, 2 * y)), ((x, 3 * y),)


sliderplot(f)

Line labels

To add a label to a line that will be displayed in the plot legend, return the line data with the following format:

(x, y, label: str)

Example

def f(amplitude, frequency, phase):
    x = np.linspace(0, 10, 1000)
    y = amplitude * np.sin(frequency * x + phase)
    return (x, y, "First"), (x, 2 * y), (x, 3 * y, "Third")


sliderplot(f)

Initial slider position

To set the slider initial value for a parameter, simply add a default argument to the function.

Example

In the following example, the initial slider values are:

  • amplitude = 1
  • frequency = np.pi
  • phase = np.pi / 2
def f(amplitude=1, frequency=np.pi, phase=np.pi / 2):
    x = np.linspace(0, 10, 1000)
    y = amplitude * np.sin(frequency * x + phase)
    return x, y


sliderplot(f)

Slider bounds settings

Use the param_bounds argument of the sliderplot() function to specify the slider bounds of each parameter. It takes a list of pairs of (min_value, max_value).

The first pair contains the bounds of the first argument, the second pair contains the bounds of the second argument, etc...

Example

In the following example, the slider bounds are:

  • amplitude = (0, 1)
  • frequency = (1, 1000)
  • phase = (0, np.pi)
def f(amplitude, frequency, phase):
    x = np.linspace(0, 10, 1000)
    y = amplitude * np.sin(frequency * x + phase)
    return x, y


sliderplot(f, params_bounds=((0, 1), (1, 1000), (0, np.pi)))

Axes labels

To add axes labels to the subplots, set the axes_labels argument with a sequence of (x_label, y_label) pair of strings. The first pair will set the axis labels of the first subplot, the second pair the axis labels of the second subplot, etc...

Example

def f(amplitude, frequency, phase):
    x = np.linspace(0, 10, 1000)
    y = amplitude * np.sin(frequency * x + phase)
    return ((x, y), (x, 2 * y)), ((x, 3 * y),)


sliderplot(f, axes_labels=(("x1", "y1"), ("x2", "y2")))

Plot title

To add plot titles to subplots, set the titles argument with a sequence of strings. The first string will be the title of the first subplot, the second string the title of the second subplot, etc...

Example

def f(amplitude, frequency, phase):
    x = np.linspace(0, 10, 1000)
    y = amplitude * np.sin(frequency * x + phase)
    return ((x, y), (x, 2 * y)), ((x, 3 * y),)


sliderplot(f, titles=("Subplot 1", "Subplot2"))

Web page title

To set the title of the web page that show the sliderplot, use the page_title argument.

def f(amplitude=1, frequency=np.pi, phase=np.pi / 2):
    x = np.linspace(0, 10, 1000)
    y = amplitude * np.sin(frequency * x + phase)
    return x, y


sliderplot(f, page_title="Page title")

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

sliderplot-0.0.5.tar.gz (7.2 kB view details)

Uploaded Source

Built Distribution

sliderplot-0.0.5-py3-none-any.whl (6.8 kB view details)

Uploaded Python 3

File details

Details for the file sliderplot-0.0.5.tar.gz.

File metadata

  • Download URL: sliderplot-0.0.5.tar.gz
  • Upload date:
  • Size: 7.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for sliderplot-0.0.5.tar.gz
Algorithm Hash digest
SHA256 65fd700751014f235ac7b4b9a2562ad394dcb6cd8288f9b18b1135202a1a9f67
MD5 944e7d1b165c4b2a4c1f0ca191b04cef
BLAKE2b-256 92ae1e35b62fb4107bee71848028243a94c56b3e2e389ac1bcd95df0f50e140a

See more details on using hashes here.

Provenance

The following attestation bundles were made for sliderplot-0.0.5.tar.gz:

Publisher: publish-to-pypi.yml on ngripon/sliderplot

Attestations:

File details

Details for the file sliderplot-0.0.5-py3-none-any.whl.

File metadata

  • Download URL: sliderplot-0.0.5-py3-none-any.whl
  • Upload date:
  • Size: 6.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for sliderplot-0.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 463c23fa23b33e5644e427cab4046e69e008b890d36e9899a5ce86e7b1de5a5c
MD5 137f64adb7039e1ab17d335121f96122
BLAKE2b-256 831256486aae4c71c74e7b4445d0cbb0592c159d6eba5279d7ab9518cfb3483e

See more details on using hashes here.

Provenance

The following attestation bundles were made for sliderplot-0.0.5-py3-none-any.whl:

Publisher: publish-to-pypi.yml on ngripon/sliderplot

Attestations:

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