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()
1
Apakah Anda melihat stackoverflow.com/questions/48844600/… ?
—
plasmon360
@ plasmon360 Saya memperbarui posting dengan pekerjaan saya dari solusi yang diusulkan
—
Ethan
Saat Anda menggunakannya
—
ImportanceOfBeingErnest
C=df['Bin'],
tidak akan menunjukkan kepadatan, melainkan kuantitas yang ada di Bin
kolom. Jadi plotnya benar. Anda dapat meninggalkan C
argumen, dan mendapatkan ukuran berdasarkan kepadatan.
@ImportanceOfBeingErnest oke, mengerti. Bagaimana saya bisa mewarnai heks dengan df ['Bin']? Saya juga ingin dapat mengubah ukuran min dari segi enam menjadi sedikit lebih besar, apakah ini mungkin?
—
Ethan
Ukurannya ditentukan oleh rasio
—
ImportanceOfBeingErnest
val/ma
dalam kode. Anda dapat menggantinya dengan apa pun yang menurut Anda cocok. Warna-warna diatur melalui pc.set_array(values)
; Anda dapat menggunakan sesuatu selain values
tentu saja.