Python 由散点图转换为等高线图 (Make contour of scatter)

可以参考

  1. Make contour of scatter
  2. 将散点转换为等高线,每个点变成一个高地

其中 1. 是一个主要的参考, 2. 的排版很乱, 但是也值得一看.

一. 问题的描述

在 Python 中, 已有的数据点为

x y z

则可以直接画出散点图如下

import matplotlib.pyplot as plt
plt.scatter(x,y,c=z)

那么从上面散点图 (的数据) 转为画等高线图?

补充:
Python 中 plt.contourf(X, Y, Z) 可以画等高线图, 其用法通常如下

import matplotlib.pyplot as plt

###### 数据X,Y,Z
x = np.arange(-10, 10, 0.01) # 步长为0.01, 即每隔0.01取一个点
y = np.arange(-10, 10, 0.01) # 步长为0.01, 即每隔0.01取一个点
X, Y = np.meshgrid(x, y)     # 将原始数据变成网格数据形式
Z = X**2 + Y**2              # 我们假设Z为关于X,Y的函数, 以Z=X^2+Y^2为例

ct = plt.contour(X,Y,Z,25)     # 画等高线,25:等高线的数目 
ctf = plt.contourf(X,Y,Z,25)   # 画等高线,并填充颜色, 25:等高线的数目

二. 回答

根据高赞的回答, 最简单的一种方法就是:

import matplotlib.tri as tri
import matplotlib.pyplot as plt

plt.tricontour(x, y, z, 15, linewidths=0.5, colors='k')  # 15:等高线的数目
plt.tricontourf(x, y, z, 15)  # 15:等高线的数目

猜你喜欢

转载自blog.csdn.net/mifangdebaise/article/details/125119098
今日推荐