Caffe學習系列(7):solver及其配置

solver算是caffe的核心的核心,它協調著整個模型的運作。caffe程序運行必帶的一個參數就是solver配置文件。運行代碼一般為

# caffe train --solver=*_slover.prototxt

在Deep Learning中,往往loss function是非凸的,沒有解析解,我們需要通過優化方法來求解。solver的主要作用就是交替調用前向(forward)算法和后向(backward)算法來更新參數,從而最小化loss,實際上就是一種迭代的優化算法。

到目前的版本,caffe提供了六種優化算法來求解最優參數,在solver配置文件中,通過設置type類型來選擇。

  • Stochastic Gradient Descent (type: "SGD"),
  • AdaDelta (type: "AdaDelta"),
  • Adaptive Gradient (type: "AdaGrad"),
  • Adam (type: "Adam"),
  • Nesterov’s Accelerated Gradient (type: "Nesterov") and
  • RMSprop (type: "RMSProp")

?具體的每種方法的介紹,請看本系列的下一篇文章, 本文著重介紹solver配置文件的編寫。

Solver的流程:

1.?????設計好需要優化的對象,以及用于學習的訓練網絡和用于評估的測試網絡。(通過調用另外一個配置文件prototxt來進行)

2.?????通過forward和backward迭代的進行優化來跟新參數。

3.?????定期的評價測試網絡。 (可設定多少次訓練后,進行一次測試)

4.?????在優化過程中顯示模型和solver的狀態

在每一次的迭代過程中,solver做了這幾步工作:

1、調用forward算法來計算最終的輸出值,以及對應的loss

2、調用backward算法來計算每層的梯度

3、根據選用的slover方法,利用梯度進行參數更新

4、記錄并保存每次迭代的學習率、快照,以及對應的狀態。

接下來,我們先來看一個實例:

net: "examples/mnist/lenet_train_test.prototxt"
test_iter: 100
test_interval: 500
base_lr: 0.01
momentum: 0.9
type: SGD
weight_decay: 0.0005
lr_policy: "inv"
gamma: 0.0001
power: 0.75
display: 100
max_iter: 20000
snapshot: 5000
snapshot_prefix: "examples/mnist/lenet"
solver_mode: CPU

接下來,我們對每一行進行詳細解譯:

net: "examples/mnist/lenet_train_test.prototxt"

設置深度網絡模型。每一個模型就是一個net,需要在一個專門的配置文件中對net進行配置,每個net由許多的layer所組成。每一個layer的具體配置方式可參考本系列文文章中的(2)-(5)。注意的是:文件的路徑要從caffe的根目錄開始,其它的所有配置都是這樣。

也可用train_net和test_net來對訓練模型和測試模型分別設定。例如:

train_net: "examples/hdf5_classification/logreg_auto_train.prototxt"
test_net: "examples/hdf5_classification/logreg_auto_test.prototxt"

接下來第二行:

test_iter: 100

這個要與test layer中的batch_size結合起來理解。mnist數據中測試樣本總數為10000,一次性執行全部數據效率很低,因此我們將測試數據分成幾個批次來執行,每個批次的數量就是batch_size。假設我們設置batch_size為100,則需要迭代100次才能將10000個數據全部執行完。因此test_iter設置為100。執行完一次全部數據,稱之為一個epoch

test_interval: 500

測試間隔。也就是每訓練500次,才進行一次測試。

base_lr: 0.01
lr_policy: "inv"
gamma: 0.0001
power: 0.75

這四行可以放在一起理解,用于學習率的設置。只要是梯度下降法來求解優化,都會有一個學習率,也叫步長。base_lr用于設置基礎學習率,在迭代的過程中,可以對基礎學習率進行調整。怎么樣進行調整,就是調整的策略,由lr_policy來設置。

lr_policy可以設置為下面這些值,相應的學習率的計算為:

    • - fixed:  ?保持base_lr不變.
    • - step:   ?如果設置為step,則還需要設置一個stepsize, ?返回 base_lr * gamma ^ (floor(iter / stepsize)),其中iter表示當前的迭代次數
    • - exp: ?   返回base_lr * gamma ^ iter, iter為當前迭代次數
    • - inv:  ? ? 如果設置為inv,還需要設置一個power, 返回base_lr * (1 + gamma * iter) ^ (- power)
    • - multistep:?如果設置為multistep,則還需要設置一個stepvalue。這個參數和step很相似,step是均勻等間隔變化,而multistep則是根據 ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? stepvalue值變化
    • - poly:    ?學習率進行多項式誤差, 返回 base_lr (1 - iter/max_iter) ^ (power)
    • - sigmoid: 學習率進行sigmod衰減,返回 base_lr ( 1/(1 + exp(-gamma * (iter - stepsize))))

multistep示例:

base_lr: 0.01
momentum: 0.9
weight_decay: 0.0005
# The learning rate policy
lr_policy: "multistep"
gamma: 0.9
stepvalue: 5000
stepvalue: 7000
stepvalue: 8000
stepvalue: 9000
stepvalue: 9500

接下來的參數:

momentum :0.9

上一次梯度更新的權重,具體可參看下一篇文章。

type: SGD

優化算法選擇。這一行可以省掉,因為默認值就是SGD。總共有六種方法可選擇,在本文的開頭已介紹。

weight_decay: 0.0005

權重衰減項,防止過擬合的一個參數。

display: 100

每訓練100次,在屏幕上顯示一次。如果設置為0,則不顯示。

max_iter: 20000

最大迭代次數。這個數設置太小,會導致沒有收斂,精確度很低。設置太大,會導致震蕩,浪費時間。

snapshot: 5000
snapshot_prefix: "examples/mnist/lenet"

快照。將訓練出來的model和solver狀態進行保存,snapshot用于設置訓練多少次后進行保存,默認為0,不保存snapshot_prefix設置保存路徑。

還可以設置snapshot_diff,是否保存梯度值,默認為false,不保存。

也可以設置snapshot_format,保存的類型。有兩種選擇:HDF5 和BINARYPROTO ,默認為BINARYPROTO

solver_mode: CPU

設置運行模式。默認為GPU,如果你沒有GPU,則需要改成CPU,否則會出錯。

?

注意:以上的所有參數都是可選參數,都有默認值。根據solver方法(type)的不同,還有一些其它的參數,在此不一一列舉。

?

轉載于:https://www.cnblogs.com/denny402/p/5074049.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/458523.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/458523.shtml
英文地址,請注明出處:http://en.pswp.cn/news/458523.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Qt DLL總結-創建及調用QT的 DLL

目錄 Qt DLL總結【一】-鏈接庫預備知識 Qt DLL總結【二】-創建及調用QT的 DLL Qt DLL總結【三】-VS2008Qt 使用QPluginLoader訪問DLL 開發環境:VS2008Qt4.7.4 最近看了不少Qt的DLL例子,總結一下如何創建和調用QT 動態鏈接庫。 先講一下對QT動態鏈接庫的…

Unable to install pirate

真機測試的時候,報這個錯誤,主要原因就是證書的問題 xcode7以上進行的真機測試,可以沒有使用證書,xcode可以進行的傻瓜操作幫助我們完成真機測試,但是今天我進行真機測試的時候報這個錯誤,同時xcode也不進…

memmove 對同一個指針不操作

memmove 對同一個指針不操作,所以調用memmove之前不用比較兩個指針是否相同 void CTestDLLDlg::OnBnClickedButton6() {const int size 999999;char* data new char[size];memset(data, 1, size - 1);char* data1 new char[size];memset(data1, a, size - 1);clo…

.Net JIT

.Net JIT(轉) JIT 轉載于:https://www.cnblogs.com/HelloMyWorld/p/5501135.html

Hadoop HDFS概念學習系列之HDFS升級和回滾機制(十二)

不多說,直接上干貨! HDFS升級和回滾機制 作為一個大型的分布式系統,Hadoop內部實現了一套升級機制,當在一個集群上升級Hadoop時,像其他的軟件升級一樣,可能會有新的bug或一些會影響現有應用的非兼容性變更出…

TCP協議的特性

TCP協議的特性:建立連接:三次握手將數據打包成段:校驗和(CRC32)確認、重傳及超時排序:邏輯序號流量控制:滑動窗口算法擁塞控制:慢啟動和擁塞便面算法轉載于:https://blog.51cto.com/…

屬性動畫基礎之ValueAnimator

概述 屬性動畫是谷歌在android3.0(API level 11)時候給我們帶來了屬性動畫,真正意義上帶來了”動畫“,以前的幀動畫也就4中效果的組合(旋轉、淡入淡出、放大縮小、平移),而且只是表面的動畫&…

經驗之談:10位頂級PHP大師的開發原則

導讀:在Web開發世界里,PHP是最流行的語言之一,從PHP里,你能夠很容易的找到你所需的腳本,遺憾的是,很少人會去用“最佳做法”去寫一個PHP程序。這里,我們向大家介紹PHP的10種最佳實踐&#xff0c…

#Pragma Pack(n)與內存分配 pragma pack(push,1)與#pragma pack(1)的區別

from:http://blog.csdn.net/mylinx/article/details/7007309 #pragma pack(n) 解釋一: 每個特定平臺上的編譯器都有自己的默認“對齊系數”(也叫對齊模數)。程序員可以通過預編譯命令#pragma pack(n),n1,2,4,8,16來改變這一系數,…

ShowDoc的搭建

其實,官方文檔也說的很清楚了。主要貼一下我遇見的問題。環境:LNMP(LAMP沒試過,有興趣的同學可以試試,然后發出來)PHP5.3以上版本、php-mbstring模塊、php-pdo模塊、mysql數據庫克隆或者下載代碼&#xff1…

BroadcastReceiver

本文介紹Broadcast Receiver,包括幾部分內容:Broadcast Receiver概述及實例、自定義Broadcast Receiver、Broadcast Receiver的實現細節、生命周期等。 csdn貌似今天出問題了,無法上傳圖片。 資料來源:最牛網,《官方解…

如何確定VS編譯器版本--_MSC_VER || #if _MSC_VER 1000 #pragma once #endif

如何確定VS編譯器版本 _MSC_VER是MSVC編譯器的內置宏,定義了編譯器的版本,_MSC_VER 值對應版本關系 MSVC 11.0 _MSC_VER 1700 (Visual Studio 2012) MSVC 10.0 _MSC_VER 1600 (Visual Studio 2010) MSVC 9.0 _MSC_VER 1500 (Visual Studio 2008) …

NIO復習02

Selector 1. Selector(選擇器)是Java NIO中能夠檢測一到多個NIO通道,并能夠知曉通道是否為諸如讀寫事件做好準備的組件。這樣,一個單獨的線程可以管理多個channel,從而管理多個網絡連接。 2. Selector的創建&#xff1…

c/c++標準預定義宏

C標準中的一些預定義宏昨天寫代碼時需要在代碼獲取當前編譯時間,從而可動態地作為版本信息,因此用到了C標準中的一些預定義的宏。在此將C標準中定義的幾個宏一并總結一下: __DATE__ 進行預處理的日期(“Mmm dd yyyy”形式的字符串…

安裝cocoa pods時出現Operation not permitted - /usr/bin/xcodeproj的問題

在更新完ruby,更換Ruby鏡像--淘寶的那個鏡像(https://ruby.taobao.org/ )已經不可用了。官方的需要FQ。所以我們現在用最新支持的ruby鏡像(https://gems.ruby-china.org/) 安裝cocoa pods時, 在命令行中輸入: 安裝&…

js 日期控件laydate使用

官網 http://sentsin.com/layui/laydate/ 1. 下載官網上的壓縮包,解壓后只需要復制laydate 文件夾到你的項目中; 2. 在頁面引入 <script type"text/javascript" src"js/laydate/laydate.js"></script> 3. 在頁面添加: <div class"i…

老李推薦:第8章2節《MonkeyRunner源碼剖析》MonkeyRunner啟動運行過程-解析處理命令行參數 2...

我們這一節會先去分析下monkeyrunner是如何對參數進行處理的&#xff0c;我們跳轉到MonkeyRunnerOptions這個類里面的processOptions這個方法&#xff1a; 93 public static MonkeyRunnerOptions processOptions(String[] args) 94 { 95 int index 0; 96 97 Strin…