Python package for plotting alluvial diagrams with an arbitrary number of layers
Project description
pylluvial
A python library for creating alluvial diagrams with an arbitrary number of layers
Installation
Simply run the following
pip install pylluvial
or clone the repository
git clone git@github.com:dmalzl/pylluvial.git
and run
cd pyluvial
pip install .
you should then be able to import the package as usual
Usage
A minimal usage example would be as follows
import pylluvial as pa
data = pa.generate_test_data(
[3, 4, 3, 2]
)
# by default labels are not shown
fig, ax = pa.alluvial(
x='timepoint',
stratum='module',
alluvium='nodename',
data=data,
palette='husl',
stratum_gap=2,
stratum_width=2
)
fig.set_figwidth(10)
fig.set_figheight(5)
fig.tight_layout()
# pass show_labels = True to get labelled plots
fig, ax = pa.alluvial(
x = 'timepoint',
stratum = 'module',
alluvium = 'nodename',
palette = 'husl',
data = data,
stratum_gap = 2,
stratum_width = 2,
show_labels = True
)
fig.set_figwidth(10)
fig.set_figheight(5)
fig.tight_layout()
# use hue to split strata by a given grouping variable
fig, ax = pa.alluvial(
x = 'timepoint',
stratum = 'module',
alluvium = 'nodename',
hue = 'signif',
palette = 'tab20',
data = data,
stratum_gap = 2,
stratum_width = 2,
show_labels = True
)
fig.set_figwidth(10)
fig.set_figheight(5)
fig.tight_layout()
The color assignment for hue elements using string arguments for palette can be quite cumbersome. However, you can always pass a dictionary with the colors you want to use to palette instead of a string
tab20_colors = {
'1_s': '#1F77B5',
'1_ns': '#B0C6E8',
'2_s': '#F07E21',
'2_ns': '#F9BA79',
'3_s': '#2AA137',
'3_ns': '#9DCB88',
'4_s': '#D62828',
'4_ns': '#F29697'
}
colors = {
f't{i}': tab20_colors for i in range(4)
}
fig, ax = pa.alluvial(
x = 'timepoint',
stratum = 'module',
alluvium = 'nodename',
hue = 'signif',
palette = colors,
data = data,
stratum_gap = 2,
stratum_width = 2,
show_labels = True
)
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 Distribution
pylluvial-1.1.1.tar.gz
(11.2 kB
view hashes)
Built Distribution
pylluvial-1.1.1-py3-none-any.whl
(11.9 kB
view hashes)
Close
Hashes for pylluvial-1.1.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 82b8b25e311da1cb12843ce52f7225d2ca470e13c6e8ef24432b3e1921928471 |
|
MD5 | ec6a2c3c30f8658664a3acba6d3dd9a8 |
|
BLAKE2b-256 | 0e675107bd736712be97afd24c0c2d03c1c840cf2048355588b05b1786186879 |