/** * Copyright FunASR (https://github.com/alibaba-damo-academy/FunASR). All Rights Reserved. * MIT License (https://opensource.org/licenses/MIT) */ #pragma once namespace funasr { class CTTransformer : public PuncModel { /** * Author: Speech Lab of DAMO Academy, Alibaba Group * CT-Transformer: Controllable time-delay transformer for real-time punctuation prediction and disfluency detection * https://arxiv.org/pdf/2003.01309.pdf */ private: CTokenizer m_tokenizer; vector m_strInputNames, m_strOutputNames; vector m_szInputNames; vector m_szOutputNames; std::shared_ptr m_session; Ort::Env env_; Ort::SessionOptions session_options; public: CTTransformer(); void InitPunc(const std::string &punc_model, const std::string &punc_config, const std::string &token_file, int thread_num); ~CTTransformer(); vector Infer(vector input_data); string AddPunc(const char* sz_input, std::string language="zh-cn"); }; } // namespace funasr