2023-12-14 10:37:07 +00:00
|
|
|
from typing import Any, List, Union
|
|
|
|
|
|
|
|
try:
|
|
|
|
import web_rwkv_py as wrp
|
|
|
|
except ModuleNotFoundError:
|
|
|
|
try:
|
|
|
|
from . import web_rwkv_py as wrp
|
|
|
|
except ImportError:
|
|
|
|
raise ModuleNotFoundError(
|
|
|
|
"web_rwkv_py not found, install it from https://github.com/cryscan/web-rwkv-py"
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
class RWKV:
|
2023-12-14 12:39:42 +00:00
|
|
|
def __init__(self, model_path: str, strategy: str = None):
|
2024-03-01 06:23:05 +00:00
|
|
|
layer = (
|
|
|
|
int(s.lstrip("layer"))
|
|
|
|
for s in strategy.split()
|
|
|
|
for s in s.split(",")
|
|
|
|
if s.startswith("layer")
|
|
|
|
)
|
|
|
|
|
2024-03-02 08:41:29 +00:00
|
|
|
chunk_size = (
|
|
|
|
int(s.lstrip("chunk"))
|
|
|
|
for s in strategy.split()
|
|
|
|
for s in s.split(",")
|
|
|
|
if s.startswith("chunk")
|
|
|
|
)
|
2024-05-28 13:27:10 +00:00
|
|
|
self.token_chunk_size = next(chunk_size, 32)
|
2024-03-02 08:41:29 +00:00
|
|
|
|
2024-02-03 12:32:23 +00:00
|
|
|
args = {
|
2024-05-28 13:27:10 +00:00
|
|
|
"path": model_path,
|
2024-03-01 06:23:05 +00:00
|
|
|
"quant": next(layer, 31) if "i8" in strategy else 0,
|
|
|
|
"quant_nf4": next(layer, 26) if "i4" in strategy else 0,
|
2024-02-03 12:32:23 +00:00
|
|
|
}
|
2024-05-28 13:27:10 +00:00
|
|
|
self.model = wrp.Model(**args)
|
|
|
|
self.info = self.model.info()
|
|
|
|
self.w = {} # fake weight
|
|
|
|
self.w["emb.weight"] = [0] * self.info.num_vocab
|
|
|
|
self.version = str(self.info.version).lower()
|
|
|
|
self.version = float(self.version.lower().replace("v", ""))
|
2023-12-14 10:37:07 +00:00
|
|
|
|
|
|
|
def forward(self, tokens: List[int], state: Union[Any, None] = None):
|
2024-05-28 13:27:10 +00:00
|
|
|
if state is None:
|
|
|
|
self.model.clear_state()
|
|
|
|
elif type(state).__name__ == "State_Cpu":
|
|
|
|
self.model.load_state(state)
|
|
|
|
logits = self.model.run(tokens, self.token_chunk_size)
|
|
|
|
ret_state = "State_Gpu"
|
|
|
|
return logits, ret_state
|