Pytorch:CNN理论基础

目录

一、图象基础知识

1、图像的构成

2、图像的分类

3、拓展知识

4、图像的加载方法

二、卷积神经网络概述

1、什么是卷积神经网络?

2、卷积神经网络的组成

3、CNN概述

三、卷积层

1、卷积计算

2、padding(填充)

3、stride(步长)

4、多通道卷积计算

5、多卷积核计算

6、特征图大小

7、卷积层API

四、池化层

1、池化层的作用

2、池化分类

3、池化层API


CNN = 卷积神经网络(Convolutional Neural Network)

一、图象基础知识

1、图像的构成

由像素点构成

2、图像的分类
  1. 灰度图像(单通道)
  • 只有 1 个通道
  • 每个像素:0~255
    • 0 = 纯黑
    • 255 = 纯白
  • 形状:H,W 高 × 宽
  1. 彩色图像(RGB 三通道)
  • R 红、G 绿、B 蓝 3 个通道
  • 每个通道像素值:0~255
  • 形状:H,W,C 高 × 宽 × 通道数
3、拓展知识
  • PyTorch 格式:B,C,H,W 批次、通道、高、宽
  • 黑白图不是只有黑色白色,是深浅灰色组成
  • 彩色图 = 三张灰度图叠加(R/G/B 各一张)

总结速记版:

图片由像素组成,灰度单通道,RGB 三通道,数值 0 到 255,矩阵存储。

4、图像的加载方法

plt.imread()

plt.imshow()

二、卷积神经网络概述

1、什么是卷积神经网络?

**卷积神经网络(Convolutional Neural Network)**是含有卷积层的神经网络. 卷积层的作用就是用来自动学习、提取图像的特征。

2、卷积神经网络的组成

CNN网络主要由三部分构成:卷积层、池化层和全连接层构成:

卷积层负责提取图像中的局部特征;

池化层用来大幅降低参数量级(降维);

全连接层用来输出想要的结果。

3、CNN概述

CNN要做的事情是:

给定一张图片,是车还是马未知,是什么车也未知,现在需要模型判断这张图片里具体是一个什么东西,总之输出一个结果:如果是车 那是什么车

最左边是 数据输入层:对数据做一些处理,比如去均值(各维度都减对应维度的均值,使得输入数据各个维度都中心化为0,避免数据过多偏差,影响训练效果)、归一化(把所有的数据都归一到同样的范围)、PCA等等。CNN只对训练集做"去均值"这一步。

中间是 卷积层(CONV):线性乘积求和,提取图像中的局部特征

激励层(RELU):ReLU激活函数,输入数据转换成输出数据

池化层(POOL):取区域平均值或最大值,大幅降低参数量级(降维) 最右边是

全连接层(FC):输出CNN模型预测结果

功能总结:

卷积层:特征提取

池化层:降维

全连接层:得到输出结果

三、卷积层

1、卷积计算

输入通过滤波器得到输出:

计算一下参数用二维表示:

11=4 = 1*1 +1*0 +1*1 + 0*0+1*1 +1+0 +0*1 +0*0 +1+1=4

22=4= 1*1 + 1*0 + 1+1 +0*1 +1*1 +1*0 + 0*1 + 1*0 +1*1 =4

可以根据示意图计算一下其他位置的数据验证。

2、padding(填充)

padding(填充)操作用于处理卷积时图像边缘的像素。 其目的是在输入图像的边界周围添加额外的像素(通常是零),从而解决卷积操作时边缘信息丢失的问题。

3、stride(步长)

stride(步长)指的是卷积核在图像上滑动时的步伐大小,即每次卷积时卷积核在图像中向右(或向下)移动的像素数。步长直接影响卷积操作后输出特征图的尺寸,以及计算量和模型的特征提取能力。

4、多通道卷积计算
5、多卷积核计算
6、特征图大小

输出特征图的大小与以下参数息息相关:

size: 卷积核/过滤器大小,一般会选择为奇数,比如有 1*1 、3*3、5*5

Padding: 零填充的方式

Stride: 步长

那计算方法如下图所示:

输入图像大小: W x W

卷积核大小: F x F

Stride: S

Padding:

P 输出图像大小: N x N

计算公式:

计算示例:

以下图为例:

图像大小: 5 x 5

卷积核大小: 3 x 3

Stride: 1

Padding: 1

(5 - 3 + 2) / 1 + 1 = 5, 即得到的特征图大小为: 5 x 5

7、卷积层API
python 复制代码
conv = nn.Conv2d(in_channels, out_channels, kernel_size, stride, padding)
"""
参数说明:
in_channels: 输入通道数,
out_channels: 输出通道,也可以理解为卷积核kernel的数量
kernel_size:卷积核的高和宽设置,一般为3,5,7...
stride:卷积核移动的步长
padding:在四周加入padding的数量,默认补0
"""

四、池化层

1、池化层的作用

池化层 (Pooling) 降低维度, 从而减少计算量、减少内存消耗,并提高模型的鲁棒性。

2、池化分类

(1) 最大池化

(2)平均池化

3、池化层API
python 复制代码
# 最大池化
nn.MaxPool2d(kernel_size=2, stride=2, padding=1)
# 平均池化
nn.AvgPool2d(kernel_size=2, stride=1, padding=0)
相关推荐
KaMeidebaby8 分钟前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
Cloud_Shy6189 分钟前
解读《Effective Python 3rd Edition》:从练气到老魔(第五章 Item 30 - 32)
开发语言·人工智能·笔记·python·学习方法
YueTann11 分钟前
OpenRLHF设计
人工智能
云烟成雨TD13 分钟前
Spring AI 1.x 系列【52】可观测集成 SkyWalking
人工智能·spring·skywalking
云烟成雨TD13 分钟前
Spring AI 1.x 系列【57】动态工具发现:Tool Search Tool
java·人工智能·spring
AndrewHZ14 分钟前
【LLM技术全景】规模定律与模型演进:为什么模型越大越强?
人工智能·gpt·深度学习·语言模型·llm·openai·规模定律
galaxylove14 分钟前
Gartner发布创新洞察:AI SOC智能体加速通信运营商安全运营转型
大数据·人工智能·安全
甩手网软件24 分钟前
Shopee2026新规:费率重构与履约收紧下,卖家如何破局?
大数据·人工智能
数据库小学妹26 分钟前
AI时代数据库怎么选?多模融合、数据统一存储与选型实战指南
数据库·人工智能·经验分享·ai
lizhihai_9933 分钟前
股市学习心得-AI 产业链核心标的梳理清单
大数据·服务器·人工智能·科技·学习