-
Notifications
You must be signed in to change notification settings - Fork 30
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
ai: Proximal Policy Optimization (#220)
- Loading branch information
Showing
1 changed file
with
52 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,52 @@ | ||
--- | ||
tags: | ||
- engineering | ||
- ai | ||
- ppo | ||
- chatgpt | ||
- llm | ||
- reinforcement | ||
title: "Proximal Policy Optimization" | ||
date: 2024-07-03 | ||
authors: | ||
- thanhpn | ||
--- | ||
## Introduction | ||
Proximal Policy Optimization (PPO) is an algorithm that aims to improve the stability of training by avoiding overly large policy updates. It is a popular and effective method used for training [[Reinforcement Learning | reinforcement learning]] models in complex environments. To achieve this, PPO uses a ratio that indicates the difference between the current policy and the old policy and clips this ratio within a specific range, ensuring that the policy updates are not too large and the training process is more stable. | ||
|
||
## How does PPO work? | ||
|
||
PPO uses the gradient ascent method to search for the optimal policy, but it applies constraints on policy changes by limiting the distance (clipping) between the old policy and the new policy. This helps control the policy update process to avoid excessive changes while ensuring stability and effectiveness in learning. | ||
|
||
There are two approaches to accomplish this: | ||
|
||
- *TRPO (Trust Region Policy Optimization)* is complex to implement and computationally expensive. It uses outer KL-divergence constraints on the objective function to limit policy updates. | ||
- *PPO's Clipped Surrogate Objective* substitutes the KL-divergence constraints with its own clipped objective function. | ||
|
||
## How to apply PPO for training large language models? | ||
Large language models are trained with billions of parameters and produce impressive results. However, during actual operation, these models may introduce errors and inaccurate outputs. To address this, experts have applied reinforcement learning to improve the quality. PPO is used to fine-tune the models based on curated prompts and enhance the performance to provide more user-friendly responses. It was use in step 3 when we trained the RL model. | ||
|
||
In this context, the policy refers to the pre-trained Language Model (LLM) that is being fine-tuned. We construct both the policy function and the value function. | ||
|
||
- The policy function is responsible for generating sentences in a specific prompt. It can be a large language model | ||
- The value function is The scalar value obtained from the reward function. It measures the expected value of an input (prompt) or a state-action pair and is used to estimate the advantage of action during policy updates. | ||
|
||
To apply the PPO algorithm for language model training, the training process typically involves the following steps: | ||
|
||
- Data Sampling: Use the current model to generate responses and collect training data. | ||
- Model Update: Apply the PPO algorithm to update the model parameters based on the collected training data. | ||
- Model Evaluation: Evaluate the model's performance by calculating metrics such as accuracy, perplexity, or similar evaluation measures. | ||
|
||
## Comparing PPO with Other Algorithms | ||
|
||
- *RAFT Alignment*: It is a method in transfer learning that leverages knowledge learned from a source task to a related target task. It allows reusing learned knowledge from the source model to quickly achieve high performance on the target task without retraining from scratch. | ||
- *TRPO*: It utilizes an optimization mechanism that ensures gradual policy changes and restricts policy updates within a trust region. It guarantees that policy updates do not cause significant changes and instability. TRPO is a powerful algorithm but has complex computations and longer training times. In contrast, PPO is a simpler, more efficient, and stable algorithm. | ||
- *PPO2*: It is simply an updated version of the algorithm released by OpenAI. PPO2 is an implementation optimized for GPU-accelerated vectorized environments and provides better support for parallel training. While it has some differences (e.g., automatically normalized advantages and clipped value functions), it uses the same mathematical framework as described in this article. If you plan to use the OpenAI implementation directly, keep in mind that PPO is outdated, and you should use PPO2 instead. | ||
|
||
To summarize, PPO has quickly gained popularity in continuous control problems. It seems to strike a suitable balance between speed, caution, and usability. While lacking theoretical guarantees and mathematical intricacies like natural gradients and TRPO, PPO tends to converge faster and perform better compared to its competing counterparts. | ||
|
||
## References | ||
|
||
- https://towardsdatascience.com/proximal-policy-optimization-ppo-explained-abed1952457b | ||
- https://medium.com/@mlblogging.k/reinforcement-learning-for-tuning-language-models-how-chatgpt-is-trained-9ecf23518302 | ||
- https://openai.com/research/learning-to-summarize-with-human-feedback |