Keras 中Leaky ReLU等高级激活函数的用法


Posted in Python onJuly 05, 2020

在用Keras来实现CNN等一系列网络时,我们经常用ReLU作为激活函数,一般写法如下:

from keras import layers
from keras import models
 
model = models.Sequential()
model.add(layers.Conv2D(32, (3, 3), activation='relu', input_shape=(28, 28, 1))) 
model.add(layers.MaxPooling2D((2, 2)))
model.add(layers.Conv2D(64, (3, 3), activation='relu')) 
model.add(layers.MaxPooling2D((2, 2)))
model.add(layers.Conv2D(64, (3, 3), activation='relu'))

上面这段代码实现了一个基本的卷积神经网络,用ReLU作为激活函数,关于ReLU具体内容不做详细介绍。还有一些常用的主流激活函数:

softmax: 在多分类中常用的激活函数,是基于逻辑回归的。

Softplus:softplus(x)=log(1+e^x),近似生物神经激活函数,最近出现的。

Relu:近似生物神经激活函数,最近出现的。

tanh:双曲正切激活函数,也是很常用的。

sigmoid:S型曲线激活函数,最常用的。

hard_sigmoid:基于S型激活函数。

linear:线性激活函数,最简单的。

主流的激活函数可以如上述例子一样通过名称直接使用,但是还有一些复杂的激活函数如:Leaky ReLU、PReLU是不可以这样直接使用的,必须使用add方法将高级激活函数作为层(layer)来使用,举例如下:

from keras import layers
from keras import models
from keras.layers import LeakyReLU
 
model = models.Sequential()
model.add(layers.Conv2D(32, (3, 3), input_shape=(28, 28, 1)))
model.add(LeakyReLU(alpha=0.05))
model.add(layers.MaxPooling2D((2, 2))) 
 
model.add(layers.Conv2D(64, (3, 3))) 
model.add(LeakyReLU(alpha=0.05))
model.add(layers.MaxPooling2D((2, 2)))
 
model.add(layers.Conv2D(64, (3, 3))
model.add(LeakyReLU(alpha=0.05))

这里我们在卷积层中去掉激活函数的参数,并在卷积层后加入高级激活层,下面来测试:

>>model.summary()

Keras 中Leaky ReLU等高级激活函数的用法

这里从整个网络结构的结果可以看出,卷积层后确实加入了一层新的激活层,使用的是LeakyReLU函数。

补充知识:Keras 调用leaky_relu

Keras 中有leaky_relu的实现。leaky_relu被整合进了relu函数。

参考官方文档:

https://tensorflow.google.cn/api_docs/python/tf/keras/backend/relu?hl=en

Arguments
x A tensor or variable.
alpha A scalar, slope of negative section (default=0.).
max_value float. Saturation threshold.
threshold float. Threshold value for thresholded activation.

alpha(超参数)值控制负数部分线性函数的梯度。当alpha = 0 ,是原始的relu函数。当alpha >0,即为leaky_relu。

查看源码,在Keras.backbend 中,也是调用tensorflow.python.ops库nn中的leaky_relu函数实现的:

def relu(x, alpha=0., max_value=None, threshold=0):
 """Rectified linear unit.
 With default values, it returns element-wise `max(x, 0)`.
 Otherwise, it follows:
 `f(x) = max_value` for `x >= max_value`,
 `f(x) = x` for `threshold <= x < max_value`,
 `f(x) = alpha * (x - threshold)` otherwise.
 Arguments:
   x: A tensor or variable.
   alpha: A scalar, slope of negative section (default=`0.`).
   max_value: float. Saturation threshold.
   threshold: float. Threshold value for thresholded activation.
 Returns:
   A tensor.
 """

 if alpha != 0.:
  if max_value is None and threshold == 0:
   return nn.leaky_relu(x, alpha=alpha)  ##在这里调用了leaky_relu

  if threshold != 0:
   negative_part = nn.relu(-x + threshold)
  else:
   negative_part = nn.relu(-x)

 clip_max = max_value is not None

 if threshold != 0:
  # computes x for x > threshold else 0
  x = x * math_ops.cast(math_ops.greater(x, threshold), floatx())
 elif max_value == 6:
  # if no threshold, then can use nn.relu6 native TF op for performance
  x = nn.relu6(x)
  clip_max = False
 else:
  x = nn.relu(x)

 if clip_max:
  max_value = _constant_to_tensor(max_value, x.dtype.base_dtype)
  zero = _constant_to_tensor(0, x.dtype.base_dtype)
  x = clip_ops.clip_by_value(x, zero, max_value)

 if alpha != 0.:
  alpha = _to_tensor(alpha, x.dtype.base_dtype)
  x -= alpha * negative_part
 return x

以上这篇Keras 中Leaky ReLU等高级激活函数的用法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python利用有道翻译实现&quot;语言翻译器&quot;的功能实例
Nov 14 Python
python随机数分布random测试
Aug 27 Python
python 文件查找及内容匹配方法
Oct 25 Python
在pandas多重索引multiIndex中选定指定索引的行方法
Nov 16 Python
对pyqt5之menu和action的使用详解
Jun 20 Python
Python列表的切片实例讲解
Aug 20 Python
JupyterNotebook设置Python环境的方法步骤
Dec 03 Python
Python+Selenium+phantomjs实现网页模拟登录和截图功能(windows环境)
Dec 11 Python
jupyter notebook 恢复误删单元格或者历史代码的实现
Apr 17 Python
Pandas的Apply函数具体使用
Jul 21 Python
python 实现Harris角点检测算法
Dec 11 Python
Python手拉手教你爬取贝壳房源数据的实战教程
May 21 Python
Django --Xadmin 判断登录者身份实例
Jul 03 #Python
详解Python多线程下的list
Jul 03 #Python
Python 字符串池化的前提
Jul 03 #Python
Pycharm打开已有项目配置python环境的方法
Jul 03 #Python
使用Dajngo 通过代码添加xadmin用户和权限(组)
Jul 03 #Python
windows支持哪个版本的python
Jul 03 #Python
Django Form设置文本框为readonly操作
Jul 03 #Python
You might like
利用PHP和AJAX创建RSS聚合器的代码
2007/03/13 PHP
简单PHP上传图片、删除图片实现代码
2010/05/12 PHP
php 启动报错如何解决
2014/01/17 PHP
async和DOM Script文件加载比较
2014/07/20 PHP
浅谈php+phpStorm+xdebug配置方法
2015/09/17 PHP
php制作简单模版引擎
2016/04/07 PHP
php弹出提示框的是实例写法
2019/09/26 PHP
常用js脚本
2006/12/03 Javascript
由document.body和document.documentElement想到的
2009/04/13 Javascript
JS+CSS实现大气清新的滑动菜单效果代码
2015/10/22 Javascript
JS实现超简洁网页title标题跑动闪烁提示效果代码
2015/10/23 Javascript
原生js和jQuery实现淡入淡出轮播效果
2015/12/25 Javascript
js和jquery中获取非行间样式
2017/05/05 jQuery
JavaScript中document.referrer的用法详解
2017/07/04 Javascript
用JS实现根据当前时间随机生成流水号或者订单号
2018/05/31 Javascript
vue两个组件间值的传递或修改方式
2018/07/04 Javascript
vue在手机中通过本机IP地址访问webApp的方法
2018/08/15 Javascript
node.js爬取中关村的在线电瓶车信息
2018/11/13 Javascript
js获取对象,数组所有属性键值(key)和对应值(value)的方法示例
2019/06/19 Javascript
js实现页面导航层级指示效果
2020/08/25 Javascript
python基于xml parse实现解析cdatasection数据
2014/09/30 Python
Python数据结构之图的应用示例
2018/05/11 Python
对Python中列表和数组的赋值,浅拷贝和深拷贝的实例讲解
2018/06/28 Python
Python正则表达式和元字符详解
2018/11/29 Python
python将print输出的信息保留到日志文件中
2019/09/27 Python
Python 基于wxpy库实现微信添加好友功能(简洁)
2019/11/29 Python
tensorflow tf.train.batch之数据批量读取方式
2020/01/20 Python
使用python修改文件并立即写回到原始位置操作(inplace读写)
2020/06/28 Python
利用Pycharm + Django搭建一个简单Python Web项目的步骤
2020/10/22 Python
jupyter notebook快速入门及使用详解
2020/11/13 Python
Nike英国官网:Nike.com (UK)
2017/02/13 全球购物
Ellos瑞典官网:北欧地区时尚、美容和住宅领域领先的电子商务网站
2019/11/21 全球购物
澳大利亚最早和最古老的巨型游戏专家:Yardgames
2020/02/20 全球购物
自强之星事迹材料
2014/05/12 职场文书
2015年社会治安综合治理工作总结
2015/04/10 职场文书
话题作文之财富(600字)
2019/12/03 职场文书