Source code for lmcache.storage_backend.serde.fast_serde
import torch
from lmcache.logging import init_logger
from lmcache.storage_backend.serde.serde import Deserializer, Serializer
logger = init_logger(__name__)
[docs]
class FastSerializer(Serializer):
def __init__(self):
super().__init__()
[docs]
def to_bytes(self, t: torch.Tensor) -> bytes:
# make tensor into bit stream
buf = t.contiguous().cpu().view(torch.uint8).numpy().tobytes()
return buf
[docs]
class FastDeserializer(Deserializer):
def __init__(self):
super().__init__()
[docs]
def from_bytes_normal(self,
b: bytes,
dtype=torch.bfloat16) -> torch.Tensor:
return torch.frombuffer(b, dtype=dtype)
[docs]
def from_bytes(self, b: bytes) -> torch.Tensor:
return self.from_bytes_normal(b)