IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 多层神经网络实验 -> 正文阅读

[人工智能]多层神经网络实验

本次实验受益匪浅,下面附代码详解?

from sklearn import datasets
import numpy as np
import matplotlib.pyplot as plt
from sklearn.linear_model import Perceptron #感知机
from sklearn.neural_network import MLPClassifier #多层神经网络

from warnings import simplefilter
simplefilter(action='ignore', category=FutureWarning)

plt.rcParams['font.sans-serif'] = ['SimHei']
plt.rcParams['axes.unicode_minus']=False  # 用来正常显示负号

# 定义一个layer
class Layer:
    def __init__(self):
        pass
    #前向计算
    def forward(self, input):  #前向计算
        return input
    #反向传播
    def backward(self, input, grad_output):
        pass
class ReLU(Layer):
    pass
# 定义Sigmoid层
class Sigmoid(Layer):
    def __init__(self):
        pass
    
    def _sigmoid(self,x):
        return 1.0/(1+np.exp(-x))
    
    def forward(self,input):
        return self._sigmoid(input)
    
    #求偏导,反向传播,grad_output 是上一层反馈的梯度乘积
    def backward(self,input,grad_output):
        sigmoid_grad = self._sigmoid(input)*(1-self._sigmoid(input))
        return grad_output*sigmoid_grad
#隐藏层
class Dense(Layer):
    def __init__(self, input_units, output_units, learning_rate=0.5):
        self.learning_rate = learning_rate #学习率
        self.weights = np.random.randn(input_units, output_units)
#         self.weights = np.random.randn(input_units, output_units)*0.01    #初始化影响很大,权重w矩阵类型
        self.biases = np.zeros(output_units) #偏置取决于神经元个数
    def forward(self,input):
        return np.dot(input,self.weights)+self.biases #矩阵乘积结果为An
    
    #重点中的重点,这个函数你读懂了,那神经网络你就彻底入门了。这个函数是我们神经网络,任督二脉!
    def backward(self,input,grad_output):
        grad_input = np.dot(grad_output, self.weights.T) #J对a的偏导
        grad_weights = np.dot(input.T,grad_output)/input.shape[0] #J对w的偏导并加权平均
        grad_biases = grad_output.mean(axis=0) #J对b的偏导加权平均
        self.weights = self.weights - self.learning_rate*grad_weights #更新权重w
        self.biases = self.biases - self.learning_rate*grad_biases #更新偏移量b
        return grad_input #返回J对a的偏导给下一层让他再次反向梯度

class MLPClassifier:
    def __init__(self):
        self.network = [] #列表存神经元个数
        self.network.append(Dense(2,5)) #输入两个隐藏层神经元个数5
        self.network.append(Sigmoid()) #激活函数sigmoid
        self.network.append(Dense(5,1)) #输出层,5个输入转化为1个输出
        self.network.append(Sigmoid()) #输出结果二分类问题
        self.lost=[]
    def forward(self,X):
        self.activations = [] #保存每一层输出
        input = X
        for layer in self.network: #针对每一层进行前项计算
            self.activations.append(layer.forward(input)) #进行前向计算
            input = self.activations[-1] #当前激活层输出作为下一层输入
                
        assert len(self.activations) == len(self.network)
        return self.activations #返回每一层输出

    def predict(self,X): #将sigmod值二值化
        y_pred = self.forward(X)[-1] 
        y_pred[y_pred>0.5]  = 1 
        y_pred[y_pred<=0.5] = 0
        return y_pred

    def predict_proba(self,X): #返回最终值不进行二值化
        logits = self.forward(X)[-1]
        return logits

    def _train(self,X,y):   
        #先前向计算,再反向传播,梯度下降更新权重参数w,b
        self.forward(X)
        layer_inputs = [X]+self.activations   #每一层值
        logits = self.activations[-1] #输出值an
    
        # 这里的损失函数需要自己定义 
        loss = np.square(logits - y.reshape(-1,1)).sum() #损失函数
        loss_grad = 2.0*(logits-y.reshape(-1,1)) #j对an求偏导
        
        for layer_i in range(len(self.network))[::-1]:
            layer = self.network[layer_i] #拿到当前层
            loss_grad = layer.backward(layer_inputs[layer_i],loss_grad) #grad w.r.t. input, also weight updates
            #返回损失函数平均值
        return np.mean(loss)
    def train(self, X, y):
        for e in range(1000): #进行一千次计算损失函数
            loss = self._train(X,y)
            self.lost.append(loss)
            print(loss)
        return self

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-03-21 20:50:48  更:2022-03-21 20:51:31 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 1:53:07-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码