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>
33 lines
1.6 KiB
C++
33 lines
1.6 KiB
C++
|
|
#ifndef MODEL_H
|
|
#define MODEL_H
|
|
|
|
#include <string>
|
|
#include <map>
|
|
#include "funasrruntime.h"
|
|
namespace funasr {
|
|
class Model {
|
|
public:
|
|
virtual ~Model(){};
|
|
virtual void StartUtterance() = 0;
|
|
virtual void EndUtterance() = 0;
|
|
virtual void Reset() = 0;
|
|
virtual void InitAsr(const std::string &am_model, const std::string &am_cmvn, const std::string &am_config, int thread_num){};
|
|
virtual void InitAsr(const std::string &en_model, const std::string &de_model, const std::string &am_cmvn, const std::string &am_config, int thread_num){};
|
|
virtual void InitAsr(const std::string &am_model, const std::string &en_model, const std::string &de_model, const std::string &am_cmvn, const std::string &am_config, int thread_num){};
|
|
virtual void InitLm(const std::string &lm_file, const std::string &lm_config){};
|
|
virtual void InitFstDecoder(){};
|
|
virtual std::string Forward(float *din, int len, bool input_finished, const std::vector<std::vector<float>> &hw_emb={{0.0}}, void* wfst_decoder=nullptr){return "";};
|
|
virtual std::string Rescoring() = 0;
|
|
virtual void InitHwCompiler(const std::string &hw_model, int thread_num){};
|
|
virtual void InitSegDict(const std::string &seg_dict_model){};
|
|
virtual std::vector<std::vector<float>> CompileHotwordEmbedding(std::string &hotwords){return std::vector<std::vector<float>>();};
|
|
virtual std::string GetLang(){return "";};
|
|
};
|
|
|
|
Model *CreateModel(std::map<std::string, std::string>& model_path, int thread_num=1, ASR_TYPE type=ASR_OFFLINE);
|
|
Model *CreateModel(void* asr_handle, std::vector<int> chunk_size);
|
|
|
|
} // namespace funasr
|
|
#endif
|