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()
これはデータの小さなサンプルのプロットです -
上記のプロットの領域の 1 つを詳しく見てみましょう (重なっている/交差している線に注意してください) -
等高線図のように見えない理由がわかりません。線が交差していますが、これは起こるべきではありません。何が間違っている可能性がありますか?助けてください。