音频生成bin文件步骤

搭建环境 :

Linux、Cool Pro 2.1 010Editor

  1. 将音频文件.wav 、.mp3等格式的音源文件,通过Cool Edit Pro 2.1 软件打开。点击新建文件:选择采样率、声道、分辨率

Sample采样率:采集每一个音频信号点的周期,也就是信号点与信号点之间的时间间隔。Eg: 8000 = 8KHz, T = 1/8000 = 125us,也就是每一个点周期是125us.

Resolution: 分辨率,就是用多少位数据来体现当先信号的幅值,分辨率越高信号精度也就越高,音源解析出来的质量也就越好。

一般:音源使用WAV格式(MP3等其他格式也要转成WAV格式),遵循WAV文件的标准。

  1. 打开需要剪裁的音频文件
  1. 截取重复的一段音频,并拷贝到新建文件

注意:一般不需要截取太长或多个周期,因为会造成音源文件的size 变大,导致资源存储过大。

(3)保存

1、可以save as...另存为

2、也可以重新批量处理 更改音源文件的采样率、声道等参数。

  1. 将生成的音源文件放入,在Linux系统内新建的audio文件夹中

Linux终端下运行命令:

Gcc test.c ./a.out : 生成test.bin音频文件

cp test.bin audio.bin :将音频文件改名audio.bin就是最终生成的音源文件,可以烧录到mcu的flash中。

音源文件的计算

  1. DAC 驱动
  1. DAC设置12bit分辨率:音源文件8/16/32bit分辨率需要转成12bit的数据,运行 即可得到16bit -> 12bit的音频文件。

  2. dma搬移数据:需要根据8K/16K等采样率,设置定时器的触发周期与采样率保持一致。

  3. DAC转换时使用dma驱动数据,需要设置定时器作为触发输入源

  4. Dma设置16bit,按字节tyte搬移,不使能loop循环。

  5. ***** 因为DMA每次搬移16bit 2个字节,因此搬移的数据长度应该是音频文件总长度 / 2

  6. DAC的硬件地址不能直接操作DATA寄存器,应该操作DAHD寄存器

  7. I2S驱动

I2s和SPI共用硬件驱动,需要切换i2s功能

设置i2s的时钟源需要根据音频文件的采样率计算。

因为DMA每次按字节搬移16bit 2个字节,因此搬移的数据长度应该是音频文件总长度 / 2

注意:需不需要先发一字节数据触发i2s的搬移

使用

将音源文件转成16bit分辨率

相关推荐
reasonsummer15 小时前
【教学类-160-11】20260419 AI视频培训-练习011“豆包AI视频《佛源植语》+豆包图片风格:无(关键词:藏传唐卡)”
数据库·音视频·豆包
彷徨而立17 小时前
音频编码格式 G.729 和 G.729A 的区别
音视频
EasyDSS17 小时前
私有化视频会议平台/视频直播点播/高清点播/音视频点播EasyDSS“直播+点播+会议”全场景融合解锁视频协作新体验
音视频
EasyDSS17 小时前
企业级融媒体生产管理平台/私有化音视频系统EasyDSS一体化架构打造全流程应急指挥视频会议体系
架构·音视频·媒体
视频技术分享17 小时前
音视频SDK深度解析:技术演进、核心要点与发展前景
音视频
大蚂蚁2号18 小时前
本地视频转文字|video2text
python·音视频·视频转文本
肖爱Kun19 小时前
wvp-GB28181服务器网页报错调试
音视频
byte轻骑兵19 小时前
【LE Audio】BASS精讲[4]: 控制点解析,广播接收指令交互全流程
人工智能·音视频·语音识别·le audio·低功耗音频
ai产品老杨19 小时前
告别协议碎片化:基于 GB28181 与 RTSP 的统一 AI 视频中台架构实现(附 Docker 源码交付方案)
人工智能·架构·音视频
code 小楊21 小时前
最新快乐马视频模型深度解析:特性、对比测试与完整使用教程
大数据·人工智能·音视频