a smol course documentation

Tinh Chỉnh Theo Sự Ưu Tiên (Preference Alignment)

Hugging Face's logo
Join the Hugging Face community

and get access to the augmented documentation experience

to get started

Tinh Chỉnh Theo Sự Ưu Tiên (Preference Alignment)

Trong chương này, bạn sẽ học về các kỹ thuật tinh chỉnh mô hình ngôn ngữ theo sự ưu tiên của con người. Trong khi học có giám sát giúp mô hình học các tác vụ, tinh chỉnh theo sự ưu tiên khuyến khích đầu ra phù hợp với kỳ vọng và giá trị của con người.

Tổng Quan

Các phương pháp tinh chỉnh theo sự ưu tiên thường bao gồm 2 giai đoạn:

  1. Bắt đầu bằng quá trình học có giám sát (SFT) để thích ứng mô hình với các lĩnh vực cụ thể
  2. Sau đó, tinh chỉnh mô hình theo sự ưu tiên (như RLHF hoặc DPO) để cải thiện chất lượng phản hồi

Các phương pháp thay thế như ORPO kết hợp cả tinh chỉnh theo chỉ thịtinh chỉnh theo sự ưu tiên thành 1 giai đoạn tinh chỉnh duy nhất. Ở đây, chúng ta sẽ tập trung vào các thuật toán DPO và ORPO.

Nếu bạn muốn tìm hiểu thêm về các kỹ thuật tinh chỉnh khác, bạn có thể đọc thêm tại Argilla Blog.

1️⃣ Tối Ưu Hóa Ưu Tiên Trực Tiếp (Direct Preference Optimization - DPO)

Phương pháp này đơn giản hóa quá trình tinh chỉnh theo chỉ thị bằng cách tối ưu hóa trực tiếp mô hình sử dụng dữ liệu ưu tiên (preference data). Phương pháp này loại bỏ nhu cầu về các Mô hình thưởng phạt (Reward model) riêng biệt và Học tăng cường phức tạp, giúp quá trình ổn định và hiệu quả hơn so với Học tăng cường từ phản hồi của con người (RLHF) truyền thống. Để biết thêm chi tiết, bạn có thể tham khảo tài liệu tối ưu hóa ưu tiên trực tiếp (DPO).

2️⃣ Tối Ưu Hóa Ưu Tiên Theo Tỷ Lệ Odds (Odds Ratio Preference Optimization - ORPO)

ORPO giới thiệu một phương pháp kết hợp cả 2 giai đoạn tinh chỉnh theo chỉ thịtinh chỉnh theo sự ưu tiên vào trong 1 giai đoạn tinh chỉnh duy nhất. Phương pháp này điều chỉnh mục tiêu tiêu chuẩn của mô hình ngôn ngữ bằng cách kết hợp negative log-likelihood loss với một tỷ lệ odds ở cấp độ token. Vì vậy, ORPO tạo ra 1 quá trình tinh chỉnh thống nhất với kiến trúc không cần mô hình thưởng phạt và cải thiện đáng kể hiệu quả tính toán. ORPO đã cho thấy kết quả ấn tượng trên nhiều benchmark, thể hiện hiệu suất tốt hơn trên AlpacaEval so với các phương pháp truyền thống. Để biết thêm chi tiết, bạn có thể tham khảo tài liệu tối ưu hóa ưu tiên theo tỷ lệ odds (ORPO).

Resources

  • Tài liệu thư viện TRL - Tài liệu cho thư viện Transformers Reinforcement Learning (TRL), triển khai nhiều kỹ thuật căn chỉnh bao gồm DPO và ORPO.
  • Bài báo nghiên cứu DPO - bài nghiên cứu gốc giới thiệu tối ưu hóa ưu tiên trực tiếp như một giải pháp thay thế đơn giản hơn cho RLHF.
  • Bài báo nghiên cứu ORPO - Giới thiệu Odds Ratio Preference Optimization, một phương pháp mới kết hợp tinh chỉnh theo chỉ thịtinh chỉnh theo sự ưu tiên thành 1
  • Bài hướng dẫn của Argilla - Hướng dẫn giải thích các kỹ thuật căn chỉnh khác nhau bao gồm RLHF, DPO và cách triển khai thực tế.
  • Blog về DPO - Hướng dẫn thực hành về triển khai DPO sử dụng thư viện TRL với các ví dụ code và phương pháp tốt nhất.
  • Code mẫu cho DPO trong thư viên TRL - Code mẫu về cách triển khai tinh chỉnh DPO sử dụng thư viện TRL.
  • Code mẫu cho ORPD trong thư viên TRL - Code mẫu của tinh chỉnh ORPO sử dụng thư viện TRL với các tùy chọn cấu hình chi tiết.
  • Hugging Face Alignment Handbook - Hướng dẫn và codebase cho việc tinh chỉnh mô hình ngôn ngữ sử dụng các kỹ thuật khác nhau bao gồm SFT, DPO và RLHF.
Update on GitHub