- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试将原始 PCM 音频数据编码为 u-law,这听起来很奇怪(当它听起来......)。我不太了解如何初始化我的 AVCodecContext
结构(以及我的输入 AVFrame
)。
这是我的参数:
输入:PCM(16 位有符号)、MONO、44.1kHz(采样率)(来 self 的 Android 设备 MIC)
要求的输出:G.711 u-law、MONO、8kHz(采样率)、64 kbits/s(比特率)(来 self 的输出目标设备的文档)
我也知道我的输入 nb 样本,这就是我拥有的所有信息。
所以我像这样初始化我的 AVCodecContext
:
AVCodec* pCodec = avcodec_find_encoder(AV_CODEC_ID_PCM_MULAW);
// ...
AVCodecContext* pCodecContext = avcodec_alloc_context3(pCodec);
// ...
// Do I need input or output params in following lines?
pCodecContext->channels = 1:
pCodecContext->channel_layout = AV_CH_LAYOUT_MONO;
pCodecContext->sample_rate = 8000;
pCodecContext->bit_rate = 64000
pCodecContext->sample_fmt = AV_SAMPLE_FMT_S16;
我的 AVFrame
就像:
AVFrame* pFrame = av_frame_alloc();
pFrame->channels = 1;
pFrame->channel_layout = AV_CH_LAYOUT_MONO;
pFrame->sample_rate = 44100;
pFrame->format = AV_SAMPLE_FMT_S16;
pFrame->nb_samples = /*my audio data samples count*/;
avcodec_fill_audio_frame(pFrame, 1, AV_SAMPLE_FMT_S16, /*my audio data*/, /*my audio data size*/, 0);
然后,我使用 avcodec_send_frame()
和 avcodec_receive_packet()
进行编码。
所以我的问题是我不确定是否必须将输入或输出期望值放在不同的参数中。可能我必须以某种方式进行编码,然后使用 swresample
库“重新采样”。但就目前而言,我很确定我没有正确编码。有什么建议吗?谢谢!
最佳答案
G.711 要求您的输入为 8kHz 单声道(例如 sample_rate 为 8000)。因此,在将原始 pcm 音频样本传递给 libavcodec 之前,您必须使用 swresample 或任何其他可以做到这一点的库将它们转换为 8kHz。如果您自己捕获原始 pcm,通常您可以从 os sound api 请求 8kHz 采样率。
我很确定您可以在 Android 设备上请求 8kHz 音频。 G.711 是如此简单的编解码器,您不需要 libavcodec。您可以使用任何可用的 g711.c并为每个样本简单地调用 linear2alaw
或 linear2ulaw
。基本上 linear2alaw
或 linear2ulaw
将每个 16 位音频样本转换为一个字节的 g711 比特流。
您还应该确保正确初始化您的 AVCodecContext
:
pCodecContext->channels = 1;
pCodecContext->channel_layout = AV_CH_LAYOUT_MONO;
...
关于c++ - 配置 AVCodecContext 结构以从原始 PCM 编码为 u-law,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43974705/
我们最近的类(class)是关于德摩根定律的。我已经有点明白了 (A+B)' = A'B' (AB)' = A'+B' 我遇到了有关此类法律的一个具体问题,我想澄清一下 ((A'B')+(AB))'
我需要将A-Law压缩文件转换为常规的未压缩PCM。有没有我可以看的源代码? 最佳答案 看AlawCodec.java。 有趣的事情在该类的静态块中,该块中的初始化解码表和read方法。 关于audi
我正在尝试了解如何正确使用被动 View 。在我看来,我在被动 View 上看到的每个例子都违反了德米特法则: //In the presenter code myview.mytextfield.t
我正在尝试设计一个玩具 CoversionRate 实现,以了解如何通过链式隐式定义对“定律”进行编码。编译以下代码: case class ConversionRate[X X x: A => B
关闭。这个问题是off-topic .它目前不接受答案。 想改善这个问题吗? Update the question所以它是 on-topic对于堆栈溢出。 8 年前关闭。 Improve this
在 Evolution of JPEG 上学习本文档时,我在上述文档的第7.3节中遇到了“八定律”。 Despite the introduction of other block sizes fro
一些Rust特征的文档包括“法律”部分,例如num::traits::identities::One的documentation包括以下内容: Defines a multiplicative ide
如果我有一个包含方法 f 的类 C,该方法将 D 类型的对象(我定义的另一个类)作为参数 如果我在方法f中调用对象D的方法,是否会违反得墨忒耳定律?为什么? 例如: public C { pu
我在用 LiquidHaskell 证明以下定律时遇到了麻烦: 它被称为(之一)德摩根定律,并简单地说明了 or 的否定。两个值必须与 and 相同否定每个。它已经被证明了很长时间,并且是 Liqui
我最近才知道 Law of Demeter . 像很多事情一样,我意识到这是我已经在做但没有名字的事情。虽然有几个地方我似乎违反了它。 例如... 我可能有一个地址对象: public class A
如何将具有编码:ALaw,SampleRate:8000,BitsPerSample:8, channel :1, block 对齐 channel :1,每秒位数:8000 的波转换为具有 pcm
我在过去 2 周内搜索了这个问题,但无法找到算法或解决方案。我有一些简短的 .wav 文件,但它有 MULAW 压缩,而 python 内部似乎没有功能 wave.py可以成功解压它。所以我决定自己在
我已经安装了 networkx 和 matplotlib 包。如何根据度相关性生成幂律图,即具有高或低同质度的图 最佳答案 您看过 Networkx 站点上的示例了吗? This example可能会
我想从字节码播放音频文件。我已经有了音频文件的字节码。但是当我使用 System.Media.SoundPlayer 播放时,出现错误“{Sound API 仅支持播放 PCM 波形文件。”}。我的音
无法找到一种方法来按照以下问题将CCITT u-Law波形文件编程转换为PCM文件(Soundplayer要求):How to play non-PCM file or convert it to P
由于我对音频编解码器的理解有限,请多多包涵。我有来自 IPCAM 的音频源(通过 htto//... CGI 接口(interface))。我正在尝试编写几个客户端程序来在 Windows、MAC 以
我需要将 wav 文件从 FORMAT 1 转换为 FORMAT 2 格式 1:μ-law,8000Hz,64 kbps,单声道 格式 2:容器WAV编码PCM评分 16K样本格式 16 位 chan
我想在 python2.7 下面做。它适用于 2 个子元素,但我可以有多个子元素。 NOT = "not" OR = "or" AND = "and" def convertMain(prop) :
我正在尝试通过日志分析保存的搜索创建用于更新管理的计算机组,但无法完全弄清楚。 使用此查询时,它将列出名称中包含“test”的所有计算机。工作正常,但不完全是我想要的。 Heartbeat | wh
我正在尝试使用 Props 更改组件 vue-cookie-law 的 buttonText 默认值。 我可以直接从node_modules插件源代码更改默认值,但我想从Vue单文件组件更改它。 vu
我是一名优秀的程序员,十分优秀!