trl-mcsd / docs /source /liger_kernel_integration.md
ihbkaiser's picture
Implement MCSD for experimental SDPO
1fa3c6c verified

Liger Kernel Integration

Liger Kernel is a collection of Triton kernels designed specifically for LLM training. It can effectively increase multi-GPU training throughput by 20% and reduce memory usage by 60%. That way, we can 4x our context length, as described in the benchmark below. They have implemented Hugging Face compatible RMSNorm, RoPE, SwiGLU, CrossEntropy, FusedLinearCrossEntropy, with more to come. The kernel works out of the box with FlashAttention, PyTorch FSDP, and Microsoft DeepSpeed.

With this memory reduction, you can potentially turn off cpu_offloading or gradient checkpointing to further boost the performance.

Speed Up Memory Reduction
Speed up Memory

Supported Trainers

Liger Kernel is supported in the following TRL trainers:

  • SFT (Supervised Fine-Tuning)
  • DPO (Direct Preference Optimization)
  • GRPO (Group Relative Policy Optimization)
  • KTO (Kahneman-Tversky Optimization)
  • GKD (Generalized Knowledge Distillation)

Usage

  1. First, install Liger Kernel:
pip install liger-kernel
  1. Once installed, set use_liger_kernel=True in your trainer config. No other changes are needed!
from trl import SFTConfig

training_args = SFTConfig(..., use_liger_kernel=True)
from trl import DPOConfig

training_args = DPOConfig(..., use_liger_kernel=True)
from trl import GRPOConfig

training_args = GRPOConfig(..., use_liger_kernel=True)
from trl import KTOConfig

training_args = KTOConfig(..., use_liger_kernel=True)
from trl.experimental.gkd import GKDConfig

training_args = GKDConfig(..., use_liger_kernel=True)

To learn more about Liger-Kernel, visit their official repository.