offline-speaker-segmentation-pyannote-model-config.cc
1.0 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
// sherpa-onnx/csrc/offline-speaker-segmentation-pyannote-model-config.cc
//
// Copyright (c) 2024 Xiaomi Corporation
#include "sherpa-onnx/csrc/offline-speaker-segmentation-pyannote-model-config.h"
#include <sstream>
#include <string>
#include "sherpa-onnx/csrc/file-utils.h"
#include "sherpa-onnx/csrc/macros.h"
namespace sherpa_onnx {
void OfflineSpeakerSegmentationPyannoteModelConfig::Register(ParseOptions *po) {
po->Register("pyannote-model", &model,
"Path to model.onnx of the Pyannote segmentation model.");
}
bool OfflineSpeakerSegmentationPyannoteModelConfig::Validate() const {
if (!FileExists(model)) {
SHERPA_ONNX_LOGE("Pyannote segmentation model: '%s' does not exist",
model.c_str());
return false;
}
return true;
}
std::string OfflineSpeakerSegmentationPyannoteModelConfig::ToString() const {
std::ostringstream os;
os << "OfflineSpeakerSegmentationPyannoteModelConfig(";
os << "model=\"" << model << "\")";
return os.str();
}
} // namespace sherpa_onnx