24小时热门版块排行榜    

Znn3bq.jpeg
查看: 2676  |  回复: 9
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

ConAntares

捐助贵宾 (初入文坛)

混沌的学渣

[求助] Matplotlib 三维绘图问题 已有1人参与

首先,我用Fortran程序计算出我想要的数据,为三列,保存在一个 .dat的文件里。
格式如下:(x, y, z代表各自列上的数据,z和y之间存在关系 z=f(y))
x1    y1    z1=f(y1)
x1    y2    z2=f(y2)
x1    y3    z3=f(y3)
……
x2    y1    z'1=f'(y1)
x2    y2    z'2=f'(y2)
x2    y3    z'3=f'(y3)
……
……
x2    y1    z''1=f'(y1)
x2    y2    z''2=f'(y2)
x2    y3    z''3=f'(y3)
……
大致意思是x每做一个循环,都算一遍 z=f(y) 的函数图像,其中x和f是有关系的。

而且y轴很长,我想只画出前一的部分。

想画出如 mat.jpg 所示的图

后来我的Matplotlib语言如下:
CODE:
import matplotlib
import mpl_toolkits.mplot3d
import numpy as np
import pylab

from matplotlib import cm
from matplotlib import rc
from mpl_toolkits.mplot3d import axes3d

fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')

#X, Y, Z = axes3d.get_test_data(0.05)

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


ax.plot_wireframe(x, y, z, rstride=100, cstride=100, color='red')

plt.ylim(0.1, 20)
plt.show()

但是绘出图像: figure_1.png 的效果却不尽人意,不仅没法控制绘出图像的范围,而且还有连接处的斜线。
求教如何修改成我想要的结果。

Matplotlib 三维绘图问题
mat.jpg


Matplotlib 三维绘图问题-1
figure_1.png
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

我很好玩哦,不信你玩玩看~
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ConAntares

捐助贵宾 (初入文坛)

混沌的学渣

为了帮助有同样问题的人,我把绘图程序代码贴上上来了。

处理数据文件的 bat 执行程序是我上网找的,其实我也不会编,好在资源很丰富。

我的程序是 Python3.5 中的 Matplotlib2.0 数据可视化程序包
CODE:
################################################################ ####    A 3D Drawing Program ####    Version of April 11, 2017 ####    Lu Niu ################################################################  import matplotlib.pyplot as plt import numpy as np  from matplotlib import pyplot as plt from matplotlib import rc from mpl_toolkits.mplot3d import Axes3D  fig = plt.figure(figsize=(8, 6)) ax = Axes3D(fig)  plt.rc('font', family='serif') ax.text2D(0.20, 0.72, 'Left Current', fontsize = 16, transform=ax.transAxes) ax.text2D(0.22, 0.68, '$\\tau_s=0.1ps$', fontsize = 16, transform=ax.transAxes) #### J10 with open('G-E01-Ts001-J10-e01-P10-TVC/CurrentLTVC00.dat', 'r') as fig:     x = 0.0     y = []     z = []     for line in fig:         data = line.split()         y.append((float(data[1])))         z.append((float(data[2]))) ax.plot_wireframe(x, y, z, rstride=100, cstride=100, color='#D62728', lw='1.6', antialiased=True) with open('G-E01-Ts001-J10-e01-P10-TVC/CurrentLTVC02.dat', 'r') as fig:     x = 0.2     y = []     z = []     for line in fig:         data = line.split()         y.append((float(data[1])))         z.append((float(data[2]))) ax.plot_wireframe(x, y, z, rstride=100, cstride=100, color='#D62728', lw='1.6', antialiased=True) with open('G-E01-Ts001-J10-e01-P10-TVC/CurrentLTVC04.dat', 'r') as fig:     x = 0.4     y = []     z = []     for line in fig:         data = line.split()         y.append((float(data[1])))         z.append((float(data[2]))) ax.plot_wireframe(x, y, z, rstride=100, cstride=100, color='#D62728', lw='1.6', antialiased=True) with open('G-E01-Ts001-J10-e01-P10-TVC/CurrentLTVC06.dat', 'r') as fig:     x = 0.6     y = []     z = []     for line in fig:         data = line.split()         y.append((float(data[1])))         z.append((float(data[2]))) ax.plot_wireframe(x, y, z, rstride=100, cstride=100, color='#D62728', lw='1.6', antialiased=True) with open('G-E01-Ts001-J10-e01-P10-TVC/CurrentLTVC08.dat', 'r') as fig:     x = 0.8     y = []     z = []     for line in fig:         data = line.split()         y.append((float(data[1])))         z.append((float(data[2]))) ax.plot_wireframe(x, y, z, rstride=100, cstride=100, color='#D62728', lw='1.6', antialiased=True) with open('G-E01-Ts001-J10-e01-P10-TVC/CurrentLTVC10.dat', 'r') as fig:     x = 1.0     y = []     z = []     for line in fig:         data = line.split()         y.append((float(data[1])))         z.append((float(data[2]))) ax.plot_wireframe(x, y, z, rstride=100, cstride=100, color='#D62728', lw='1.6', antialiased=True)  #### J01 with open('G-E01-Ts001-J01-e01-P10-TVC/CurrentLTVC00.dat', 'r') as fig:     x = 0.0     y = []     z = []     for line in fig:         data = line.split()         y.append((float(data[1])))         z.append((float(data[2]))) ax.plot_wireframe(x, y, z, rstride=100, cstride=100, color='#FF7F0E', lw='1.6', antialiased=True) with open('G-E01-Ts001-J01-e01-P10-TVC/CurrentLTVC02.dat', 'r') as fig:     x = 0.2     y = []     z = []     for line in fig:         data = line.split()         y.append((float(data[1])))         z.append((float(data[2]))) ax.plot_wireframe(x, y, z, rstride=100, cstride=100, color='#FF7F0E', lw='1.6', antialiased=True) with open('G-E01-Ts001-J01-e01-P10-TVC/CurrentLTVC04.dat', 'r') as fig:     x = 0.4     y = []     z = []     for line in fig:         data = line.split()         y.append((float(data[1])))         z.append((float(data[2]))) ax.plot_wireframe(x, y, z, rstride=100, cstride=100, color='#FF7F0E', lw='1.6', antialiased=True) with open('G-E01-Ts001-J01-e01-P10-TVC/CurrentLTVC06.dat', 'r') as fig:     x = 0.6     y = []     z = []     for line in fig:         data = line.split()         y.append((float(data[1])))         z.append((float(data[2]))) ax.plot_wireframe(x, y, z, rstride=100, cstride=100, color='#FF7F0E', lw='1.6', antialiased=True) with open('G-E01-Ts001-J01-e01-P10-TVC/CurrentLTVC08.dat', 'r') as fig:     x = 0.8     y = []     z = []     for line in fig:         data = line.split()         y.append((float(data[1])))         z.append((float(data[2]))) ax.plot_wireframe(x, y, z, rstride=100, cstride=100, color='#FF7F0E', lw='1.6', antialiased=True) with open('G-E01-Ts001-J01-e01-P10-TVC/CurrentLTVC10.dat', 'r') as fig:     x = 1.0     y = []     z = []     for line in fig:         data = line.split()         y.append((float(data[1])))         z.append((float(data[2]))) ax.plot_wireframe(x, y, z, rstride=100, cstride=100, color='#FF7F0E', lw='1.6', antialiased=True)  #### J00 with open('G-E01-Ts001-J00-e01-P10-TVC/CurrentLTVC00.dat', 'r') as fig:     x = 0.0     y = []     z = []     for line in fig:         data = line.split()         y.append((float(data[1])))         z.append((float(data[2]))) ax.plot_wireframe(x, y, z, rstride=100, cstride=100, color='#1F77B4', lw='1.6', antialiased=True) with open('G-E01-Ts001-J00-e01-P10-TVC/CurrentLTVC02.dat', 'r') as fig:     x = 0.2     y = []     z = []     for line in fig:         data = line.split()         y.append((float(data[1])))         z.append((float(data[2]))) ax.plot_wireframe(x, y, z, rstride=100, cstride=100, color='#1F77B4', lw='1.6', antialiased=True) with open('G-E01-Ts001-J00-e01-P10-TVC/CurrentLTVC04.dat', 'r') as fig:     x = 0.4     y = []     z = []     for line in fig:         data = line.split()         y.append((float(data[1])))         z.append((float(data[2]))) ax.plot_wireframe(x, y, z, rstride=100, cstride=100, color='#1F77B4', lw='1.6', antialiased=True) with open('G-E01-Ts001-J00-e01-P10-TVC/CurrentLTVC06.dat', 'r') as fig:     x = 0.6     y = []     z = []     for line in fig:         data = line.split()         y.append((float(data[1])))         z.append((float(data[2]))) ax.plot_wireframe(x, y, z, rstride=100, cstride=100, color='#1F77B4', lw='1.6', antialiased=True) with open('G-E01-Ts001-J00-e01-P10-TVC/CurrentLTVC08.dat', 'r') as fig:     x = 0.8     y = []     z = []     for line in fig:         data = line.split()         y.append((float(data[1])))         z.append((float(data[2]))) ax.plot_wireframe(x, y, z, rstride=100, cstride=100, color='#1F77B4', lw='1.6', antialiased=True) with open('G-E01-Ts001-J00-e01-P10-TVC/CurrentLTVC10.dat', 'r') as fig:     x = 1.0     y = []     z = []     for line in fig:         data = line.split()         y.append((float(data[1])))         z.append((float(data[2]))) ax.plot_wireframe(x, y, z, rstride=100, cstride=100, color='#1F77B4', lw='1.6', antialiased=True)  ax.view_init(30, 30) ax.set_xlim3d(0, 1) ax.set_ylim3d(0, 4) ax.set_zlim3d(-0.10, 0.25) ax.set_xlabel(r'Voltage $(V)$', family='serif', fontsize=14) ax.set_ylabel(r'Time $(ps)$', family='serif', fontsize=14) ax.set_zlabel(r'Current $(nA)$', family='serif', fontsize=14)  plt.xticks([0, 0.2, 0.4, 0.6, 0.8, 1.0], fontsize=12) plt.yticks([0.0, 0.5, 1.0, 1,5, 2.0, 2.5, 3.0, 3.5, 4.0], fontsize=12) ax.set_zticks([-0.10,-0.05,0,0.05,0.10,0.15,0.20,0.25]) #ax.set_zticks(np.arange(0,6,1.0)) plt.gca().invert_xaxis()  plt.savefig('GV-Ts001-L.png', dpi=512) plt.savefig('GV-Ts001-L.eps', dpi=512) plt.show()

我很好玩哦,不信你玩玩看~
9楼2017-04-11 21:25:37
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 10 个回答

ConAntares

捐助贵宾 (初入文坛)

混沌的学渣

链接处的线该如何消除?

我做了差不多两百个这样的数据,如果再做一次那工程量我实在是承受不起。

附件里面有示范数据,求好心人帮帮忙,老司机带带我。

TvT
Matplotlib 三维绘图问题-2
figure_2.png

» 本帖附件资源列表

  • 欢迎监督和反馈:小木虫仅提供交流平台,不对该内容负责。
    本内容由用户自主发布,如果其内容涉及到知识产权问题,其责任在于用户本人,如对版权有异议,请联系邮箱:xiaomuchong@tal.com
  • 附件 1 : CurrentLTVC.dat
  • 2017-04-07 04:19:15, 5.83 M
我很好玩哦,不信你玩玩看~
2楼2017-04-07 04:19:54
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ConAntares

捐助贵宾 (初入文坛)

混沌的学渣

再补充一下,我的Python版本是3.5,Matplotlib是最新的版本,希望有大佬带我飞一波。
我的论文其他配图都用Matplotlib做好了,就差几个三维的数据可视化图形了。
我很好玩哦,不信你玩玩看~
3楼2017-04-07 05:01:59
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

约束陶瓷装甲

金虫 (正式写手)


jjdg: 金币+1, 感谢参与 2017-04-12 00:18:41
x=x1,x2,x3,...,xn要用循环分成n次来plot,而不是一次plot,一次plot的结果就是连在一起。

[ 发自手机版 http://muchong.com/3g ]
4楼2017-04-07 05:38:50
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 一志愿0703化学招61最终排名62化学求调剂 +23 招61排名62 2026-04-07 27/1350 2026-04-10 15:26 by MOF_Catal
[基金申请] 山东省基金2026 +3 jerry681 2026-04-08 3/150 2026-04-10 13:59 by 过客卡卡
[考研] 材料与化工300求调剂 +30 肖开文 2026-04-09 32/1600 2026-04-10 10:59 by 紫翼精灵
[考研] 调剂 +15 小张ZA 2026-04-10 16/800 2026-04-10 09:56 by 690616278
[考研] 289求调剂 +4 L1ttleTiger 2026-04-04 4/200 2026-04-09 19:53 by xiayizhi
[考研] 291分调剂 +3 上岸小莹加油 2026-04-09 4/200 2026-04-09 17:28 by 1753564080
[考研] 086004 求调剂 309 +7 Yin DY 2026-04-08 7/350 2026-04-09 13:59 by Delta2012
[考研] 化学调剂求助 +14 LULONG1 2026-04-03 19/950 2026-04-09 10:43 by chenxi233
[考研] 283电子信息求调剂 +4 三石WL 2026-04-08 4/200 2026-04-09 10:21 by wp06
[考研] 材料调剂 +14 一样YWY 2026-04-06 14/700 2026-04-08 23:00 by 猪会飞
[考研] 化学0703-一志愿211-338分求调剂 +10 vants 2026-04-05 11/550 2026-04-08 16:02 by screening
[考研] 388求调剂 +6 四川王涛 2026-04-07 8/400 2026-04-08 00:17 by JourneyLucky
[考研] 323求调剂 +3 林zlu 2026-04-07 4/200 2026-04-07 23:21 by lbsjt
[考研] 313求调剂 +3 十六拾陆 2026-04-07 3/150 2026-04-07 23:20 by lbsjt
[考研] 071000生物学,一志愿深圳大学296分,求调剂 +12 TIckLw 2026-04-06 13/650 2026-04-07 20:34 by lijunpoly
[考博] 博士申请 +3 IQwQl 2026-04-05 3/150 2026-04-07 20:31 by greychen00
[考研] 复试调剂 +14 呼呼?~+123456 2026-04-05 14/700 2026-04-06 22:50 by chenzhimin
[考研] 22408 331分求调剂 +4 y__1 2026-04-06 4/200 2026-04-06 17:26 by 土木硕士招生
[考研] 302分 085601求调剂推荐 +11 zyx上岸! 2026-04-05 11/550 2026-04-05 22:13 by dongzh2009
[考研] 能动调剂326专硕 +4 wan112233 2026-04-04 4/200 2026-04-04 22:47 by yu221
信息提示
请填处理意见