barplot¶
This section describes various options available for bar charts in fivecentplots
Setup¶
Import packages:
import fivecentplots as fcp
import pandas as pd
from pathlib import Path
Read some fake bar chart data with 3 replicates of pH data for various liquids measured at multiple temperatures:
df = pd.read_csv(Path(fcp.__file__).parent / 'test_data/fake_data_bar.csv')
df.groupby(['Liquid', 'Measurement', 'T [C]']).count()
pH | |||
---|---|---|---|
Liquid | Measurement | T [C] | |
Battery acid | A | 25 | 1 |
100 | 1 | ||
B | 25 | 1 | |
100 | 1 | ||
C | 25 | 1 | |
100 | 1 | ||
Bottled water | A | 25 | 1 |
100 | 1 | ||
B | 25 | 1 | |
100 | 1 | ||
C | 25 | 1 | |
100 | 1 | ||
Coke | A | 25 | 1 |
100 | 1 | ||
B | 25 | 1 | |
100 | 1 | ||
C | 25 | 1 | |
100 | 1 | ||
Lemon juice | A | 25 | 1 |
100 | 1 | ||
B | 25 | 1 | |
100 | 1 | ||
C | 25 | 1 | |
100 | 1 | ||
Orange juice | A | 25 | 1 |
100 | 1 | ||
B | 25 | 1 | |
100 | 1 | ||
C | 25 | 1 | |
100 | 1 |
Optionally set the design theme (skipping here and using default):
#fcp.set_theme('gray')
#fcp.set_theme('white')
Bar plot types¶
Vertical bars¶
We can plot a basic vertical bar chart as follows. Note: * filter
is applied to show only measurement “A” at 25C * tick labels are rotated 90° for readability (fcp.bar
does not currently have auto-rotation for long tick labels)
fcp.bar(df, x='Liquid', y='pH', filter='Measurement=="A" & T [C]==25', tick_labels_major_x_rotation=90)
data:image/s3,"s3://crabby-images/72182/72182f671a649002e5596d1d4c48e1d0f4fd3eee" alt="_images/barplot_13_0.png"
Horizontal bars¶
We can plot the same data with horizontal bars by adding the keyword horizontal=True
.
For convenience, fivecentplots often supports two versions of plot-specific keywords (in this case, horizontal or bar_horizontal). For inline plotting the shorter version may be preferred but for cases where kwargs are pulled from theme files or when precision is required to avoid applying a particular kwarg to other Elements
in the plot, the long version is recommended.
fcp.bar(df, x='Liquid', y='pH', filter='Measurement=="A" & T [C]==25', horizontal=True)
data:image/s3,"s3://crabby-images/1e8c2/1e8c2442857fa03df71e1ba75e469ef35f62a96a" alt="_images/barplot_16_0.png"
Error bars¶
Next we group all measured data by liquid, regardless of replicate or temperature, into a single bars (this means each bar represents the mean value of a given liquid across all data sets). We add error bars to indicate the standard deviation across measurements with the error_bars
keyword:
fcp.bar(df, x='Liquid', y='pH', tick_labels_major_x_rotation=90, error_bars=True)
data:image/s3,"s3://crabby-images/ff0d7/ff0d7914c1a5570150cd6f9ffea6552b8f8c577a" alt="_images/barplot_19_0.png"
Grouping¶
Like all other plots in fivecentplots, bar plots can grouped in various ways to provide further insight into the data set. This includes:
legend
stacking
row
col
wrap
keyword options.
Legend¶
When a legend is applied, each measurement set is displayed in its own bar:
fcp.bar(df, x='Liquid', y='pH', tick_labels_major_x_rotation=90, legend='Measurement')
data:image/s3,"s3://crabby-images/6b396/6b39621ab336b76851a4e1288c3683cd940f83b8" alt="_images/barplot_24_0.png"
Stacked¶
Alternatively, we can stack the measurements to give a cumulative bar using stacked=True
(which makes absolutely no sense for this example but whatever):
fcp.bar(df, x='Liquid', y='pH', tick_labels_major_x_rotation=90, stacked=True, legend='Measurement')
[ 0.5 10. 4.5 1.2 5.2]
[ 0.85 20.5 8.25 2.2 11.2 ]
data:image/s3,"s3://crabby-images/da084/da08460e78deda32d6594b75e7da310e40cf4623" alt="_images/barplot_27_1.png"
Row/column plot¶
We can separate different conditions using row/col plots as shown below. (Negative pH values?? These data are truly fake!)
fcp.bar(df, x='Liquid', y='pH', tick_labels_major_x_rotation=90, col='Measurement', row='T [C]', ax_hlines=0, ax_size=[300, 300])
data:image/s3,"s3://crabby-images/86b45/86b457e3e5b8f077ce101df5f12fcb5a51117247" alt="_images/barplot_30_0.png"
Wrap plot¶
We can use a wrap
plot to visualize:
fcp.bar(df, x='Liquid', y='pH', tick_labels_major_x_rotation=90, wrap='Measurement', ax_size=[300, 300])
data:image/s3,"s3://crabby-images/bd089/bd089b63237a74622b7c314c9f6e4df7ec928194" alt="_images/barplot_33_0.png"
Rolling mean¶
fivecentplots can automatically apply a rolling mean to bar chart data using rolling_mean
, to which we pass a positive integer for the window size of the mean calculation. For this example, we read in some different data.
df2 = pd.read_csv(Path(fcp.__file__).parent / 'test_data/real_data_bar.csv')
Default line styling¶
By default, the rolling mean curve will have markers disabled and will use the second color in the default color list (red) and a line width of 2:
fcp.bar(df2, x='date', y='cases', ax_size=[800, 500], tick_labels_major_x_rotation=90, rolling_mean=14)
data:image/s3,"s3://crabby-images/84614/846146228d43b8e5dc6e873418d9410813c8ed9b" alt="_images/barplot_39_0.png"
Custom line style¶
The rolling mean curve style can be easily modified using standard kwargs for line plots with a rolling_mean_
prefix. Markers can also be enabled using the markers
element object:
fcp.bar(df2, x='date', y='cases', ax_size=[800, 500], tick_labels_major_x_rotation=90, rolling_mean=14,
bar_fill_color='#aaaaaa', rolling_mean_line_color='#000000', rolling_mean_line_width = 1, markers=True, marker_size=4)
data:image/s3,"s3://crabby-images/b790f/b790f9b9d02d53c204fc74e9606c21052801f210" alt="_images/barplot_42_0.png"
Styles¶
Bar plots have many style options. A few are demonstrated below.
Color by bar¶
color_by_bar
gives each bar in the chart a different color. These colors can be set manually or the fcp.DEFAULT_COLORS
scheme is used by default.
fcp.bar(df, x='Liquid', y='pH', filter='Measurement=="A" & T [C]==25', tick_labels_major_x_rotation=90, color_by_bar=True)
data:image/s3,"s3://crabby-images/09768/09768cd51dab94f232d3b232b580fb19ca04e8f2" alt="_images/barplot_47_0.png"
fcp.bar(df, x='Liquid', y='pH', filter='Measurement=="A" & T [C]==25', tick_labels_major_x_rotation=90,
color_by_bar=True, colors=['#FF0000', '#FF00FF', '#FFFF00', '#00FF00', '#0000FF'])
data:image/s3,"s3://crabby-images/268f7/268f7c81b00213acc3a6d50ab481381731eb849f" alt="_images/barplot_48_0.png"
Other color kwargs¶
fcp.bar(df, x='Liquid', y='pH', tick_labels_major_x_rotation=90, error_bars=True,
bar_error_color='#FF0000', bar_fill_alpha=1, bar_edge_color='#000000', bar_edge_width=3)
data:image/s3,"s3://crabby-images/c1b18/c1b18db68fa5771be81cb6c3d48d7fc5bebf974a" alt="_images/barplot_50_0.png"