吴恩达 深度学习 神经网络 softmax adam 交叉验证

神经网络中的层 :输入层(layer 0)、隐藏层、卷积层(看情况用这个)、输出层。(参考文章

激活函数

隐藏层一般用relu函数;

输出层根据需要,二分类用sigmoid,多分类用softmax...前向传播算法参考文章
前向传播python实现
反向传播算法参考文章
用Tensorflow搭建一个神经网络参考文章

多分类问题

  1. softmax回归算法
    上图中 左二分类;右多分类

算法公式:

  1. Softmax回归算法的损失函数

Adam算法

参考文章

  • 在梯度下降中,学习率α控制着每一步的大小,如果α太小,可能会导致每一步走的太小,从而使梯度下降执行的太慢;相反,如果α太大,可能会导致每一步走的太大,从而使梯度下降来回振荡。
  • Adam算法可以自动调整α的大小 ,来保证可以用最短、最平滑的路径到达成本函数的最小值,通常它比梯度下降算法的速度要更快。
  • 在w、b参数每次改变都朝着大致相同的方向 移动时,adam算法会加大学习率α
  • 在w、b参数每次改变都不断来回振荡 时,adam算法会减小学习率α

交叉验证集


首先用训练集训练模型,之后用验证集选出最小的J,即相对最好的模型。
超参数d与 J t r a i n J_{train} Jtrain、 J c v J_{cv} Jcv的关系 :(即随着数据的增多, J t r a i n J_{train} Jtrain、 J c v J_{cv} Jcv的图)

λ如何影响 J t r a i n J_{train} Jtrain、 J c v J_{cv} Jcv :

通过最小 J c v J_{cv} Jcv,可以帮助选择一个合适的λ、d,从而帮助选择合适的模型
补充:下图中的式子为L2正则化(L1和L2正则化的区别

如何选择一个合适的λ:

从0开始,一次次的增大,找出最小的J。

学习曲线

通过画学习曲线这种可视化方式,来观察 J c v J_{cv} Jcv和 J t r a i n J_{train} Jtrain,并判断模型是否有高方差和高偏差。通过高方差、高偏差来改善模型算法。

(貌似一般不咋用,了解即可)参考文章

数据添加

  1. 加新数据
  2. 数据增强:通过旋转、缩小、方法、增加对比度、镜像变换等改变已有的训练样本,来获得一个全新的训练样本
    3. 数据合成:使用电脑上的字体,通过不同的对比度,颜色,字体进行截图得到。

迁移学习

参考文章1
参考文章2

举例:你要训练狗的图片,但你先用猫的图片进行训练模型,训练好的模型再用狗的进行训练微调模型。这就是迁移学习。

相关推荐
2501_941623326 小时前
人工智能赋能智慧农业互联网应用:智能种植、农业数据分析与产量优化实践探索》
大数据·人工智能
不爱吃糖的程序媛6 小时前
华为 CANN:昇腾 AI 的异构计算架构核心与开源生态解析
人工智能·华为·架构
AKAMAI7 小时前
从客户端自适应码率流媒体迁移到服务端自适应码率流媒体
人工智能·云计算
jinxinyuuuus7 小时前
GTA 风格 AI 生成器:跨IP融合中的“视觉语义冲突”与风格适配损失
人工智能·网络协议
如何原谅奋力过但无声7 小时前
TensorFlow 1.x常用函数总结(持续更新)
人工智能·python·tensorflow
翔云 OCR API7 小时前
人脸识别API开发者对接代码示例
开发语言·人工智能·python·计算机视觉·ocr
咚咚王者7 小时前
人工智能之数据分析 numpy:第十三章 工具衔接与迁移
人工智能·数据分析·numpy
咚咚王者7 小时前
人工智能之数据分析 numpy:第九章 数组运算(二)
人工智能·数据分析·numpy
YangYang9YangYan7 小时前
网络安全专业职业能力认证发展路径指南
大数据·人工智能·安全·web安全
aitoolhub7 小时前
精选AI设计工具测评:创新性、易用性及行业应用
人工智能·在线设计