Mam następujący kod, który tworzy następujący rysunek
import numpy as np
np.random.seed(3)
import pandas as pd
import matplotlib.pyplot as plt
df = pd.DataFrame()
df['X'] = list(np.random.randint(100, size=100)) + list(np.random.randint(30, size=100))
df['Y'] = list(np.random.randint(100, size=100)) + list(np.random.randint(30, size=100))
df['Bin'] = df.apply(lambda row: .1 if row['X'] < 30 and row['Y'] < 30 else .9, axis=1)
fig, ax = plt.subplots(figsize=(10,10))
plt.scatter(df['X'], df['Y'])
Zarysowałem dane za pomocą heksbins, jak zauważono poniżej
from matplotlib import cm
fig, ax = plt.subplots(figsize=(10,10))
hexbin = ax.hexbin(df['X'], df['Y'], C=df['Bin'], gridsize=20, cmap= cm.get_cmap('RdYlBu_r'),edgecolors='black')
plt.show()
Chciałbym zmienić rozmiar sześciokątów w oparciu o gęstość punktów wykreślonych w obszarze pokrywanym przez sześciokąt. Na przykład sześciokąty w lewym dolnym rogu (gdzie punkty są zwarte) będą większe niż sześciokąty wszędzie indziej (gdzie punkty są rzadkie). Czy jest na to sposób?
Edycja: Wypróbowałem to rozwiązanie , ale nie mogę wymyślić, jak pokolorować heksy na podstawie df [„Bin”], ani jak ustawić minimalny i maksymalny rozmiar heksa.
from matplotlib.collections import PatchCollection
from matplotlib.path import Path
from matplotlib.patches import PathPatch
fig, ax = plt.subplots(figsize=(10,10))
hexbin = ax.hexbin(df['X'], df['Y'], C=df['Bins'], gridsize=20, cmap= cm.get_cmap('RdYlBu_r'),edgecolors='black')
def sized_hexbin(ax,hc):
offsets = hc.get_offsets()
orgpath = hc.get_paths()[0]
verts = orgpath.vertices
values = hc.get_array()
ma = values.max()
patches = []
for offset,val in zip(offsets,values):
v1 = verts*val/ma+offset
path = Path(v1, orgpath.codes)
patch = PathPatch(path)
patches.append(patch)
pc = PatchCollection(patches, cmap=cm.get_cmap('RdYlBu_r'), edgecolors='black')
pc.set_array(values)
ax.add_collection(pc)
hc.remove()
sized_hexbin(ax,hexbin)
plt.show()
C=df['Bin'],
go użyjesz , nie pokaże gęstości, ale ilość, która jest w Bin
kolumnie. Fabuła jest więc poprawna. Możesz pominąć C
argument i uzyskać rozmiary oparte na gęstości.
val/ma
w kodzie. Możesz go zastąpić tym, co uznasz za odpowiednie. Kolory są ustawiane za pomocą pc.set_array(values)
; możesz użyć czegoś innego niż values
oczywiście.