mirror of
https://github.com/oobabooga/text-generation-webui.git
synced 2025-01-28 21:07:17 +01:00
124 lines
4.5 KiB
Python
124 lines
4.5 KiB
Python
import importlib
|
|
from typing import Sequence
|
|
|
|
from tqdm import tqdm
|
|
|
|
from modules import shared
|
|
from modules.cache_utils import process_llamacpp_cache
|
|
|
|
|
|
imported_module = None
|
|
|
|
|
|
def llama_cpp_lib():
|
|
global imported_module
|
|
|
|
return_lib = None
|
|
|
|
if shared.args.cpu:
|
|
if imported_module and imported_module != 'llama_cpp':
|
|
raise Exception(f"Cannot import 'llama_cpp' because '{imported_module}' is already imported. See issue #1575 in llama-cpp-python. Please restart the server before attempting to use a different version of llama-cpp-python.")
|
|
try:
|
|
return_lib = importlib.import_module('llama_cpp')
|
|
imported_module = 'llama_cpp'
|
|
except:
|
|
pass
|
|
|
|
if shared.args.tensorcores and return_lib is None:
|
|
if imported_module and imported_module != 'llama_cpp_cuda_tensorcores':
|
|
raise Exception(f"Cannot import 'llama_cpp_cuda_tensorcores' because '{imported_module}' is already imported. See issue #1575 in llama-cpp-python. Please restart the server before attempting to use a different version of llama-cpp-python.")
|
|
try:
|
|
return_lib = importlib.import_module('llama_cpp_cuda_tensorcores')
|
|
imported_module = 'llama_cpp_cuda_tensorcores'
|
|
except:
|
|
pass
|
|
|
|
if return_lib is None:
|
|
if imported_module and imported_module != 'llama_cpp_cuda':
|
|
raise Exception(f"Cannot import 'llama_cpp_cuda' because '{imported_module}' is already imported. See issue #1575 in llama-cpp-python. Please restart the server before attempting to use a different version of llama-cpp-python.")
|
|
try:
|
|
return_lib = importlib.import_module('llama_cpp_cuda')
|
|
imported_module = 'llama_cpp_cuda'
|
|
except:
|
|
pass
|
|
|
|
if return_lib is None and not shared.args.cpu:
|
|
if imported_module and imported_module != 'llama_cpp':
|
|
raise Exception(f"Cannot import 'llama_cpp' because '{imported_module}' is already imported. See issue #1575 in llama-cpp-python. Please restart the server before attempting to use a different version of llama-cpp-python.")
|
|
try:
|
|
return_lib = importlib.import_module('llama_cpp')
|
|
imported_module = 'llama_cpp'
|
|
except:
|
|
pass
|
|
|
|
if return_lib is not None:
|
|
monkey_patch_llama_cpp_python(return_lib)
|
|
|
|
return return_lib
|
|
|
|
|
|
def eval_with_progress(self, tokens: Sequence[int]):
|
|
"""
|
|
A copy of
|
|
|
|
https://github.com/abetlen/llama-cpp-python/blob/main/llama_cpp/llama.py
|
|
|
|
with tqdm to show prompt processing progress.
|
|
"""
|
|
assert self._ctx.ctx is not None
|
|
assert self._batch.batch is not None
|
|
self._ctx.kv_cache_seq_rm(-1, self.n_tokens, -1)
|
|
|
|
if len(tokens) > 1:
|
|
progress_bar = tqdm(range(0, len(tokens), self.n_batch), desc="Prompt evaluation", leave=False)
|
|
else:
|
|
progress_bar = range(0, len(tokens), self.n_batch)
|
|
|
|
for i in progress_bar:
|
|
batch = tokens[i : min(len(tokens), i + self.n_batch)]
|
|
n_past = self.n_tokens
|
|
n_tokens = len(batch)
|
|
self._batch.set_batch(
|
|
batch=batch, n_past=n_past, logits_all=self.context_params.logits_all
|
|
)
|
|
self._ctx.decode(self._batch)
|
|
# Save tokens
|
|
self.input_ids[n_past : n_past + n_tokens] = batch
|
|
# Save logits
|
|
if self.context_params.logits_all:
|
|
rows = n_tokens
|
|
cols = self._n_vocab
|
|
logits = self._ctx.get_logits()[: rows * cols]
|
|
self.scores[n_past : n_past + n_tokens, :].reshape(-1)[: :] = logits
|
|
else:
|
|
rows = 1
|
|
cols = self._n_vocab
|
|
logits = self._ctx.get_logits()[: rows * cols]
|
|
self.scores[n_past + n_tokens - 1, :].reshape(-1)[: :] = logits
|
|
# Update n_tokens
|
|
self.n_tokens += n_tokens
|
|
|
|
|
|
def monkey_patch_llama_cpp_python(lib):
|
|
if getattr(lib.Llama, '_is_patched', False):
|
|
# If the patch is already applied, do nothing
|
|
return
|
|
|
|
def my_generate(self, *args, **kwargs):
|
|
if shared.args.streaming_llm:
|
|
new_sequence = args[0]
|
|
past_sequence = self._input_ids
|
|
|
|
# Do the cache trimming for StreamingLLM
|
|
process_llamacpp_cache(self, new_sequence, past_sequence)
|
|
|
|
for output in self.original_generate(*args, **kwargs):
|
|
yield output
|
|
|
|
lib.Llama.eval = eval_with_progress
|
|
lib.Llama.original_generate = lib.Llama.generate
|
|
lib.Llama.generate = my_generate
|
|
|
|
# Set the flag to indicate that the patch has been applied
|
|
lib.Llama._is_patched = True
|