Histogram2D Artist#
In this example notebook, we show how to create a histogram 2D plot using the Histogram2D
class. The Histogram2D
class is a subclass of the Artist
class.
It has a simplified interface for creating histogram 2D plots and updating some of its properties, like assigning different classes to underlying points and displaying bins/patches with different colors based on a categorical colormap.
It can be imported like shown below:
import numpy as np
import matplotlib.pyplot as plt
from biaplotter.artists import Histogram2D
np.random.seed(2)
Creating a Histogram 2D Plot#
To create an empty histogram 2D plot, just instanciate the Histogram2D
class and provide an axes object as an argument.
fig, ax = plt.subplots()
histogram = Histogram2D(ax)
data:image/s3,"s3://crabby-images/d2901/d290132339052880676efc003b75d46d9d87ed28" alt="../_images/ed677fe7b0f5f38d48caa0ab8c4daf4732bb40f161b78a8109858b641c89bf0d.png"
Adding Data to the Histogram 2D Artist#
To add data to the histogram 2D plot, just feed the property data
with a (N, 2) shaped numpy array. The plot gets updated automatically every time one of its properties is changed.
Below, we have a small function to generate 2 gaussian distributions with different means and standard deviations.
n_samples = 100
def generate_gaussian_data(n_samples):
"""Generate a 2D dataset with two Gaussian clusters."""
# Gaussian 1
x1 = np.random.normal(loc=2, scale=1, size=n_samples//2)
y1 = np.random.normal(loc=2, scale=1, size=n_samples//2)
# Gaussian 2
x2 = np.random.normal(loc=-2, scale=0.5, size=n_samples//2)
y2 = np.random.normal(loc=-2, scale=0.5, size=n_samples//2)
x_data = np.concatenate([x1, x2])
y_data = np.concatenate([y1, y2])
return np.vstack([x_data, y_data]).T
data = generate_gaussian_data(n_samples)
histogram.data = data
fig # show the updated figure
data:image/s3,"s3://crabby-images/66bac/66bac91d1c2258f29632af501b523ed8cabc4125" alt="../_images/f5839e781f537f8c0d0d062eae9ba7679663f51668a3839db350077607c03f8c.png"
Assigning Classes to Data Points#
The Histogram2D
artist comes with a custom categorical colormap, which can be used to assign different classes to underlying points and display the bins/patches with the corresponding class color as an overlay.
You can access the histogram current categorical colormap via its private _colormap
attribute.
histogram.categorical_colormap
To assign classes to underlying points, just feed the property color_indices
with a (N,) shaped numpy array containing integers. These integers will be used as indices to the colormap.
Histogram2D
has a convenience method called indices_in_above_threshold_patches
, which returns an array with the indices of the points that are inside the patches that are above a certain threshold.
Below, we get the indices of points that fall in patches that are above two thresholds and we color them with the first 2 non-transparent colors (color_indices
1
and 2
) of the histogram categorical colormap (color index 0
is transparent for the histogram).
threshold_1 = 2
threshold_2 = 4
indices_in_patches_above_threshold_1 = histogram.indices_in_above_threshold_patches(threshold_1)
indices_in_patches_above_threshold_2 = histogram.indices_in_above_threshold_patches(threshold_2)
color_indices = np.zeros(n_samples, dtype=int)
color_indices[indices_in_patches_above_threshold_1] = 1
color_indices[indices_in_patches_above_threshold_2] = 2
histogram.color_indices = color_indices
fig
data:image/s3,"s3://crabby-images/5d986/5d986f4c00fffff7e954d907254ccd14ddb9cca5" alt="../_images/98cd5ad8c79f2b1d7263127c9ab6c93f05bcd753677649cf619447da4dea4dc5.png"
print("Histogram color_indices:\n", histogram.color_indices)
Histogram color_indices:
[0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0
0 0 1 0 1 0 0 0 0 1 1 0 0 0 1 1 0 2 0 0 1 0 0 0 2 1 0 1 2 0 0 0 1 0 0 1 1
1 0 1 1 0 1 0 1 1 1 2 0 0 1 1 1 1 2 0 0 0 0 0 1 1 1]
Colors are kept if new data is added, but they may not make sense anymore.
For example, below, patches where data was previously colored received more data (with ‘unlabelled’ colors (color index 0)), thus many patches are transparent again (dominant color index is 0).
# Adding 400 more samples
n_samples = 400
data = np.concatenate([data, generate_gaussian_data(n_samples)])
histogram.data = data
fig
data:image/s3,"s3://crabby-images/328db/328dbf9dfb1c9ca68016c95c8791e1b4326adc87" alt="../_images/c15ffb2392c975e10beb52ea8245252659ff4d6ebf4c40045de576517908a9f2.png"
print("Histogram color_indices (up to 100th index):\n", histogram.color_indices[:100])
Histogram color_indices (up to 100th index):
[0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0
0 0 1 0 1 0 0 0 0 1 1 0 0 0 1 1 0 2 0 0 1 0 0 0 2 1 0 1 2 0 0 0 1 0 0 1 1
1 0 1 1 0 1 0 1 1 1 2 0 0 1 1 1 1 2 0 0 0 0 0 1 1 1]
Set color_indices
to 0
to reset the colors.
histogram.color_indices = 0
fig
data:image/s3,"s3://crabby-images/3e9cc/3e9cc9d60bab367e2f593eb0c034da1c5d4a3cd3" alt="../_images/50a5cc5d39cd964d68627238e759e30a3ae616b78fac693cbe7e8bc67b847695.png"
Changing Histogram Colormap#
You can change the histogram colormap by setting the histogram_colormap
attribute. Below, we show the default histogram colormap, which is magma
.
histogram.histogram_colormap
Here we display another colormap from matplotlib (viridis
) and assign it to the histogram.
plt.cm.viridis
histogram.histogram_colormap = plt.cm.viridis
fig
data:image/s3,"s3://crabby-images/531a6/531a6f1c209f442ab732f1e46f8f4d4f786225bd" alt="../_images/c78002a526e5c05467ea0a9dfc4190dac2fe87d7156ff564ad0b309f565c95ac.png"
Changing Histogram Bins#
You can set the number of bins in the histogram by setting the bins
attribute. The default number of bins is 20.
histogram.bins = 50
fig
data:image/s3,"s3://crabby-images/f044e/f044ea9b494d62919884bbfa698c1acd4c4df724" alt="../_images/f85840ab5c2bed8dbc481859b5d8fa64d364724933f3e880112affa5c752270b.png"
Histogram Visibility#
Optionally, hide/show the artist by setting the visible
attribute.
histogram.visible = False
fig
data:image/s3,"s3://crabby-images/19195/191951a745907e960a1d44b053a35c156201dbbf" alt="../_images/0d7e3f1d86b8feaa05130db0aedb5ade3303d2aae57219443f391c1f657ba056.png"
histogram.visible = True
fig
data:image/s3,"s3://crabby-images/f044e/f044ea9b494d62919884bbfa698c1acd4c4df724" alt="../_images/f85840ab5c2bed8dbc481859b5d8fa64d364724933f3e880112affa5c752270b.png"