14 深度学习-卷积
1.简述人工智能、机器学习和深度学习三者的联系与区别。
(1)人工智能是目的,是结果;深度学习、机器学习是方法,是工具;
(2)机器学习,一种实现人工智能的方法;机器学习都可以被精准地定义为:1、任务T;2、训练过程E;3、模型表现P;
(3)深度学习则是一种实现机器学习的技术;深度学习使得机器学习能够实现众多应用,并拓展了人工智能的领域范畴。
2. 全连接神经网络与卷积神经网络的联系与区别。
联系:
(1)全连接神经网络与卷积神经网络都是通过一层一层的节点组织起来的,和全连接神经网络一样,卷积神经网络中的每一个节点就是一个神经元。
(2)卷积神经网络的输入输出以及训练的流程和全连接神经网络也基本一致。
区别:
(1)在全连接神经网络中,每相邻两层之间的节点都有边相连,于是会将每一层的全连接层中的节点组织成一列,这样方便显示连接结构。
(2)在卷积神经网络中,相邻两层之间只有部分节点相连,为了展示每一层神经元的维度,一般会将每一层卷积层的节点组织成一个三维矩阵。
3.理解卷积计算。
以digit0为例,进行手工演算。
from sklearn.datasets import load_digits #小数据集8*8
digits = load_digits()
以digit0为例,进行手工演算。
from sklearn.datasets import load_digits #小数据集8*8
digits = load_digits()
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 from scipy.signal import convolve2d import numpy as np import matplotlib.pyplot as plt from pylab import mpl mpl.rcParams[‘font.sans-serif‘] = [‘SimHei‘] image = Image.open(r"./1111.jpg") p = image.convert("L") k = np.array([[-1, 0, 1], [-2, 0, 2], [-1, 0, 1]]) 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]]) pkq0 = convolve2d(p, k, boundary=‘symm‘, mode=‘same‘) pkq1 = convolve2d(p, k1, boundary=‘symm‘, mode=‘same‘) pkq2 = convolve2d(p, k2, boundary=‘symm‘, mode=‘same‘) pkq3 = convolve2d(p, k3, boundary=‘symm‘, mode=‘same‘) plt.imshow(p) plt.title("原图片") plt.show() # 显示图片 plt.imshow(pkq0) plt.title("pkq0图片") plt.show() plt.imshow(pkq1) plt.title("pkq1图片") plt.show() plt.imshow(pkq2) plt.title("pkq2图片") plt.show() plt.imshow(pkq3) plt.title("pkq3图片") plt.show()
5. 安装Tensorflow,keras