日日噜噜噜夜夜爽亚洲精品_欧美视频在线观看一区_久久久久久久久久久久久久久99_成人在线视频网站_国产丝袜美腿一区二区三区_亚洲黄页视频免费观看_国产成+人+综合+亚洲欧洲_日韩一级精品视频在线观看_欧美激情极品视频_亚洲精品国产精品国自产在线

首頁 | 資訊 | 財經 | 公益 | 彩店 | 奇聞 | 速遞 | 前瞻 | 提點 | 網站相關 | 科技 | 熱點 | 生活 |
什么是神經網絡?用代碼示例解析其工作原理|每日播報

發稿時間:2023-06-23 17:24:36 來源: 博客園


【資料圖】

本文由gpt4輔助撰寫(gptschools.cn)
神經網絡是一種模仿人腦神經元工作原理的計算模型,用于實現機器學習和人工智能系統。它由一系列相互連接的神經元(也稱為節點或單元)組成,這些神經元組織成不同的層。神經網絡通常包括輸入層、一個或多個隱藏層和輸出層。每個節點根據其輸入數據和相應的權重計算輸出值,并通過激活函數進行非線性轉換。 神經網絡可以通過學習和調整權重實現自適應,從而在處理復雜問題(如圖像識別、自然語言處理和游戲策略等)時具有很高的靈活性。訓練神經網絡的過程通常包括使用大量輸入數據和期望輸出,計算損失函數(用于衡量網絡輸出與期望輸出之間的差距),并使用優化算法(如梯度下降法)調整權重以最小化損失。 神經網絡是深度學習的核心組成部分,深度學習模型通常包含多個隱藏層,從而能夠學習更復雜數學表示和抽象概念。?下面以一個簡單的神經網絡(用于解決 XOR 問題)為例,說明神經網絡中的各個概念。該神經網絡示例中,包含一個輸入層(2個節點),一個隱藏層(2個節點)和一個輸出層(1個節點)。輸入輸出層之間以及隱藏層與輸出層之間的所有節點均相互連接。激活函數為 Sigmoid 函數。上述神經網絡的python實現如下:
import numpy as np# Sigmoid 激活函數def sigmoid(x):    return 1 / (1 + np.exp(-x))# 使用 sigmoid 導數進行非線性變換以及反向傳播計算梯度def sigmoid_derivative(x):    return x * (1 - x)def mse_loss(y_true, y_pred):    return np.mean(np.square(y_true - y_pred))class NeuralNetwork:    def __init__(self, input_nodes, hidden_nodes, output_nodes):        self.input_nodes = input_nodes        self.hidden_nodes = hidden_nodes        self.output_nodes = output_nodes        self.weights_ih = np.random.rand(self.input_nodes, self.hidden_nodes) - 0.5        self.weights_ho = np.random.rand(self.hidden_nodes, self.output_nodes) - 0.5        self.bias_h = np.random.rand(1, self.hidden_nodes) - 0.5        self.bias_o = np.random.rand(1, self.output_nodes) - 0.5    def feedforward(self, input_data):        hidden = sigmoid(np.dot(input_data, self.weights_ih) + self.bias_h)        output = sigmoid(np.dot(hidden, self.weights_ho) + self.bias_o)        return hidden, output    def backward(self, input_data, hidden, output, target_data, learning_rate=0.1):        # 計算損失函數的梯度        output_error = target_data - output        output_delta = output_error * sigmoid_derivative(output)        hidden_error = np.dot(output_delta, self.weights_ho.T)        hidden_delta = hidden_error * sigmoid_derivative(hidden)        self.weights_ho += learning_rate * np.dot(hidden.T, output_delta)        self.weights_ih += learning_rate * np.dot(input_data.T, hidden_delta)        self.bias_o += learning_rate * np.sum(output_delta, axis=0)        self.bias_h += learning_rate * np.sum(hidden_delta, axis=0)    # 根據輸入輸出數據,訓練多輪,更新神經網絡的權重和偏置,最終得到正確的神經網絡參數    def train(self, input_data, target_data, epochs, learning_rate=0.5):        for _ in range(epochs):            hidden, output = self.feedforward(input_data)            self.backward(input_data, hidden, output, target_data, learning_rate)if __name__ == "__main__":    # 示例    X = np.array([[0, 0], [0, 1], [1, 0], [1, 1]])    Y = np.array([[0], [1], [1], [0]])    nn = NeuralNetwork(input_nodes=2, hidden_nodes=2, output_nodes=1)    print("Before training:")    _, output = nn.feedforward(X)    print(output)    nn.train(X, Y, epochs=2000, learning_rate=0.8)    print("After training:")    _, output = nn.feedforward(X)    print(output)    # 計算損失    loss = mse_loss(Y, output)    print("Loss:", loss)
首先,創建 XOR 問題的輸入和輸出數據集,分別存儲在 NumPy 數組中初始化權重與偏置然后,根據輸入輸出數據,訓練2000輪每輪訓練都會通過反向傳播更新各層的權重和偏置,最終得到正確的神經網絡參數上述簡單示例中,涉及到如下神經網絡基本概念:前向傳播:利用若干個權重系數矩陣W,偏倚向量b來和輸入值向量x進行一系列線性運算和激活運算,從輸入層開始,一層層的向后計算,一直到運算到輸出層,得到輸出結果為值激活函數:(Activation Function)是一種在神經網絡中使用的非線性函數,用于將神經元的累積輸入值轉換為輸出值。激活函數的主要目的是引入非線性特性,使得神經網絡能夠學習并表示復雜的數據模式。如果沒有激活函數,神經網絡將僅僅是一個線性回歸模型,無法處理復雜的問題。反向傳播:核心思想是通過優化權重與偏置,從而逐漸減小預測輸出與真實值之間的差距,提高神經網絡的性能。反向傳播過程開始于計算輸出層的誤差,即預測輸出與實際目標之間的差值。然后,這個誤差將從輸出層向后傳播到隱藏層。為了更新神經網絡中的權重,我們需要計算損失函數相對于每個權重的梯度。我們使用鏈式法則(chain rule)將這些梯度分解為前一層的輸出、當前層的梯度和后一層的梯度。通過這種方式,我們可以得到每個權重的梯度,并用它們更新權重以最小化損失。損失函數:損失函數值在訓練過程中起到的作用是衡量模型預測結果與實際目標值之間的差距。在反向傳播過程中,我們實際上是通過損失函數的梯度來調整神經網絡的權重和偏置,從而使得損失值最小化。在上面的代碼示例中,我們計算了輸出層的誤差(output_error),這個誤差實際上就是損失函數的梯度。這里的損失函數是均方誤差(MSE),計算梯度的公式為:
output_error = target_data - output
在反向傳播過程中,我們通過該梯度來更新權重和偏置,以使得損失值最小化。因此,損失值在訓練過程中起到了關鍵作用。其中,Sigmoid 函數是一種常用的激活函數,用于神經網絡中對節點輸出進行非線性轉換。Sigmoid 函數的數學表達式如下:
sigmoid(x) = 1 / (1 + e^(-x))
其中,x 是輸入值,e 是自然常數(約等于 2.71828)。Sigmoid 函數的輸出值范圍在 0 和 1 之間,具有平滑的 S 形曲線。當輸入值 x 趨向于正無窮大時,函數值接近 1;當輸入值 x 趨向于負無窮大時,函數值接近 0。因此,Sigmoid 函數可以將任意實數輸入映射到 (0, 1) 區間內,使得網絡輸出具有更好的解釋性。此外,Sigmoid 函數的導數也可以方便地用其函數值表示,便于進行梯度下降優化算法。然而,Sigmoid 函數也存在一些問題,例如梯度消失問題。當輸入值過大或過小時,Sigmoid 函數的梯度(導數)接近于 0,導致權重更新非常緩慢,從而影響訓練速度和效果。因此,在深度學習中,有時會選擇其他激活函數,如 ReLU(線性整流單元)等。另外,偏置(bias)的引入是為了增加模型的表達能力。具體來說,在 Sigmoid 激活函數中,偏置的作用如下:調整激活函數的輸出:在神經網絡中,激活函數(如 Sigmoid 函數)用于對節點的線性加權和進行非線性轉換。偏置相當于一個常數值,可以使得激活函數的輸出在整體上向上或向下平移。這樣,激活函數可以在不同區域內保持對輸入的敏感性,提高模型的擬合能力。提高模型的靈活性:加入偏置后,神經網絡可以學習到更復雜的表示。偏置參數使神經網絡能夠在沒有輸入(或輸入為零)時產生非零輸出。如果沒有偏置,即使權重參數不同,神經元在輸入為零時的輸出也將相同。因此,引入偏置為神經網絡提供了額外的自由度,使其能夠更好地擬合復雜的數據。以 Sigmoid 函數為例,一個神經元的輸出可以表示為:output = sigmoid(w1 * x1 + w2 * x2 + ... + wn * xn + b)這里,w1、w2、...、wn 是輸入數據(x1、x2、...、xn)對應的權重,b 是偏置。通過調整偏置 b 的值,可以使 Sigmoid 函數的輸出整體上升或下降,從而改變神經元的激活閾值。這使神經網絡能夠更好地適應不同的數據分布,提高模型的泛化能力。FAQs梯度與函數導數的關系?梯度與導數密切相關,但它們有一些區別。對于單變量函數(即只有一個自變量的函數),梯度就是導數。導數表示該函數在某一點處的切線斜率。對于多變量函數(即有多個自變量的函數),梯度是一個向量,包含了函數在某一點處沿著各個坐標軸方向的偏導數。換句話說,梯度是一個向量,它將多個偏導數組合在一起,描述了多變量函數在各個方向上的變化情況。梯度的方向是函數在該點處變化最快的方向,梯度的大小表示函數在該點處的變化速率。總結一下:對于單變量函數,梯度就是導數。對于多變量函數,梯度是一個包含所有偏導數的向量。 AI Advisor公眾號:?參考什么是神經網絡?深度神經網絡(DNN)

標簽:

責任編輯:mb01

網站首頁 | 關于我們 | 免責聲明 | 聯系我們

生活晚報網版權所有

Copyright @ 1999-2017 m.islamic-portal.net All Rights Reserved豫ICP備2022016495號-7

聯系郵箱:939 674 669@qq.com    

日日噜噜噜夜夜爽亚洲精品_欧美视频在线观看一区_久久久久久久久久久久久久久99_成人在线视频网站_国产丝袜美腿一区二区三区_亚洲黄页视频免费观看_国产成+人+综合+亚洲欧洲_日韩一级精品视频在线观看_欧美激情极品视频_亚洲精品国产精品国自产在线
中文久久乱码一区二区| 一区二区三区在线视频观看 | 日韩欧美国产系列| 在线看国产一区二区| 同产精品九九九| 亚洲一区影音先锋| 国产精品免费久久| 国精产品一区一区三区mba桃花| 久久久久99精品一区| 97se亚洲国产综合自在线| 久久亚洲二区三区| 日韩精品一区二区三区在线播放| 亚洲地区一二三色| 国产精品萝li| 亚洲精品日日夜夜| 亚洲一卡二卡三卡四卡无卡久久| 欧美sm极限捆绑bd| 日本中文字幕一区二区有限公司| 国产精品免费免费| 94色蜜桃网一区二区三区| 国产日韩欧美精品综合| 国产一区二区三区免费在线观看| 91亚洲精品久久久蜜桃| 奇米一区二区三区| 国产精品污www在线观看| 精品电影一区二区| 国产精品夫妻自拍| 丝袜亚洲另类欧美| 日韩女优电影在线观看| 亚洲sss视频在线视频| 国产91色综合久久免费分享| 精品国产一区二区三区久久久蜜月 | 日韩成人午夜精品| 日本中文字幕一区二区视频| 91激情在线视频| 日韩视频一区在线观看| 久久激五月天综合精品| 日韩女优制服丝袜电影| 国精产品一区一区三区mba桃花| 欧美激情综合五月色丁香| 不卡欧美aaaaa| 久久精品二区亚洲w码| 欧美—级在线免费片| 日韩限制级电影在线观看| 亚洲天堂免费在线观看视频| 91网站在线观看视频| 欧美无人高清视频在线观看| 99免费精品在线| 欧美久久一二三四区| 日本网站在线观看一区二区三区| 日韩欧美在线观看一区二区三区| 亚洲韩国一区二区三区| 亚洲国产高清在线观看视频| 欧美老肥妇做.爰bbww视频| 一区二区三区精品在线观看| 日本va欧美va精品发布| 国产精品乱码一区二三区小蝌蚪| 首页亚洲欧美制服丝腿| caoporm超碰国产精品| 日韩一区二区三区视频在线| 日本精品免费观看高清观看| 精品女同一区二区| 亚洲婷婷综合久久一本伊一区| 欧美亚洲一区二区三区四区| 678五月天丁香亚洲综合网| 久久久久国产成人精品亚洲午夜 | 日韩一级高清毛片| 大桥未久av一区二区三区中文| 风间由美一区二区三区在线观看| 久久亚洲影视婷婷| 中文字幕在线不卡视频| 毛片一区二区三区| 日本韩国精品在线| 亚洲另类在线制服丝袜| 国产成人一级电影| 亚洲免费观看高清完整版在线 | 中文字幕一区二区三区色视频| 成人在线一区二区三区| 日韩高清不卡在线| 亚洲成在人线在线播放| 国产精品每日更新在线播放网址| 欧美色综合网站| 成人网在线播放| 欧美精品一区二区三区在线| 国产精品毛片a∨一区二区三区| 欧美色精品天天在线观看视频| 久久久精品免费网站| 亚洲国产日韩a在线播放| 国产aⅴ综合色| 亚洲日本免费电影| 一区二区三区日韩欧美| 亚洲欧美综合色| 图片区小说区国产精品视频| 日韩精品一区二区在线观看| 欧美日韩亚洲高清一区二区| 欧美一个色资源| zzijzzij亚洲日本少妇熟睡| 亚洲欧洲综合另类在线 | 国产又黄又大久久| 韩国精品在线观看| 91亚洲精品一区二区乱码| 欧美sm美女调教| 亚洲免费观看高清完整版在线观看熊 | 97精品久久久午夜一区二区三区| 色老汉一区二区三区| 91热门视频在线观看| 成人黄色一级视频| 男人的天堂亚洲一区| 久久精品男人的天堂| 国产自产v一区二区三区c| 精品国产免费人成在线观看| 从欧美一区二区三区| 麻豆精品一区二区三区| 中文字幕一区二区三区蜜月| 欧洲国内综合视频| 国产精品护士白丝一区av| 国产一区二区福利视频| 欧美肥妇毛茸茸| 99精品国产热久久91蜜凸| 欧美日韩一区二区三区在线 | 久久久久久影视| 91精品国产综合久久精品麻豆| 亚洲综合色噜噜狠狠| 亚洲男人天堂av网| 国产精品国产a| 亚洲午夜免费电影| 午夜精品久久久久久久久久| 国产欧美日韩麻豆91| 99国产麻豆精品| 色综合久久综合| 亚洲欧美色一区| 91麻豆视频网站| 亚洲乱码中文字幕综合| 国产精品久久三| 午夜精品久久久久| 国产精品综合一区二区三区| 国产精品久久久久久久蜜臀| 99久久免费国产| 成人福利视频在线看| 国产激情一区二区三区| 国产真实精品久久二三区| 欧美日韩一级黄| 国产成人小视频| 成人av综合在线| 国产乱人伦精品一区二区在线观看| 五月婷婷色综合| 精品一区二区三区久久| 亚洲欧美色图小说| 亚洲品质自拍视频网站| 久久久久高清精品| 欧美日本视频在线| 日韩一区二区免费电影| 琪琪久久久久日韩精品| 久久久久成人黄色影片| 在线观看91精品国产入口| 日韩成人伦理电影在线观看| 在线看一区二区| 欧美日韩国产精选| 色婷婷久久久综合中文字幕| 中文av字幕一区| 色综合天天视频在线观看| 欧美电影免费观看高清完整版| 亚洲无线码一区二区三区| 成人黄动漫网站免费app| 欧美一级久久久久久久大片| 亚洲乱码日产精品bd| 国v精品久久久网| 亚洲国产欧美一区二区三区丁香婷| 亚洲欧美综合网| 国产日韩欧美制服另类| 国产精品网站导航| 91成人在线精品| 欧美性生活一区| 成人综合在线网站| 日韩欧美国产一区二区三区| 色综合天天性综合| 午夜精品久久一牛影视| 亚洲综合色丁香婷婷六月图片| 中文字幕av不卡| 欧美性一级生活| 亚洲色欲色欲www| 欧美日韩mp4| 成人综合婷婷国产精品久久蜜臀 | 久久国产精品第一页| 精品一区二区三区的国产在线播放| 亚洲欧美自拍偷拍色图| 成人精品视频一区二区三区 | 国产欧美日韩麻豆91| 国产精品日日摸夜夜摸av| www.亚洲精品| 国产在线乱码一区二区三区| 久久久久久久综合日本| 国产伦精品一区二区三区视频青涩 | 日韩免费一区二区| 国产伦理精品不卡| 日韩一区有码在线| 成人免费高清视频| 亚洲影院免费观看| 国产精品久久二区二区| 国产精品理论片|