Adafactor: Difference between revisions

From Cornell University Computational Optimization Open Textbook - Optimization Wiki
Jump to navigation Jump to search
 
(81 intermediate revisions by the same user not shown)
Line 4: Line 4:


== Introduction ==
== Introduction ==
Adafactor is an efficient, adaptive learning rate optimization algorithm proposed by Noam Shazeer and Mitchell Stern in 2018. <sup>1</sup>
Unlike traditional Adam optimizers, Adafactor does not store complete second-order moment matrices. Instead, it employs a factorization approach that only maintains gradient statistics for the rows and columns of parameter matrices, significantly reducing memory usage. Moreover, Adafactor uses an adaptive learning rate, allowing it to dynamically adjust step sizes without the need for manually setting a global learning rate or relying heavily on hyperparameter tuning. Its design also defaults to not performing bias correction, yet it remains stable in scenarios involving large-batch training data.<sup>1</sup> This efficiency makes it an ideal choice for training ultra-large-scale models such as T5.<sup>2</sup>
Adafactor’s efficient memory usage and outstanding performance make it widely applicable in scenarios such as Natural Language Processing (NLP).<sup>2</sup> Compared to the Adam optimizer, Adafactor significantly reduces memory and computational resource requirements while maintaining comparable performance when training large-scale language models and vision models. <sup>3,6</sup>
== Problem formulation ==
== Problem formulation ==
<body>
=== 1. Objective ===
    <h1>1. Objective</h1>
Minimize the loss function <math>f(x)</math>, where <math>x \in R^n</math> and <math>x</math> is the weight vector to be optimized.
    <p>Minimize the loss function <b>f(x)</b>, where <b>x ∈ ℝⁿ</b> and <b>x</b> is the weight vector to be optimized.</p>
 
   
=== 2. Parameters ===
    <h1>2. Parameters</h1>
*''' Gradient:'''
    <ul>
<math>G_t = \nabla f(x_{t-1})</math>
        <li><b>Gradient:</b>
 
            <div><i>G<sub>t</sub> = ∇f(x<sub>t-1</sub>)</i></div>
* '''Second moment estimate:'''
        </li>
 
        <li><b>Second moment estimate:</b>
<math> \hat{V}_t = \hat{\beta}_{2t} \hat{V}_{t-1} + (1 - \hat{\beta}_{2t})(G_t^2 + \epsilon_1 1_n)</math>
            <div><i>Ĥ<sub>Vt</sub> = Ĥ<sub>β2t</sub> Ĥ<sub>Vt-1</sub> + (1 - Ĥ<sub>β2t</sub>)(G<sub>t</sub>² + ε₁ 1ₙ)</i></div>
 
            <ul>
* '''Where:'''
                <li><i>Ĥ<sub>Vt</sub></i> is the running average of the squared gradient.</li>
** <math>\hat{V}_t</math> is the running average of the squared gradient.
                <li><i>Ĥ<sub>β2t</sub></i> is the corrected decay parameter.</li>
**<math>\hat{\beta}_{2t}</math> is the corrected decay parameter.
                <li><i>ε₁</i> is a regularization constant.</li>
**<math>\epsilon_1</math> is a regularization constant.
            </ul>
 
        </li>
* '''Step size:'''
        <li><b>Step size:</b>
<math>\alpha_t = \max(\epsilon_2, \text{RMS}(x_{t-1})) \rho_t</math>
            <div><i>α<sub>t</sub> = max(ε₂, RMS(x<sub>t-1</sub>)) ρ<sub>t</sub></i></div>
* '''Where''':
            <ul>
** <math>\rho_t</math> is the relative step size.
                <li><i>ρ<sub>t</sub></i> is the relative step size.</li>
** <math>\epsilon_2</math> is a regularization constant.
                <li><i>ε₂</i> is a regularization constant.</li>
** <math>\text{RMS}</math> is the root mean square, defined as:
                <li><i>RMS</i> is the root mean square, defined as:
*** <math>u_{xt} = \frac{-g_{xt}}{\sqrt{\hat{v}_{xt}}}</math>
                    <div><i>u<sub>xt</sub> = -g<sub>xt</sub> / √Ĥ<sub>vxt</sub></i></div>
*** <math>\text{RMS}(U_t) = \text{RMS}_{x \in X}(u_{xt}) = \sqrt{\text{Mean}_{x \in X}\left(\frac{(g_{xt})^2}{\hat{v}_{xt}}\right)}</math>
                    <div><i>RMS(U<sub>t</sub>) = RMS<sub>x ∈ X</sub>(u<sub>xt</sub>) = √Mean<sub>x ∈ X</sub>(g<sub>xt</sub>² / Ĥ<sub>vxt</sub>)</i></div>
 
                </li>
=== 3. Algorithms ===
            </ul>
==== Adafactor for Weighted Vectors ====
        </li>
'''Inputs:'''
    </ul>
* Initial point: <math>X_0 \in \mathbb{R}^n</math>
   
* Relative step sizes: <math>\rho_t</math> for <math>t = 1</math> to <math>T</math>
    <h1>3. Problem Formulation</h1>
* Second moment decay: <math>\hat{\beta}_{2t}</math> for <math>t = 1</math> to <math>T</math>, with <math>\hat{\beta}_{21} = 0</math>
    <h2>Adafactor for Weighted Vectors</h2>
* Regularization constants: <math>\epsilon_1, \epsilon_2</math>
    <h3>Inputs:</h3>
* Clipping threshold: <math>d</math>
    <ul>
 
        <li>Initial point: <i>X₀ ∈ ℝⁿ</i></li>
'''Algorithm:'''
        <li>Relative step sizes: <i>ρ<sub>t</sub></i> for <i>t = 1</i> to <i>T</i></li>
* For <math>t = 1</math> to <math>T</math>:
        <li>Second moment decay: <i>Ĥ<sub>β2t</sub></i> for <i>t = 1</i> to <i>T</i>, with <i>Ĥ<sub>β21</sub> = 0</i></li>
** Compute adaptive step size: <math>\alpha_t = \max(\epsilon_2, \text{RMS}(X_{t-1})) \rho_t</math>
        <li>Regularization constants: <i>ε₁, ε₂</i></li>
** Compute gradient: <math>G_t = \nabla f_t(X_{t-1})</math>
        <li>Clipping threshold: <i>d</i></li>
** Update second moment estimate: <math>\hat{V}_t = \hat{\beta}_{2t} \hat{V}_{t-1} + (1 - \hat{\beta}_{2t})(G_t^2 + \epsilon_1 1_n)</math>
    </ul>
** Compute normalized gradient: <math>U_t = \frac{G_t}{\sqrt{\hat{V}_t}}</math>
    <h3>Algorithm:</h3>
** Apply clipping: <math>\hat{U}_t = \frac{U_t}{\max(1, \text{RMS}(U_t) / d)}</math>
    <ul>
** Update parameter: <math>X_t = X_{t-1} - \alpha_t \hat{U}_t</math>
        <li>For <i>t = 1</i> to <i>T</i>:
* End for
            <ul>
 
                <li>Compute adaptive step size:
==== Adafactor for Weighted Matrices ====
                    <div><i>α<sub>t</sub> = max(ε₂, RMS(X<sub>t-1</sub>)) ρ<sub>t</sub></i></div>
'''Inputs:'''
                </li>
* Initial point: <math>X_0 \in \mathbb{R}^{n \times m}</math>
                <li>Compute gradient:
* Relative step sizes: <math>\rho_t</math> for <math>t = 1</math> to <math>T</math>
                    <div><i>G<sub>t</sub> = ∇f<sub>t</sub>(X<sub>t-1</sub>)</i></div>
* Second moment decay: <math>\hat{\beta}_{2t}</math> for <math>t = 1</math> to <math>T</math>, with <math>\hat{\beta}_{21} = 0</math>
                </li>
* Regularization constants: <math>\epsilon_1, \epsilon_2</math>
                <li>Update second moment estimate:
* Clipping threshold: <math>d</math>
                    <div><i>Ĥ<sub>Vt</sub> = Ĥ<sub>β2t</sub> Ĥ<sub>Vt-1</sub> + (1 - Ĥ<sub>β2t</sub>)(G<sub>t</sub>² + ε₁ 1ₙ)</i></div>
 
                </li>
'''Algorithm:'''
                <li>Compute normalized gradient:
* For <math>t = 1</math> to <math>T</math>:
                    <div><i>U<sub>t</sub> = G<sub>t</sub> / √Ĥ<sub>Vt</sub></i></div>
** Compute adaptive step size: <math>\alpha_t = \max(\epsilon_2, \text{RMS}(X_{t-1})) \rho_t</math>
                </li>
** Compute gradient: <math>G_t = \nabla f_t(X_{t-1})</math>
                <li>Apply clipping:
** Update row-wise second moment: <math>R_t = \hat{\beta}_{2t} R_{t-1} + (1 - \hat{\beta}_{2t})(G_t^2 + \epsilon_1 1_n 1_m^T) 1_m</math>
                    <div><i>Ĥ<sub>U<sub>t</sub></i> = U<sub>t</sub> / max(1, RMS(U<sub>t</sub>) / d)</i></div>
** Update column-wise second moment: <math>C_t = \hat{\beta}_{2t} C_{t-1} + (1 - \hat{\beta}_{2t}) 1_n^T (G_t^2 + \epsilon_1 1_n 1_m^T)</math>
                </li>
** Update overall second moment estimate: <math>\hat{V}_t = \frac{R_t C_t}{1_n^T R_t}</math>
                <li>Update parameter:
** Compute normalized gradient: <math>U_t = \frac{G_t}{\sqrt{\hat{V}_t}}</math>
                    <div><i>X<sub>t</sub> = X<sub>t-1</sub> - α<sub>t</sub> Ĥ<sub>U<sub>t</sub></i></div>
** Apply clipping: <math>\hat{U}_t = \frac{U_t}{\max(1, \text{RMS}(U_t) / d)}</math>
                </li>
** Update parameter: <math>X_t = X_{t-1} - \alpha_t \hat{U}_t</math>
            </ul>
* End for
        </li>
 
    </ul>
 
   
 
    <h2>Adafactor for Weighted Matrices</h2>
=== Proposed Hyperparameters for Adafactor ===
    <h3>Inputs:</h3>
 
    <ul>
* '''Regularization constant 1 (<math>\epsilon_1</math>):''' <math>10^{-30}</math>
        <li>Initial point: <i>X₀ ∈ ℝⁿ × ℝ<sup>m</sup></i></li>
**Ensures numerical stability by preventing division by zero in the calculation of second-moment estimates. This value is set extremely low to avoid instability in calculations.
        <li>Relative step sizes: <i>ρ<sub>t</sub></i> for <i>t = 1</i> to <i>T</i></li>
 
        <li>Second moment decay: <i>Ĥ<sub>β2t</sub></i> for <i>t = 1</i> to <i>T</i>, with <i>Ĥ<sub>β21</sub> = 0</i></li>
* '''Regularization constant 2 (<math>\epsilon_2</math>):''' <math>10^{-3}</math>
        <li>Regularization constants: <i>ε₁, ε₂</i></li>
**Helps stabilize parameter updates by controlling the scaling effect of second-moments in low-magnitude scenarios. This prevents instability caused by noise in small gradients.
        <li>Clipping threshold: <i>d</i></li>
 
    </ul>
* '''Clipping threshold (<math>d</math>):''' <math>1</math>
    <h3>Algorithm:</h3>
**A clipping threshold of 1 ensures stability by limiting large gradient values while maintaining sufficient learning efficiency. This avoids excessive suppression of large gradients, which could hinder learning.
    <ul>
 
        <li>For <i>t = 1</i> to <i>T</i>:
* '''Relative step size (<math>\rho_t</math>):''' <math>\min(10^{-2}, 1 / \sqrt{t})</math>
            <ul>
**The <math>\min(10^{-2}, ...)</math> term caps the learning rate at <math>10^{-2}</math>, an empirically determined upper bound. 
                <li>Compute adaptive step size:
**The <math>1 / \sqrt{t}</math> term ensures convergence by reducing the step size over time, balancing exploration during early iterations with stability later in training.
                    <div><i>α<sub>t</sub> = max(ε₂, RMS(X<sub>t-1</sub>)) ρ<sub>t</sub></i></div>
 
                </li>
* '''Second moment decay (<math>\hat{\beta}_{2t}</math>):''' <math>1 - t^{-0.8}</math>
                <li>Compute gradient:
**The decay factor remains close to 1 initially to allow rapid adaptation. 
                    <div><i>G<sub>t</sub> = ∇f<sub>t</sub>(X<sub>t-1</sub>)</i></div>
**The <math>t^{-0.8}</math> power balances between rapid learning in early training and stability during later stages, ensuring smoother convergence.
                </li>
 
                <li>Update row-wise second moment:
=== 5. Discussion ===
                    <div><i>R<sub>t</sub> = Ĥ<sub>β2t</sub> R<sub>t-1</sub> + (1 - Ĥ<sub>β2t</sub>)(G<sub>t</sub>² + ε₁ 1ₙ 1ₘᵀ) 1ₘ</i></div>
 
                </li>
==== Why Clipping ====
                <li>Update column-wise second moment:
Adafactor employs clipping to maintain numerical stability, especially since it is designed for use with very large models and often works with unscaled learning rates.
                    <div><i>C<sub>t</sub> = Ĥ<sub>β2t</sub> C<sub>t-1</sub> + (1 - Ĥ<sub>β2t</sub>) 1ₙᵀ (G<sub>t</sub>² + ε₁ 1ₙ 1ₘᵀ)</i></div>
* Clipping prevents the update step from becoming very large, which would destabilize training
                </li>
* Clipping mitigates the effects of very large gradients preventing numerical instability
                <li>Update overall second moment estimate:
Therefore, implementing clipping helps ensure stability and efficient training without requiring per-parameter scaling like Adam.
                    <div><i>Ĥ<sub>Vt</sub> = R<sub>t</sub> C<sub>t</sub> / (1ₙᵀ R<sub>t</sub>)</i></div>
 
                </li>
==== Why Adafactor is more memory efficient, compared to Adam ====
                <li>Compute normalized gradient:
'''Row-wise and Column-wise Second Moment Updates'''
                    <div><i>U<sub>t</sub> = G<sub>t</sub> / √Ĥ<sub>Vt</sub></i></div>
*<math>R_t = \hat{\beta}_{2t} R_{t-1} + (1 - \hat{\beta}_{2t})(G_t^2 + \epsilon_1 1_n 1_m^T) 1_m</math>
                </li>
*<math>C_t = \hat{\beta}_{2t} C_{t-1} + (1 - \hat{\beta}_{2t}) 1_n^T (G_t^2 + \epsilon_1 1_n 1_m^T)</math>
                <li>Apply clipping:
Instead of storing the full <math>G_t^2</math>, Adafactor computes the row and column respectively, which reduces the memory requirements from <math>O(n\times m)</math> to <math>O(n + m)</math>
                    <div><i>Ĥ<sub>U<sub>t</sub></i> = U<sub>t</sub> / max(1, RMS(U<sub>t</sub>) / d)</i></div>
 
                </li>
'''Factored Representation of the Second Moment'''
                <li>Update parameter:
* <math>\hat{V}_t = \frac{R_t C_t}{1_n^T R_t}</math>
                    <div><i>X<sub>t</sub> = X<sub>t-1</sub> - α<sub>t</sub> Ĥ<sub>U<sub>t</sub></i></div>
This updates the second momentum based on the outer product <math>R_t C_t</math>.
                </li>
*However, this is not <math>O(n\times m)</math> since
            </ul>
** The operation is performed element-wise, so it actually never materializes <math>\hat{V_t}</math> as a <math>n\times n</math> matrix
        </li>
** It also only storing <math>R_t</math>and <math> C_t</math> instead of storage the full second-moment matrix
    </ul>
   
    <h1>4. Proposed Hyperparameters for Adafactor</h1>
    <ul>
        <li>Regularization constant 1: <i>ε₁ = 10⁻³⁰</i></li>
        <li>Regularization constant 2: <i>ε₂ = 10⁻³</i></li>
        <li>Clipping threshold: <i>d = 1</i></li>
        <li>Relative step size: <i>ρ<sub>t</sub> = min(10⁻², 1/√t)</i></li>
        <li>Second moment decay: <i>Ĥ<sub>β2t</sub> = 1 - t⁻⁰.⁸</i></li>
    </ul>
</body>
</html>


== Numerical Examples ==
== Numerical Examples ==
Step-by-step instructions for determining the result of the first iteration.
=== Problem setup ===
'''Minimize the loss function:'''
<math>f(X) = \frac{1}{2}\sum_{i,j}(X_{ij}-C_{ij})^2</math>
'''Initial weights ('''<math>X_0</math>​'''):'''
<math>X_0 = \begin{bmatrix} 0.7 &-0.5& 0.9\\ -1.1 & 0.8& -1.6\\1.2&-0.7& 0.4 \end{bmatrix}</math>
'''Target matrix (<math>C</math>):'''
<math>C = \begin{bmatrix} 0.4 & -0.3 &0.5 \\ -0.6 & 0.2&-1.5\\1.0&-0.3&0.1 \end{bmatrix}</math>
=== Hyperparameters setup ===
<math>\epsilon_1 = 10^{-30}</math> (Minimum learning rate scaling factor))
<math>\epsilon_2 = 10^{-3}</math> (Regularization constant)
<math>d = 1</math> (Clipping threshold)
<math>\rho_t = \min(10^{-2}, 1/\sqrt{t})</math> (Relative step size)
<math>\hat{\beta}_{2t} = 1 - t^{-0.8}</math> (Second moment decay)
=== Step 1:  Learning Rate Scaling ===
Define the relative step size
<math>\rho_1 = \min(10^{-2}, 1/\sqrt{1})= 10^{-2}</math>
'''Step 1.1: Root Mean Square(RMS) calculation for <math>X_0</math>'''
Root Mean Square(RMS) calculation for <math>X_0</math>
RMS formula
<math>RMS(X_0) = \sqrt{\tfrac{1}{n}\sum_{i=1}^n  X_0[i]^2}</math>
Substitute the initial weights
<math>RMS(X_0) = \sqrt{\tfrac{1}{9}(0.7^2+(-0.5)^2+0.9^2+(-1.1)^2+0.8^2+(-0.6)^2+1.2^2+(-0.7)^2+0.4^2)}</math>
<math>RMS(X_0) = \sqrt{\frac{6.85}{9}}\approx 0.806</math>
'''Step 1.2: Find the Learning Rate Scaling ('''<math>\alpha_t</math>​'''):'''
Learning rate formula
<math>\alpha_1 = max(\epsilon_2,RMS(X_0))\cdot p_1</math>
Substitute the RMS
<math>\alpha_1 = max(0.001,0.806)\cdot 0.01=0.00806</math>
=== Step 2: Compute the element-wise (Square of Gradient) ===
'''Step 2.1: Compute the gradient of the loss function'''
Gradient formula
<math>G_t =    {\partial f(X)\over\partial X} = X_{t-1} - C</math>
Subtract C from <math>X_0</math>
<math>G_1 = \begin{bmatrix} 0.7 &-0.5& 0.9\\ -1.1 & 0.8& -1.6\\1.2&-0.7& 0.4 \end{bmatrix} - \begin{bmatrix} 0.4 & -0.3 &0.5 \\ -0.6 & 0.2&-1.5\\1.0&-0.3&0.1 \end{bmatrix}</math>
<math>G_1 = \begin{bmatrix} 0.3&-0.2&0.4\\ -0.5&0.6&-0.1\\0.2&-0.4 &0.3 \end{bmatrix}</math>
'''Step 2.2: Compute the squared value of each element in the gradient matrix <math>G_t</math>'''
<math>G^{2}_1 = \begin{bmatrix} 0.3^2&(-0.2)^2&0.4^2\\ (-0.5)^2&0.6^2&(-0.1)^2\\0.2^2&(-0.4)^2 &0.3^2 \end{bmatrix}</math>
<math>G^{2}_1 = \begin{bmatrix} 0.09& 0.04&0.16\\ 0.25&0.36&0.01\\0.04&0.16&0.09\end{bmatrix}</math>
=== Step 3: Find the moment estimate ===
Compute the exponential moving average of squared gradients to capture the variance or scale of gradients.
'''Step 3.1: Compute row moments (<math>R_t</math>)'''
This equation computes the row-wise second moments ('''<math>R_t</math>''' ​) as an exponential moving average of past moments ('''<math>R_{t-1}</math>''') and the current row-wise mean of squared gradients ( <small><math>G^{2}_t</math></small>​ ), with a balance controlled by (<math>\hat{\beta}_{2t}</math>).
For <math>G^{2}_t=\mathbb{R}^{m\times n} </math>
<math>R_t = \hat{\beta_{2t}} \cdot R_{t-1} + (1-\hat{\beta})\cdot (\tfrac{1}{m}\sum_{j=1}^m G^{2}_t[i,j]+\epsilon_1) </math>
Since <math>\hat{\beta}_{2t} = 1 - t^{-0.8}</math>, for first iteration: <math>\hat{\beta}_{21} = 0</math>. And because <math>\epsilon_1 </math> is too small, we can ignore it. The update of '''<math>R_t</math>''' is:
<math>R_{1} = \tfrac{1}{m}\textstyle \sum_{j=1}^m \displaystyle G^{2}_1[i,j] </math>
Row-wise mean ('''<math>R_t</math>'''):
<math>R_1 = \begin{bmatrix} \tfrac{0.09+0.04+0.16}{3} \\ \tfrac{0.25+0.36+0.01}{3}\\\tfrac{0.04+0.16+0.09}{3} \end{bmatrix} = \begin{bmatrix} 0.0967\\ 0.2067\\0.0967\end{bmatrix} </math>
'''Step 3.2: Compute column moments (<math>C_t</math>)'''
The process is same as row moments.
<math>C_t = \hat{\beta}\cdot C_{{t-1}} + (1-\hat{\beta})\cdot (\tfrac{1}{n}\sum_{j=1}^n G^{2}_t[i,j]+\epsilon_1) </math>
Column-wise mean (<math>C_t</math>):
<math>C_1 = \begin{bmatrix} \tfrac{0.09+025+0.04}{3} \\ \tfrac{0.04+0.36+0.16}{3}\\\tfrac{0.16+0.01+0.09}{3} \end{bmatrix} = \begin{bmatrix} 0.1267\\ 0.1867\\0.0867\end{bmatrix} </math>
'''Step 3.3: Second Moment Estimate ('''<math>\hat{V_t}</math>​''')'''
The Second Moment Estimate is calculated as the outer product of the row moments ('''<math>R_t</math>'''​) and column moments ('''<math>C_t</math>'''​).
<math>\hat{V}_t = R_t \otimes C_t</math>
<math>\hat{V}_1  = \begin{bmatrix} 0.0967\\0.2067\\0.0967 \end{bmatrix} \otimes    \begin{bmatrix} 0.1267&0.1867&0.0867\\ \end{bmatrix} </math>
<math>\hat{V}_1      =  \begin{bmatrix} 0.0122&0.0180&0.0084\\ 0.0262&0.0386&0.0179\\ 0.0122&0.0180&0.0084\end{bmatrix} </math>
=== Step 4: Update the vector ===
Computed by scaling the gradient matrix '''<math>G_t</math>'''​ element-wise with the inverse square root of the second moment estimate (<math>\hat{V_t}</math>​)
'''Step 4.1: Find the vector value of <math>U_t </math>'''
Formula of '''<small><math>U_t </math></small>'''
<math>U_t = \frac{G_t}{\sqrt{\hat{V_t}+\epsilon_1}} </math>
Substitute '''<small><math>C_t</math></small>''' and <small><math>V_t</math></small>
<math>U_1 =    \frac{\begin{bmatrix}0.3&-0.2&0.4 \\ -0.5&0.6&-0.1\\0.2&-0.4&0.3 \end{bmatrix}}{\sqrt{\begin{bmatrix} 0.0122&0.0180&0.0084\\ 0.0262&0.0386&0.0179\\0.0122&0.0180&0.0084 \end{bmatrix}}} </math>
<math>U_1 = \begin{bmatrix} 2.711&-1.489&4.370\\-3.090&3.055&-0.747\\1.807&-2.978&3.278  \end{bmatrix} </math>
'''Step 4.2: Clipped Update Vector <math>\hat{U_t} </math>'''
Scale the update vector ( '''<math>U_t </math>'''​ ) to ensure its RMS value does not exceed a predefined clipping threshold (<math>d </math>), maintaining stability in updates.
Formula of '''<small><math>\hat{U_t} </math></small>'''
'''<small><math>\hat{U_t} = \frac{U_t}{max(1,\tfrac{RMS(U_t)}{d})        } </math></small>'''
Compute RMS of '''<math>U_t </math>'''
'''<small><math>RMS(U_1)  = \sqrt{\tfrac{1}{9}  \sum_{i=1}^9 U_t[i]^2}  \approx 3.303 </math></small>'''
Since RMS('''<math>U_t </math>'''​)>d, scale '''<math>U_t </math>'''​ by <math>\tfrac{1}{3.303} </math>
'''<math>\hat{U_1} =  \begin{bmatrix} 0.965&-0.53&1.556 \\-1.1&1.088&-0.266\\0.664&-1.06&1.167 \end{bmatrix} </math>'''
=== Step 5: Weight Update ===
Adjust the weights (<math>X_t </math>) by subtracting the product of the learning rate (<math>\alpha_t </math>) and the clipped update vector (<math>\hat{U_t} </math> ).
<math>X_1 = X_0 - \alpha \cdot      \hat{U_t}</math>
The result for first iteration.
<math>X_1 = \begin{bmatrix} 0.7 &-0.5& 0.9\\ -1.1 & 0.8& -1.6\\1.2&-0.7& 0.4 \end{bmatrix}  - 0.00806 \cdot      \begin{bmatrix} 0.965&-0.53&1.556 \\-1.1&1.088&-0.266\\0.664&-1.06&1.167 \end{bmatrix}      </math>
<math>X_1 =  \begin{bmatrix} 0.692&-0.496&0.887 \\-1.091&0.791&-0.596\\ 1.195&-0.691&0.391\end{bmatrix}      </math>
== Applications ==
== Applications ==
Adafactor is an efficient adaptive optimizer designed specifically for large-scale deep learning tasks. Its unique memory-saving properties have made it widely used for training large-scale language models, image recognition models, and reinforcement learning policy networks. Compared to other optimizers (e.g., Adam), Adafactor delivers exceptional performance in large-scale computations while significantly reducing memory requirements. Below are several specific application scenarios of Adafactor:
'''1. Natural Language Processing (NLP)'''
In NLP tasks, Adafactor has been successfully applied to training ultra-large-scale language models, such as Google’s Transformer and T5 (Text-To-Text Transfer Transformer). By significantly reducing memory usage during the gradient update process, Adafactor enables efficient model training in resource-constrained environments. For example, the T5 model in Google’s research employed Adafactor to effectively train on large datasets through text-to-text conversion tasks.<sup>2</sup>
'''2. Training Large-Scale Language Models'''
Adafactor has been used to train large-scale language models like LLaMA, combining it with novel preconditioned diagonalization methods to significantly enhance training efficiency. Experiments showed that Adafactor achieved performance comparable to the Adam optimizer while consuming substantially less memory and computational resources.<sup>3</sup>
'''3. Humor Detection Tasks'''
Adafactor has been utilized to optimize ALBERT-based models for humor detection tasks. Configured as an adaptive learning rate optimizer and paired with a cross-entropy loss function, Adafactor was used to train models that achieved 99% accuracy and F1 scores. Moreover, training time was faster than with Adam, completing in approximately 43 minutes. Comparisons with Adam and AdaBound optimizers demonstrated that Adafactor excelled in terms of both time efficiency and performance, especially in accuracy, recall, and F1 scores for humor detection tasks .<sup>4</sup>
'''4. Multilingual Model Training'''
In training multilingual models, Adafactor improved scalability and efficiency, particularly by significantly reducing memory consumption when handling large-scale parameters.<sup>5</sup>
'''5. Pretraining Vision Models'''
When training ResNet50 and ViT on the ImageNet1k dataset, Adafactor successfully optimized these deep networks with its low memory requirements. Additionally, with new algorithms combining preconditioned diagonalization methods (e.g., AdafacDiag and AdafacDiag++), it outperformed the standard Adam optimizer in both convergence speed and final accuracy.<sup>6</sup>
==== Software Tools and Platforms ====
Adafactor has been integrated into the following mainstream deep learning frameworks, making it accessible to developers:
'''TensorFlow''': Provides a built-in implementation of Adafactor.<sup>7</sup>
'''PyTorch:''' PyTorch provides the Adafactor optimizer through the torch.optim.AdaFactor class.<sup>8</sup>
'''JAX/Flax:''' JAX provides an optimizer library called Optax, which includes the Adafactor optimizer.<sup>9</sup>
==== Future Prospects ====
As the scale of deep learning models continues to grow, Adafactor’s memory-saving and computational efficiency advantages will become increasingly important. In the training of ultra-large-scale models (e.g., GPT and Vision Transformers), Adafactor is expected to become an indispensable optimization tool. Furthermore, by combining with other optimization strategies, such as mixed precision training, Adafactor may further enhance its applicability in both industrial and research settings.
== Conclusion ==
== Conclusion ==
Adafactor addresses the memory consumption challenge of training large-scale deep learning models. By factorizing the second-order moment matrix and dynamically adjusting the learning rate, Adafactor minimizes resource usage without compromising performance. Adafactor can be applied to the training tasks of large language models such as Transformers, T5 models, and Vision Transformers.
== Reference ==
== Reference ==
# Shazeer, Noam, and Mitchell Stern. "Adafactor: Adaptive learning rates with sublinear memory cost." ''International Conference on Machine Learning''. PMLR, 2018.
# Raffel, Colin, et al. "Exploring the limits of transfer learning with a unified text-to-text transformer." ''Journal of machine learning research'' 21.140 (2020): 1-67.
# DIAGONALIZATION, VIA PRECONDITIONER. "Improving Adaptive Moment Optimization via Preconditioner Diagonalization."
# Chauhan, Tavishee, and Hemant Palivela. "The Fine tuning of Language models for automation of Humor Detection." ''INFOCOMP Journal of Computer Science'' 20.2 (2021).
# Lepikhin, Dmitry, et al. "Gshard: Scaling giant models with conditional computation and automatic sharding." ''arXiv preprint arXiv:2006.16668'' (2020).
# DIAGONALIZATION, VIA PRECONDITIONER. "Improving Adaptive Moment Optimization via Preconditioner Diagonalization."
# <nowiki>https://www.tensorflow.org/api_docs/python/tf/keras/optimizers/Adafactor</nowiki>
# <nowiki>https://pytorch.org/docs/stable/generated/torch.optim.Adafactor.html</nowiki>
# <nowiki>https://flax.readthedocs.io/en/v0.5.3/_autosummary/flax.optim.Adafactor.html</nowiki>

Latest revision as of 21:46, 15 December 2024

Author: Aolei Cao (ac3237), Ziyang Li (zl986), Junjia Liang (jl4439) (ChemE 6800 Fall 2024)

Stewards: Nathan Preuss, Wei-Han Chen, Tianqi Xiao, Guoqing Hu

Introduction

Adafactor is an efficient, adaptive learning rate optimization algorithm proposed by Noam Shazeer and Mitchell Stern in 2018. 1

Unlike traditional Adam optimizers, Adafactor does not store complete second-order moment matrices. Instead, it employs a factorization approach that only maintains gradient statistics for the rows and columns of parameter matrices, significantly reducing memory usage. Moreover, Adafactor uses an adaptive learning rate, allowing it to dynamically adjust step sizes without the need for manually setting a global learning rate or relying heavily on hyperparameter tuning. Its design also defaults to not performing bias correction, yet it remains stable in scenarios involving large-batch training data.1 This efficiency makes it an ideal choice for training ultra-large-scale models such as T5.2

Adafactor’s efficient memory usage and outstanding performance make it widely applicable in scenarios such as Natural Language Processing (NLP).2 Compared to the Adam optimizer, Adafactor significantly reduces memory and computational resource requirements while maintaining comparable performance when training large-scale language models and vision models. 3,6

Problem formulation

1. Objective

Minimize the loss function , where and is the weight vector to be optimized.

2. Parameters

  • Gradient:

  • Second moment estimate:

  • Where:
    • is the running average of the squared gradient.
    • is the corrected decay parameter.
    • is a regularization constant.
  • Step size:

  • Where:
    • is the relative step size.
    • is a regularization constant.
    • is the root mean square, defined as:

3. Algorithms

Adafactor for Weighted Vectors

Inputs:

  • Initial point:
  • Relative step sizes: for to
  • Second moment decay: for to , with
  • Regularization constants:
  • Clipping threshold:

Algorithm:

  • For to :
    • Compute adaptive step size:
    • Compute gradient:
    • Update second moment estimate:
    • Compute normalized gradient:
    • Apply clipping:
    • Update parameter:
  • End for

Adafactor for Weighted Matrices

Inputs:

  • Initial point:
  • Relative step sizes: for to
  • Second moment decay: for to , with
  • Regularization constants:
  • Clipping threshold:

Algorithm:

  • For to :
    • Compute adaptive step size:
    • Compute gradient:
    • Update row-wise second moment:
    • Update column-wise second moment:
    • Update overall second moment estimate:
    • Compute normalized gradient:
    • Apply clipping:
    • Update parameter:
  • End for


Proposed Hyperparameters for Adafactor

  • Regularization constant 1 ():
    • Ensures numerical stability by preventing division by zero in the calculation of second-moment estimates. This value is set extremely low to avoid instability in calculations.
  • Regularization constant 2 ():
    • Helps stabilize parameter updates by controlling the scaling effect of second-moments in low-magnitude scenarios. This prevents instability caused by noise in small gradients.
  • Clipping threshold ():
    • A clipping threshold of 1 ensures stability by limiting large gradient values while maintaining sufficient learning efficiency. This avoids excessive suppression of large gradients, which could hinder learning.
  • Relative step size ():
    • The term caps the learning rate at , an empirically determined upper bound.
    • The term ensures convergence by reducing the step size over time, balancing exploration during early iterations with stability later in training.
  • Second moment decay ():
    • The decay factor remains close to 1 initially to allow rapid adaptation.
    • The power balances between rapid learning in early training and stability during later stages, ensuring smoother convergence.

5. Discussion

Why Clipping

Adafactor employs clipping to maintain numerical stability, especially since it is designed for use with very large models and often works with unscaled learning rates.

  • Clipping prevents the update step from becoming very large, which would destabilize training
  • Clipping mitigates the effects of very large gradients preventing numerical instability

Therefore, implementing clipping helps ensure stability and efficient training without requiring per-parameter scaling like Adam.

Why Adafactor is more memory efficient, compared to Adam

Row-wise and Column-wise Second Moment Updates

Instead of storing the full , Adafactor computes the row and column respectively, which reduces the memory requirements from to

Factored Representation of the Second Moment

This updates the second momentum based on the outer product .

  • However, this is not since
    • The operation is performed element-wise, so it actually never materializes as a matrix
    • It also only storing and instead of storage the full second-moment matrix

Numerical Examples

Step-by-step instructions for determining the result of the first iteration.

Problem setup

Minimize the loss function:

Initial weights ():

Target matrix ():

Hyperparameters setup

(Minimum learning rate scaling factor))

(Regularization constant)

(Clipping threshold)

(Relative step size)

(Second moment decay)

Step 1: Learning Rate Scaling

Define the relative step size

Step 1.1: Root Mean Square(RMS) calculation for

Root Mean Square(RMS) calculation for

RMS formula

Substitute the initial weights

Step 1.2: Find the Learning Rate Scaling ():

Learning rate formula

Substitute the RMS

Step 2: Compute the element-wise (Square of Gradient)

Step 2.1: Compute the gradient of the loss function

Gradient formula

Subtract C from



Step 2.2: Compute the squared value of each element in the gradient matrix

Step 3: Find the moment estimate

Compute the exponential moving average of squared gradients to capture the variance or scale of gradients.

Step 3.1: Compute row moments ()

This equation computes the row-wise second moments ( ​) as an exponential moving average of past moments () and the current row-wise mean of squared gradients ( ​ ), with a balance controlled by ().

For

Since , for first iteration: . And because is too small, we can ignore it. The update of is:

Row-wise mean ():

Step 3.2: Compute column moments ()

The process is same as row moments.

Column-wise mean ():

Step 3.3: Second Moment Estimate ()

The Second Moment Estimate is calculated as the outer product of the row moments (​) and column moments (​).


Step 4: Update the vector

Computed by scaling the gradient matrix ​ element-wise with the inverse square root of the second moment estimate (​)

Step 4.1: Find the vector value of

Formula of

Substitute and



Step 4.2: Clipped Update Vector

Scale the update vector ( ​ ) to ensure its RMS value does not exceed a predefined clipping threshold (), maintaining stability in updates.

Formula of

Compute RMS of

Since RMS(​)>d, scale ​ by


Step 5: Weight Update

Adjust the weights () by subtracting the product of the learning rate () and the clipped update vector ( ).

The result for first iteration.




Applications

Adafactor is an efficient adaptive optimizer designed specifically for large-scale deep learning tasks. Its unique memory-saving properties have made it widely used for training large-scale language models, image recognition models, and reinforcement learning policy networks. Compared to other optimizers (e.g., Adam), Adafactor delivers exceptional performance in large-scale computations while significantly reducing memory requirements. Below are several specific application scenarios of Adafactor:

1. Natural Language Processing (NLP)

In NLP tasks, Adafactor has been successfully applied to training ultra-large-scale language models, such as Google’s Transformer and T5 (Text-To-Text Transfer Transformer). By significantly reducing memory usage during the gradient update process, Adafactor enables efficient model training in resource-constrained environments. For example, the T5 model in Google’s research employed Adafactor to effectively train on large datasets through text-to-text conversion tasks.2

2. Training Large-Scale Language Models

Adafactor has been used to train large-scale language models like LLaMA, combining it with novel preconditioned diagonalization methods to significantly enhance training efficiency. Experiments showed that Adafactor achieved performance comparable to the Adam optimizer while consuming substantially less memory and computational resources.3

3. Humor Detection Tasks

Adafactor has been utilized to optimize ALBERT-based models for humor detection tasks. Configured as an adaptive learning rate optimizer and paired with a cross-entropy loss function, Adafactor was used to train models that achieved 99% accuracy and F1 scores. Moreover, training time was faster than with Adam, completing in approximately 43 minutes. Comparisons with Adam and AdaBound optimizers demonstrated that Adafactor excelled in terms of both time efficiency and performance, especially in accuracy, recall, and F1 scores for humor detection tasks .4

4. Multilingual Model Training

In training multilingual models, Adafactor improved scalability and efficiency, particularly by significantly reducing memory consumption when handling large-scale parameters.5

5. Pretraining Vision Models

When training ResNet50 and ViT on the ImageNet1k dataset, Adafactor successfully optimized these deep networks with its low memory requirements. Additionally, with new algorithms combining preconditioned diagonalization methods (e.g., AdafacDiag and AdafacDiag++), it outperformed the standard Adam optimizer in both convergence speed and final accuracy.6

Software Tools and Platforms

Adafactor has been integrated into the following mainstream deep learning frameworks, making it accessible to developers:

TensorFlow: Provides a built-in implementation of Adafactor.7

PyTorch: PyTorch provides the Adafactor optimizer through the torch.optim.AdaFactor class.8

JAX/Flax: JAX provides an optimizer library called Optax, which includes the Adafactor optimizer.9

Future Prospects

As the scale of deep learning models continues to grow, Adafactor’s memory-saving and computational efficiency advantages will become increasingly important. In the training of ultra-large-scale models (e.g., GPT and Vision Transformers), Adafactor is expected to become an indispensable optimization tool. Furthermore, by combining with other optimization strategies, such as mixed precision training, Adafactor may further enhance its applicability in both industrial and research settings.

Conclusion

Adafactor addresses the memory consumption challenge of training large-scale deep learning models. By factorizing the second-order moment matrix and dynamically adjusting the learning rate, Adafactor minimizes resource usage without compromising performance. Adafactor can be applied to the training tasks of large language models such as Transformers, T5 models, and Vision Transformers.

Reference

  1. Shazeer, Noam, and Mitchell Stern. "Adafactor: Adaptive learning rates with sublinear memory cost." International Conference on Machine Learning. PMLR, 2018.
  2. Raffel, Colin, et al. "Exploring the limits of transfer learning with a unified text-to-text transformer." Journal of machine learning research 21.140 (2020): 1-67.
  3. DIAGONALIZATION, VIA PRECONDITIONER. "Improving Adaptive Moment Optimization via Preconditioner Diagonalization."
  4. Chauhan, Tavishee, and Hemant Palivela. "The Fine tuning of Language models for automation of Humor Detection." INFOCOMP Journal of Computer Science 20.2 (2021).
  5. Lepikhin, Dmitry, et al. "Gshard: Scaling giant models with conditional computation and automatic sharding." arXiv preprint arXiv:2006.16668 (2020).
  6. DIAGONALIZATION, VIA PRECONDITIONER. "Improving Adaptive Moment Optimization via Preconditioner Diagonalization."
  7. https://www.tensorflow.org/api_docs/python/tf/keras/optimizers/Adafactor
  8. https://pytorch.org/docs/stable/generated/torch.optim.Adafactor.html
  9. https://flax.readthedocs.io/en/v0.5.3/_autosummary/flax.optim.Adafactor.html