PCM 输入到 pocketsphinx
PCM input to pocketsphinx
是否可以直接将 pcm 数据提供给 pocketsphinx 而不是先将其转换为 wav 文件?如果是,请帮我处理 c.
中的代码
PS:pcm 输入来自模拟设备,例如与 arduino 接口的麦克风,然后将采样的 pcm 数据转发到 linux 机器。
代码在 tutorial 和 continuous.c 中更高级版本的源代码中提供:
ps_start_utt(ps);
utt_started = FALSE
while ((k = fread(adbuf, sizeof(int16), 2048, rawfd)) > 0) {
ps_process_raw(ps, adbuf, k, FALSE, FALSE);
in_speech = ps_get_in_speech(ps);
if (in_speech && !utt_started) {
utt_started = TRUE;
}
if (!in_speech && utt_started) {
ps_end_utt(ps);
hyp = ps_get_hyp(ps, NULL);
ps_start_utt(ps);
utt_started = FALSE;
}
}
ps_end_utt(ps);
主要的调用是ps_process_raw
,它需要一个数据缓冲区。
是否可以直接将 pcm 数据提供给 pocketsphinx 而不是先将其转换为 wav 文件?如果是,请帮我处理 c.
中的代码PS:pcm 输入来自模拟设备,例如与 arduino 接口的麦克风,然后将采样的 pcm 数据转发到 linux 机器。
代码在 tutorial 和 continuous.c 中更高级版本的源代码中提供:
ps_start_utt(ps);
utt_started = FALSE
while ((k = fread(adbuf, sizeof(int16), 2048, rawfd)) > 0) {
ps_process_raw(ps, adbuf, k, FALSE, FALSE);
in_speech = ps_get_in_speech(ps);
if (in_speech && !utt_started) {
utt_started = TRUE;
}
if (!in_speech && utt_started) {
ps_end_utt(ps);
hyp = ps_get_hyp(ps, NULL);
ps_start_utt(ps);
utt_started = FALSE;
}
}
ps_end_utt(ps);
主要的调用是ps_process_raw
,它需要一个数据缓冲区。