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

首頁 > 編程 > Python > 正文

python實現簡單神經網絡算法

2020-02-22 23:24:44
字體:
來源:轉載
供稿:網友

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實現三層神經網絡

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

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             
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 桓台县| 朔州市| 日土县| 彩票| 东兰县| 辽宁省| 南漳县| 绍兴市| 长沙县| 灵丘县| 湛江市| 孝义市| 大邑县| 河间市| 宁阳县| 永仁县| 洮南市| 河源市| 闸北区| 南漳县| 武平县| 华蓥市| 格尔木市| 宁河县| 五寨县| 霞浦县| 布拖县| 日照市| 同心县| 温州市| 瑞丽市| 龙游县| 宁陕县| 包头市| 西畴县| 通海县| 汕尾市| 漠河县| 特克斯县| 买车| 溆浦县|