-
Notifications
You must be signed in to change notification settings - Fork 119
/
Copy pathsimple_tts.cpp
88 lines (73 loc) · 2.91 KB
/
simple_tts.cpp
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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
#include <filesystem>
#include <fstream>
#include <iostream>
#include <string>
#include "voicevox_core/voicevox_core.h"
#define STYLE_ID 0
#define OUTPUT_WAV_NAME "audio.wav"
int main(int argc, char *argv[]) {
if (argc != 2) {
std::cout << "使い方: ./simple_tts <文章>" << std::endl;
return 0;
}
std::string open_jtalk_dict_path("voicevox_core/open_jtalk_dic_utf_8-1.11");
std::string text(argv[1]);
std::cout << "coreの初期化中..." << std::endl;
auto initialize_options = voicevox_make_default_initialize_options();
const VoicevoxOnnxruntime* onnxruntime;
auto load_ort_options = voicevox_make_default_load_onnxruntime_options();
auto result = voicevox_onnxruntime_load_once(load_ort_options, &onnxruntime);
if (result != VOICEVOX_RESULT_OK){
std::cerr << voicevox_error_result_to_message(result) << std::endl;
return 1;
}
OpenJtalkRc* open_jtalk;
result = voicevox_open_jtalk_rc_new(open_jtalk_dict_path.c_str(),&open_jtalk);
if (result != VOICEVOX_RESULT_OK){
std::cerr << voicevox_error_result_to_message(result) << std::endl;
return 1;
}
VoicevoxSynthesizer* synthesizer;
result = voicevox_synthesizer_new(onnxruntime,open_jtalk,initialize_options,&synthesizer);
if (result != VOICEVOX_RESULT_OK) {
std::cerr << voicevox_error_result_to_message(result) << std::endl;
return 1;
}
voicevox_open_jtalk_rc_delete(open_jtalk);
for (auto const& entry :
std::filesystem::directory_iterator{"./voicevox_core/model"}) {
const auto path = entry.path();
if (path.extension() != ".vvm") {
continue;
}
VoicevoxVoiceModelFile* model;
result = voicevox_voice_model_file_open(path.c_str(), &model);
if (result != VoicevoxResultCode::VOICEVOX_RESULT_OK) {
std::cerr << voicevox_error_result_to_message(result) << std::endl;
return 0;
}
result = voicevox_synthesizer_load_voice_model(synthesizer, model);
if (result != VoicevoxResultCode::VOICEVOX_RESULT_OK) {
std::cerr << voicevox_error_result_to_message(result) << std::endl;
return 0;
}
voicevox_voice_model_file_close(model);
}
std::cout << "音声生成中..." << std::endl;
size_t output_wav_size = 0;
uint8_t *output_wav = nullptr;
result = voicevox_synthesizer_tts(synthesizer,text.c_str(), STYLE_ID,
voicevox_make_default_tts_options(),
&output_wav_size, &output_wav);
if (result != VOICEVOX_RESULT_OK) {
std::cerr << voicevox_error_result_to_message(result) << std::endl;
return 1;
}
std::cout << "音声ファイル保存中..." << std::endl;
std::ofstream wav_file(OUTPUT_WAV_NAME, std::ios::binary);
wav_file.write(reinterpret_cast<const char *>(output_wav), output_wav_size);
voicevox_wav_free(output_wav);
std::cout << "音声ファイル保存完了 (" << OUTPUT_WAV_NAME << ")" << std::endl;
voicevox_synthesizer_delete(synthesizer);
return 0;
}