mirror of
https://github.com/modelscope/FunASR
synced 2025-09-15 14:48:36 +08:00
* sensevoice finetune * sensevoice finetune * sensevoice finetune * sensevoice finetune * sensevoice finetune * sensevoice finetune * sensevoice finetune * sensevoice finetune * sensevoice finetune * sensevoice finetune * bugfix * update with main (#1631) * update seaco finetune * v1.0.24 --------- Co-authored-by: 维石 <shixian.shi@alibaba-inc.com> * sensevoice * sensevoice * sensevoice * update with main (#1638) * update seaco finetune * v1.0.24 * update rwkv template --------- Co-authored-by: 维石 <shixian.shi@alibaba-inc.com> * sensevoice * sensevoice * sensevoice * sensevoice * sensevoice * sensevoice * sensevoice * sensevoice * sensevoice * sensevoice * sensevoice * sensevoice * sensevoice * sensevoice * sensevoice * sense voice * sense voice * sense voice * sense voice * sense voice * sense voice * sense voice * sense voice * sense voice * sense voice * sense voice * sense voice * sense voice * sense voice * sense voice * sense voice * sense voice * sense voice * sense voice * sense voice * whisper * whisper * update style * update style --------- Co-authored-by: 维石 <shixian.shi@alibaba-inc.com>
48 lines
1.6 KiB
Python
48 lines
1.6 KiB
Python
from pathlib import Path
|
|
from typing import Iterable
|
|
from typing import List
|
|
from typing import Union
|
|
|
|
import sentencepiece as spm
|
|
|
|
from funasr.tokenizer.abs_tokenizer import BaseTokenizer
|
|
from funasr.register import tables
|
|
|
|
|
|
@tables.register("tokenizer_classes", "SentencepiecesTokenizer")
|
|
class SentencepiecesTokenizer(BaseTokenizer):
|
|
def __init__(self, bpemodel: Union[Path, str], **kwargs):
|
|
super().__init__(**kwargs)
|
|
self.bpemodel = str(bpemodel)
|
|
# NOTE(kamo):
|
|
# Don't build SentencePieceProcessor in __init__()
|
|
# because it's not picklable and it may cause following error,
|
|
# "TypeError: can't pickle SwigPyObject objects",
|
|
# when giving it as argument of "multiprocessing.Process()".
|
|
self.sp = None
|
|
|
|
def __repr__(self):
|
|
return f'{self.__class__.__name__}(model="{self.bpemodel}")'
|
|
|
|
def _build_sentence_piece_processor(self):
|
|
# Build SentencePieceProcessor lazily.
|
|
if self.sp is None:
|
|
self.sp = spm.SentencePieceProcessor()
|
|
self.sp.load(self.bpemodel)
|
|
|
|
def text2tokens(self, line: str) -> List[str]:
|
|
self._build_sentence_piece_processor()
|
|
return self.sp.EncodeAsPieces(line)
|
|
|
|
def tokens2text(self, tokens: Iterable[str]) -> str:
|
|
self._build_sentence_piece_processor()
|
|
return self.sp.DecodePieces(list(tokens))
|
|
|
|
def encode(self, line: str) -> List[int]:
|
|
self._build_sentence_piece_processor()
|
|
return self.sp.EncodeAsIds(line)
|
|
|
|
def decode(self, line: List[int]):
|
|
self._build_sentence_piece_processor()
|
|
return self.sp.DecodeIds(line)
|