一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

用Python從頭實現(xiàn)一個神經(jīng)網(wǎng)絡來理解神經(jīng)網(wǎng)絡的原理4

jf_78858299 ? 來源:機器學習雜貨店 ? 作者:機器學習雜貨店 ? 2023-02-27 15:06 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

***14 ***代碼:一個完整的神經(jīng)網(wǎng)絡

我們終于可以實現(xiàn)一個完整的神經(jīng)網(wǎng)絡了:

圖片

圖片

import numpy as np
defsigmoid(x):# Sigmoid activation function: f(x) = 1 / (1 + e^(-x)) return 1 / (1 + np.exp(-x))
defderiv_sigmoid(x): # Derivative of sigmoid: f'(x) = f(x) * (1 - f(x)) fx = sigmoid(x) return fx * (1 - fx)
defmse_loss(y_true, y_pred): # y_true和y_pred是相同長度的numpy數(shù)組。 return ((y_true - y_pred) ** 2).mean()
classOurNeuralNetwork: ''' A neural network with: - 2 inputs - a hidden layer with 2 neurons (h1, h2) - an output layer with 1 neuron (o1)
*** 免責聲明 ***: 下面的代碼是為了簡單和演示,而不是最佳的。 真正的神經(jīng)網(wǎng)絡代碼與此完全不同。不要使用此代碼。 相反,讀/運行它來理解這個特定的網(wǎng)絡是如何工作的。 ''' def__init__(self): # 權(quán)重,Weights self.w1 = np.random.normal() self.w2 = np.random.normal() self.w3 = np.random.normal() self.w4 = np.random.normal() self.w5 = np.random.normal() self.w6 = np.random.normal()
# 截距項,Biases self.b1 = np.random.normal() self.b2 = np.random.normal() self.b3 = np.random.normal()
deffeedforward(self, x): # X是一個有2個元素的數(shù)字數(shù)組。 h1 = sigmoid(self.w1 * x[0] + self.w2 * x[1] + self.b1) h2 = sigmoid(self.w3 * x[0] + self.w4 * x[1] + self.b2) o1 = sigmoid(self.w5 * h1 + self.w6 * h2 + self.b3) return o1
deftrain(self, data, all_y_trues): ''' - data is a (n x 2) numpy array, n = # of samples in the dataset. - all_y_trues is a numpy array with n elements. Elements in all_y_trues correspond to those in data. ''' learn_rate = 0.1 epochs = 1000 # 遍歷整個數(shù)據(jù)集的次數(shù)
for epoch in range(epochs): for x, y_true in zip(data, all_y_trues): # --- 做一個前饋(稍后我們將需要這些值) sum_h1 = self.w1 * x[0] + self.w2 * x[1] + self.b1 h1 = sigmoid(sum_h1)
sum_h2 = self.w3 * x[0] + self.w4 * x[1] + self.b2 h2 = sigmoid(sum_h2)
sum_o1 = self.w5 * h1 + self.w6 * h2 + self.b3 o1 = sigmoid(sum_o1) y_pred = o1
# --- 計算偏導數(shù)。 # --- Naming: d_L_d_w1 represents "partial L / partial w1" d_L_d_ypred = -2 * (y_true - y_pred)
# Neuron o1 d_ypred_d_w5 = h1 * deriv_sigmoid(sum_o1) d_ypred_d_w6 = h2 * deriv_sigmoid(sum_o1) d_ypred_d_b3 = deriv_sigmoid(sum_o1)
d_ypred_d_h1 = self.w5 * deriv_sigmoid(sum_o1) d_ypred_d_h2 = self.w6 * deriv_sigmoid(sum_o1)
# Neuron h1 d_h1_d_w1 = x[0] * deriv_sigmoid(sum_h1) d_h1_d_w2 = x[1] * deriv_sigmoid(sum_h1) d_h1_d_b1 = deriv_sigmoid(sum_h1)
# Neuron h2 d_h2_d_w3 = x[0] * deriv_sigmoid(sum_h2) d_h2_d_w4 = x[1] * deriv_sigmoid(sum_h2) d_h2_d_b2 = deriv_sigmoid(sum_h2)
# --- 更新權(quán)重和偏差 # Neuron h1 self.w1 -= learn_rate * d_L_d_ypred * d_ypred_d_h1 * d_h1_d_w1 self.w2 -= learn_rate * d_L_d_ypred * d_ypred_d_h1 * d_h1_d_w2 self.b1 -= learn_rate * d_L_d_ypred * d_ypred_d_h1 * d_h1_d_b1
# Neuron h2 self.w3 -= learn_rate * d_L_d_ypred * d_ypred_d_h2 * d_h2_d_w3 self.w4 -= learn_rate * d_L_d_ypred * d_ypred_d_h2 * d_h2_d_w4 self.b2 -= learn_rate * d_L_d_ypred * d_ypred_d_h2 * d_h2_d_b2
# Neuron o1 self.w5 -= learn_rate * d_L_d_ypred * d_ypred_d_w5 self.w6 -= learn_rate * d_L_d_ypred * d_ypred_d_w6 self.b3 -= learn_rate * d_L_d_ypred * d_ypred_d_b3
# --- 在每次epoch結(jié)束時計算總損失 if epoch % 10 == 0: y_preds = np.apply_along_axis(self.feedforward, 1, data) loss = mse_loss(all_y_trues, y_preds) print("Epoch %d loss: %.3f" % (epoch, loss))
# 定義數(shù)據(jù)集data = np.array([ [-2, -1], # Alice [25, 6], # Bob [17, 4], # Charlie [-15, -6], # Diana])all_y_trues = np.array([ 1, # Alice 0, # Bob 0, # Charlie 1, # Diana])
# 訓練我們的神經(jīng)網(wǎng)絡!network = OurNeuralNetwork()network.train(data, all_y_trues)
隨著網(wǎng)絡的學習,損失在穩(wěn)步下降。

圖片

現(xiàn)在我們可以用這個網(wǎng)絡來預測性別了:

# 做一些預測emily = np.array([-7, -3]) # 128 磅, 63 英寸frank = np.array([20, 2])  # 155 磅, 68 英寸print("Emily: %.3f" % network.feedforward(emily)) # 0.951 - Fprint("Frank: %.3f" % network.feedforward(frank)) # 0.039 - M

*15 ***** 接下來?

搞定了一個簡單的神經(jīng)網(wǎng)絡,快速回顧一下:

  • 介紹了神經(jīng)網(wǎng)絡的基本結(jié)構(gòu)——神經(jīng)元;
  • 在神經(jīng)元中使用S型激活函數(shù);
  • 神經(jīng)網(wǎng)絡就是連接在一起的神經(jīng)元;
  • 構(gòu)建了一個數(shù)據(jù)集,輸入(或特征)是體重和身高,輸出(或標簽)是性別;
  • 學習了損失函數(shù)和均方差損失;
  • 訓練網(wǎng)絡就是最小化其損失;
  • 用反向傳播方法計算偏導;
  • 用隨機梯度下降法訓練網(wǎng)絡;

接下來你還可以:

  • 機器學習庫實現(xiàn)更大更好的神經(jīng)網(wǎng)絡,例如TensorFlow、Keras和PyTorch;
  • 其他類型的激活函數(shù);
  • 其他類型的優(yōu)化器;
  • 學習卷積神經(jīng)網(wǎng)絡,這給計算機視覺領域帶來了革命;
  • 學習遞歸神經(jīng)網(wǎng)絡,常用于自然語言處理;
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 神經(jīng)網(wǎng)絡

    關(guān)注

    42

    文章

    4812

    瀏覽量

    103213
  • 神經(jīng)元
    +關(guān)注

    關(guān)注

    1

    文章

    368

    瀏覽量

    18795
  • python
    +關(guān)注

    關(guān)注

    56

    文章

    4825

    瀏覽量

    86458
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    人工神經(jīng)網(wǎng)絡原理及下載

    這個網(wǎng)絡輸入和相應的輸出來“訓練”這個網(wǎng)絡,網(wǎng)絡根據(jù)輸入和輸出不斷地調(diào)節(jié)自己的各節(jié)點之間的權(quán)值滿足輸入和輸出。這樣,當訓練結(jié)束后,我們給定
    發(fā)表于 06-19 14:40

    labview BP神經(jīng)網(wǎng)絡實現(xiàn)

    請問:我在用labview做BP神經(jīng)網(wǎng)絡實現(xiàn)故障診斷,在NI官網(wǎng)找到了機器學習工具包(MLT),但是里面沒有關(guān)于這部分VI的幫助文檔,對于”BP神經(jīng)網(wǎng)絡分類“這個范例有很多不懂的地方,比如
    發(fā)表于 02-22 16:08

    【PYNQ-Z2試用體驗】神經(jīng)網(wǎng)絡基礎知識

    神經(jīng)網(wǎng)絡的計算。對于多層多節(jié)點的神經(jīng)網(wǎng)絡,我們可以使用矩陣乘法表示。在上面的神經(jīng)網(wǎng)絡中,我們將權(quán)重作為
    發(fā)表于 03-03 22:10

    卷積神經(jīng)網(wǎng)絡如何使用

    卷積神經(jīng)網(wǎng)絡(CNN)究竟是什么,鑒于神經(jīng)網(wǎng)絡在工程上經(jīng)歷了曲折的歷史,您為什么還會在意它呢? 對于這些非常中肯的問題,我們似乎可以給出相對簡明的答案。
    發(fā)表于 07-17 07:21

    【案例分享】ART神經(jīng)網(wǎng)絡與SOM神經(jīng)網(wǎng)絡

    今天學習了兩神經(jīng)網(wǎng)絡,分別是自適應諧振(ART)神經(jīng)網(wǎng)絡與自組織映射(SOM)神經(jīng)網(wǎng)絡。整體感覺不是很難,只不過些最基礎的概念容易
    發(fā)表于 07-21 04:30

    人工神經(jīng)網(wǎng)絡實現(xiàn)方法有哪些?

    人工神經(jīng)網(wǎng)絡(Artificial Neural Network,ANN)是種類似生物神經(jīng)網(wǎng)絡的信息處理結(jié)構(gòu),它的提出是為了解決些非線性,非平穩(wěn),復雜的實際問題。那有哪些辦法能
    發(fā)表于 08-01 08:06

    什么是LSTM神經(jīng)網(wǎng)絡

    簡單理解LSTM神經(jīng)網(wǎng)絡
    發(fā)表于 01-28 07:16

    如何構(gòu)建神經(jīng)網(wǎng)絡?

    原文鏈接:http://tecdat.cn/?p=5725 神經(jīng)網(wǎng)絡種基于現(xiàn)有數(shù)據(jù)創(chuàng)建預測的計算系統(tǒng)。如何構(gòu)建神經(jīng)網(wǎng)絡?神經(jīng)網(wǎng)絡包括:輸入層:根據(jù)現(xiàn)有數(shù)據(jù)獲取輸入的層隱藏層:使用反
    發(fā)表于 07-12 08:02

    matlab實現(xiàn)神經(jīng)網(wǎng)絡 精選資料分享

    神經(jīng)神經(jīng)網(wǎng)絡,對于神經(jīng)網(wǎng)絡實現(xiàn)是如何直沒有具體實現(xiàn)
    發(fā)表于 08-18 07:25

    基于BP神經(jīng)網(wǎng)絡的PID控制

    最近在學習電機的智能控制,上周學習了基于單神經(jīng)元的PID控制,這周研究基于BP神經(jīng)網(wǎng)絡的PID控制。神經(jīng)網(wǎng)絡具有任意非線性表達能力,可以通過對系統(tǒng)性能的學習
    發(fā)表于 09-07 07:43

    卷積神經(jīng)網(wǎng)絡維卷積的處理過程

    inference在設備端上做。嵌入式設備的特點是算力不強、memory小??梢酝ㄟ^對神經(jīng)網(wǎng)絡做量化降load和省memory,但有時可能memory還吃緊,就需要對神經(jīng)網(wǎng)絡在memory使用上做進
    發(fā)表于 12-23 06:16

    Python從頭實現(xiàn)神經(jīng)網(wǎng)絡理解神經(jīng)網(wǎng)絡的原理1

    事情可能會讓初學者驚訝:神經(jīng)網(wǎng)絡模型并不復雜!『神經(jīng)網(wǎng)絡』這個詞讓人覺得很高大上,但實際上神經(jīng)網(wǎng)絡算法要比人們想象的簡單。 這篇文章完全是為新手準備的。我們會通過
    的頭像 發(fā)表于 02-27 15:05 ?936次閱讀
    <b class='flag-5'>用</b><b class='flag-5'>Python</b><b class='flag-5'>從頭</b><b class='flag-5'>實現(xiàn)</b><b class='flag-5'>一</b><b class='flag-5'>個</b><b class='flag-5'>神經(jīng)網(wǎng)絡</b><b class='flag-5'>來</b><b class='flag-5'>理解</b><b class='flag-5'>神經(jīng)網(wǎng)絡</b>的原理1

    Python從頭實現(xiàn)神經(jīng)網(wǎng)絡理解神經(jīng)網(wǎng)絡的原理2

    事情可能會讓初學者驚訝:神經(jīng)網(wǎng)絡模型并不復雜!『神經(jīng)網(wǎng)絡』這個詞讓人覺得很高大上,但實際上神經(jīng)網(wǎng)絡算法要比人們想象的簡單。 這篇文章完全是為新手準備的。我們會通過
    的頭像 發(fā)表于 02-27 15:06 ?832次閱讀
    <b class='flag-5'>用</b><b class='flag-5'>Python</b><b class='flag-5'>從頭</b><b class='flag-5'>實現(xiàn)</b><b class='flag-5'>一</b><b class='flag-5'>個</b><b class='flag-5'>神經(jīng)網(wǎng)絡</b><b class='flag-5'>來</b><b class='flag-5'>理解</b><b class='flag-5'>神經(jīng)網(wǎng)絡</b>的原理2

    Python從頭實現(xiàn)神經(jīng)網(wǎng)絡理解神經(jīng)網(wǎng)絡的原理3

    事情可能會讓初學者驚訝:神經(jīng)網(wǎng)絡模型并不復雜!『神經(jīng)網(wǎng)絡』這個詞讓人覺得很高大上,但實際上神經(jīng)網(wǎng)絡算法要比人們想象的簡單。 這篇文章完全是為新手準備的。我們會通過
    的頭像 發(fā)表于 02-27 15:06 ?982次閱讀
    <b class='flag-5'>用</b><b class='flag-5'>Python</b><b class='flag-5'>從頭</b><b class='flag-5'>實現(xiàn)</b><b class='flag-5'>一</b><b class='flag-5'>個</b><b class='flag-5'>神經(jīng)網(wǎng)絡</b><b class='flag-5'>來</b><b class='flag-5'>理解</b><b class='flag-5'>神經(jīng)網(wǎng)絡</b>的原理3

    BP神經(jīng)網(wǎng)絡和人工神經(jīng)網(wǎng)絡的區(qū)別

    BP神經(jīng)網(wǎng)絡和人工神經(jīng)網(wǎng)絡(Artificial Neural Networks,簡稱ANNs)之間的關(guān)系與區(qū)別,是神經(jīng)網(wǎng)絡領域中基礎且
    的頭像 發(fā)表于 07-10 15:20 ?2203次閱讀