首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在matplotlib中绘制多个子图之间的相关区域线

在matplotlib中绘制多个子图之间的相关区域线
EN

Stack Overflow用户
提问于 2013-06-29 17:22:55
回答 1查看 1.3K关注 0票数 5

我是个地质学家,有一堆深度不一的钻孔。

我粗略地设置了子地块的数量、宽度和高度,以根据钻孔的数量和这些钻孔中的样本数量而变化。

在每个钻孔中都有一个我想要突出显示的区域,这是我用axhspan完成的。

我想要做的是在钻孔(子地块)之间进行关联,在所有钻孔上绘制一条连接所有分区的顶部和底部的线。

我尝试过使用annotate,但没有取得很大进展。我真的不确定如何处理这一点,并感谢任何建议。

以下是一些示例代码,以及它可能产生的结果的图片

代码语言:javascript
复制
import numpy as np
import matplotlib.pyplot as plt
from random import randint

fig = plt.figure()

Wells=np.arange(0,10,1) #number of wells to plot

for i in Wells:
    samp=randint(50,100) #number of samples in well

    dist=0.02     #space between plots
    left=0.05     #left border
    right=0.05    #right border
    base=0.05     #bottom border
    width=((1.0-(left+right))/len(Wells))     #width of subplot
    height=(1.0-base)/(100.0/samp)            #height of subplot

    #create subplots
    ax = fig.add_axes([left+(i*width)+dist, 1.0-(base+height), width-dist, height])    #left,bottom,width,height of subplot

    #random data 
    x=np.random.random_integers(100,size=(samp))
    y=np.arange(0,len(x),1)

    #plot
    ax.plot(x,y,alpha=0.5)    

    #zone area of plot 
    zone=samp/2.5
    ax.axhspan(15, zone, color='k', alpha=0.2) #axis 'h' horizontal span

    #format
    ax.set_ylim(0,max(y))
    ax.set_xlim(0,max(x))
    ax.tick_params(axis='both',label1On=False,label2On=False)

plt.show()

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-06-30 02:18:48

您可以使用matplotlib.patches.ConnectionPatch建立此连接。

for循环之前添加:

代码语言:javascript
复制
xys_bot = []
xys_top = []

for循环的末尾:

代码语言:javascript
复制
for i in Wells:
    #
    #...
    #
    xys_bot.append( ((x.max() - x.min())/2., 15) )
    xys_top.append( ((x.max() - x.min())/2., zone) )
    if i > 0:
        # bottom line
        p = ConnectionPatch(xyA = xys_bot[i-1], xyB = xys_bot[i],
               coordsA='data', coordsB='data',
               axesA=fig.axes[i-1], axesB=ax,
               arrowstyle='-')
        ax.add_artist(p)
        # top line
        p = ConnectionPatch(xyA = xys_top[i-1], xyB = xys_top[i],
               coordsA='data', coordsB='data',
               axesA=fig.axes[i-1], axesB=ax,
               arrowstyle='-')
        ax.add_artist(p)

plt.draw()
plt.show()
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17378675

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档