// sherpa-onnx/csrc/online-rnn-lm.h // // Copyright (c) 2023 Pingfeng Luo // Copyright (c) 2023 Xiaomi Corporation #ifndef SHERPA_ONNX_CSRC_ONLINE_RNN_LM_H_ #define SHERPA_ONNX_CSRC_ONLINE_RNN_LM_H_ #include #include #include #include "onnxruntime_cxx_api.h" // NOLINT #include "sherpa-onnx/csrc/online-lm-config.h" #include "sherpa-onnx/csrc/online-lm.h" namespace sherpa_onnx { class OnlineRnnLM : public OnlineLM { public: ~OnlineRnnLM() override; explicit OnlineRnnLM(const OnlineLMConfig &config); std::vector GetInitStates() override; /** Rescore a batch of sentences. * * @param x A 2-D tensor of shape (N, L) with data type int64. * @param y A 2-D tensor of shape (N, L) with data type int64. * @param states It contains the states for the LM model * @return Return a pair containingo * - negative loglike * - updated states * * Caution: It returns negative log likelihood (nll), not log likelihood */ std::pair> Rescore( Ort::Value x, Ort::Value y, std::vector states) override; private: class Impl; std::unique_ptr impl_; }; } // namespace sherpa_onnx #endif // SHERPA_ONNX_CSRC_ONLINE_RNN_LM_H_