Python实现之激活函数

开发 后端
激活函数(Activation Function),就是在人工神经网络的神经元上运行的函数,负责将神经元的输入映射到输出端。

 [[416737]]

本文转载自微信公众号「python与大数据分析」,作者一只小小鸟鸟。转载本文请联系python与大数据分析公众号。

激活函数(Activation Function),就是在人工神经网络的神经元上运行的函数,负责将神经元的输入映射到输出端。

如果不用激活函数,每一层输出都是上层输入的线性函数,无论神经网络有多少层,输出都是输入的线性组合,这种情况就是最原始的感知机。

如果使用的话,激活函数给神经元引入了非线性因素,使得神经网络可以任意逼近任何非线性函数,这样神经网络就可以应用到众多的非线性模型中。

  1. #!/usr/bin/env python 
  2. # -*- coding: UTF-8 -*- 
  3. #                     _ooOoo_ 
  4. #                   o8888888o 
  5. #                    88" . "88 
  6. #                 ( | -  _  - | ) 
  7. #                     O\ = /O 
  8. #                 ____/`---'\____ 
  9. #                  .' \\| |// `. 
  10. #                 / \\|||:|||// \ 
  11. #               / _|||||-:- |||||- \ 
  12. #                | | \\\ - /// | | 
  13. #              | \_| ''\---/'' | _/ | 
  14. #               \ .-\__ `-` ___/-. / 
  15. #            ___`. .' /--.--\ `. . __ 
  16. #         ."" '< `.___\_<|>_/___.' >'""
  17. #       | | : `- \`.;`\  _ /`;.`/ - ` : | | 
  18. #          \ \ `-. \_ __\ /__ _/ .-` / / 
  19. #      ==`-.____`-.___\_____/___.-`____.-'== 
  20. #                     `=---=' 
  21. ''
  22. @Project :pythonalgorithms  
  23. @File :Activationfunction.py 
  24. @Author :不胜人生一场醉@Date :2021/8/11 0:14  
  25. ''
  26. import numpy as np 
  27. from matplotlib import pyplot as plt 
  28.  
  29.  
  30. def drawpic(x, y, label=' ', title=' '): 
  31.    plt.figure(figsize=(10, 8)) 
  32.    ax = plt.gca()  # 通过gca:get current axis得到当前轴 
  33.    plt.rcParams['font.sans-serif'] = ['SimHei']  # 绘图中文 
  34.    plt.rcParams['axes.unicode_minus'] = False  # 绘图负号 
  35.    plt.plot(x, y, label=label) 
  36.  
  37.    # 设置图片的右边框和上边框为不显示 
  38.    ax.spines['right'].set_color('none'
  39.    ax.spines['top'].set_color('none'
  40.  
  41.    # 挪动x,y轴的位置,也就是图片下边框和左边框的位置 
  42.    # data表示通过值来设置x轴的位置,将x轴绑定在y=0的位置 
  43.    ax.spines['bottom'].set_position(('data', 0)) 
  44.    # axes表示以百分比的形式设置轴的位置,即将y轴绑定在x轴50%的位置 
  45.    ax.spines['left'].set_position(('axes', 0.5)) 
  46.    # ax.spines['left'].set_position(('data', 0)) 
  47.    plt.title(title) 
  48.    plt.legend(loc='upper right'
  49. plt.show() 
  50.  
  51.  
  52. if __name__ == '__main__'
  53.    std = 0.1  # 标准差为0.1 
  54.    avg = 1  # 平均值为1 
  55.    x = np.linspace(avg - 5 * std, avg + 5 * std, 100) 
  56.    y = normaldistribution(x, avg, std) 
  57.    drawpic(x, y, 'normaldistribution''normal distribution function'
  58.  
  59.    x = np.linspace(-5, 5, 100) 
  60.    y = sigmoid(x) 
  61.    drawpic(x, y, 'sigmoid''sigmoid Activation function'
  62.  
  63.    y = tanh(x) 
  64.    drawpic(x, y, 'tanh''tanh Activation function'
  65.  
  66.    y = stepfunction(x) 
  67.    drawpic(x, y, 'tanh''step Activation function'
  68.  
  69.    y = relu(x) 
  70.    drawpic(x, y, 'relu''relu Activation function'
  71.  
  72.    y = leakyrelu(x) 
  73.    drawpic(x, y, 'leakyrelu''leakyrelu Activation function'
  74.  
  75.    y = softmax(x) 
  76.    drawpic(x, y, 'softmax''softmax Activation function'
  1. # 求正态分布值,avg表示期望值,std表示标准差 
  2. def normaldistribution(x, avg=0, std=1): 
  3.    return np.exp(-(x - avg) ** 2 / (2 * std ** 2)) / (np.sqrt(2 * np.pi) * std) 
  4.    # return np.exp(-(x - avg) ** 2 / (2 * std ** 2)) / (math.sqrt(2 * math.pi) *  

  1. # Sigmoid函数 
  2. # Sigmoid函数是一个在生物学中常见的S型函数,也称为S型生长曲线。 
  3. # 在信息科学中,由于其单增以及反函数单增等性质,Sigmoid函数常被用作神经网络的阈值函数,将变量映射到0,1之间 
  4. def sigmoid(x): 
  5.    return 1 / (1 + np.power(np.e, -x)) 

  1. # Tanh函数 
  2. # Tanh是双曲函数中的一个,Tanh()为双曲正切。 
  3. # 在数学中,双曲正切“Tanh”是由基本双曲函数双曲正弦和双曲余弦推导而来。 
  4. # 函数tanh(蓝色)和函数sigmoid(橙色)一样,在其饱和区的接近于0,都容易产生后续梯度消失、计算量大的问题 
  5. def tanh(x): 
  6.    return (np.exp(x) - np.exp(-x)) / (np.exp(x) + np.exp(-x)) 

  1. # 阶跃函数 
  2. def stepfunction(x): 
  3.    return np.array(x > 0, dtype=np.int32) 

  1. # ReLU函数 
  2. # Relu激活函数(The Rectified Linear Unit),用于隐层神经元输出。 
  3. # Relu会使一部分神经元的输出为0,这样就造成了网络的稀疏性,并且减少了参数的相互依存关系,缓解了过拟合问题的发生。 
  4. def relu(x): 
  5.    return np.maximum(0, x) 

  1. # leaky ReLU函数 
  2. def leakyrelu(x): 
  3.    return np.maximum(0.01 * x, x) 

  1. # softmax函数 
  2. # softmax函数可以看做是Sigmoid函数的一般化,用于多分类神经网络输出。 
  3. def softmax(x): 
  4.    return np.exp(x) / np.sum(np.exp(x)) 

 

 

责任编辑:武晓燕 来源: python与大数据分析
相关推荐

2021-07-30 05:00:04

Python初等函数

2021-08-03 05:00:57

Python实现导数

2022-09-26 00:00:00

神经网络激活函数sigmoid

2021-07-27 05:04:12

python初等函数

2021-05-22 23:08:08

深度学习函数算法

2022-04-14 09:30:22

深度学习激活函数人工神经

2021-03-31 07:39:18

pythonHIVEUDF函数

2010-09-16 09:35:17

SQL函数

2023-04-18 15:15:06

神经网络激活函数开发

2017-11-20 05:08:16

深度学习激活函数神经网络

2010-07-05 11:38:02

SQL Server

2021-07-30 06:58:27

python实现三角函数

2020-09-04 06:32:20

Pythonshutil函数

2010-09-10 14:05:12

SQL聚合函数

2024-04-08 14:29:41

大型语言模型SwiGLU

2021-01-10 08:46:43

神经网络激活函数人工神经网络

2023-11-23 19:30:35

Python编程语言

2010-07-12 11:38:24

SQL Server函

2022-04-05 20:54:21

OpenCVPython人脸检测

2010-02-02 17:33:35

Python函数编译
点赞
收藏

51CTO技术栈公众号