我想缩放一部分数据/图像并将其绘制在同一图中。它看起来像这个数字。
是否可以在同一图表中插入一部分缩放图像。我认为可以用子图绘制另一个图,但它绘制了两个不同的数字。我还读过添加补丁来插入矩形/圆形,但不确定将图像的一部分插入图中是否有用。我基本上从文本文件加载数据并使用下面显示的简单绘图命令绘制它。
我在matplotlib图片库here中找到了一个相关示例,但不确定它是如何工作的。非常感谢您的帮助。
from numpy import *
import os
import matplotlib.pyplot as plt
data = loadtxt(os.getcwd()+txtfl[0], skiprows=1)
fig1 = plt.figure()
ax1 = fig1.add_subplot(111)
ax1.semilogx(data[:,1],data[:,2])
plt.show()
答案 0 :(得分:28)
使用可运行代码是其中之一 学习Python的最快方法。
让我们从code from the matplotlib example gallery开始。
鉴于代码中的注释,似乎代码分为4个主要节。 第一节生成一些数据,第二节生成主要情节, 第三和第四节创造了插入轴。
我们知道如何生成数据并绘制主要情节,所以让我们关注第三节:
a = axes([.65, .6, .2, .2], axisbg='y')
n, bins, patches = hist(s, 400, normed=1)
title('Probability')
setp(a, xticks=[], yticks=[])
将示例代码复制到一个名为test.py
的新文件中。
如果我们将.65
更改为.3
会怎样?
a = axes([.35, .6, .2, .2], axisbg='y')
运行脚本:
python test.py
你会发现“概率”插图向左移动。
因此axes
函数控制插入的位置。
如果你用数字玩更多,你会发现(.35,.6)是
插图左下角的位置,(。2,.2)是宽度和
插入的高度。数字从0到1,(0,0)位于
图的左下角。
好的,现在我们正在做饭。到下一行,我们有:
n, bins, patches = hist(s, 400, normed=1)
您可能会将此识别为matplotlib command for drawing a histogram,但是 如果没有,将数字400更改为,比方说10,将产生一个有很多的图像 更粗略的直方图,所以再次通过玩你很快就会发现的数字 这条线与插图内的图像有关。
您需要在此处致电semilogx(data[3:8,1],data[3:8,2])
。
第title('Probability')
行
显然会在插图上方生成文本。
最后我们来setp(a, xticks=[], yticks=[])
。没有数字可以玩,
那么如果我们只是通过在行的开头放置一个#
来注释整行,会发生什么呢?
# setp(a, xticks=[], yticks=[])
重新运行脚本。哦!现在插入轴上有很多刻度线和刻度标签。
精细。所以现在我们知道setp(a, xticks=[], yticks=[])
会从轴a
中删除刻度线和标签。
现在,从理论上讲,您有足够的信息将此代码应用于您的问题。
但还有一个潜在的障碍:matplotlib示例使用
from pylab import *
而你使用import matplotlib.pyplot as plt
。
The matplotlib FAQ说import matplotlib.pyplot as plt
是编写脚本时使用matplotlib的推荐方法
from pylab import *
用于交互式会话。所以你正在以正确的方式做到这一点,(尽管我建议使用import numpy as np
代替from numpy import *
)。
那么我们如何将matplotlib示例转换为与import matplotlib.pyplot as plt
一起运行?
进行转换需要matplotlib的一些经验。一般来说,你只是
在plt.
和axes
之类的裸名称前面添加setp
,但有时也会
函数来自numpy,有时调用应来自轴
对象,而不是模块plt
。需要经验才能知道所有这些
功能来自。使用“matplotlib”搜索函数名称可以提供帮助。
阅读示例代码可以构建体验,但没有简单的快捷方式。
因此,转换后的代码变为
ax2 = plt.axes([.65, .6, .2, .2], axisbg='y')
ax2.semilogx(t[3:8],s[3:8])
plt.setp(ax2, xticks=[], yticks=[])
你可以在你的代码中使用它:
from numpy import *
import os
import matplotlib.pyplot as plt
data = loadtxt(os.getcwd()+txtfl[0], skiprows=1)
fig1 = plt.figure()
ax1 = fig1.add_subplot(111)
ax1.semilogx(data[:,1],data[:,2])
ax2 = plt.axes([.65, .6, .2, .2], axisbg='y')
ax2.semilogx(data[3:8,1],data[3:8,2])
plt.setp(ax2, xticks=[], yticks=[])
plt.show()
答案 1 :(得分:25)
最简单的方法是组合“zoomed_inset_axes”和“mark_inset”,其描述和 相关的例子可以在这里找到: Overview of AxesGrid toolkit
答案 2 :(得分:22)
我所知道的最好的方法是使用mpl_toolkits.axes_grid1.inset_locator(matplotlib的一部分)。
这里有一个很好的源代码示例: https://github.com/NelleV/jhepc/tree/master/2013/entry10
答案 3 :(得分:6)
使用matplotlib缩放图形的一部分的基本步骤
import numpy as np
from matplotlib import pyplot as plt
# Generate the main data
X = np.linspace(-6, 6, 1024)
Y = np.sinc(X)
# Generate data for the zoomed portion
X_detail = np.linspace(-3, 3, 1024)
Y_detail = np.sinc(X_detail)
# plot the main figure
plt.plot(X, Y, c = 'k')
# location for the zoomed portion
sub_axes = plt.axes([.6, .6, .25, .25])
# plot the zoomed portion
sub_axes.plot(X_detail, Y_detail, c = 'k')
# insert the zoomed figure
# plt.setp(sub_axes)
plt.show()