中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Tensorflow實現部分參數梯度更新操作

發布時間:2020-09-06 08:42:39 來源:腳本之家 閱讀:181 作者:zchenack 欄目:開發技術

在深度學習中,遷移學習經常被使用,在大數據集上預訓練的模型遷移到特定的任務,往往需要保持模型參數不變,而微調與任務相關的模型層。

本文主要介紹,使用tensorflow部分更新模型參數的方法。

1. 根據Variable scope剔除需要固定參數的變量

def get_variable_via_scope(scope_lst):
  vars = []
  for sc in scope_lst:
    sc_variable = tf.get_collection(tf.GraphKeys.TRAINABLE_VARIABLES,scope=scope)
    vars.extend(sc_variable)
  return vars
 
trainable_vars = tf.trainable_variables()
no_change_scope = ['your_unchange_scope_name']
 
no_change_vars = get_variable_via_scope(no_change_scope)
 
for v in no_change_vars:
  trainable_vars.remove(v)
 
grads, _ = tf.gradients(loss, trainable_vars)
 
optimizer = tf.train.AdamOptimizer(lr)
 
train_op = optimizer.apply_gradient(zip(grads, trainable_vars), global_step=global_step)

2. 使用tf.stop_gradient()函數

在建立Graph過程中使用該函數,非常簡潔地避免了使用scope獲取參數

3. 一個矩陣中部分行或列參數更新

如果一個矩陣,只有部分行或列需要更新參數,其它保持不變,該場景很常見,例如word embedding中,一些預定義的領域相關詞保持不變(使用領域相關word embedding初始化),而另一些通用詞變化。

import tensorflow as tf
import numpy as np
 
def entry_stop_gradients(target, mask):
  mask_h = tf.abs(mask-1)
  return tf.stop_gradient(mask_h * target) + mask * target
 
mask = np.array([1., 0, 1, 1, 0, 0, 1, 1, 0, 1])
mask_h = np.abs(mask-1)
 
emb = tf.constant(np.ones([10, 5]))
 
matrix = entry_stop_gradients(emb, tf.expand_dims(mask,1))
 
parm = np.random.randn(5, 1)
t_parm = tf.constant(parm)
 
loss = tf.reduce_sum(tf.matmul(matrix, t_parm))
grad1 = tf.gradients(loss, emb)
grad2 = tf.gradients(loss, matrix)
print matrix
with tf.Session() as sess:
  print sess.run(loss)
  print sess.run([grad1, grad2])

以上這篇Tensorflow實現部分參數梯度更新操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

南部县| 遂川县| 正阳县| 满城县| 乌兰浩特市| 武川县| 靖西县| 兴宁市| 济源市| 清水河县| 安顺市| 苏尼特右旗| 台州市| 股票| 镇平县| 萨嘎县| 长治县| 江西省| 衡阳市| 宾阳县| 白玉县| 灵武市| 嘉兴市| 万年县| 响水县| 佳木斯市| 平泉县| 高阳县| 贡嘎县| 昭觉县| 新安县| 安泽县| 商都县| 蓝田县| 闸北区| 九台市| 蓬溪县| 南京市| 大庆市| 库尔勒市| 肥西县|