matplotlib Gridspec子图意外的大小不同。

问题描述 投票:0回答:1

我试图使用matplotlib创建一个图像网格,第一行和第二列定义了一个函数的输入,网格的其余部分是输出,下面是别人的参考资料,我希望它看起来如何。参考.

特别是注意到,将第一行和列与其他一切事物隔开的行。

在过去的几个小时里,我一直在尝试让它工作。到目前为止,我所做的最好的是使用Gridspec将图像分为四组,并使用PIL构建图像.然而,由于一个我无法理解的原因,不同子图的形状不匹配。

附上一个最小的代码和它的输出。

import matplotlib.pyplot as plt
    import matplotlib.gridspec as gridspec
    import PIL

    f = plt.figure(figsize=(20, 20))

    resolution = 256
    num_images = 6
    h = w = num_images
    main_grid = gridspec.GridSpec(h, w, hspace=0, wspace=0)

    col = f.add_subplot(main_grid[0, 1:])
    row = f.add_subplot(main_grid[1:, 0])
    mid = f.add_subplot(main_grid[1:, 1:])
    corner = f.add_subplot(main_grid[0, 0])

    corner_canvas = PIL.Image.new('RGB', (resolution, resolution), 'gray')
    mid_canvas = PIL.Image.new('RGB', (resolution * w, resolution * h), 'yellow')
    col_canvas = PIL.Image.new('RGB', (resolution * w, resolution), 'blue')
    row_canvas = PIL.Image.new('RGB', (resolution, resolution * h), 'red')

    corner.imshow(corner_canvas)
    col.imshow(col_canvas)
    row.imshow(row_canvas)
    mid.imshow(mid_canvas)

    plt.savefig('fig.png')

如你所见 此处形状不匹配,使得网格不对齐.任何解决方法,产生一个参考的风格的图像将是巨大的!我试图使用matplotlib创建一个图像的网格。

python image matplotlib grid python-imaging-library
1个回答
0
投票

我会使用以下组合 GridSpecGridSpecFromSubplotSpec 对于这种布局。

Nx = 2
Ny = 3
sp = 0.5

fig = plt.figure()
gs0 = matplotlib.gridspec.GridSpec(2,2, width_ratios=[1,Nx+1], height_ratios=[1,Ny+1], wspace=sp, hspace=sp, figure=fig)
gs00 = matplotlib.gridspec.GridSpecFromSubplotSpec(1,Nx,subplot_spec=gs0[0,1:], wspace=0, hspace=0)
gs01 = matplotlib.gridspec.GridSpecFromSubplotSpec(Ny,1,subplot_spec=gs0[1:,0], wspace=0, hspace=0)
gs11 = matplotlib.gridspec.GridSpecFromSubplotSpec(Ny,Nx, subplot_spec=gs0[1:,1:], wspace=0, hspace=0)



top_axes = [fig.add_subplot(gs00[i]) for i in range(Nx)]
left_axes = [fig.add_subplot(gs01[i]) for i in range(Ny)]
center_axes = [fig.add_subplot(gs11[j,i]) for j in range(Ny) for i in range(Nx)]

enter image description here

© www.soinside.com 2019 - 2024. All rights reserved.