深度学习--激活函数

一、阶跃函数

python 复制代码
import numpy as np
# 阶跃函数
def binary_step0(x):
    if x>0:
        return 1
    return 0

# 阶跃函数-numpy
def binary_step(x):
    return np.array(x > 0,dtype=int)

二、Sigmoid函数

python 复制代码
import numpy as np
# Sigmoid函数
def sigmoid(x):
    return 1/(1+np.exp(-x))

三、Tanh函数

python 复制代码
import numpy as np
# Tanh函数
def tanh(x):
    return np.tanh(x)

四、ReLu函数

python 复制代码
import numpy as np
# ReLu函数
def relu(x):
    return np.maximum(0,x)

# leaky ReLu函数
def leaky_relu(x,alpha=0.01):
    return np.maximum(alpha*x,x)

# pReLu 函数(alpha 可训练)   RReLu(alpha 在训练时在一个均匀分布中随机选取)
def pReLu(x,alpha):
    return np.maximum(alpha*x,x)

# ELu
def EReLu(x,alpha):
    return np.maximum(alpha*(np.exp(x)-1),x)

五、softmax函数

python 复制代码
import numpy as np
# softmax 函数
def softmax(x):
    # 二维
    if x.ndim==2:
        # 溢出处理   keepdims保持维度一致
        x=x-np.max(x,axis=1,keepdims=True)
        # 二维axis有0 1   0表示高维  1表示次维   [高维][次维]    因为对行求  那么就是次维发生变化即 axis=1
        return np.exp(x)/np.sum(np.exp(x),axis=1,keepdims=True)
    # 三维
    if x.ndim==3:
        # 对行操作  则变化最低维    对列求操作变化最高维
        return np.exp(x)/np.sum(np.exp(x),axis=2,keepdims=True)
    # 一维的axis只有0
    # 溢出处理
    x=x-np.max(x)
    return np.exp(x) / np.sum(np.exp(x), axis=0)

六、其他激活函数

七、激活函数的选择

八、整体代码

python 复制代码
import numpy as np
# 阶跃函数
def binary_step0(x):
    if x>0:
        return 1
    return 0

# 阶跃函数-numpy
def binary_step(x):
    return np.array(x > 0,dtype=int)

# Sigmoid函数
def sigmoid(x):
    return 1/(1+np.exp(-x))

# Tanh函数
def tanh(x):
    return np.tanh(x)

# ReLu函数
def relu(x):
    return np.maximum(0,x)

# leaky ReLu函数
def leaky_relu(x,alpha=0.01):
    return np.maximum(alpha*x,x)

# pReLu 函数(alpha 可训练)   RReLu(alpha 在训练时在一个均匀分布中随机选取)
def pReLu(x,alpha):
    return np.maximum(alpha*x,x)
# ELu
def EReLu(x,alpha):
    return np.maximum(alpha*(np.exp(x)-1),x)
# Swish (SiLu)
def Swish(x):
    return x/1+(np.exp(-x))


# softmax 函数
def softmax(x):
    # 二维
    if x.ndim==2:
        # 溢出处理   keepdims保持维度一致
        x=x-np.max(x,axis=1,keepdims=True)
        # 二维axis有0 1   0表示高维  1表示次维   [高维][次维]    因为对行求  那么就是次维发生变化即 axis=1
        return np.exp(x)/np.sum(np.exp(x),axis=1,keepdims=True)
    # 三维
    if x.ndim==3:
        # 对行操作  则变化最低维    对列求操作变化最高维
        return np.exp(x)/np.sum(np.exp(x),axis=2,keepdims=True)
    # 一维的axis只有0
    # 溢出处理
    x=x-np.max(x)
    return np.exp(x) / np.sum(np.exp(x), axis=0)

# softplus
def softplus(x):
    return np.log(1+np.exp(x))

# 恒等函数
def identity(x):
    return x



if __name__ == '__main__':
    arr=np.array([1,2,3,4,5,-1,-2,-3,-4,-5])
    print(binary_step(arr))
    print(sigmoid(arr))
    print(tanh(arr))
    print(relu(arr))
    print(softmax(arr))

    X = np.array([[1,2,3,4,5],[-1,-2,-3,-4,-5]])
    print(softmax(X))
相关推荐
想你依然心痛1 小时前
HarmonyOS 5.0医疗健康开发实战:构建分布式健康监测与AI预警系统
人工智能·分布式·harmonyos
阿_旭1 小时前
基于YOLO26深度学习的骑行安全检测与语音提示系统【python源码+Pyqt5界面+数据集+训练代码】
人工智能·python·深度学习·骑行安全检测
weixin_446260851 小时前
释放工作效率,Multica开源管理代理平台
人工智能·开源
xiaotao1311 小时前
阶段零:Python 安装与虚拟环境(venv / Conda)
开发语言·人工智能·python·conda
黑剑客与剑1 小时前
pycdc-studio v0.1.8,支持Pyarmor 解密
python·pycdc·pyarmor·pycdc-studio
岁岁的O泡奶1 小时前
NSSCTF_reverse_[SWPUCTF 2022 新生赛]base64——[HDCTF 2023]easy_re
经验分享·python·逆向
Rubin智造社1 小时前
04月12日AI每日参考:企业级AI入口争夺升温,舱驾融合芯片加速落地
人工智能·openai·智能体·anthropic·企业级ai·人工智能+
薛定e的猫咪1 小时前
2026 年 4 月实测:OpenAI Codex 保姆级教程,从安装到 MCP、Skills 与多智能体协作
前端·数据库·人工智能
wgzrmlrm741 小时前
Django怎么优雅发送邮件_Python配置SMTP后端实现异步通知
jvm·数据库·python
d1z8882 小时前
(二十)32天GPU测试从入门到精通-llama.cpp CPU/GPU 混合推理day18
人工智能·llama·显卡·llama.cpp