-
Notifications
You must be signed in to change notification settings - Fork 1.7k
Expand file tree
/
Copy pathcommonfunc.h
More file actions
111 lines (93 loc) · 2.98 KB
/
commonfunc.h
File metadata and controls
111 lines (93 loc) · 2.98 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
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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
#pragma once
#include <algorithm>
#ifdef _WIN32
#include <codecvt>
#endif
namespace funasr {
typedef struct
{
std::string msg;
std::string stamp;
std::string stamp_sents;
std::string tpass_msg;
float snippet_time;
int64_t start = 0;
int64_t end = 0;
}FUNASR_RECOG_RESULT;
typedef struct
{
std::vector<std::vector<int>>* segments;
float snippet_time;
}FUNASR_VAD_RESULT;
typedef struct
{
string msg;
vector<string> arr_cache;
}FUNASR_PUNC_RESULT;
#ifdef _WIN32
#define ORTSTRING(str) StrToWstr(str)
#define ORTCHAR(str) StrToWstr(str).c_str()
inline std::wstring String2wstring(const std::string& str, const std::string& locale)
{
typedef std::codecvt_byname<wchar_t, char, std::mbstate_t> F;
std::wstring_convert<F> strCnv(new F(locale));
return strCnv.from_bytes(str);
}
inline std::wstring StrToWstr(std::string str) {
if (str.length() == 0)
return L"";
return String2wstring(str, "zh-CN");
}
#else
#define ORTSTRING(str) str
#define ORTCHAR(str) str
#endif
inline void GetInputName(Ort::Session* session, string& inputName,int nIndex=0) {
size_t numInputNodes = session->GetInputCount();
if (numInputNodes > 0) {
Ort::AllocatorWithDefaultOptions allocator;
{
auto t = session->GetInputNameAllocated(nIndex, allocator);
inputName = t.get();
}
}
}
inline void GetInputNames(Ort::Session* session, std::vector<std::string> &m_strInputNames,
std::vector<const char *> &m_szInputNames) {
Ort::AllocatorWithDefaultOptions allocator;
size_t numNodes = session->GetInputCount();
m_strInputNames.resize(numNodes);
m_szInputNames.resize(numNodes);
for (size_t i = 0; i != numNodes; ++i) {
auto t = session->GetInputNameAllocated(i, allocator);
m_strInputNames[i] = t.get();
m_szInputNames[i] = m_strInputNames[i].c_str();
}
}
inline void GetOutputName(Ort::Session* session, string& outputName, int nIndex = 0) {
size_t numOutputNodes = session->GetOutputCount();
if (numOutputNodes > 0) {
Ort::AllocatorWithDefaultOptions allocator;
{
auto t = session->GetOutputNameAllocated(nIndex, allocator);
outputName = t.get();
}
}
}
inline void GetOutputNames(Ort::Session* session, std::vector<std::string> &m_strOutputNames,
std::vector<const char *> &m_szOutputNames) {
Ort::AllocatorWithDefaultOptions allocator;
size_t numNodes = session->GetOutputCount();
m_strOutputNames.resize(numNodes);
m_szOutputNames.resize(numNodes);
for (size_t i = 0; i != numNodes; ++i) {
auto t = session->GetOutputNameAllocated(i, allocator);
m_strOutputNames[i] = t.get();
m_szOutputNames[i] = m_strOutputNames[i].c_str();
}
}
template <class ForwardIterator>
inline static size_t Argmax(ForwardIterator first, ForwardIterator last) {
return std::distance(first, std::max_element(first, last));
}
} // namespace funasr