Comment dessiner deux histogrammes empilés côte à côte avec Matplotlib/Seaborn
Je dessine quelques histogrammes empilés en utilisant le code ci-dessous. J'utilise les mêmes bords de bac pour les deux afin qu'ils soient bien alignés.
Comment puis-je les afficher sur le même graphique ? C'est-à-dire une barre verte/rouge et une barre bleue/orange pour chaque bac -- côte à côte.
J'ai vu de nombreuses questions et réponses similaires à celle-ci suggérant d'utiliser un graphique à barres et de calculer la largeur des barres, mais cela semble être quelque chose qui devrait être pris en charge immédiatement, du moins dans matplotlib.
Aussi, puis-je dessiner des histogrammes empilés directement avec seaborn ? Je n'ai pas pu trouver de chemin.
plt.hist( [correct_a, incorrect_a], bins=edges, stacked=True, color=['green', 'red'], rwidth=0.95, alpha=0.5)

plt.hist( [correct_b, incorrect_b], bins=edges, stacked=True, color=['green', 'red'], rwidth=0.95, alpha=0.5)

Réponses
Eh bien, je pense que plt.barc'est votre meilleur pari ici. Pour créer des histogrammes empilés, vous pouvez utiliser son bottom
argument. Pour afficher deux graphiques à barres côte à côte, vous pouvez décaler les x
valeurs de some width
, comme dans cet exemple original de matplotlib :
import numpy as np
import matplotlib.pyplot as plt
fig, ax = plt.subplots(figsize=(16, 8))
correct_a = np.random.randint(0, 20, 20)
incorrect_a = np.random.randint(0, 20, 20)
correct_b = np.random.randint(0, 20, 20)
incorrect_b = np.random.randint(0, 20, 20)
edges = len(correct_a)
width=0.35
rects1 = ax.bar(np.arange(edges), incorrect_a, width, color="red", label="incorrect_a")
rects2 = ax.bar(np.arange(edges), correct_a, width, bottom=incorrect_a, color='seagreen', label="correct_a")
rects3 = ax.bar(np.arange(edges) + width, incorrect_b, width, color="blue", label="incorrect_b")
rects4 = ax.bar(np.arange(edges) + width, correct_b, width, bottom=incorrect_b, color='orange', label="correct_b")
# placing the ticks to the middle
ticks_aligned = np.arange(edges) + width // 2
ax.set_xticks(np.arange(edges) + width / 2)
ax.set_xticklabels((str(tick) for tick in ticks_aligned))
ax.legend()
Cela renvoie :
Voici un exemple simple (les histogrammes ne sont pas empilés) pour 2 histogrammes affichés ensemble, chaque bac ayant un emplacement dédié pour chacun d'eux côte à côte :
# generating some data for this example:
a = [1,2,3,4,3,4,2,3,4,5,4,3,4,5,4,1,2,3,2,1,3,4,5,6,7,6,5,4,3,4,6,5,4,3,4]
b = [1,2,3,4,5,6,7,6,5,6,7,6,5,4,3,4,5,6,7,6,7,6,7,5,4,3,2,1,3,4,5,6,5,6,5,6,7,6,7]
# plotting 2 histograms with bars centered differently within each bin:
plt.hist(a, bins=5, align='left', rwidth=0.5)
plt.hist(b, bins=5, align='mid', rwidth=0.5, color='r')