An open source library for statistical plotting
Project description
Lets-Plot for Python
Latest Release | |
License | |
OS | Linux, MacOS |
Python versions | 3.7, 3.8 |
Implementation Overview
The Lets-Plot python extension includes native backend and a Python API, which was mostly based on the ggplot2
package well-known to data scientists who use R.
R ggplot2
has extensive documentation and a multitude of examples and therefore is an excellent resource for those who want to learn the grammar of graphics.
Note that the Python API being very similar yet is different in detail from R. Although we have not implemented the entire ggplot2 API in our Python package, we have added a few new features to our Python API.
You can try the Lets-Plot library in Datalore. Lets-Plot is available in Datalore out-of-the-box and is almost identical to the one we ship as PyPI package. This is because Lets-Plot is an offshoot of the Datalore project from which it was extracted to a separate plotting library.
One important difference is that the python package in Datalore is named datalore.plot and the package you install from PyPI has name lets_plot.
The advantage of Datalore as a learning tool in comparison to Jupyter is that it is equipped with very friendly Python editor which comes with auto-completion, intentions, and other useful coding assistance features.
Installation
To install the Lets-Plot library, run the following command:
pip install lets-plot
Quickstart in Jupyter
To evaluate the plotting capabilities of Lets-Plot, add the following code to a Jupyter notebook:
import numpy as np
from lets_plot import *
np.random.seed(12)
data = dict(
cond=np.repeat(['A','B'], 200),
rating=np.concatenate((np.random.normal(0, 1, 200), np.random.normal(1, 1.5, 200)))
)
ggplot(data, aes(x='rating', fill='cond')) + ggsize(500, 250) \
+ geom_density(color='dark_green', alpha=.7) + scale_fill_brewer(type='seq') \
+ theme(axis_line_y='blank')
Examples
Try the following examples to study more features of the Lets-Plot library.
Quickstart in Jupyter: quickstart.ipynb
Histogram, density plot, box plot and facets: distributions.ipynb
Error-bars, points, lines, bars, dodge position: error_bars.ipynb
Points, point shapes, linear regression, jitter position: scatter_plot.ipynb
Points, density2d, polygons, density2df: density_2d.ipynb
Tiles, contours, polygons, contourf: contours.ipynb
Various presentation options: legend_and_axis.ipynb
Other demos
A set of interesting notebooks with Lets-Plot
for visualization.
New to experienced users
The following features of Lets-Plot
are not present or have different implementation in other Grammar of Graphics
libraries.
Plotting functions
-
ggsize()
- sets the size of the plot. Used in many examples starting fromquickstart
. -
geom_density2df()
- fills space between equal density lines on a 2D density plot. Similar togeom_density2d
but supports thefill
aesthetic.Example: density_2d.ipynb
-
geom_contourf()
- fills space between the lines of equal level of the bivariate function. Similar togeom_contour
but supports thefill
aesthetic.Example: contours.ipynb
-
geom_image()
- displays an image specified by a ndarray with shape (n,m) or (n,m,3) or (n,m,4).Example: image_101.ipynb
Example: image_fisher_boat.ipynb
-
gg_image_matrix()
- a utility helping to combine several images into one graphical object.Example: image_matrix.ipynb
GGBanch
GGBunch allows to show a collection of plots on one figure. Each plot in the collection can have arbitrary location and size. There is no automatic layout inside the bunch.
Examples:
Data sampling
Sampling is a special technique of data transformation, which helps dealing with large datasets and overplotting.
Learn more about sampling in Lets-Plot.
Change Log
See Lets-Plot at Github.
License
Code and documentation released under the MIT license. Copyright 2019, JetBrains s.r.o.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distributions
File details
Details for the file lets_plot-1.2.0rc2-cp38-cp38-manylinux1_x86_64.whl
.
File metadata
- Download URL: lets_plot-1.2.0rc2-cp38-cp38-manylinux1_x86_64.whl
- Upload date:
- Size: 3.3 MB
- Tags: CPython 3.8
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.6.0.post20191030 requests-toolbelt/0.9.1 tqdm/4.37.0 CPython/3.8.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3344a4521a226bb454bd1524f2ab0fe6a01eff99ae101429bb9abd18d8d1e074 |
|
MD5 | 426778f191d2fc22e049af7b3efa1d4d |
|
BLAKE2b-256 | 2b631b934c3867952a390c4c4a460bf45888a48187b5a8554bff60255c06b307 |
File details
Details for the file lets_plot-1.2.0rc2-cp38-cp38-macosx_10_9_x86_64.whl
.
File metadata
- Download URL: lets_plot-1.2.0rc2-cp38-cp38-macosx_10_9_x86_64.whl
- Upload date:
- Size: 2.8 MB
- Tags: CPython 3.8, macOS 10.9+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/42.0.2.post20191201 requests-toolbelt/0.9.1 tqdm/4.40.2 CPython/3.8.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | af22025b1fabfb0864f20882396b65aec2a6bde89c9fb36f764f75d5040e2c89 |
|
MD5 | 97a8e7d7aa59b1d29063c53d8bc9baa9 |
|
BLAKE2b-256 | c789b458bb4ba3217c4549a314cccbf6287bcca5f2672a11c87814963cae198c |
File details
Details for the file lets_plot-1.2.0rc2-cp37-cp37m-manylinux1_x86_64.whl
.
File metadata
- Download URL: lets_plot-1.2.0rc2-cp37-cp37m-manylinux1_x86_64.whl
- Upload date:
- Size: 3.3 MB
- Tags: CPython 3.7m
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.6.0.post20191030 requests-toolbelt/0.9.1 tqdm/4.37.0 CPython/3.8.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e16b5300a79ab23a7aecfa7d35fd8090fcb00d499f0c0f8bab7a465c7ada9541 |
|
MD5 | e83a99436ec8319022f49145be72da69 |
|
BLAKE2b-256 | 9c153dced1a7827f3128697898224b259ad6e543701f079c901a63ba090cd0c8 |
File details
Details for the file lets_plot-1.2.0rc2-cp37-cp37m-macosx_10_9_x86_64.whl
.
File metadata
- Download URL: lets_plot-1.2.0rc2-cp37-cp37m-macosx_10_9_x86_64.whl
- Upload date:
- Size: 2.8 MB
- Tags: CPython 3.7m, macOS 10.9+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/42.0.2.post20191201 requests-toolbelt/0.9.1 tqdm/4.40.2 CPython/3.8.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 319cf1c5130f8dd1637766543e11947b4486ee57d1837f4729738b4030cf2d14 |
|
MD5 | c5669f9c944fe3d48dcb1851500dc764 |
|
BLAKE2b-256 | 255a83d32baedaa40f71c0c54eb9708b9c0d895d4a7aea015d7ef43ff2efd3c6 |