テンソルフロー::作戦::リソースApplyCenteredRMSProp

#include <training_ops.h>

中心の RMSProp アルゴリズムに従って「*var」を更新します。

まとめ

中心RMSPropアルゴリズムは、(非中心の)2次モーメントを使用する通常のRMSPropとは対照的に、正規化に中心2次モーメント(つまり、分散)の推定値を使用します。これはトレーニングに役立つことがよくありますが、計算とメモリの点で若干高価になります。

このアルゴリズムの高密度実装では、grad が 0 であっても mg、ms、および mom が更新されますが、このスパース実装では、grad が 0 である反復では mg、ms、および mom が更新されないことに注意してください。

平均二乗 = 減衰 * 平均二乗 + (1-減衰) * 勾配 ** 2 平均勾配 = 減衰 * 平均勾配 + (1-減衰) * 勾配

デルタ = 学習率 * 勾配 / sqrt(平均二乗 + イプシロン - 平均勾配 ** 2)

mg <- rho * mg_{t-1} + (1-rho) * grad ms <- rho * ms_{t-1} + (1-rho) * grad * grad mom <- 勢い * mom_{t-1 } + lr * grad / sqrt(ms - mg * mg + イプシロン) var <- var - mom

引数:

  • スコープ:スコープオブジェクト
  • var: Variable() から取得する必要があります。
  • mg: Variable() から取得する必要があります。
  • ms: Variable() からのものである必要があります。
  • mom: Variable() からのものである必要があります。
  • lr: スケーリング係数。スカラーでなければなりません。
  • rho: 減衰率。スカラーでなければなりません。
  • イプシロン: リッジ項。スカラーでなければなりません。
  • grad: グラデーション。

オプションの属性 ( Attrsを参照):

  • use_locking: Trueの場合、var、mg、ms、および mom テンソルの更新はロックによって保護されます。それ以外の場合、動作は未定義ですが、競合が少なくなる可能性があります。

戻り値:

コンストラクターとデストラクター

ResourceApplyCenteredRMSProp (const :: tensorflow::Scope & scope, :: tensorflow::Input var, :: tensorflow::Input mg, :: tensorflow::Input ms, :: tensorflow::Input mom, :: tensorflow::Input lr, :: tensorflow::Input rho, :: tensorflow::Input momentum, :: tensorflow::Input epsilon, :: tensorflow::Input grad)
ResourceApplyCenteredRMSProp (const :: tensorflow::Scope & scope, :: tensorflow::Input var, :: tensorflow::Input mg, :: tensorflow::Input ms, :: tensorflow::Input mom, :: tensorflow::Input lr, :: tensorflow::Input rho, :: tensorflow::Input momentum, :: tensorflow::Input epsilon, :: tensorflow::Input grad, const ResourceApplyCenteredRMSProp::Attrs & attrs)

パブリック属性

operation

公共機能

operator::tensorflow::Operation () const

パブリック静的関数

UseLocking (bool x)

構造体

tensorflow:: ops:: ResourceApplyCenteredRMSProp:: Attrs

ResourceApplyCenteredRMSPropのオプションの属性セッター。

パブリック属性

手術

Operation operation

公共機能

リソースApplyCenteredRMSProp

 ResourceApplyCenteredRMSProp(
  const ::tensorflow::Scope & scope,
  ::tensorflow::Input var,
  ::tensorflow::Input mg,
  ::tensorflow::Input ms,
  ::tensorflow::Input mom,
  ::tensorflow::Input lr,
  ::tensorflow::Input rho,
  ::tensorflow::Input momentum,
  ::tensorflow::Input epsilon,
  ::tensorflow::Input grad
)

リソースApplyCenteredRMSProp

 ResourceApplyCenteredRMSProp(
  const ::tensorflow::Scope & scope,
  ::tensorflow::Input var,
  ::tensorflow::Input mg,
  ::tensorflow::Input ms,
  ::tensorflow::Input mom,
  ::tensorflow::Input lr,
  ::tensorflow::Input rho,
  ::tensorflow::Input momentum,
  ::tensorflow::Input epsilon,
  ::tensorflow::Input grad,
  const ResourceApplyCenteredRMSProp::Attrs & attrs
)

演算子::tensorflow::オペレーション

 operator::tensorflow::Operation() const 

パブリック静的関数

ロックを使用する

Attrs UseLocking(
  bool x
)