FunASR/runtime/tools/fst/generate_lexicon.py
zhifu gao 861147c730
Dev gzf exp (#1654)
* 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>
2024-04-24 16:03:38 +08:00

36 lines
953 B
Python
Executable File

#!/usr/bin/env python3
# encoding: utf-8
import sys
# sys.argv[1]: lm dict
# sys.argv[2]: lexicon file
# sys.argv[3]: lexicon file for corpus.dict
lex_dict = {}
with open(sys.argv[2], "r", encoding="utf8") as fin:
for line in fin:
words = line.strip().split("\t")
if len(words) != 2:
continue
lex_dict[words[0]] = words[1]
with open(sys.argv[1], "r", encoding="utf8") as fin, open(
sys.argv[3], "w", encoding="utf8"
) as fout:
for line in fin:
word = line.strip()
if word == "<s>" or word == "</s>":
continue
word_lex = ""
if word in lex_dict:
word_lex = lex_dict[word]
else:
for i in range(len(word)):
if word[i] in lex_dict:
word_lex += " " + lex_dict[word[i]]
else:
word_lex += " <unk>"
fout.write("{}\t{}\n".format(word, word_lex.strip()))