From e0fa63765bfb4a36bde7047c2a6066ca5a80e90f Mon Sep 17 00:00:00 2001
From: Yabin Li <wucong.lyb@alibaba-inc.com>
Date: 星期一, 21 八月 2023 10:37:42 +0800
Subject: [PATCH] Dev hw (#878)
---
funasr/runtime/onnxruntime/src/paraformer.h | 15 ++++++++++++++-
1 files changed, 14 insertions(+), 1 deletions(-)
diff --git a/funasr/runtime/onnxruntime/src/paraformer.h b/funasr/runtime/onnxruntime/src/paraformer.h
index 0dd55b5..4080881 100644
--- a/funasr/runtime/onnxruntime/src/paraformer.h
+++ b/funasr/runtime/onnxruntime/src/paraformer.h
@@ -16,6 +16,7 @@
*/
private:
Vocab* vocab = nullptr;
+ SegDict* seg_dict = nullptr;
//const float scale = 22.6274169979695;
const float scale = 1.0;
@@ -23,6 +24,14 @@
void LoadCmvn(const char *filename);
vector<float> ApplyLfr(const vector<float> &in);
void ApplyCmvn(vector<float> *v);
+
+ std::shared_ptr<Ort::Session> hw_m_session = nullptr;
+ Ort::Env hw_env_;
+ Ort::SessionOptions hw_session_options;
+ vector<string> hw_m_strInputNames, hw_m_strOutputNames;
+ vector<const char*> hw_m_szInputNames;
+ vector<const char*> hw_m_szOutputNames;
+ bool use_hotword;
public:
Paraformer();
@@ -32,13 +41,17 @@
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);
// 2pass
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);
+ void InitHwCompiler(const std::string &hw_model, int thread_num);
+ void InitSegDict(const std::string &seg_dict_model);
+ std::vector<std::vector<float>> CompileHotwordEmbedding(std::string &hotwords);
void Reset();
vector<float> FbankKaldi(float sample_rate, const float* waves, int len);
- string Forward(float* din, int len, bool input_finished=true);
+ string Forward(float* din, int len, bool input_finished=true, const std::vector<std::vector<float>> &hw_emb={{0.0}});
string GreedySearch( float* in, int n_len, int64_t token_nums, bool is_stamp=false, std::vector<float> us_alphas={0}, std::vector<float> us_cif_peak={0});
void TimestampOnnx(std::vector<float> &us_alphas, vector<float> us_cif_peak, vector<string>& char_list, std::string &res_str,
vector<vector<float>> ×tamp_list, float begin_time = 0.0, float total_offset = -1.5);
string PostProcess(std::vector<string> &raw_char, std::vector<std::vector<float>> ×tamp_list);
+
string Rescoring();
knf::FbankOptions fbank_opts_;
--
Gitblit v1.9.1