Tại sao Q-learning thường xuyên (và DQN) lại đánh giá quá cao các giá trị Q?

Jan 10 2021

Động lực cho sự ra đời của DQN kép (và Q-learning kép) là Q-learning thông thường (hoặc DQN) có thể đánh giá quá cao giá trị Q, nhưng có lời giải thích ngắn gọn về lý do tại sao nó được đánh giá quá cao không?

Trả lời

3 DavidIreland Jan 11 2021 at 00:44

Ước tính quá mức xuất phát từ việc khởi tạo ngẫu nhiên các ước tính giá trị Q của bạn. Rõ ràng là những thứ này sẽ không hoàn hảo (nếu là chúng thì chúng ta sẽ không cần học các giá trị Q thực sự!). Trong nhiều phương pháp học tập củng cố dựa trên giá trị như SARSA hoặc Q-learning, các thuật toán liên quan đến$\max$nhà điều hành trong việc xây dựng chính sách mục tiêu. Như bạn đã đề cập, trường hợp rõ ràng nhất là Q-learning. Cập nhật học tập là$$Q(s, a) = Q(s, a) + \alpha \left[r(s, a) + \gamma \max_a Q(s', a) - Q(s, a) \right] \;.$$Hàm Q cho bộ hành động trạng thái mà chúng ta đang xem xét được chuyển sang hàm Q tối đa ở trạng thái tiếp theo, nơi$\max$ được thực hiện đối với các hành động.

Bây giờ, như đã đề cập, ước tính ban đầu của chúng tôi về giá trị Q được khởi tạo ngẫu nhiên. Điều này đương nhiên dẫn đến các giá trị không chính xác. Hệ quả của việc này là khi chúng ta tính toán$\max_aQ(s', a)$chúng ta có thể đang chọn các giá trị được đánh giá quá cao .

Vì Q-learning (trong trường hợp dạng bảng) được đảm bảo hội tụ (theo một số giả định nhẹ) nên hậu quả chính của sự thiên lệch đánh giá quá cao là làm chậm sự hội tụ một cách nghiêm trọng. Tất nhiên điều này có thể được khắc phục với Double Q-learning.

Câu trả lời ở trên dành cho trường hợp Q-Learning dạng bảng. Ý tưởng tương tự đối với Deep Q-Learning, ngoại trừ lưu ý rằng Deep Q-learning không có đảm bảo hội tụ (khi sử dụng NN làm công cụ xấp xỉ hàm) và do đó, sai lệch đánh giá quá cao là một vấn đề vì nó có thể có nghĩa là các tham số của mạng bị mắc kẹt trong các giá trị dưới mức tối ưu.

Như một người nào đó đã hỏi trong các nhận xét về việc luôn khởi tạo các giá trị là những con số rất thấp, điều này sẽ không thực sự hiệu quả.

Hãy xem xét MDP sau được lấy từ Sutton và Barto: Chúng ta bắt đầu ở trạng thái A, từ đó chúng ta có thể đi sang phải với phần thưởng 0 dẫn đến trạng thái cuối hoặc đi sang trái với phần thưởng 0 đến trạng thái B. Từ trạng thái B, chúng ta có thể lấy, 100 hành động khác nhau, tất cả đều dẫn đến trạng thái đầu cuối và có phần thưởng được rút ra từ phân phối Chuẩn với giá trị trung bình -0,1 và phương sai 1.

Bây giờ, rõ ràng hành động tối ưu từ trạng thái A là đi đúng. Tuy nhiên, khi chúng ta đi sang trái và thực hiện một hành động ở trạng thái B, có (gần như) 0,5 xác suất nhận được phần thưởng lớn hơn 0. Bây giờ, hãy nhớ lại rằng giá trị Q được dịch chuyển về phía$r(s, a) + \max_a Q(s', a)$; vì phần thưởng ngẫu nhiên khi chuyển ra khỏi trạng thái B và thực tế là chúng ta có thể sẽ thấy phần thưởng tích cực$\max_a Q(s', a)$ sẽ tích cực.

Điều này có nghĩa là khi chúng ta thực hiện hành động bên trái, giá trị Q (Q (A, trái)) được chuyển sang một giá trị dương, có nghĩa là khi chúng ta ở trạng thái A, giá trị di chuyển sang trái sẽ cao hơn di chuyển sang phải (điều này sẽ dần dần được dịch chuyển về phía giá trị thực của 0) và vì vậy khi theo sau $\epsilon$-chính sách tham lam hành động tham lam sẽ được thực hiện bên trái khi trên thực tế đây là hành động dưới mức tối ưu.

Tất nhiên, bây giờ chúng ta biết rằng các giá trị Q thực cuối cùng sẽ hội tụ nhưng nếu chúng ta có, chẳng hạn như 100 hành động thì bạn có thể thấy rằng thời gian để các giá trị Q hội tụ thành giá trị thực sẽ có khả năng là một thời gian dài vì chúng tôi sẽ phải tiếp tục chọn tất cả các giá trị được đánh giá quá cao cho đến khi chúng tôi có sự hội tụ.