python中griddata_python – 来自xyz数据的Matplotlib轮廓:griddata无效索引[通俗易懂]

python中griddata_python – 来自xyz数据的Matplotlib轮廓:griddata无效索引[通俗易懂]我正在尝试使用具有以下格式的文件的matplotlib来绘制等高线图:x1y1z1x2y2z2等等我可以用numpy.loadtxt加载它来获取向量.到目前为止,没有麻烦.我读这个是为了学习如何绘图,并且可以通过复制粘贴来重现它,所以我确定我的安装没有错:我知道我必须输入x和y作为矢量,z作为数组输入,这可以用griddata完成.这也是我在这个网站上找到的.文件说:zi=gridda…

大家好,又见面了,我是你们的朋友全栈君。

我正在尝试使用具有以下格式的文件的matplotlib来绘制等高线图:

x1 y1 z1

x2 y2 z2

等等

我可以用numpy.loadtxt加载它来获取向量.到目前为止,没有麻烦.

我读这个是为了学习如何绘图,并且可以通过复制粘贴来重现它,所以我确定我的安装没有错:

我知道我必须输入x和y作为矢量,z作为数组输入,这可以用griddata完成.这也是我在这个网站上找到的.

文件说:

zi = griddata(x,y,z,xi,yi) fits a surface of the form z = f*(*x, y) to the data in the (usually) nonuniformly spaced vectors (x, y, z). griddata() interpolates this surface at the points specified by (xi, yi) to produce zi. xi and yi must describe a regular grid, can be either 1D or 2D, but must be monotonically increasing.

为了这个例子,我写了这段代码:

import numpy as np

import matplotlib.pyplot as plt

import matplotlib.mlab as ml

x=np.linspace(1.,10.,20)

y=np.linspace(1.,10.,20)

z=np.linspace(1.,2.,20)

xi=np.linspace(1.,10.,10)

yi=np.linspace(1.,10.,10)

zi = ml.griddata(x,y,z,xi,yi)

但是,当涉及到griddata时,我收到以下错误:

IndexError:索引无效

所以,我试着修改一下doc的例子,如下所示:

from matplotlib.mlab import griddata

import matplotlib.pyplot as plt

import numpy as np

x = np.linspace(-2.1,2.1,300)

y = np.linspace(-2.1,2.1,300)

z = x*np.exp(-x**2-y**2)

# define grid.

xi = np.linspace(-2.1,2.1,100)

yi = np.linspace(-2.1,2.1,200)

# grid the data.

zi = griddata(x,y,z,xi,yi,interp=’linear’)

我得到了同样的错误.我不明白出了什么问题.

谢谢你的帮助.

解决方法:

考虑:

x = np.linspace(1., 10., 20)

y = np.linspace(1., 10., 20)

z = np.linspace(1., 2., 20)

这意味着我们知道沿x = y线的某些点的z值.

从那里,

zi = ml.griddata(x,y,z,xi,yi)

要求mlab.griddata推断矩形网格中所有点的z值.

我们已经提供了很多关于z如何沿着这条线变化的信息,但没有关于z如何在垂直方向上变化的信息(远离x = y线).由于mlab.griddata拒绝猜测,因此引发了错误.

如果您的初始x,y数据更随机分布,您将获得更好的结果:

import numpy as np

import matplotlib.pyplot as plt

import matplotlib.mlab as ml

ndata = 10

ny, nx = 100, 200

xmin, xmax = 1, 10

ymin, ymax = 1, 10

# x = np.linspace(1, 10, ndata)

# y = np.linspace(1, 10, ndata)

x = np.random.randint(xmin, xmax, ndata)

y = np.random.randint(ymin, ymax, ndata)

z = np.random.random(ndata)

xi = np.linspace(xmin, xmax, nx)

yi = np.linspace(ymin, ymax, ny)

zi = ml.griddata(x, y, z, xi, yi)

plt.contour(xi, yi, zi, 15, linewidths = 0.5, colors = ‘k’)

plt.pcolormesh(xi, yi, zi, cmap = plt.get_cmap(‘rainbow’))

plt.colorbar()

plt.scatter(x, y, marker = ‘o’, c = ‘b’, s = 5, zorder = 10)

plt.xlim(xmin, xmax)

plt.ylim(ymin, ymax)

plt.show()

如果你想让mlab.griddata以任意方式沿着x = y线将数据外推到整个网格,你可以添加两个额外的边界点(xmin,ymax,z [0])和(xmax,ymin,z [ – 1]):

import numpy as np

import matplotlib.pyplot as plt

import matplotlib.mlab as ml

np.random.seed(8)

ndata = 10

ny, nx = 100, 200

xmin, xmax = 1, 10

ymin, ymax = 1, 10

x = np.linspace(1, 10, ndata)

y = np.linspace(1, 10, ndata)

z = np.random.random(ndata)

x = np.r_[x,xmin,xmax]

y = np.r_[y,ymax,ymin]

z = np.r_[z,z[0],z[-1]]

xi = np.linspace(xmin, xmax, nx)

yi = np.linspace(ymin, ymax, ny)

# Requires installation of natgrid

# http://sourceforge.net/projects/matplotlib/files/matplotlib-toolkits/

zi = ml.griddata(x, y, z, xi, yi, interp=’nn’)

# Or, without natgrid:

# zi = ml.griddata(x, y, z, xi, yi, interp=’linear’)

plt.contour(xi, yi, zi, 15, linewidths = 0.5, colors = ‘k’)

plt.pcolormesh(xi, yi, zi, cmap = plt.get_cmap(‘rainbow’))

plt.colorbar()

plt.scatter(x, y, marker = ‘o’, c = ‘b’, s = 10, zorder = 10)

plt.xlim(xmin, xmax)

plt.ylim(ymin, ymax)

plt.show()

标签:python,matplotlib,interpolation

来源: https://codeday.me/bug/20191004/1851562.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/141297.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 树莓派连接wifi个人热点和远程windows远程登录

    树莓派连接wifi个人热点和远程windows远程登录1.安装完系统后在该目录下新建wpa_supplicant.conf文件填入以下信息country=CNctrl_interface=DIR=/var/run/wpa_supplicantGROUP=netdevupdate_config=1network={ssid="WiFi-A"psk="12345678"key_mgmt=WPA-PSKpriority=1}…

    2022年5月5日
    77
  • 微信小程序轮播图调用接口

    微信小程序轮播图调用接口生命周期函数,页面加载:onLoad:function(options){let_this=this;wx.request({url:’http://www.day.com/index.php/img’,//仅为示例,并非真实的接口地址method:”GET”,success(res){//console.log(res.data.data)letdatas=res.data.data;//渲染_this.setData({datas})},}

    2022年5月11日
    41
  • 业务架构和系统架构_技术架构和系统架构

    业务架构和系统架构_技术架构和系统架构通用业务系统架构演进

    2022年4月21日
    302
  • 蓝天准系统P750的介绍与开箱

    蓝天准系统P750的介绍与开箱准系统笔记本:准系统笔记本是指使用由工厂(即ODM厂商)采购的标准化笔记本模具,再通过商家或懂技术的玩家安装相兼容的配件(如CPU,显卡,内存,硬盘,光驱,无线网卡,屏幕等)组成的完整笔记本产品。和INTEL于2004年提出的CBB计划有一定相似。2008年的金融危机,使得部分工厂如蓝天、微星向零售商出售模具,准系统笔记本在中国逐渐普及开来。台式DIY装机的人不少,组装笔电的人则不多。对于一个…

    2022年6月14日
    92
  • 安卓数据转移到iphone老是中断_关于iPhone手机之间数据转移的几种方式[通俗易懂]

    安卓数据转移到iphone老是中断_关于iPhone手机之间数据转移的几种方式[通俗易懂]最近肯定有很多小伙伴已经买了iPhone11的新机,或者有些打算换一台新iPhone。拿到新机之后转移数据可是一件麻烦的事。关于iPhone手机之间的数据转移有哪几种呢?今天码哥就来跟大家科普一。其实,除了通过iTunes或者iClouds之外,苹果后来又增加了两种方式:1.通过无线局域网把数据从旧iPhone传输到新iPhone手机。2.通过LightingtoLifhtin…

    2022年9月18日
    0
  • 教你win10系统显卡驱动安装失败的解决方法

    教你win10系统显卡驱动安装失败的解决方法我们日常在对电脑的使用过程中,经常都会遇到这样或那样的问题。比如说win10系统显卡驱动安装失败该怎么办呢?别着急,还有小编在呢?接下来小编就来告诉大家win10电脑系统显卡驱动安装失败怎么解决。详细教你win10系统显卡驱动安装失败怎么办:方法一,删除之前的显卡驱动文件重新安装1,首先,右键点击“此电脑”,菜单栏选择“管理”。2,进入计算机管理界面后,点击“设备管理器”,然后在界面右侧展开“显示适配器”选项,并右键点击显卡驱动程序,菜单栏选择“属性”下一步。3,点击“卸载设备”。4,显卡

    2022年6月13日
    29

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号