tf.nn.conv2d是怎样实现卷积的

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了tf.nn.conv2d是怎样实现卷积的相关的知识,希望对你有一定的参考价值。

tf.nn.conv2d(input, filter, strides, padding, use_cudnn_on_gpu=None, name=None)
12

除去name参数用以指定该操作的name,与方法有关的一共五个参数:

input:
指需要做卷积的输入图像,它要求是一个Tensor,具有[batch, in_height, in_width,
in_channels]这样的shape,具体含义是[训练时一个batch的图片数量, 图片高度, 图片宽度,
图像通道数],注意这是一个4维的Tensor,要求类型为float32和float64其中之一
filter:
相当于CNN中的卷积核,它要求是一个Tensor,具有[filter_height, filter_width, in_channels,
out_channels]这样的shape,具体含义是[卷积核的高度,卷积核的宽度,图像通道数,卷积核个数],要求类型与参数input相同,有一个地方需要注意,第三维in_channels,就是参数input的第四维
strides:卷积时在图像每一维的步长,这是一个一维的向量,长度4
padding:
string类型的量,只能是”SAME”,”VALID”其中之一,这个值决定了不同的卷积方式(后面会介绍)
use_cudnn_on_gpu:
bool类型,是否使用cudnn加速,默认为true

结果返回一个Tensor,这个输出,就是我们常说的feature map
参考技术A 傅立叶变换,表示能将满足一定条件的某个函数表示成三角函数(正弦和/或余弦函数)或者它们的积分的线性组合。在不同的研究领域,傅立叶变换具有多种不同的变体形式,如连续傅立叶变换和离散傅立叶变换。最初傅立叶分析是作为热过程的解析分析的工具被提出的。 参考技术B 神经的回答

机器学习——14 深度学习-卷积

1.简述人工智能、机器学习和深度学习三者的联系与区别。

 人工智能是研究、开发用于模拟、延伸和扩展人的智能的理论、方法、技术及应用系统的一门新的技术科学。

机器学习是一门多领域交叉学科,涉及概率论、统计学、逼近论、凸分析、算法复杂度理论等多门学科。专门研究计算机怎样模拟或实现人类的学习行为,以获取新的知识或技能,重新组织已有的知识结构使之不断改善自身的性能。它是人工智能的核心,是使计算机具有智能的根本途径。

深度学习是机器学习领域中一个新的研究方向,它被引入机器学习使其更接近于最初的目标——人工智能。深度学习是一类模式分析方法的统称,就具体研究内容而言,主要涉及三类方法:基于卷积运算的神经网络系统,即卷积神经网络;基于多层神经元的自编码神经网络;以多层自编码神经网络的方式进行预训练,进而结合鉴别信息进一步优化神经网络权值的深度置信网络。

简而言之,机器学习是一种实现人工智能的方法,深度学习是一种实现机器学习的技术。人工智能最大,次之是机器学习,最后是深度学习;人工智能包含机器学习,机器学习包含深度学习。

技术图片

 

 

 

2. 全连接神经网络与卷积神经网络的联系与区别。

  相同点:都是通过一层一层的节点组织起来的,每一个节点就是一个神经元;结构相似,卷积神经网络的输入输出以及训练的流程和全连接神经网络也基本一致。

  区别:在全连接神经网络中,每相邻两层之间的节点都有边相连,于是会将每一层的全连接层中的节点组织成一列,这样方便显示连接结构。而对于卷积神经网络,相邻两层之间只有部分节点相连,为了展示每一层神经元的维度,一般会将每一层卷积层的节点组织成一个三维矩阵。全连接神经网络和卷积神经网络的唯一区别就是神经网络相邻两层的连接方式。

3.理解卷积计算。

以digit0为例,进行手工演算。

from sklearn.datasets import load_digits #小数据集8*8

digits = load_digits()

0 0 5 13 9 1 0 0
0 0 13 15 10 15 5 0
0 3 15 2 0 11 8 0
0 4 12 0 0 8 8 0
0 5 8 0 0 9 8 0
0 4 11 0 1 12 7 0
0 2 14 5 10 12 0 0
0 0 6 13 10 0 0 0

 

 卷积核:

技术图片

 

 卷积结果:

技术图片

 

 

4.理解卷积如何提取图像特征。

读取一个图像;

以下矩阵为卷积核进行卷积操作;

显示卷积之后的图像,观察提取到什么特征。

 

1 0 -1
1 0 -1
1 0 -1

 

1 1 1
0 0 0
-1 -1 -1

 

-1 -1 -1
-1 8 -1
-1 -1 -1

 

卷积API

scipy.signal.convolve2d

tf.keras.layers.Conv2D

 源代码:

from PIL import Image
import matplotlib.pyplot as plt
import numpy as np
from scipy.signal import convolve2d

I=Image.open(r‘D:桌面机器学习截图皮卡丘.jpg‘)
L=I.convert(‘L‘)

cat=np.array(I) #原图
plt.matshow(cat)
plt.show()
catg=np.array(L) #灰质图
plt.matshow(catg)
plt.show()

k1=np.array([[1,0,-1],[1,0,-1],[1,0,-1]])   #垂直边缘检测
k2=np.array([[1,1,1],[0,0,0],[-1,-1,-1]])   #水平边缘检测
k3=np.array([[-1,-1,-1],[-1,8,-1],[-1,-1,-1]])  #中间检测

#boundary:边界填充方式,mode卷积类型
cat1=convolve2d(catg,k1,boundary=‘symm‘,mode=‘same‘)
cat2=convolve2d(catg,k2,boundary=‘symm‘,mode=‘same‘)
cat3=convolve2d(catg,k3,boundary=‘symm‘,mode=‘same‘)

plt.matshow(cat1)
plt.show()
plt.matshow(cat2)
plt.show()
plt.matshow(cat3)
plt.show()

原图:                                                                                               灰质图:

 技术图片         技术图片       

垂直边缘:                                  水平边缘:
技术图片 技术图片

 


中间检测:


技术图片

5. 安装Tensorflow,keras

参考:https://blog.csdn.net/u011119817/article/details/88309256 

 技术图片

 

 

6. 设计手写数字识别模型结构,注意数据维度的变化。

from tensorflow.keras.models import Sequential

from tensorflow.keras.layers import Dense, Flatten, Conv2D, MaxPool2D

model = tf.keras.Sequential()

model.add(Conv2D(…))

model.add(MaxPool2D(…))

...

#可以上传手动演算的每层数据结构的变化过程。model.summary() 

参考:

https://www.jianshu.com/p/afe485aa08ce

https://blog.csdn.net/junjun150013652/article/details/82217571

源代码:

# 导入相关包
from tensorflow.keras.models import Sequential
from tensorflow.keras.layers import Dense, Dropout, Flatten, Conv2D, MaxPool2D

# 建立模型
model = Sequential()
model.add(Conv2D(filters=16,kernel_size=(5, 5),padding=‘same‘,
                 input_shape=(28, 28, 1),activation=‘relu‘))  # 一层卷积
model.add(MaxPool2D(pool_size=(2, 2))) # 池化层1
model.add(Dropout(0.25))

model.add(Conv2D(filters=32,kernel_size=(5, 5),padding=‘same‘,activation=‘relu‘)) # 二层卷积
model.add(MaxPool2D(pool_size=(2, 2))) # 池化层2
model.add(Dropout(0.25))

model.add(Conv2D(filters=64,kernel_size=(5, 5),padding=‘same‘,activation=‘relu‘)) # 三层卷积

model.add(Flatten())  # 平坦层
model.add(Dense(128, activation=‘relu‘))  # 全连接层
model.add(Dropout(0.25))
model.add(Dense(10, activation=‘softmax‘)) # 激活函数

model.summary()

  每层数据结构的变化过程:

技术图片

 

 技术图片

 

以上是关于tf.nn.conv2d是怎样实现卷积的的主要内容,如果未能解决你的问题,请参考以下文章

TF-卷积函数 tf.nn.conv2d 介绍

TF-卷积函数 tf.nn.conv2d 介绍

tf.nn.conv2d 参数介绍

TensorFlow conv2d实现卷积

tf.nn的conv2d卷积与max_pool池化

tensorflow-tf.nn.conv2d卷积运算