一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術(shù)及教程分享平臺!
分類導(dǎo)航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務(wù)器之家 - 腳本之家 - Python - python實(shí)現(xiàn)隨機(jī)梯度下降(SGD)

python實(shí)現(xiàn)隨機(jī)梯度下降(SGD)

2020-12-25 00:23芳草碧連天lc Python

這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)隨機(jī)梯度下降SGD,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

使用神經(jīng)網(wǎng)絡(luò)進(jìn)行樣本訓(xùn)練,要實(shí)現(xiàn)隨機(jī)梯度下降算法。這里我根據(jù)麥子學(xué)院彭亮老師的講解,總結(jié)如下,(神經(jīng)網(wǎng)絡(luò)的結(jié)構(gòu)在另一篇博客中已經(jīng)定義):

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
def SGD(self, training_data, epochs, mini_batch_size, eta, test_data=None):
 if test_data:
  n_test = len(test_data)#有多少個測試集
  n = len(training_data)
  for j in xrange(epochs):
   random.shuffle(training_data)
   mini_batches = [
    training_data[k:k+mini_batch_size]
    for k in xrange(0,n,mini_batch_size)]
   for mini_batch in mini_batches:
    self.update_mini_batch(mini_batch, eta)
   if test_data:
    print "Epoch {0}: {1}/{2}".format(j, self.evaluate(test_data),n_test)
   else:
    print "Epoch {0} complete".format(j)

其中training_data是訓(xùn)練集,是由很多的tuples(元組)組成。每一個元組(x,y)代表一個實(shí)例,x是圖像的向量表示,y是圖像的類別。
epochs表示訓(xùn)練多少輪。
mini_batch_size表示每一次訓(xùn)練的實(shí)例個數(shù)。
eta表示學(xué)習(xí)率。
test_data表示測試集。
比較重要的函數(shù)是self.update_mini_batch,他是更新權(quán)重和偏置的關(guān)鍵函數(shù),接下來就定義這個函數(shù)。

?
1
2
3
4
5
6
7
8
9
10
def update_mini_batch(self, mini_batch,eta):
 nabla_b = [np.zeros(b.shape) for b in self.biases]
 nabla_w = [np.zeros(w.shape) for w in self.weights]
 for x,y in mini_batch:
  delta_nabla_b, delta_nable_w = self.backprop(x,y)#目標(biāo)函數(shù)對b和w的偏導(dǎo)數(shù)
  nabla_b = [nb+dnb for nb,dnb in zip(nabla_b,delta_nabla_b)]
  nabla_w = [nw+dnw for nw,dnw in zip(nabla_w,delta_nabla_w)]#累加b和w
 #最終更新權(quán)重為
 self.weights = [w-(eta/len(mini_batch))*nw for w, nw in zip(self.weights, nabla_w)]
 self.baises = [b-(eta/len(mini_batch))*nb for b, nb in zip(self.baises, nabla_b)]

這個update_mini_batch函數(shù)根據(jù)你傳入的一些數(shù)據(jù)進(jìn)行更新神經(jīng)網(wǎng)絡(luò)的權(quán)重和偏置。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

原文鏈接:http://blog.csdn.net/leichaoaizhaojie/article/details/56840328

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 变态人shou交小说 | 国产午夜亚洲精品不卡 | 丝袜足控免费网站xx动漫漫画 | 成年人视频在线 | 国产精品免费观在线 | v视影院| 国产精品玖玖玖影院 | 99热.com | 晚上禁用的十大黄台视频 | 久久成人精品免费播放 | 国产探花视频在线观看 | 荷兰精品女人性hd | 男人女人性生活视频 | 久久热这里只有 精品 | 扒开老师两片湿漉的肉 | 四虎影视e456fcom四虎影视 | 思思91精品国产综合在线 | 国产成人精品一区二三区 | 亚洲 色 欧美 爱 视频 日韩 | 96av视频在线观看 | 国产精品久久久久久久久久久威 | 精品国产日韩亚洲一区在线 | 精品99一区二区三区麻豆 | 天堂avav| 无遮免费网站在线入口 | 免费看片aⅴ免费大片 | 高清色黄毛片一级毛片 | 日韩精选视频 | 99超级碰碰成人香蕉网 | 欧美猛男同志video在线 | 99re热精品这里精品 | 亚洲老头老太hd | 欧美日本一本线在线观看 | 成版人快猫永久破解版 | 欧美伊人久久久久久久久影院 | 91香蕉国产视频 | 国产在线步兵一区二区三区 | 久久99精国产一区二区三区四区 | 日韩大片免费观看 | 紧身牛仔裤美女被啪啪久久网 | re99|