Saya punya kode berikut yang menghasilkan gambar berikut
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'])
Saya membuat grafik data menggunakan hexbins, seperti yang tercantum di bawah ini
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()
Saya ingin mengubah ukuran segi enam berdasarkan kepadatan titik yang diplot di area yang dicakup segi enam. Misalnya, segi enam di kiri bawah (di mana titik-titiknya kompak) akan lebih besar dari segi enam di tempat lain (di mana titik-titiknya jarang). Apakah ada cara untuk melakukan ini?
Sunting: Saya mencoba solusi ini , tetapi saya tidak tahu bagaimana cara mewarnai heksa berdasarkan df ['Bin'], atau bagaimana mengatur ukuran hex min dan max.
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()
python
matplotlib
Ethan
sumber
sumber
C=df['Bin'],
tidak akan menunjukkan kepadatan, melainkan kuantitas yang ada diBin
kolom. Jadi plotnya benar. Anda dapat meninggalkanC
argumen, dan mendapatkan ukuran berdasarkan kepadatan.val/ma
dalam kode. Anda dapat menggantinya dengan apa pun yang menurut Anda cocok. Warna-warna diatur melaluipc.set_array(values)
; Anda dapat menggunakan sesuatu selainvalues
tentu saja.Jawaban:
Anda mungkin ingin menghabiskan waktu dalam memahami pemetaan warna.
sumber
df['Bin']
kolom?df['Bin']
kolom, sehingga heksa kiri bawah berwarna biru dan lainnya berwarna merah