stm32adc采集dac的数据_音频信号运用,数字电位器和DAC电路调节声音大小

1.为什么讨论电子电位器?

为什么要讨论使用一个 DAC[1]来作为一个电位器呢?这里面主要原因如下:

使用电位器可以很方便在信号源的驱动下形成一个幅值可以调节的交流信号源。这比起使用通常的可编程直流电源,或者DAC输出电压来说,输出的是幅度可以变的交流信号源,可以用于很多的自动测量环节。

为什么不直接使用 机械电位器[2]来改变信号源的幅值呢?还是一个原因,那就是自动可编程改变信号的幅值。

2.为什么使用DAC做电位器?

DAC用作电位器改变交流信号原理;

使用DAC来分压交流信号的优点是什么?

是否能够克服前面数字电位器的频带过窄的问题?

写这些话的时候,我还不知道具体答案,下面就通过实验来验证一下吧。

02 实验电路

最近,刚刚购买了几片16bit的DAC芯片 DAC8830IDR[5](价格6.6),具有SPI接口,基于该DAC来验证一下前面的思路的可行性。

1.实验电路设计

由于DAC8830使用SPI接口来设置输出电压,使用STC8G1K(SOP16)作为控制器来完成对它的信号控制。

1)SCH [6]

98894a5f3eb9b33379483dd5e5f7a102.png

▲ 原理图设计

2)PCB

对于实验原理图进行LAYOUT,尽可以满足单面PCB板制作的工艺要求。快速制版之后得到对应的实验电路板。

3e2e369a02766e7977f3e92d31c5eceb.png

▲ 实验电路板的PCB设计

2. MCU软件编程[7]

1) DA8830访问子程序

使用STC8G的SPI端口对DA8830进行访问。根据DA8830的SPI读写时序,相应的DAC8830写入转换(16bit)数据的子程序为:

void DAC8830Set(unsigned int nDAC) {

OFF(DAC8830_CS);

SPISendChar((unsigned char)(nDAC >> 8));

SPISendChar((unsigned ch

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个简单的实例代码,用于在STM32上进行DACADC数据采集和转换: ``` #include "stm32f10x.h" #include "stm32f10x_adc.h" #include "stm32f10x_dac.h" #include "stm32f10x_gpio.h" #include "stm32f10x_rcc.h" int main(void) { GPIO_InitTypeDef GPIO_InitStructure; ADC_InitTypeDef ADC_InitStructure; DAC_InitTypeDef DAC_InitStructure; // 开启GPIOA、ADC1、DAC通道1时钟 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_ADC1 | RCC_APB1Periph_DAC, ENABLE); // 配置DAC通道1的GPIO引脚PA4 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN; GPIO_Init(GPIOA, &GPIO_InitStructure); // 配置ADC1的GPIO引脚PA0 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN; GPIO_Init(GPIOA, &GPIO_InitStructure); // 配置DAC通道1 DAC_InitStructure.DAC_Trigger = DAC_Trigger_None; DAC_InitStructure.DAC_WaveGeneration = DAC_WaveGeneration_None; DAC_InitStructure.DAC_OutputBuffer = DAC_OutputBuffer_Enable; DAC_Init(DAC_Channel_1, &DAC_InitStructure); // 配置ADC1 ADC_InitStructure.ADC_Mode = ADC_Mode_Independent; ADC_InitStructure.ADC_ScanConvMode = DISABLE; ADC_InitStructure.ADC_ContinuousConvMode = DISABLE; ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None; ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right; ADC_InitStructure.ADC_NbrOfChannel = 1; ADC_Init(ADC1, &ADC_InitStructure); // 配置ADC1的通道0 ADC_RegularChannelConfig(ADC1, ADC_Channel_0, 1, ADC_SampleTime_55Cycles5); // 启动ADC1的转换器 ADC_Cmd(ADC1, ENABLE); // 启动DAC通道1 DAC_Cmd(DAC_Channel_1, ENABLE); // 等待DAC通道1的输出稳定 while (DAC_GetFlagStatus(DAC_Channel_1, DAC_FLAG_DMAUDR) == RESET); // 开始ADC1的转换 ADC_SoftwareStartConvCmd(ADC1, ENABLE); // 等待转换结束 while (ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC) == RESET); // 读取转换结果 uint16_t adc_value = ADC_GetConversionValue(ADC1); uint16_t dac_value = DAC_GetDataOutputValue(DAC_Channel_1); while (1); } ``` 此代码中,我们首先启用了GPIOA、ADC1和DAC通道1的时钟。然后,我们配置了PA4作为DAC通道1的引脚,PA0作为ADC1的引脚。接下来,我们配置了DAC通道1和ADC1,并将ADC通道0与ADC1关联起来。然后,我们启动了ADC1的转换器和DAC通道1,并等待DAC通道1的输出稳定。最后,我们开始ADC1的转换,并等待转换结束。我们读取了ADCDAC的转换结果并停止程序的运行。 希望这个例子对你有帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值