9 #ifndef INCLUDED_AILIA_SPEECH
10 #define INCLUDED_AILIA_SPEECH
15 #include "ailia_tokenizer.h"
19 #if defined(_WIN64) || defined(_M_X64) || defined(__amd64__) || defined(__x86_64__) || defined(__APPLE__) || \
20 defined(__ANDROID__) || defined(ANDROID) || defined(__linux__) || defined(NN_NINTENDO_SDK)
23 #define AILIA_API __stdcall
43 #define AILIA_SPEECH_MODEL_TYPE_WHISPER_MULTILINGUAL_TINY (0)
54 #define AILIA_SPEECH_MODEL_TYPE_WHISPER_MULTILINGUAL_BASE (1)
65 #define AILIA_SPEECH_MODEL_TYPE_WHISPER_MULTILINGUAL_SMALL (2)
76 #define AILIA_SPEECH_MODEL_TYPE_WHISPER_MULTILINGUAL_MEDIUM (3)
87 #define AILIA_SPEECH_MODEL_TYPE_WHISPER_MULTILINGUAL_LARGE (4)
98 #define AILIA_SPEECH_MODEL_TYPE_WHISPER_MULTILINGUAL_LARGE_V3 (5)
113 #define AILIA_SPEECH_TASK_TRANSCRIBE (0)
124 #define AILIA_SPEECH_TASK_TRANSLATE (1)
139 #define AILIA_SPEECH_CONSTRAINT_CHARACTERS (0)
150 #define AILIA_SPEECH_CONSTRAINT_WORDS (1)
165 #define AILIA_SPEECH_FLAG_NONE (0)
176 #define AILIA_SPEECH_FLAG_LIVE (1)
191 #define AILIA_SPEECH_VAD_TYPE_SILERO (0)
206 #define AILIA_SPEECH_DIARIZATION_TYPE_PYANNOTE_AUDIO (0)
221 #define AILIA_SPEECH_DICTIONARY_TYPE_REPLACE (0)
236 #define AILIA_SPEECH_POST_PROCESS_TYPE_T5 (0)
251 #define AILIA_SPEECH_POST_PROCESS_TYPE_FUGUMT_EN_JA (1)
266 #define AILIA_SPEECH_POST_PROCESS_TYPE_FUGUMT_JA_EN (2)
274 #if defined(_WIN32) && !defined(_WIN64)
275 #define AILIA_SPEECH_USER_API __stdcall
277 #define AILIA_SPEECH_USER_API
282 typedef int(
AILIA_SPEECH_USER_API*
AILIA_SPEECH_USER_API_AILIA_AUDIO_GET_MEL_SPECTROGRAM)(
void*,
const void*, int, int, int, int, int, int, int, int, float, int, float, float, int, int, int);
327 #define AILIA_SPEECH_API_CALLBACK_VERSION (6)
401 #define AILIA_SPEECH_TEXT_VERSION (2)
412 #define AILIA_SPEECH_SPEAKER_ID_UNKNOWN 0xFFFFFFFF
607 int AILIA_API ailiaSpeechOpenPostProcessFileA(
struct AILIASpeech* net,
const char* encoder_path,
const char* decoder_path,
const char* source_path,
const char* target_path,
const char* prefix,
int post_process_type);
634 int AILIA_API ailiaSpeechOpenPostProcessFileW(
struct AILIASpeech* net,
const wchar_t* encoder_path,
const wchar_t* decoder_path,
const wchar_t* source_path,
const wchar_t* target_path,
const char* prefix,
int post_process_type);
700 ailiaSpeechPushInputData(
struct AILIASpeech* net,
const float* src,
unsigned int channels,
unsigned int samples,
unsigned int sampling_rate);
1046 #define ailiaSpeechOpenModelFile ailiaSpeechOpenModelFileW
1047 #define ailiaSpeechOpenVadFile ailiaSpeechOpenVadFileW
1048 #define ailiaSpeechOpenDiarizationFile ailiaSpeechOpenDiarizationFileW
1049 #define ailiaSpeechOpenDictionaryFile ailiaSpeechOpenDictionaryFileW
1050 #define ailiaSpeechOpenPostProcessFile ailiaSpeechOpenPostProcessFileW
1052 #define ailiaSpeechOpenModelFile ailiaSpeechOpenModelFileA
1053 #define ailiaSpeechOpenVadFile ailiaSpeechOpenVadFileA
1054 #define ailiaSpeechOpenDiarizationFile ailiaSpeechOpenDiarizationFileA
1055 #define ailiaSpeechOpenDictionaryFile ailiaSpeechOpenDictionaryFileA
1056 #define ailiaSpeechOpenPostProcessFile ailiaSpeechOpenPostProcessFileA
int AILIA_API ailiaSpeechOpenVadFileA(struct AILIASpeech *net, const char *vad_path, int vad_type)
Set vad model for voice activity detection.
void AILIA_API ailiaSpeechDestroy(struct AILIASpeech *net)
It destroys the network instance.
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_SET_INPUT_BLOB_DATA)(struct AILIANetwork *, const void *, unsigned int, unsigned int)
Definition: ailia_speech.h:311
int AILIA_API ailiaSpeechBuffered(struct AILIASpeech *net, unsigned int *buffered)
Determines if there is enough data to perform speech recognition.
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_AUDIO_RESAMPLE)(void *, const void *, int, int, int, int)
Definition: ailia_speech.h:283
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_TOKENIZER_OPEN_MODEL_FILE_A)(struct AILIATokenizer *, const char *)
Definition: ailia_speech.h:288
int AILIA_API ailiaSpeechOpenVadFileW(struct AILIASpeech *net, const wchar_t *vad_path, int vad_type)
Set vad model for voice activity detection.
#define AILIA_API
Definition: ailia_speech.h:23
int AILIA_API ailiaSpeechSetText(struct AILIASpeech *net, const AILIASpeechText *text, unsigned int version, unsigned int idx)
Set postprocess text.
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_TOKENIZER_GET_TOKEN_COUNT)(struct AILIATokenizer *, unsigned int *)
Definition: ailia_speech.h:291
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_GET_BLOB_SHAPE)(struct AILIANetwork *, AILIAShape *, unsigned int, unsigned int)
Definition: ailia_speech.h:313
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_TOKENIZER_ENCODE)(struct AILIATokenizer *, const char *)
Definition: ailia_speech.h:290
struct _AILIASpeechApiCallback AILIASpeechApiCallback
void(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_TOKENIZER_DESTROY)(struct AILIATokenizer *)
Definition: ailia_speech.h:296
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_CREATE)(struct AILIANetwork **, int, int)
Definition: ailia_speech.h:301
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_AUDIO_GET_RESAMPLE_LEN)(int *, int, int, int)
Definition: ailia_speech.h:284
int AILIA_API ailiaSpeechPushInputData(struct AILIASpeech *net, const float *src, unsigned int channels, unsigned int samples, unsigned int sampling_rate)
Push PCM data to queue.
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_AUDIO_GET_FRAME_LEN)(int *, int, int, int, int)
Definition: ailia_speech.h:281
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_INTERMEDIATE_CALLBACK)(void *handle, const char *text)
Notify the status during the inference.
Definition: ailia_speech.h:384
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_TOKENIZER_GET_TEXT_LENGTH)(struct AILIATokenizer *, unsigned int *)
Definition: ailia_speech.h:294
int AILIA_API ailiaSpeechOpenModelFileA(struct AILIASpeech *net, const char *encoder_path, const char *decoder_path, int model_type)
Set models into a network instance.
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_TOKENIZER_DECODE)(struct AILIATokenizer *, const int *, unsigned int)
Definition: ailia_speech.h:293
int AILIA_API ailiaSpeechGetText(struct AILIASpeech *net, AILIASpeechText *text, unsigned int version, unsigned int idx)
Get recognized text.
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_GET_BLOB_INDEX_BY_INPUT_INDEX)(struct AILIANetwork *, unsigned int *, unsigned int)
Definition: ailia_speech.h:308
int AILIA_API ailiaSpeechSetIntermediateCallback(struct AILIASpeech *net, AILIA_SPEECH_USER_API_INTERMEDIATE_CALLBACK callback, void *handle)
Set a callback to get intermediate results of recognition.
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_TOKENIZER_UTF32_TO_UTF8)(char *, unsigned int *, unsigned int)
Definition: ailia_speech.h:298
int AILIA_API ailiaSpeechOpenDiarizationFileW(struct AILIASpeech *net, const wchar_t *segmentation_path, const wchar_t *embedding_path, int type)
Set AI model for speaker diarization (UTF16)
#define AILIA_SPEECH_USER_API
Definition: ailia_speech.h:277
int AILIA_API ailiaSpeechSetLanguage(struct AILIASpeech *net, const char *language)
Set language.
int AILIA_API ailiaSpeechPostProcess(struct AILIASpeech *net)
Execute post process.
struct _AILIASpeechText AILIASpeechText
int AILIA_API ailiaSpeechOpenDictionaryFileW(struct AILIASpeech *net, const wchar_t *dictionary_path, int dictionary_type)
Set dictionary for error correction.
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_COPY_BLOB_DATA)(struct AILIANetwork *dst_net, unsigned int dst_blob_idx, struct AILIANetwork *src_net, unsigned int src_blob_idx)
Definition: ailia_speech.h:315
int AILIA_API ailiaSpeechGetTextCount(struct AILIASpeech *net, unsigned int *count)
Get recognized text count.
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_OPEN_WEIGHT_FILE_A)(struct AILIANetwork *, const char *)
Definition: ailia_speech.h:302
void(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_DESTROY)(struct AILIANetwork *)
Definition: ailia_speech.h:306
int AILIA_API ailiaSpeechOpenPostProcessFileA(struct AILIASpeech *net, const char *encoder_path, const char *decoder_path, const char *source_path, const char *target_path, const char *prefix, int post_process_type)
Set AI model for post process (MBSC)
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_AUDIO_GET_MEL_SPECTROGRAM)(void *, const void *, int, int, int, int, int, int, int, int, float, int, float, float, int, int, int)
Definition: ailia_speech.h:282
int AILIA_API ailiaSpeechSetConstraint(struct AILIASpeech *net, const char *constraint, int type)
Set constraint.
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_TOKENIZER_OPEN_MODEL_FILE_W)(struct AILIATokenizer *, const wchar_t *)
Definition: ailia_speech.h:289
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_GET_BLOB_DATA)(struct AILIANetwork *, void *, unsigned int, unsigned int)
Definition: ailia_speech.h:310
int AILIA_API ailiaSpeechResetTranscribeState(struct AILIASpeech *net)
It resets the network instance.
int AILIA_API ailiaSpeechOpenModelFileW(struct AILIASpeech *net, const wchar_t *encoder_path, const wchar_t *decoder_path, int model_type)
Set models into a network instance.
int AILIA_API ailiaSpeechComplete(struct AILIASpeech *net, unsigned int *complete)
Determines whether all data has been processed.
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_SET_MEMORY_MODE)(struct AILIANetwork *, unsigned int)
Definition: ailia_speech.h:305
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_TOKENIZER_GET_TEXT)(struct AILIATokenizer *, char *, unsigned int)
Definition: ailia_speech.h:295
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_TOKENIZER_UTF8_TO_UTF32)(unsigned int *, unsigned int *, const char *, unsigned int)
Definition: ailia_speech.h:297
int AILIA_API ailiaSpeechFinalizeInputData(struct AILIASpeech *net)
Finalize input PCM data to queue.
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_TOKENIZER_CREATE)(struct AILIATokenizer **, int, int)
Definition: ailia_speech.h:287
const char *AILIA_API ailiaSpeechGetErrorDetail(struct AILIASpeech *net)
Returns the details of errors.
int AILIA_API ailiaSpeechCreate(struct AILIASpeech **net, int env_id, int num_thread, int memory_mode, int task, int flags, AILIASpeechApiCallback callback, int version)
Creates a network instance.
int AILIA_API ailiaSpeechTranscribe(struct AILIASpeech *net)
Speech recognition.
int AILIA_API ailiaSpeechOpenPostProcessFileW(struct AILIASpeech *net, const wchar_t *encoder_path, const wchar_t *decoder_path, const wchar_t *source_path, const wchar_t *target_path, const char *prefix, int post_process_type)
Set AI model for post process (UTF16)
int AILIA_API ailiaSpeechSetSilentThreshold(struct AILIASpeech *net, float silent_threshold, float speech_sec, float no_speech_sec)
Set silent threshold.
int AILIA_API ailiaSpeechOpenDiarizationFileA(struct AILIASpeech *net, const char *segmentation_path, const char *embedding_path, int type)
Set AI model for speaker diarization (MBSC)
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_GET_BLOB_INDEX_BY_OUTPUT_INDEX)(struct AILIANetwork *, unsigned int *, unsigned int)
Definition: ailia_speech.h:309
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_SET_INPUT_BLOB_SHAPE)(struct AILIANetwork *, const AILIAShape *, unsigned int, unsigned int)
Definition: ailia_speech.h:312
const char *(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_GET_ERROR_DETAIL)(struct AILIANetwork *)
Definition: ailia_speech.h:314
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_TOKENIZER_GET_TOKENS)(struct AILIATokenizer *, int *, unsigned int)
Definition: ailia_speech.h:292
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_UPDATE)(struct AILIANetwork *)
Definition: ailia_speech.h:307
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_OPEN_WEIGHT_FILE_W)(struct AILIANetwork *, const wchar_t *)
Definition: ailia_speech.h:303
int AILIA_API ailiaSpeechOpenDictionaryFileA(struct AILIASpeech *net, const char *dictionary_path, int dictionary_type)
Set dictionary for error correction.
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_GET_ENVIRONMENT)(AILIAEnvironment **env, unsigned int env_idx, unsigned int version)
Definition: ailia_speech.h:316
int AILIA_API ailiaSpeechSetPrompt(struct AILIASpeech *net, const char *prompt)
Set prompt.
int(AILIA_SPEECH_USER_API * AILIA_SPEECH_USER_API_AILIA_OPEN_WEIGHT_MEM)(struct AILIANetwork *, const void *, unsigned int)
Definition: ailia_speech.h:304
Definition: ailia_speech.h:330
AILIA_SPEECH_USER_API_AILIA_AUDIO_RESAMPLE ailiaAudioResample
Definition: ailia_speech.h:333
AILIA_SPEECH_USER_API_AILIA_SET_MEMORY_MODE ailiaSetMemoryMode
Definition: ailia_speech.h:351
AILIA_SPEECH_USER_API_AILIA_TOKENIZER_GET_TOKEN_COUNT ailiaTokenizerGetTokenCount
Definition: ailia_speech.h:339
AILIA_SPEECH_USER_API_AILIA_GET_BLOB_SHAPE ailiaGetBlobShape
Definition: ailia_speech.h:359
AILIA_SPEECH_USER_API_AILIA_TOKENIZER_DESTROY ailiaTokenizerDestroy
Definition: ailia_speech.h:344
AILIA_SPEECH_USER_API_AILIA_TOKENIZER_GET_TEXT_LENGTH ailiaTokenizerGetTextLength
Definition: ailia_speech.h:342
AILIA_SPEECH_USER_API_AILIA_TOKENIZER_UTF32_TO_UTF8 ailiaTokenizerUtf32ToUtf8
Definition: ailia_speech.h:346
AILIA_SPEECH_USER_API_AILIA_TOKENIZER_ENCODE ailiaTokenizerEncode
Definition: ailia_speech.h:338
AILIA_SPEECH_USER_API_AILIA_GET_BLOB_INDEX_BY_INPUT_INDEX ailiaGetBlobIndexByInputIndex
Definition: ailia_speech.h:354
AILIA_SPEECH_USER_API_AILIA_UPDATE ailiaUpdate
Definition: ailia_speech.h:353
AILIA_SPEECH_USER_API_AILIA_GET_BLOB_DATA ailiaGetBlobData
Definition: ailia_speech.h:356
AILIA_SPEECH_USER_API_AILIA_TOKENIZER_GET_TEXT ailiaTokenizerGetText
Definition: ailia_speech.h:343
AILIA_SPEECH_USER_API_AILIA_AUDIO_GET_RESAMPLE_LEN ailiaAudioGetResampleLen
Definition: ailia_speech.h:334
AILIA_SPEECH_USER_API_AILIA_CREATE ailiaCreate
Definition: ailia_speech.h:347
AILIA_SPEECH_USER_API_AILIA_OPEN_WEIGHT_FILE_A ailiaOpenWeightFileA
Definition: ailia_speech.h:348
AILIA_SPEECH_USER_API_AILIA_TOKENIZER_UTF8_TO_UTF32 ailiaTokenizerUtf8ToUtf32
Definition: ailia_speech.h:345
AILIA_SPEECH_USER_API_AILIA_SET_INPUT_BLOB_SHAPE ailiaSetInputBlobShape
Definition: ailia_speech.h:358
AILIA_SPEECH_USER_API_AILIA_SET_INPUT_BLOB_DATA ailiaSetInputBlobData
Definition: ailia_speech.h:357
AILIA_SPEECH_USER_API_AILIA_AUDIO_GET_FRAME_LEN ailiaAudioGetFrameLen
Definition: ailia_speech.h:331
AILIA_SPEECH_USER_API_AILIA_AUDIO_GET_MEL_SPECTROGRAM ailiaAudioGetMelSpectrogram
Definition: ailia_speech.h:332
AILIA_SPEECH_USER_API_AILIA_OPEN_WEIGHT_MEM ailiaOpenWeightMem
Definition: ailia_speech.h:350
AILIA_SPEECH_USER_API_AILIA_TOKENIZER_DECODE ailiaTokenizerDecode
Definition: ailia_speech.h:341
AILIA_SPEECH_USER_API_AILIA_OPEN_WEIGHT_FILE_W ailiaOpenWeightFileW
Definition: ailia_speech.h:349
AILIA_SPEECH_USER_API_AILIA_DESTROY ailiaDestroy
Definition: ailia_speech.h:352
AILIA_SPEECH_USER_API_AILIA_COPY_BLOB_DATA ailiaCopyBlobData
Definition: ailia_speech.h:361
AILIA_SPEECH_USER_API_AILIA_TOKENIZER_GET_TOKENS ailiaTokenizerGetTokens
Definition: ailia_speech.h:340
AILIA_SPEECH_USER_API_AILIA_GET_BLOB_INDEX_BY_OUTPUT_INDEX ailiaGetBlobIndexByOutputIndex
Definition: ailia_speech.h:355
AILIA_SPEECH_USER_API_AILIA_GET_ENVIRONMENT ailiaGetEnvironment
Definition: ailia_speech.h:362
AILIA_SPEECH_USER_API_AILIA_TOKENIZER_OPEN_MODEL_FILE_W ailiaTokenizerOpenModelFileW
Definition: ailia_speech.h:337
AILIA_SPEECH_USER_API_AILIA_TOKENIZER_OPEN_MODEL_FILE_A ailiaTokenizerOpenModelFileA
Definition: ailia_speech.h:336
AILIA_SPEECH_USER_API_AILIA_GET_ERROR_DETAIL ailiaGetErrorDetail
Definition: ailia_speech.h:360
AILIA_SPEECH_USER_API_AILIA_TOKENIZER_CREATE ailiaTokenizerCreate
Definition: ailia_speech.h:335
Definition: ailia_speech.h:414
unsigned int speaker_id
Definition: ailia_speech.h:418
float confidence
Definition: ailia_speech.h:420
float time_stamp_end
Definition: ailia_speech.h:417
const char * language
Definition: ailia_speech.h:419
const char * text
Definition: ailia_speech.h:415
float time_stamp_begin
Definition: ailia_speech.h:416