ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

python-matplotlib outlinef3d plot_surface与trisurf

2019-11-18 14:58:03  阅读:256  来源: 互联网

标签:python-3-x matplotlib mplot3d python


我正在尝试对具有以下结构的datathis

 0.90000000   0.90000000 -2133.80472139
 0.90000000   0.95000000 -2133.84134433
 ...
 1.87500000   1.82500000 -2133.96171262
 1.87500000   1.87500000 -2133.95550450

使用以下代码,我已部分成功.但是,我无法在x-y,x-z和y-z平面上绘制轮廓.我必须使用plot_trisurf,因为plot_surface选项不适用于此数据(我真的不知道为什么).创建一个np.meshgrid并没有帮助(将列表转换为np.array之后).

import numpy as np
import sys
from mpl_toolkits.mplot3d import axes3d
import matplotlib.pyplot as plt
from matplotlib import cm

filename = sys.argv[1]

with open(filename+'.dat', 'r') as f:
    x = []
    y = []
    z = []
    for line in f:
        data = line.split()
        x.append((float(data[0])))
        y.append((float(data[1])))
        z.append((float(data[2])))

zz = [627.503*(i+2134.070983645239) for i in z]

fig = plt.figure()
ax = fig.gca(projection='3d')
ax.plot_trisurf(x, y, zz, cmap=cm.jet, linewidth=0.1)
ax.dist=12
ax.view_init(30, 45)
ax.set_xlim(0.9, 1.9)
ax.set_ylim(0.9, 1.9)
ax.set_zlim(0, 170)
plt.show()

enter image description here

请问您对我如何在x-y位置上绘制轮廓以及在x-z和y-z上绘制投影有任何想法吗?

解决方法:

您必须使用三角形轮廓和实心三角形轮廓:
tricontour和tricontourf:http://matplotlib.org/examples/pylab_examples/tricontour_demo.html

我已经使用tricontourf向您添加了一个表面到XY的投影图:

fig = plt.figure()
ax = fig.gca(projection='3d')
ax.plot_trisurf(x, y, zz, cmap=cm.jet, linewidth=0.1)
# projection of a surface to XY
ax.tricontourf(x, y, zz, zdir='z', offset=-1, cmap=cm.coolwarm)

ax.dist=12
ax.view_init(30, 45)
ax.set_xlim(0.9, 1.9)
ax.set_ylim(0.9, 1.9)
ax.set_zlim(0, 170)
plt.show()

enter image description here

标签:python-3-x,matplotlib,mplot3d,python
来源: https://codeday.me/bug/20191118/2028911.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有