• Python中简单三层神经网络模拟实现(入门)


    Python中简单三层神经网络模拟实现

    三层神经网络模型:
    在这里插入图片描述
    这里采用少量矩阵表示,其中假设第一层的加权和表示为
    A ( 1 ) = X W ( 1 ) + B ( 1 ) {A}^{(1)}=X {W}^{(1)}+{B}^{(1)} A(1)=XW(1)+B(1)
    其中:
    A ( 1 ) = ( a 1 ( 1 ) a 2 ( 1 ) a 3 ( 1 ) ) {A}^{(1)}=(a^{(1)}_{1} \quad a^{(1)}_{2} \quad a^{(1)}_{3}) A(1)=(a1(1)a2(1)a3(1)) X = ( x 1 x 2 ) X=(x_{1} \quad x_{2}) X=(x1x2) B ( 1 ) = ( b 1 ( 1 ) b 2 ( 1 ) b 3 ( 1 ) ) {B}^{(1)}=(b^{(1)}_{1} \quad b^{(1)}_{2} \quad b^{(1)}_{3}) B(1)=(b1(1)b2(1)b3(1)) A = [ a 11 ( 1 ) a 21 ( 1 ) a 31 ( 1 ) a 12 ( 1 ) a 22 ( 1 ) a 32 ( 1 ) ] A=\left[

    a11(1)a21(1)a31(1)a12(1)a22(1)a32(1)
    \right] A=[a11(1)a12(1)a21(1)a22(1)a31(1)a32(1)]

    代码实现:

    # 三层神经网络的信号传递
    import numpy as np
    
    # 定义激活函数
    def sigmoid(x):
        a = 1 / (1+np.exp(-x))
        return a
    
    # 输入层到第1层的神经元信号传递
    X = np.array([1.0, 0.5])  # 输入层X
    W1 = np.array([[0.1, 0.3, 0.5], [0.2, 0.4, 0.6]])  # 权重
    B1 = np.array([0.1, 0.2, 0.3])  # 偏置神经元
    A1 = np.dot(X, W1) + B1  # 第一层的加权和
    Z1 = sigmoid(A1)  # 激活函数转化(将输入信号总和转化为输出信号)
    # print(Z1)  # Z1=[0.57444252 0.66818777 0.75026011] 第一层输出也为第二层输入
    
    # 第1层到第2层的神经元信号传递
    W2 = np.array([[0.1, 0.4], [0.2, 0.5], [0.3, 0.6]])  # 权重
    B2 = np.array([0.1, 0.2])  # 偏置神经元
    A2 = np.dot(Z1, W2) + B2  # 第2层的加权和
    Z2 = sigmoid(A2)  # 激活函数转化(将输入信号总和转化为输出信号)
    # print(Z2)  # Z2=[0.62624937 0.7710107 ] 第2层输出也为输出层输入
    
    # 第2层到输出层的神经元信号传递
    W3 = np.array([[0.1, 0.3], [0.2, 0.4]])  # 权重
    B3 = np.array([0.1, 0.2])  # 偏置神经元
    A3 = np.dot(Z2, W3) + B3  # 第3层的加权和
    # 这里定义恒等函数将其作为输出层激活函数
    def identify_function(x):
        return x
    Y = identify_function(A3)  # 激活函数转化
    # print(A3, '\n', Y)  # 输出层
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32

    参考文献
    《深度学习入门 基于Python的理论与实现》[日] 斋藤康毅

  • 相关阅读:
    .net中定义get请求的接口实现
    传智教育|Git实战-上线出bug,如何代码回滚?
    Mybatis映射文件中动态sql语句
    刷题之莲子的软件工程学和机械动力学以及物理热力学
    基于SSM的网络财务管理系统设计与实现
    【Python实战因果推断】35_双重差分6
    Linux系统下rar软件的安装以及如何解压文件
    c++ vscode cmake debug for mac
    【leetcode】二分法和牛顿迭代法=>69
    pytest测试框架使用基础07 fixture—parametrize获取参数的几种常用形式
  • 原文地址:https://blog.csdn.net/weixin_45272908/article/details/125417339