Răsfoiți Sursa

fix bug when cache assignment surpasses max length

justheuristic 3 ani în urmă
părinte
comite
93951779e1
1 a modificat fișierele cu 3 adăugiri și 2 ștergeri
  1. 3 2
      src/server/backend.py

+ 3 - 2
src/server/backend.py

@@ -84,8 +84,9 @@ class TransformerBackend(ModuleBackend):
                 assert new_k.shape[0] == past_k.shape[0] and new_v.shape[0] == past_v.shape[0]
                 assert new_k.shape[1] == new_length and new_v.shape[1] == new_length
                 assert new_k.shape[2:] == past_k.shape[2:] and new_v.shape[2:] == past_v.shape[2:]
-                cache[0, :, prefix_length:new_length, :] = new_k[:, prefix_length:new_length]
-                cache[1, :, prefix_length:new_length, :] = new_v[:, prefix_length:new_length]
+                if new_length < cache.shape[1]:
+                    cache[0, :, prefix_length:new_length, :] = new_k[:, prefix_length:new_length]
+                    cache[1, :, prefix_length:new_length, :] = new_v[:, prefix_length:new_length]
                 return (hidden_states,)
 
     def get_pools(self) -> Sequence[TaskPool]: