使用到的库 (课前需要提前安装好):
from matplotlib import pyplot as plt
import numpy as np
import math
from sklearn import datasets
from scipy.optimize import *
import pandas as pd
推荐教学时长:10分钟
- 向量的点乘 Vector dot product
- 从公式出发不用自带函数
- 用
np.dot()
函数 - Exercise: 以下向量的点乘结果是多少呢?
- 矩阵乘法 Matrix multiplication
- 从公式出发不用自带函数
- 用
np.dot()
函数 - Exercise: 请试着计算以下两个矩阵的矩阵乘法结果
- 只有哪些矩阵可以做矩阵乘法呢? Conclusion: 矩阵乘法对于理解你马上要搭建的第一个神经网络有密不可分的关系
建议配合使用网页版 interactive demo 演示矩阵乘法过程:http://matrixmultiplication.xyz/
推荐教学时长:20分钟
感知机(Perceptron): 感知机是神经网络(深度学习)的起源算法,学习感知机的构造是通向神经网络和深度学习的一种重要思想。 感知机是 二类分类 的线性分类模型,由输入特征 x 得到输出类别 1 或 0 的函数。它只有一层输出层,一个神经元。从这个文件中我们将会学会如何将输入特征进行单个神经元的计算。 学习完了计算,我们会浅谈损失函数,梯度下降在神经网络中的作用
- Perceptron 一个神经元的计算
- activation function(weights * x + bias)
- 激活层
- 思考一下激活层对于输出结果有着什么样的影响?
- 多个神经元计算 (如果输出层有多个(> 1), 比如,两神经元呢?如何计算结果?(需要矩阵乘法的知识))
推荐教学时长:7分钟
损失函数 cost function 损失函数用来评价模型的预测值和真实值不一样的程度。 损失函数结果越小,通常模型的性能越好。 所以在机器学习问题中通常都会遇到 - 【寻找损失函数最小值问题】
简单介绍一种常用的损失函数 RMSE - root mean squared error
- 使用 numpy 函数从公式出发,计算数据集的RMSE
- 使用sklearn library 的
mean_squared_error
函数
推荐教学时长:8分钟
人工智能会帮我们最小化损失函数,让预测值变得越来越准确
- 使用网页版 interactive demo 演示神经网络训练过程:https://playground.tensorflow.org/#activation=relu&batchSize=1&dataset=gauss®Dataset=reg-plane&learningRate=0.00001®ularizationRate=0&noise=35&networkShape=&seed=0.17057&showTestData=false&discretize=true&percTrainData=50&x=true&y=true&xTimesY=false&xSquared=false&ySquared=false&cosX=false&sinX=false&cosY=false&sinY=false&collectStats=false&problem=classification&initZero=false&hideText=false
- 代码 demo,观察一下如何用python代码实现感知机的训练
perceptron_1layer.py