我正在尝试在 python 中使用 matplotlib 制作以下数据的等高线图。数据是这种形式 -
# x y height
77.23 22.34 56
77.53 22.87 63
77.37 22.54 72
77.29 22.44 88
数据实际上包含近 10,000 个点,我是从输入文件中读取的。然而,z 的不同可能值的集合很小(在 50-90 之间,整数),我希望每个这样不同的 z 都有一个等高线。
这是我的代码 -
import matplotlib
import numpy as np
import matplotlib.cm as cm
import matplotlib.mlab as mlab
import matplotlib.pyplot as plt
import csv
import sys
# read data from file
data = csv.reader(open(sys.argv[1], 'rb'), delimiter='|', quotechar='"')
x = []
y = []
z = []
for row in data:
try:
x.append(float(row[0]))
y.append(float(row[1]))
z.append(float(row[2]))
except Exception as e:
pass
#print e
X, Y = np.meshgrid(x, y) # (I don't understand why is this required)
# creating a 2D array of z whose leading diagonal elements
# are the z values from the data set and the off-diagonal
# elements are 0, as I don't care about them.
z_2d = []
default = 0
for i, no in enumerate(z):
z_temp = []
for j in xrange(i): z_temp.append(default)
z_temp.append(no)
for j in xrange(i+1, len(x)): z_temp.append(default)
z_2d.append(z_temp)
Z = z_2d
CS = plt.contour(X, Y, Z, list(set(z)))
plt.figure()
CB = plt.colorbar(CS, shrink=0.8, extend='both')
plt.show()
这是一小部分数据的图 -
这是对上图区域之一的仔细观察(注意重叠/相交线) -
我不明白为什么它看起来不像等高线图。线相交,这不应该发生。什么可能是错的?请帮忙。