我有一個名爲funcPower3的函數,其正文如下所示。我想用MatplotLib中的三維繪圖函數繪製該函數。我看到一個關於meshgrid的scipy文檔的例子。然而,在這個例子中,功能不定義的功能,但一個簡單的數學運算:python matplotlib - 使用meshgrid爲用戶定義的函數進行格式化
fig = plt.figure()
ax = fig.gca(projection='3d')
X = np.arange(-5, 5, 0.25)
Y = np.arange(-5, 5, 0.25)
X, Y = np.meshgrid(X, Y)
R = np.sqrt(X**2 + Y**2)
Z = np.sin(R)
surf = ax.plot_surface(X, Y, Z, rstride=1, cstride=1, cmap=cm.jet,
linewidth=0, antialiased=False)
我的靈感在此示例中,但我自己的函數簽名不出來meshgrid的數據兼容。我有這樣的錯誤:
ValueError: zero-size array to minimum.reduce without identity
我的函數的代碼是在這裏:
def funcPower3(PARAM):
inputX1 = open("power3X.txt","r")
inputY = open("power3Y.txt","r")
X1=[]
Y=[]
for line in inputX1:
X1.append(float(line))
for line in inputY:
Y.append(float(line))
resTmp_ = 0
res = 0
for i in range(len(X1)):
resTmp_ = Y[i] - (PARAM[0]*(X1[i])**float(PARAM[1]))
res += resTmp_**2
return res
和代碼來繪製3D這個功能是在這裏:
XMIN = 0 YMIN = 0 XMAX = 10 ymax = 1
fig = plt.figure('Power 3')
ax = fig.gca(projection='3d')
Z = []
Xpl = numpy.arange(xmin, xmax, 0.1).tolist()
Ypl = numpy.arange(ymin, ymax, 0.01).tolist()
Xpl, Ypl = numpy.meshgrid(Xpl, Ypl)
Z=[]
for i in range(len(Xpl[0])):
for j in range(len(Xpl)):
Z.append(funcPower3([Xpl[j][i],Ypl[j][i]]))
surf=ax.plot_surface(Xpl, Ypl, Z, rstride=8, cstride=8, alpha=0.3,cmap=cm.jet)
ax.set_xlabel('X Label')
ax.set_ylabel('Y Label')
plt.show()
謝謝並且會提出任何建議; ))
這看起來非常有前途和代碼是超清晰。我有一個小問題,這個錯誤:「打開(打開(」power3X.txt「,」r「))infile: TypeError:脅迫Unicode:需要字符串或緩衝區,找到文件」 – octoback 2012-03-27 20:37:53
@dlib:oops太很多「開放」:)。現在修好。 – Avaris 2012-03-27 20:38:57
修正爲打開(「power3Y.txt」,「r」)爲infile: y = [float(line)for line in infile],效果很好! – octoback 2012-03-27 20:47:36