mirror of
https://github.com/modelscope/FunASR
synced 2025-09-15 14:48:36 +08:00
* add hotword for deploy_tools * Support wfst decoder and contextual biasing (#1039) * Support wfst decoder and contextual biasing * Turn on fstbin compilation --------- Co-authored-by: gongbo.gb <gongbo.gb@alibaba-inc.com> * mv funasr/runtime runtime * Fix crash caused by OOV in hotwords list * funasr infer * funasr infer * funasr infer * funasr infer * funasr infer * fix some bugs about fst hotword; support wfst for websocket server and clients; mv runtime out of funasr; modify relative docs * del onnxruntime/include/gflags * update tensor.h * update run_server.sh * update deploy tools * update deploy tools * update websocket-server * update funasr-wss-server * Remove self loop propagation * Update websocket_protocol_zh.md * Update websocket_protocol_zh.md * update hotword protocol * author zhaomingwork: change hotwords for h5 and java * update hotword protocol * catch exception for json_fst_hws * update hotword on message * update onnx benchmark for ngram&hotword * update docs * update funasr-wss-serve * add NONE for LM_DIR * update docs * update run_server.sh * add whats-new * modify whats-new * update whats-new * update whats-new * Support decoder option for beam searching * update benchmark_onnx_cpp * Support decoder option for websocket * fix bug of CompileHotwordEmbedding * update html client * update docs --------- Co-authored-by: gongbo.gb <35997837+aibulamusi@users.noreply.github.com> Co-authored-by: gongbo.gb <gongbo.gb@alibaba-inc.com> Co-authored-by: 游雁 <zhifu.gzf@alibaba-inc.com>
36 lines
971 B
Python
Executable File
36 lines
971 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()))
|
|
|