• Pytorch D2L Subplots方法对画图、图片处理


    问题代码

    1. def show_images(imgs, num_rows, num_cols, titles=None, scale=1.5): #@save
    2. """绘制图像列表"""
    3. figsize = (num_cols * scale, num_rows * scale)
    4. _, axes = d2l.plt.subplots(num_rows, num_cols, figsize=figsize)
    5. axes = axes.flatten()
    6. for i, (ax, img) in enumerate(zip(axes, imgs)):
    7. if torch.is_tensor(img):
    8. # 图片张量
    9. ax.imshow(img.numpy())
    10. else:
    11. # PIL图片
    12. ax.imshow(img)
    13. ax.axes.get_xaxis().set_visible(False)
    14. ax.axes.get_yaxis().set_visible(False)
    15. if titles:
    16. ax.set_title(titles[i])
    17. return axes

    d2l.plt.subplots返回值

    plt.subplots是matplotlib库中的一个函数,用于创建一个新的Figure对象,并在其中创建一个或多个子图(subplot)。
    它的基本用法是:

    fig, ax = plt.subplots(nrows=1, ncols=1, **kwargs)
    其中,nrowsncols分别指定了子图的行数和列数。如果只想创建一个子图,可以省略其中一个参数。

    返回值fig是Figure对象ax则是一个或多个子图的Axes对象(如果只创建了一个子图,则返回一个单独的Axes对象;如果创建了多个子图,则返回一个Axes对象列表)。

    kwargs是可选的关键字参数,用于设置Figure和子图的属性。例如,可以使用figsize参数设置Figure的大小,使用sharexsharey参数来共享子图的x轴和y轴。

    axes = d2l.plt.subplots(num_rows, num_cols, figsize=figsize)

    解释:

    d2l.plt.subplots创建了一个包含多个子图的网格(grid);

    num_rows和num_cols分别指定了网格中子图的行数和列数;
    figsize指定了整个图像的尺寸,即包含所有子图的画布大小。
    返回值axes是一个由网格的子图对象组成的NumPy数组。
    我们可以使用它来访问、控制和绘制每个子图。

    举例说明:

    axes是一个由子图对象组成的NumPy数组,它可以用来访问、控制和绘制每个子图。具体来说,axes是一个大小为(num_rows, num_cols)的NumPy数组,其中axes[i, j]表示第 i + 1 i+1 i+1行和第 j + 1 j+1 j+1列的子图对象。

    例如,如果我们使用以下代码创建一个包含 2 2 2行 3 3 3列子图的网格:

    1. import matplotlib.pyplot as plt
    2. import d2l
    3. figsize = (6, 4)
    4. num_rows, num_cols = 2, 3
    5. axes = d2l.plt.subplots(num_rows, num_cols, figsize=figsize)
    6. 那么`axes`将是一个大小为$(2, 3)$的NumPy数组,可以通过索引来访问每个子图对象。例如,我们可以在第$1$行第$2$列的子图中绘制一条直线:
    7. axes[0, 1].plot([0, 1], [0, 1])

    或者我们可以在所有子图中添加一个标题:

    1. for i in range(num_rows):
    2. for j in range(num_cols):
    3. axes[i, j].set_title(f'Subplot ({i+1}, {j+1})')

    原链接

    subplot()、subplots()

    subplot()、subplots()在实际过程中,先创建了一个figure画窗,然后通过调用add_subplot()来向画窗中各个分块添加坐标区,其差别在于是分次添加(subplot())还是一次性添加(subplots())

    在这里插入图片描述
    3.plt.subplots()
    语法格式:

    matplotlib.pyplot.subplots(nrows=1, ncols=1, *, sharex=False,
    sharey=False, squeeze=True,subplot_kw=None, gridspec_kw=None, **fig_kw)
    -nrows:默认为 1,设置图表的行数。
    -ncols:默认为 1,设置图表的列数。
    -sharex、sharey:设置 x、y 轴是否共享属性,默认为 false,可设置为 ‘none’、‘all’、‘row’ 或 ‘col’。 False 或 none 每个子图的 x 轴或 y 轴都是独立的,True 或 ‘all’:所有子图共享 x 轴或 y 轴,‘row’ 设置每个子图行共享一个 x 轴或 y 轴,‘col’:设置每个子图列共享一个 x 轴或 y 轴。

    1. import matplotlib.pyplot as plt
    2. import numpy as np
    3. # 创建一些测试数据
    4. x = np.linspace(0,100, 4)
    5. y = np.sin(x**2)
    6. # 创建一个画像和子图 -- 图1
    7. fig, ax = plt.subplots()
    8. ax.plot(x, y)
    9. ax.set_title('Simple plot')
    10. # 创建两个子图 -- 图2
    11. #如图figure2,四个子图中上两幅图并无x轴(与下子图共享),因为已设置sharex=True
    12. #若改为sharey=True,可观察到四副子图中右两幅无y轴(即与左子图共享)
    13. f, ([ax1, ax2],[ax3,ax4]) = plt.subplots(2, 2, sharex=True)
    14. ax1.plot(x, y)
    15. ax1.set_title('Sharing x axis')
    16. ax2.scatter(x, y)
    17. ax3.scatter(x, y)
    18. ax4.scatter(x, y)
    19. # 创建四个子图 -- 图3
    20. #通过对subplot_kw传入参数,生成关于极坐标系的子图
    21. fig, axs = plt.subplots(2, 2, subplot_kw=dict(projection="polar"))
    22. axs[0, 0].plot(x, y)
    23. axs[1, 1].scatter(x, y)
    24. plt.show()

    在这里插入图片描述

    文章来源地址

    python内置函数:zip()函数搭配enumerate函数使用,用在for循环中

    简介enumerate()

    enumerate()函数是Python的内置函数,对于一个可迭代的(iterable)/可遍历的对象(如列表、字符串),可以利用enumerate函数同时获取对象的索引和值。

    1. x=np.arange(0,100,10)
    2. for i in enumerate(x):
    3. index = i[0]; xval = i[1]
    4. print(index,xval)
    1. 0 0
    2. 1 10
    3. 2 20
    4. 3 30
    5. 4 40
    6. 5 50
    7. 6 60
    8. 7 70
    9. 8 80
    10. 9 90
    简介zip()

    zip函数是Python的内置函数,它用于将可迭代的对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的对象(即对多个序列进行并行迭代)。如果各个迭代器元素个数不一致,zip()函数则在最短序列“用完”时就会停止。

    1. sz = np.arange(1,100,10)
    2. sx = np.arange(1,10,1)
    3. for index, (szi, sxi) in enumerate(zip(sz, sx)):
    4. print(index,szi,sxi)
    1. 0 1 1
    2. 1 11 2
    3. 2 21 3
    4. 3 31 4
    5. 4 41 5
    6. 5 51 6
    7. 6 61 7
    8. 7 71 8
    9. 8 81 9

    transforms.Compose(trans)

    Compose()类会将transforms列表里面的transform操作进行遍历。实现的代码很简单:

    1. ## 这里对源码进行了部分截取。
    2. def __call__(self, img):
    3. for t in self.transforms:
    4. img = t(img)
    5. return img

    pytorch通过深度学习进行预处理图片,离不开transforms.Compose(),torchvision.datasets.ImageFolder(),torch.utils.data.DataLoader()的用法。

    源自于文章

    1.Transform.Compose()详解

    导入相应的库

    1. import torch
    2. import torchvision
    3. import matplotlib.pyplot as plt
    4. from torch.utils import data
    5. from torchvision import datasets,transforms
    6. from PIL import Image
    7. %matplotlib inline

    在这里插入图片描述

    1. class torchvision.transforms.Compose(transforms):
    2. # Composes several transforms together.
    3. # Parameters: transforms (list of Transform objects) – list of transforms to compose.
    4. Example # 可以看出Compose里面的参数实际上就是个列表,而这个列表里面的元素就是你想要执行的transform操作。
    5. >>> transforms.Compose([
    6. >>> transforms.CenterCrop(10),
    7. >>> transforms.ToTensor(),])

    展示原始图片

    1. pic = "./train/Chihuahua/n02085620_10074.jpg"
    2. img = plt.imread(pic)
    3. plt.imshow(img)

    定义图片预处理的对象。

    1. traintransform = transforms.Compose([transforms.RandomRotation(20), # 随机旋转20°
    2. transforms.ColorJitter(brightness=0.1), #随机改变图像的亮度对比度和饱和度
    3. transforms.Resize([150,150]), # 转换为需要的尺寸
    4. transforms.ToTensor(), #convert a PIL image to tensor (H*W*C)
    5. ])
    1. img1 = Image.fromarray(img) #将numpy对象的img转换为PIL格式
    2. img2 = traintransform(img1)# 图像预处理tensor
    3. img3 = transforms.ToPILImage()(img2)#转换为PIL进行展示
    4. plt.imshow(img3)

    展示处理之后的图片,可以看出,图片旋转了20°,并且大小转换为(150,150)

    附上——transforms中的函数如何使用?

    1. # Resize:把给定的图片resize到given size
    2. # Normalize:Normalized an tensor image with mean and standard deviation
    3. # ToTensor:convert a PIL image to tensor (H*W*C) in range [0,255] to a torch.Tensor(C*H*W) in the range [0.0,1.0]
    4. # ToPILImage: convert a tensor to PIL image
    5. # Scale:目前已经不用了,推荐用Resize
    6. # CenterCrop:在图片的中间区域进行裁剪
    7. # RandomCrop:在一个随机的位置进行裁剪
    8. # RandomHorizontalFlip:以0.5的概率水平翻转给定的PIL图像
    9. # RandomVerticalFlip:以0.5的概率竖直翻转给定的PIL图像
    10. # RandomResizedCrop:将PIL图像裁剪成任意大小和纵横比
    11. # Grayscale:将图像转换为灰度图像
    12. # RandomGrayscale:将图像以一定的概率转换为灰度图像
    13. # FiceCrop:把图像裁剪为四个角和一个中心
    14. # TenCrop
    15. # Pad:填充
    16. # ColorJitter:随机改变图像的亮度对比度和饱和度。

  • 相关阅读:
    es笔记三之term,match,match_phrase 等查询方法介绍
    LAMMPS小技巧
    Linux时间同步服务NTP和Chrony
    HiveSQL用户行为漏斗分析
    建模杂谈系列173 密级与交付
    开源啦!一键部署免费使用!Kubernetes上直接运行大数据平台!
    pytorch中的词性标注_seq2seq_比较naive的示例
    一文读懂存储过程
    java 泛型返回
    如何破解安全难题?另一个商用车ADAS市场窗口开启
  • 原文地址:https://blog.csdn.net/qq_19734597/article/details/134460048