python散点图密度颜色_如何在matplotlib中绘制以密度着色的散点图?

除了hist2d或hexbin如@askewchan建议的那样,您可以使用与链接到的问题中的可接受答案相同的方法。

如果要这样做:

import numpy as np

import matplotlib.pyplot as plt

from scipy.stats import gaussian_kde

# Generate fake data

x = np.random.normal(size=1000)

y = x * 3 + np.random.normal(size=1000)

# Calculate the point density

xy = np.vstack([x,y])

z = gaussian_kde(xy)(xy)

fig, ax = plt.subplots()

ax.scatter(x, y, c=z, s=100, edgecolor='')

plt.show()

5d9978c800017df705000377.jpg

如果希望按密度顺序绘制点,以使最密集的点始终位于顶部(类似于链接的示例),只需按z值对它们进行排序。我还将在此处使用较小的标记大小,因为它看起来更好一些:

import numpy as np

import matplotlib.pyplot as plt

from scipy.stats import gaussian_kde

# Generate fake data

x = np.random.normal(size=1000)

y = x * 3 + np.random.normal(size=1000)

# Calculate the point density

xy = np.vstack([x,y])

z = gaussian_kde(xy)(xy)

# Sort the points by density, so that the densest points are plotted last

idx = z.argsort()

x, y, z = x[idx], y[idx], z[idx]

fig, ax = plt.subplots()

ax.scatter(x, y, c=z, s=50, edgecolor='')

plt.show()

5d9978d200012daa05000377.jpg

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值