打印
[APM32F0]

DAC+DMA 正弦波的输出

[复制链接]
221|0
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
Peixu|  楼主 | 2024-8-30 15:16 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 Peixu 于 2024-8-30 18:46 编辑

072 DAC+DMA 正弦波1. 采样频率 32000
2. 产生的数据长度是 40ms, 1280 word
3. 数据频率是440Hz
4. TIM2也是40ms触发一次
5. DAC用的DAC2
6. DMA用的 DMA1 channel4

将正弦波映射到 DAC 范围1.中心对齐:
- 正弦波的范围是 -1 到 1,我们希望将它映射到 0 到 4095。
- 通过将正弦波值加 1,使其范围变为 0 到 2。
- 然后将其乘以 2047.5(而不是 4096),使其范围变为 0 到 4095。
- 2047.5 是 4095 的一半,确保正弦波的峰值在 DAC 输出范围的中心。
2.具体公式:
- 正弦波值范围: -1 到 1
- 映射公式: (sine_val + 1.0) * 2047.5
- 当 sine_val = -1 时,输出为 (−1 + 1) * 2047.5 = 0
- 当 sine_val = 0 时,输出为 (0 + 1) * 2047.5 = 2047.5
- 当 sine_val = 1 时,输出为 (1 + 1) * 2047.5 = 4095
因此,使用 2047.5 可以确保正弦波在 DAC 的输出范围内正确对齐,并且中心点在范围中间。
#include "stdio.h"
#include "math.h"

#define SAMPLE_RATE 32000
#define DURATION_SECONDS 0.040
#define NUM_SAMPLES ((int)(SAMPLE_RATE * DURATION_SECONDS))
#define FREQUENCY 440
#define M_PI 3.1415926535897932384626433832795

short DACBuffer[1280];

void generate_sine_wave(void)
{
    for (int i = 0; i < NUM_SAMPLES; i++) {
        double t = (double)i / SAMPLE_RATE; // 当前样本的时间点
        double fTmp = sin(2.0 * M_PI * FREQUENCY * t); // 计算正弦波值
        DACBuffer[i] = (uint16_t)((fTmp + 1.0) * 2047.5); // 调整到0到4095的范围
    }   
}

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

20

主题

42

帖子

0

粉丝