我正在尝试将 OPUS api 的基本编码和解码功能与以下主要功能一起使用:
#include <stdlib.h>
#include <errno.h>
#include <string.h>
#include <opus/opus.h>
#include <stdio.h>
int main(int argc, char **argv)
{
OpusEncoder *enc;
OpusDecoder *dec;
unsigned char *str;
float frame = 0.32;
int ret = 0;
int error;
float *returned;
if ((str = malloc(4096)) == NULL)
return (-1);
enc = opus_encoder_create (24000, 1, OPUS_APPLICATION_AUDIO, &error);
printf("ret = %d | input = %.2f\n", error, frame);
ret = opus_encode_float(enc, &frame, 480, str, 4096);
printf("ret = %d\n", ret);
dec = opus_decoder_create (24000, 1, &error);
ret = opus_decode_float(dec, str, ret, returned, 480, 0);
printf("ret = %d | res = %.2f\n", ret, returned[0]);
return (0);
}
问题是我试图在编码中传递 0.32 浮点数并使用 opus_decoder_float 对其进行解码,但是当我试图打印我的结果时,我只得到 0.00 并且我找不到任何使用这个特定函数的例子。
我没有收到任何有关 ret 值的错误消息,程序打印:
ret = 0 | input = 0.32
ret = 3
ret = 480 | res = 0.00
如何在返回的 float 中获得 0.32 ?