国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

python實現簡單神經網絡算法

2020-01-04 15:43:27
字體:
來源:轉載
供稿:網友

python實現簡單神經網絡算法,供大家參考,具體內容如下

python實現二層神經網絡

包括輸入層和輸出層

import numpy as np  #sigmoid function def nonlin(x, deriv = False):   if(deriv == True):     return x*(1-x)   return 1/(1+np.exp(-x))  #input dataset x = np.array([[0,0,1],        [0,1,1],        [1,0,1],        [1,1,1]])  #output dataset y = np.array([[0,0,1,1]]).T  np.random.seed(1)  #init weight value syn0 = 2*np.random.random((3,1))-1  for iter in xrange(100000):   l0 = x             #the first layer,and the input layer    l1 = nonlin(np.dot(l0,syn0))  #the second layer,and the output layer     l1_error = y-l1    l1_delta = l1_error*nonlin(l1,True)    syn0 += np.dot(l0.T, l1_delta) print "outout after Training:" print l1 
import numpy as np  #sigmoid function def nonlin(x, deriv = False):   if(deriv == True):     return x*(1-x)   return 1/(1+np.exp(-x))  #input dataset x = np.array([[0,0,1],        [0,1,1],        [1,0,1],        [1,1,1]])  #output dataset y = np.array([[0,0,1,1]]).T  np.random.seed(1)  #init weight value syn0 = 2*np.random.random((3,1))-1  for iter in xrange(100000):   l0 = x             #the first layer,and the input layer    l1 = nonlin(np.dot(l0,syn0))  #the second layer,and the output layer     l1_error = y-l1    l1_delta = l1_error*nonlin(l1,True)    syn0 += np.dot(l0.T, l1_delta) print "outout after Training:" print l1 

這里,
l0:輸入層

l1:輸出層

syn0:初始權值

l1_error:誤差

l1_delta:誤差校正系數

func nonlin:sigmoid函數

python,神經網絡

可見迭代次數越多,預測結果越接近理想值,當時耗時也越長。

python實現三層神經網絡

包括輸入層、隱含層和輸出層

import numpy as np  def nonlin(x, deriv = False):   if(deriv == True):     return x*(1-x)   else:     return 1/(1+np.exp(-x))  #input dataset X = np.array([[0,0,1],        [0,1,1],        [1,0,1],        [1,1,1]])  #output dataset y = np.array([[0,1,1,0]]).T  syn0 = 2*np.random.random((3,4)) - 1 #the first-hidden layer weight value syn1 = 2*np.random.random((4,1)) - 1 #the hidden-output layer weight value  for j in range(60000):   l0 = X            #the first layer,and the input layer    l1 = nonlin(np.dot(l0,syn0)) #the second layer,and the hidden layer   l2 = nonlin(np.dot(l1,syn1)) #the third layer,and the output layer     l2_error = y-l2    #the hidden-output layer error    if(j%10000) == 0:     print "Error:"+str(np.mean(l2_error))    l2_delta = l2_error*nonlin(l2,deriv = True)    l1_error = l2_delta.dot(syn1.T)   #the first-hidden layer error    l1_delta = l1_error*nonlin(l1,deriv = True)    syn1 += l1.T.dot(l2_delta)   syn0 += l0.T.dot(l1_delta) print "outout after Training:" print l2 
import numpy as np  def nonlin(x, deriv = False):   if(deriv == True):     return x*(1-x)   else:     return 1/(1+np.exp(-x))  #input dataset X = np.array([[0,0,1],        [0,1,1],        [1,0,1],        [1,1,1]])  #output dataset y = np.array([[0,1,1,0]]).T  syn0 = 2*np.random.random((3,4)) - 1 #the first-hidden layer weight value syn1 = 2*np.random.random((4,1)) - 1 #the hidden-output layer weight value  for j in range(60000):   l0 = X            #the first layer,and the input layer    l1 = nonlin(np.dot(l0,syn0)) #the second layer,and the hidden layer   l2 = nonlin(np.dot(l1,syn1)) #the third layer,and the output layer     l2_error = y-l2    #the hidden-output layer error    if(j%10000) == 0:     print "Error:"+str(np.mean(l2_error))    l2_delta = l2_error*nonlin(l2,deriv = True)    l1_error = l2_delta.dot(syn1.T)   #the first-hidden layer error    l1_delta = l1_error*nonlin(l1,deriv = True)    syn1 += l1.T.dot(l2_delta)   syn0 += l0.T.dot(l1_delta) print "outout after Training:" print l2 

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到python教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 日土县| 周宁县| 沅江市| 彭山县| 韶关市| 临沭县| 罗源县| 五家渠市| 镇安县| 德昌县| 渝北区| 南宁市| 赣榆县| 攀枝花市| 秦皇岛市| 上蔡县| 阜宁县| 石狮市| 黄龙县| 鲁甸县| 时尚| 德兴市| 宜良县| 石景山区| 鹿邑县| 凤山县| 洪湖市| 长海县| 乌拉特中旗| 牡丹江市| 大丰市| 南川市| 科技| 洞口县| 抚顺市| 宁国市| 子长县| 基隆市| 肃南| 朝阳区| 庆阳市|