mirror of
https://github.com/mozilla/DeepSpeech.git
synced 2025-10-26 11:19:39 +00:00
143 lines
3.3 KiB
C++
143 lines
3.3 KiB
C++
#ifndef __ARGS_H__
|
|
#define __ARGS_H__
|
|
|
|
#if defined(_MSC_VER)
|
|
#include "getopt_win.h"
|
|
#else
|
|
#include <getopt.h>
|
|
#endif
|
|
#include <iostream>
|
|
|
|
#include "deepspeech.h"
|
|
|
|
char* model = NULL;
|
|
|
|
char* alphabet = NULL;
|
|
|
|
char* lm = NULL;
|
|
|
|
char* trie = NULL;
|
|
|
|
char* audio = NULL;
|
|
|
|
bool load_without_trie = false;
|
|
|
|
bool show_times = false;
|
|
|
|
bool has_versions = false;
|
|
|
|
bool extended_metadata = false;
|
|
|
|
bool json_output = false;
|
|
|
|
void PrintHelp(const char* bin)
|
|
{
|
|
std::cout <<
|
|
"Usage: " << bin << " --model MODEL --alphabet ALPHABET [--lm LM --trie TRIE] --audio AUDIO [-t] [-e]\n"
|
|
"\n"
|
|
"Running DeepSpeech inference.\n"
|
|
"\n"
|
|
" --model MODEL Path to the model (protocol buffer binary file)\n"
|
|
" --alphabet ALPHABET Path to the configuration file specifying the alphabet used by the network\n"
|
|
" --lm LM Path to the language model binary file\n"
|
|
" --trie TRIE Path to the language model trie file created with native_client/generate_trie\n"
|
|
" --audio AUDIO Path to the audio file to run (WAV format)\n"
|
|
" -t Run in benchmark mode, output mfcc & inference time\n"
|
|
" --extended Output string from extended metadata\n"
|
|
" --json Extended output, shows word timings as JSON\n"
|
|
" --help Show help\n"
|
|
" --version Print version and exits\n";
|
|
DS_PrintVersions();
|
|
exit(1);
|
|
}
|
|
|
|
bool ProcessArgs(int argc, char** argv)
|
|
{
|
|
const char* const short_opts = "m:a:l:r:w:tehv";
|
|
const option long_opts[] = {
|
|
{"model", required_argument, nullptr, 'm'},
|
|
{"alphabet", required_argument, nullptr, 'a'},
|
|
{"lm", required_argument, nullptr, 'l'},
|
|
{"trie", required_argument, nullptr, 'r'},
|
|
{"audio", required_argument, nullptr, 'w'},
|
|
{"run_very_slowly_without_trie_I_really_know_what_Im_doing", no_argument, nullptr, 999},
|
|
{"t", no_argument, nullptr, 't'},
|
|
{"extended", no_argument, nullptr, 'e'},
|
|
{"json", no_argument, nullptr, 'j'},
|
|
{"help", no_argument, nullptr, 'h'},
|
|
{"version", no_argument, nullptr, 'v'},
|
|
{nullptr, no_argument, nullptr, 0}
|
|
};
|
|
|
|
while (true)
|
|
{
|
|
const auto opt = getopt_long(argc, argv, short_opts, long_opts, nullptr);
|
|
|
|
if (-1 == opt)
|
|
break;
|
|
|
|
switch (opt)
|
|
{
|
|
case 'm':
|
|
model = optarg;
|
|
break;
|
|
|
|
case 'a':
|
|
alphabet = optarg;
|
|
break;
|
|
|
|
case 'l':
|
|
lm = optarg;
|
|
break;
|
|
|
|
case 'r':
|
|
trie = optarg;
|
|
break;
|
|
|
|
case 'w':
|
|
audio = optarg;
|
|
break;
|
|
|
|
case 999:
|
|
load_without_trie = true;
|
|
break;
|
|
|
|
case 't':
|
|
show_times = true;
|
|
break;
|
|
|
|
case 'v':
|
|
has_versions = true;
|
|
break;
|
|
|
|
case 'e':
|
|
extended_metadata = true;
|
|
break;
|
|
|
|
case 'j':
|
|
json_output = true;
|
|
break;
|
|
|
|
case 'h': // -h or --help
|
|
case '?': // Unrecognized option
|
|
default:
|
|
PrintHelp(argv[0]);
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (has_versions) {
|
|
DS_PrintVersions();
|
|
return false;
|
|
}
|
|
|
|
if (!model || !alphabet || !audio) {
|
|
PrintHelp(argv[0]);
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
#endif // __ARGS_H__
|