解讀keras中的正則化(regularization)問題
keras中正則化(regularization)
keras內(nèi)置3種正則化方法
keras.regularizers.l1(lambda) keras.regularizers.l2(lambda) keras.regularizers.l1_l2(l1=lambda1, l2=lambda2)
目前我的理解是lambda越大,對(duì)參數(shù)的約束就越強(qiáng),也就是懲罰力度越大。
其中L1正則化方法,是對(duì)|w|進(jìn)行懲罰,使得w趨近0
而L2正則化方法,是對(duì)w2進(jìn)行懲罰,使得w盡可能小
Dense,Conv1D,Conv2D,Conv3D有統(tǒng)一的正則化API,見keras中文文檔。
3個(gè)正則化關(guān)鍵字
1. kernel_regularizer
對(duì)權(quán)值進(jìn)行正則化,大多數(shù)情況下使用這個(gè)
2. bias_regularizer
限制bias的大小,使得輸入和輸出接近
3. activity_regularizer
對(duì)輸出進(jìn)行正則化,使得輸出盡量小
keras中添加正則化
正則項(xiàng)
正則項(xiàng)在優(yōu)化過程中層的參數(shù)或?qū)拥募せ钪堤砑討土P項(xiàng),這些懲罰項(xiàng)將與損失函數(shù)一起作為網(wǎng)絡(luò)的最終優(yōu)化目標(biāo)
懲罰項(xiàng)基于層進(jìn)行懲罰,目前懲罰項(xiàng)的接口與層有關(guān),但Dense, Conv1D, Conv2D, Conv3D具有共同的接口。
這些層有三個(gè)關(guān)鍵字參數(shù)以施加正則項(xiàng):
kernel_regularizer:施加在權(quán)重上的正則項(xiàng),為keras.regularizer.Regularizer對(duì)象bias_regularizer:施加在偏置向量上的正則項(xiàng),為keras.regularizer.Regularizer對(duì)象activity_regularizer:施加在輸出上的正則項(xiàng),為keras.regularizer.Regularizer對(duì)象
例子
from keras import regularizers model.add(Dense(64, input_dim=64, ? ? ? ? ? ? ? ? kernel_regularizer=regularizers.l2(0.01), ? ? ? ? ? ? ? ? activity_regularizer=regularizers.l1(0.01)))
可用正則項(xiàng)
keras.regularizers.l1(0.) keras.regularizers.l2(0.) keras.regularizers.l1_l2(0.)
開發(fā)新的正則項(xiàng)
任何以權(quán)重矩陣作為輸入并返回單個(gè)數(shù)值的函數(shù)均可以作為正則項(xiàng),示例:
from keras import backend as K ? def l1_reg(weight_matrix): ? ? return 0.01 * K.sum(K.abs(weight_matrix)) ? model.add(Dense(64, input_dim=64, ? ? ? ? ? ? ? ? kernel_regularizer=l1_reg)
可參考源代碼keras/regularizer.py
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python的shutil模塊中文件的復(fù)制操作函數(shù)詳解
shutil被定義為Python中的一個(gè)高級(jí)的文件操作模塊,擁有比os模塊中更強(qiáng)大的函數(shù),這里我們就來看一下Python的shutil模塊中文件的復(fù)制操作函數(shù)詳解2016-07-07
pandas篩選某列出現(xiàn)編碼錯(cuò)誤的解決方法
今天小編就為大家分享一篇pandas篩選某列出現(xiàn)編碼錯(cuò)誤的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-11-11
Boston數(shù)據(jù)集預(yù)測(cè)放假及應(yīng)用優(yōu)缺點(diǎn)評(píng)估
這篇文章主要為大家介紹了Boston數(shù)據(jù)集預(yù)測(cè)放假及應(yīng)用優(yōu)缺點(diǎn)評(píng)估,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10
利用Python?Matlab繪制曲線圖的簡(jiǎn)單實(shí)例
們經(jīng)常會(huì)遇到這種情況,有一個(gè)數(shù)學(xué)函數(shù),我們希望了解他的圖像,這個(gè)時(shí)候使用python 的matplotlib就可以幫助我們,下面這篇文章主要介紹了利用Python?Matlab繪制曲線圖的相關(guān)資料,需要的朋友可以參考下2021-12-12
Pytorch使用Visdom進(jìn)行數(shù)據(jù)可視化的示例代碼
pytorch Visdom可視化,是一個(gè)靈活的工具,用于創(chuàng)建,組織和共享實(shí)時(shí)豐富數(shù)據(jù)的可視化,這個(gè)博客簡(jiǎn)要介紹一下在使用Pytorch進(jìn)行數(shù)據(jù)可視化的一些內(nèi)容,感興趣的朋友可以參考下2023-12-12
python executemany的使用及注意事項(xiàng)
這篇文章主要介紹了python executemany的使用及注意事項(xiàng),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-03-03
Perl中著名的Schwartzian轉(zhuǎn)換問題解決實(shí)現(xiàn)
這篇文章主要介紹了Perl中著名的Schwartzian轉(zhuǎn)換問題解決實(shí)現(xiàn),本文詳解講解了Schwartzian轉(zhuǎn)換涉及的排序問題,并同時(shí)給出實(shí)現(xiàn)代碼,需要的朋友可以參考下2015-06-06
python?argparse的使用步驟(全網(wǎng)最全)
argparse是python的一個(gè)命令行參數(shù)解析包,在代碼需要頻繁修改參數(shù)時(shí),方便使用,主要用法就是在命令行輸入自己想要修改的參數(shù),這篇文章主要介紹了python?argparse的使用步驟(全網(wǎng)最全),需要的朋友可以參考下2023-04-04
opencv3/C++ 平面對(duì)象識(shí)別&透視變換方式
今天小編就為大家分享一篇opencv3/C++ 平面對(duì)象識(shí)別&透視變換方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-12-12

