Selaa lähdekoodia

llama : add missing kv clear in llama_beam_search (#6664)

David Renshaw 1 vuosi sitten
vanhempi
sitoutus
1958f7e06c
1 muutettua tiedostoa jossa 5 lisäystä ja 0 poistoa
  1. 5 0
      llama.cpp

+ 5 - 0
llama.cpp

@@ -13063,6 +13063,11 @@ struct llama_beam_search_data {
             }
             }
             llama_logit_info logit_info(ctx);
             llama_logit_info logit_info(ctx);
             std::vector<llama_token_data> next_tokens = logit_info.top_k(n_beams);
             std::vector<llama_token_data> next_tokens = logit_info.top_k(n_beams);
+
+            // Clear the kv slot so that other beams may try different tokens at this position. The llama_decode()
+            // call in loop() will conclusively fill in the kv slot once the beams converge at this position.
+            llama_kv_cache_seq_rm(ctx, 0, n_past, -1);
+
             size_t i=0;
             size_t i=0;
             if (next_beams.size() < n_beams) {
             if (next_beams.size() < n_beams) {
                 for (; next_beams.size() < n_beams ; ++i) {
                 for (; next_beams.size() < n_beams ; ++i) {