成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

手把手教你用Python創建簡單的神經網絡(附代碼)

人工智能 深度學習 后端
了解神經網絡工作方式的最佳途徑莫過于親自創建一個神經網絡,本文將演示如何做到這一點。

 [[251984]]

了解神經網絡工作方式的***途徑莫過于親自創建一個神經網絡,本文將演示如何做到這一點。

神經網絡(NN)又稱人工神經網絡(ANN),是機器學習領域中基于生物神經網絡概念的學習算法的一個子集。

擁有五年以上經驗的德國機器學習專家Andrey Bulezyuk聲稱:“神經網絡正在徹底改變機器學習,因為它們能夠在廣泛的學科和行業中為抽象對象高效建模。”

人工神經網絡基本上由以下組件組成:

  •  輸入層:接收并傳遞數據
  •  隱藏層
  •  輸出層
  •  各層之間的權重
  •  每個隱藏層都有一個激活函數。在這個簡單的神經網絡Python教程中,我們將使用Sigmoid激活函數。

神經網絡有多種類型。在本項目中,我們將創建前饋或感知神經網絡。這種類型的ANN直接將數據從前向后傳遞。

前饋神經元的訓練往往需要反向傳播,它為網絡提供了相應的輸入和輸出集。當輸入數據被傳送到神經元時,經過處理后,產生一個輸出。

下面的圖表顯示了一個簡單的神經網絡的結構:

了解神經網絡如何工作的***方法是學習如何從頭開始構建神經網絡(而不是采用任何庫)。

在本文中,我們將演示如何利用Python編程語言創建一個簡單的神經網絡。

問題

如下是一個展示問題的表格。

我們將提供一個新的數據集,利用它訓練神經網絡,從而能夠預測正確的輸出值。

正如上表所示,輸出值總是等于輸入部分中的***個值。因此,我們期望輸出的值為1。

讓我們看看是否可以使用Python代碼來得出相同的結果(你可以在本文末尾仔細閱讀這個項目的代碼,然后再繼續閱讀本文)。

創建一個NeuralNetwork類

我們將用Python創建一個NeuralNetwork類來訓練神經元,以期給出準確的預測。這個類還會有其他的幫助函數。

即使我們不會在這個簡單的神經網絡示例中使用神經網絡庫,我們也將導入numpy庫來輔助計算。

numpy庫提供了以下四種重要方法:

  •  exp—用于生成自然指數
  •  array—用于生成矩陣
  •  dot—用于矩陣相乘
  •  random—用于生成隨機數。請注意,我們將生成隨機數,以確保它們的有效分布。

1. 應用Sigmoid函數

我們將使用Sigmoid函數,來繪制一個特征“S”型曲線,作為神經網絡的激活函數。

此函數可以將任何值映射到0到1之間的值,它將有助于我們對輸入的加權和歸一化。

此后,我們將創建Sigmoid函數的導數,以幫助計算權重的調整參數。

可以利用Sigmoid函數的輸出來生成它的導數。例如,如果輸出變量為“x”,則其導數為x*(1-x)。

2. 訓練模型

這是我們教神經網絡做出準確預測的階段。每個輸入都有一個權重-可為正值或負值。這意味著:有較大的正權重或負權重的輸入會對結果的輸出產生更大的影響。請記住,我們最初是通過為每個隨機數分配一個權重后開始的。

下面是這個神經網絡示例的訓練過程:

***步:從訓練數據集中提取輸入,根據訓練數據集的權重進行調整,并通過一種計算神經網絡輸出的方法對其進行篩選。

第二步:計算反向傳播錯誤率。在這種情況下,它是神經元的預測輸出與訓練數據集的期望輸出之間的差異。

第三步:利用誤差加權導數公式,根據所得到的誤差范圍,進行了一些較小的權值調整。

第四步:對這一過程進行15000次迭代。在每次迭代中,整個訓練集被同時處理。

我們使用“.T”函數將矩陣從水平位置轉換為垂直位置。因此,數字將以如下方式存儲: 

最終,神經元的權重將根據所提供的訓練數據進行優化。隨后,如果讓神經元考慮一個新的狀態,與先前的狀態相同,它便可以作出一個準確的預測。這就是反向傳播的方式。

打包運行

***,NeuralNetwork類初始化成功后,可以運行代碼了。

下面是如何在Python項目中創建神經網絡的完整代碼:   

  1. import numpy as np   
  2.     class NeuralNetwork():     
  3.         def __init__(self):  
  4.             # seeding for random number generation  
  5.             np.random.seed(1)    
  6.             #converting weights to a 3 by 1 matrix with values from -1 to 1 and mean of 0  
  7.             self.synaptic_weights = 2 * np.random.random((3, 1)) - 1     
  8.         def sigmoid(self, x):  
  9.             #applying the sigmoid function  
  10.             return 1 / (1 + np.exp(-x))    
  11.         def sigmoid_derivative(self, x):  
  12.             #computing derivative to the Sigmoid function  
  13.             return x * (1 - x)     
  14.         def train(self, training_inputs, training_outputs, training_iterations):      
  15.             #training the model to make accurate predictions while adjusting weights continually  
  16.             for iteration in range(training_iterations):  
  17.                 #siphon the training data via  the neuron  
  18.                 output = self.think(training_inputs)     
  19.                 #computing error rate for back-propagation  
  20.                 error = training_outputs - output    
  21.                 #performing weight adjustments  
  22.                 adjustments = np.dot(training_inputs.T, error * self.sigmoid_derivative(output))    
  23.                 self.synaptic_weights += adjustments     
  24.         def think(self, inputs):  
  25.             #passing the inputs via the neuron to get output     
  26.             #converting values to floats   
  27.             inputsinputs = inputs.astype(float)  
  28.             output = self.sigmoid(np.dot(inputs, self.synaptic_weights))  
  29.             return output  
  30.     if __name__ == "__main__":  
  31.         #initializing the neuron class  
  32.         neural_network = NeuralNetwork()  
  33.         print("Beginning Randomly Generated Weights: ")  
  34.         print(neural_network.synaptic_weights)  
  35.         #training data consisting of 4 examples--3 input values and 1 output  
  36.         training_inputs = np.array([[0,0,1],  
  37.                                     [1,1,1],  
  38.                                     [1,0,1],  
  39.                                     [0,1,1]])  
  40.         training_outputs = np.array([[0,1,1,0]]).T  
  41.         #training taking place  
  42.         neural_network.train(training_inputs, training_outputs, 15000)     
  43.         print("Ending Weights After Training: ")  
  44.         print(neural_network.synaptic_weights)     
  45.         user_input_one = str(input("User Input One: "))  
  46.         user_input_two = str(input("User Input Two: "))  
  47.         user_input_three = str(input("User Input Three: "))   
  48.         print("Considering New Situation: ", user_input_one, user_input_two, user_input_three)  
  49.         print("New Output data: ")  
  50.         print(neural_network.think(np.array([user_input_one, user_input_two, user_input_three])))  
  51.     print("Wow, we did it!") 

運行代碼之后的輸出: 

這樣,我們便成功地創建了一個簡單的神經網絡。

神經元首先給自己分配一些隨機權重,接著,利用訓練實例進行了自我訓練。

之后,如果出現新的狀態[1,0,0],則它得出的數值為0.9999584。

還記得我們想要的正確答案是1嗎?

這個數值非常接近,Sigmoid函數輸出值在0到1之間。 

當然,在這個例子中,我們只使用一個神經元網絡來完成簡單的任務。如果我們把幾千個人工神經網絡連接在一起,情況將會是怎樣呢?我們能不能完全模仿人類的思維方式呢? 

責任編輯:龐桂玉 來源: THU數據派
相關推薦

2021-08-09 13:31:25

PythonExcel代碼

2022-10-19 14:30:59

2017-06-23 19:08:23

大數據PyTorch自然語言

2021-12-11 20:20:19

Python算法線性

2021-02-02 13:31:35

Pycharm系統技巧Python

2021-01-30 10:37:18

ScrapyGerapy網絡爬蟲

2017-10-29 21:43:25

人臉識別

2021-05-10 06:48:11

Python騰訊招聘

2022-08-04 10:39:23

Jenkins集成CD

2011-03-28 16:14:38

jQuery

2021-02-06 14:55:05

大數據pandas數據分析

2021-02-04 09:00:57

SQLDjango原生

2009-04-22 09:17:19

LINQSQL基礎

2021-04-01 09:02:38

Python小說下載網絡爬蟲

2021-05-17 21:30:06

Python求均值中值

2021-02-10 09:34:40

Python文件的壓縮PyCharm

2021-03-23 09:05:52

PythonExcelVlookup

2020-03-08 22:06:16

Python數據IP

2012-01-11 13:40:35

移動應用云服務

2021-08-02 23:15:20

Pandas數據采集
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 91精品国产综合久久久久蜜臀 | 国产一级电影在线观看 | 午夜激情影院 | 婷婷色网| 久久不卡视频 | 亚洲福利精品 | 日韩视频国产 | 欧美色人 | 日日夜夜精品 | 久久精品视频在线观看 | 一久久久 | 久久久2o19精品| 日韩精品 | 欧美一区二区视频 | 国产一区二区在线免费观看 | 青青草一区 | 日日噜噜噜夜夜爽爽狠狠视频97 | 中文字幕在线免费 | 国产精品自产拍 | 亚洲成av片人久久久 | 午夜精品| 性一交一乱一透一a级 | 成年人在线视频 | 国产精品五区 | 欧美一级欧美三级在线观看 | 中文字幕日韩欧美 | 午夜寂寞影院在线观看 | 午夜精品视频一区 | 国产欧美一级二级三级在线视频 | 一区在线观看 | 久久国产精品视频 | 国产伦精品一区二区三区在线 | 精品综合久久久 | 日韩av黄色| 国产精品欧美精品 | 欧美a免费 | 精品区| 久一精品| 久久影音先锋 | 成人乱人乱一区二区三区软件 | 日韩欧美国产精品一区二区 |