Tensorflow常见激活函数 -- Tensorflow自学笔记10

激活函数 激活函数是用来加入非线性因素的,因为线性模型的表达能力不够。引入非线性激活函数,可使深层神经网络的表达能力更加强大。

一. 什么是优秀的激活函数?

优秀的激活函数应满足:

  1. 非线性:

激活函数非线性时,多层神经网络可逼近所有函数

  1. 可微性

优化器大多用梯度下降更新参数

  1. 单调性

当激活函数是单调的,能保证单层网络的损失函数是凸函数

  1. 近似恒等性

f(x)约等于x. 当参数初始化为随机小值时,神经网络更稳定

  1. 激活函数输出值的范围:
  1. 激活函数输出为有限值时,基于梯度的优化方法更稳定

  2. 激活函数输出为无限值时,建议调小学习率

二. 常见的激活函数

复制代码
常见的激活函数有

3.1 sigmoid

TensorFlow API: tf.math.sigmoid

优点:

  1. 输出映射在(0,1)之间,单调连续,输出范围有限,优化稳定,可用作输出层;

  2. 求导容易。

缺点:

  1. 易造成梯度消失;

  2. 输出非0均值,收敛慢;

  3. 幂运算复杂,训练时间长。

sigmoid函数可应用在训练过程中。然而,当处理分类问题作出输出时,sigmoid却无能为力。简 单地说,sigmoid函数只能处理两个类,不适用于多分类问题。而softmax可以有效解决这个问题,并 且softmax函数大都运用在神经网路中的最后一层网络中,使得值得区间在(0,1)之间,而不是二分类 的。

3.2 tanh

TensorFlow API: tf.math.tanh

优点:

  1. 比sigmoid函数收敛速度更快。

  2. 相比sigmoid函数,其输出以0为中心。

缺点

  1. 易造成梯度消失;

  2. 幂运算复杂,训练时间长。

3.3 ReLU

TensorFlow API: tf.nn.relu

优点

  1. 解决了梯度消失问题(在正区间);

  2. 只需判断输入是否大于0,计算速度快;

  3. 收敛速度远快于sigmoid和tanh,因为sigmoid和tanh涉及很多expensive的操作;

  4. 提供了神经网络的稀疏表达能力。

缺点:

  1. 输出非0均值,收敛慢;

  2. Dead ReLU问题:某些神经元可能永远不会被激活,导致相应的参数永远不能被更新。

3.4 Leaky ReLU

TensorFlow API: tf.nn.leaky_relu

理论上来讲,Leaky ReLU有ReLU的所有优点,外加不会有Dead ReLU问题,但是在实际操作当

中,并没有完全证明Leaky ReLU总是好于ReLU。

3.5 softmax

TensorFlow API: tf.nn.softmax

对神经网络全连接层输出进行变换,使其服从概率分布,即每个值都位于0,1区间且和为1。

3.6 建议

对初学者的的建议:

  1. 首选ReLU激活函数;

  2. 学习率设置较小值;

  3. 输入特征标准化,即让输入特征满足以0为均值,1为标准差的正态分布;

  4. 初始化问题:初始参数中心化,即让随机生成的参数满足以0为均值, 为标准差的正态分布。

相关推荐
兆。3 分钟前
简历高光_Agent_RAG项目描述
人工智能·langchain
Upsy-Daisy5 分钟前
Hermes Agent 学习笔记 01:一个会记忆、会学习、能长期运行的 AI Agent
人工智能·笔记·学习
小雨下雨的雨5 分钟前
五子棋AI在鸿蒙PC Electron上的实现的原理与实践
人工智能·游戏·华为·electron·harmonyos·鸿蒙
AI科技星6 分钟前
基于奇合数边界的离散解析数论与双螺旋宇大统一体系(中英文双语纯净终稿)
人工智能·线性代数·架构·概率论·学习方法
Swift社区7 分钟前
异构协同,算力重构:CPU+GPU架构下的AI推理优化
人工智能·重构·架构
调试优选官8 分钟前
2026上海AI搜索GEO排名优化:技术路径与服务能力解析
人工智能·ai·geo·上海
AI分享猿11 分钟前
编程教育的新篇章:AI工具如何改变教学方式
人工智能
Tiansan666613 分钟前
AI问答推广:郑州本地企业如何用技术提升40%转化率
人工智能·ai问答推广郑州本地
玩转单片机与嵌入式15 分钟前
AI 推理会不会堵住实时任务?MCU 上跑模型时,RTOS 和 DMA 该怎么配合?
人工智能·单片机·嵌入式硬件
张彦峰ZYF16 分钟前
LangGraph 条件边:让 AI Agent 学会“做选择”
人工智能·大模型·langgraph