如何平滑matplotlib等高线图?

the*_*eta 44 python matplotlib

我有这种形状的numpy数组:(33,10).当我绘制轮廓时,我会得到这样丑陋的图像: 在此输入图像描述

虽然contour()似乎没有关于平滑或某种插值特征的任何争论.

我不知何故预计提供等高线图的工具也应该提供平滑.
有没有直接的方法在MPL中做到这一点?

Joe*_*ton 56

正如其他人已经指出的那样,您需要插入数据.

有许多不同的方法可以做到这一点,但对于初学者,请考虑scipy.ndimage.zoom.

作为一个快速的例子:

import numpy as np
import scipy.ndimage
import matplotlib.pyplot as plt

data = np.loadtxt('data.txt')

# Resample your data grid by a factor of 3 using cubic spline interpolation.
data = scipy.ndimage.zoom(data, 3)

plt.contour(data)
plt.show()
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

  • 我只是花了太多时间试图让我的数字尽可能漂亮......这可能解释了为什么我从未按时完成任务!:) (12认同)
  • @nicoguaro - 使用`griddata`的问题在于它用于不规则采样的输入(即分散的数据).对于定期网格化数据的重新插值,存在不同的,更有效的算法.`scipy.ndimage.zoom`利用了输入的规则网格化特性.对于小输入网格可能并不明显,但对于较大的网格,"zoom"可以快几个数量级.但是,如果你没有开始使用常规网格,那么是的,`griddata`或类似的东西(例如`scipy.interpolate.Rbf`)就是你想要的. (4认同)

wsj*_*wsj 17

如果您的数据稀少,Joe Kingtons的答案很棒.

如果您的数据有噪音,您应该考虑过滤它:

from numpy import loadtxt
from scipy.ndimage.filters import gaussian_filter
from matplotlib.pyplot import contour, show

sigma = 0.7 # this depends on how noisy your data is, play with it!
data = loadtxt('data.txt')
data = gaussian_filter(data, sigma)
contour(data)
show()
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述


ims*_*msc 8

没有简单的方法来获得平滑的轮廓.另一种方法是尝试imshow.您可以在这里寻找其他可能性.

import pylab as plt
import numpy as np

Z=np.loadtxt('data.txt')
plt.subplot(131)
plt.imshow(Z,interpolation='nearest')

plt.subplot(132)
plt.imshow(Z)

plt.subplot(133)
plt.imshow(Z,interpolation='gaussian')

plt.show()
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述