1.简述人工智能、机器学习和深度学习三者的联系与区别。
联系:
区别:人工智能是目的,是结果。
机器学习:一种实现人工智能的方法,可以定义为:任务、训练过程、模型表现。
深度学习:是一种实现机器学习的技术,适合处理大数据。
2. 全连接神经网络与卷积神经网络的联系与区别。
区别:在全连接神经网络中,每相邻两层之间的节点都有边相连,于是会将每一层的全连接层中的节点组织成一列,这样方便显示连接结构。而对于卷积神经网络,相邻两层之间只有部分节点相连,为了展示每一层神经元的维度,一般会将每一层卷积层的节点组织成一个三维矩阵。
联系:全连接神经网络和卷积神经网络一样也是通过一层一层的节点组织起来的,他们的每一个节点都是一个神经元。
3.理解卷积计算。
以digit0为例,进行手工演算。
from sklearn.datasets import load_digits #小数据集8*8
digits = load_digits()
-33 | -27 | 14 | 3 | 6 | 27 |
-40 | -10 | 30 | -17 | -11 | 34 |
-35 | 10 | 35 | -26 | -24 | 28 |
-31 | 13 | 30 | -29 | -22 | 29 |
-33 | 6 | 22 | -28 | -4 | 33 |
-31 | -12 | 10 | -6 | 14 | 24 |
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'C:Usersmgx13Desktop1.jpg')
L = I.convert('L')
cat = np.array(I)
catg = np.array(L)
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]])
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(I)
plt.matshow(cat1)
plt.matshow(cat2)
plt.matshow(cat3)
原图:
cat1的结果
cat2的结果:
cat3的结果:
5. 安装Tensorflow,keras