~~~
model = models.Sequential()
model.add(layers.Dense(64, activation='relu',input_shape=(train_data.shape[1],)))
model.add(layers.Dense(64, activation='relu'))
model.add(layers.Dense(1))
~~~
网络的**最后一层**只有一个单元,没有激活,是一个**线性层**(网络可以学会预测任意范围内的值)。
这是**标量回归**(标量回归是预测单一连续值的回归)的典型设置。
~~如果向最后一层添加sigmoid激活函数,网络只能学会预测 0~1 范围内的值~~
*****
~~~
model.compile(optimizer='rmsprop', loss='mse', metrics=['mae'])
~~~
**均方误差**(MSE,mean squared error):预测值与目标值之差的平方
**平均绝对误差**(MAE,mean absolute error):预测值与目标值之差的绝对值
*****
## **小结**
* 回归问题使用的损失函数与分类问题不同。**回归**常用的**损失函数**是**均方误差**(**MSE**)。
* 同样,回归问题使用的**评估指标**也与分类问题不同。显而易见,精度的概念不适用于回归问题。常见的回归指标是**平均绝对误差**(**MAE**)。
* 如果输入数据的**特征**具有**不同的取值范围**,应该先进行**预处理**,对每个特征**单独进行缩放**。
* 如果可用的数据很少,使用***K*折验证**可以可靠地评估模型。
* 如果可用的**训练数据很少**,最好使用**隐藏层较少**(通常只有一到两个)的小型网络,以**避免严重的过拟合**。
- 基础
- 张量tensor
- 整数序列(列表)=>张量
- 张量运算
- 张量运算的几何解释
- 层:深度学习的基础组件
- 模型:层构成的网络
- 训练循环 (training loop)
- 数据类型与层类型、keras
- Keras
- Keras 开发
- Keras使用本地数据
- fit、predict、evaluate
- K 折 交叉验证
- 二分类问题-基于梯度的优化-训练
- relu运算
- Dens
- 损失函数与优化器:配置学习过程的关键
- 损失-二分类问题
- 优化器
- 过拟合 (overfit)
- 改进
- 小结
- 多分类问题
- 回归问题
- 章节小结
- 机械学习
- 训练集、验证集和测试集
- 三种经典的评估方法
- 模型评估
- 如何准备输入数据和目标?
- 过拟合与欠拟合
- 减小网络大小
- 添加权重正则化
- 添加 dropout 正则化
- 通用工作流程
- 计算机视觉
- 卷积神经网络
- 卷积运算
- 卷积的工作原理
- 训练一个卷积神经网络
- 使用预训练的卷积神经网络
- VGG16
- VGG16详细结构
- 为什么不微调整个卷积基?
- 卷积神经网络的可视化
- 中间输出(中间激活)
- 过滤器
- 热力图
- 文本和序列
- 处理文本数据
- n-gram
- one-hot 编码 (one-hot encoding)
- 标记嵌入 (token embedding)
- 利用 Embedding 层学习词嵌入
- 使用预训练的词嵌入
- 循环神经网络
- 循环神经网络的高级用法
- 温度预测问题
- code
- 用卷积神经网络处理序列
- GRU 层
- LSTM层
- 多输入模型
- 回调函数
- ModelCheckpoint 与 EarlyStopping
- ReduceLROnPlateau
- 自定义回调函数
- TensorBoard_TensorFlow 的可视化框架
- 高级架构模式
- 残差连接
- 批标准化
- 批再标准化
- 深度可分离卷积
- 超参数优化
- 模型集成
- LSTM
- DeepDream
- 神经风格迁移
- 变分自编码器
- 生成式对抗网络
- 术语表