STM32 数字电压表 LM317 可调电源

在原来的函数发生器基础上增加了ADC功能。依然使用DMA 传送,每次传送16个数据完成后进中断, 标记ADC_Ok 然后

main中进行一个简单的软件滤波,最后送液晶显示,完成后要重新开启DMA 。

R2 我这次用的是10K 的 电压范围是可以从0 开始的 而公式是Vo=1.25(1+ R2/R1) 。感觉这是因为只要给ADJ一个参考电压便可以使LM317有值输出的。保证R1≥0.83KΩ,R2≤23.74KΩ 便可维持一个最小工作电流,当317稳压块的输出电流小于其最小稳定工作电流时,317稳压块就不能正常工作最小稳定工作电流的值一般为1.5mA。

8290ff05266614cd3c01d6d4233dba33.jpeg

#include "stm32f10x.h"
#include "HAL.H"

#define ADC1_DR_Address ((uint32_t)0x4001244C)
/* Private variables ---------------------------------------------------------*/
DMA_InitTypeDef DMA_InitStructure;
u16 ADCConvertedValue[16];
volatile bool ADC_Ok;
void ADC_Configuration()
{

ADC_InitTypeDef ADC_InitStructure;


/* ADCCLK = PCLK2/4 */
RCC_ADCCLKConfig(RCC_PCLK2_Div4);
/* Enable DMA1 clock */
RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);
/* Enable ADC1 clock */
RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1 , ENABLE);
/* DMA1 channel1 configuration ----------------------------------------------*/
DMA_DeInit(DMA1_Channel1);
DMA_InitStructure.DMA_PeripheralBaseAddr = ADC1_DR_Address;
DMA_InitStructure.DMA_MemoryBaseAddr = (uint32_t)&ADCConvertedValue;
DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;
DMA_InitStructure.DMA_BufferSize = 16;
DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;
DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;
DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord;
DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord;
DMA_InitStructure.DMA_Mode = DMA_Mode_Normal; //普通模式 完成后就会停止
DMA_InitStructure.DMA_Priority = DMA_Priority_High;
DMA_InitStructure.DMA_M2M = DMA_M2M_Disable;
DMA_Init(DMA1_Channel1, &DMA_InitStructure);

DMA_ITConfig(DMA1_Channel1, DMA_IT_TC, ENABLE); //DMA通道1传输完成中断
/* Enable DMA1 channel1 */
DMA_Cmd(DMA1_Channel1, ENABLE);

/* ADC1 configuration ------------------------------------------------------*/
ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;
ADC_InitStructure.ADC_ScanConvMode = ENABLE;
ADC_InitStructure.ADC_ContinuousConvMode = ENABLE;
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 regular channel14 configuration 就是PC4脚 为模拟量输入 注意下边转换周期间隔 周期越长 输入ADC的阻抗越大,最大239的话大约370KΩ 而最小的周期时只有 1KΩ多,输入阻抗太小在后边的分压电路变不好设计了,这点要注意*/
ADC_RegularChannelConfig(ADC1, ADC_Channel_14, 1, ADC_SampleTime_239Cycles5);

/* Enable ADC1 DMA */
ADC_DMACmd(ADC1, ENABLE);

/* Enable ADC1 */
ADC_Cmd(ADC1, ENABLE);

/* Enable ADC1 reset calibaration register 下边进行校准ADC*/
ADC_ResetCalibration(ADC1);
/* Check the end of ADC1 reset calibration register */
while(ADC_GetResetCalibrationStatus(ADC1));

/* Start ADC1 calibaration */
ADC_StartCalibration(ADC1);
/* Check the end of ADC1 calibration */
while(ADC_GetCalibrationStatus(ADC1));

/* Start ADC1 Software Conversion */
ADC_SoftwareStartConvCmd(ADC1, ENABLE);


}

/**************************************************************
** 函数名:ADC_DigitFilter
** 功能:软件滤波
** 注意事项:取NO的2/5作为头尾忽略值,注意N要大于5,否则不会去头尾
***************************************************************/
u16 ADC_DigitFilter(u16* buf,u8 no)
{
u8 i,j;
u16 tmp;
u8 cut_no=0;
//冒泡法排序
for(i=0;i<no;i++)
{
for(j=0;j<no-i-1;j++)
{

if(buf[j]>buf[j+1])
{
/*tmp=buf[j];
buf[j]=buf[j+1];
buf[j+1]=tmp;*/
buf[j]=buf[j]^buf[j+1];
buf[j+1]=buf[j]^buf[j+1];
buf[j]=buf[j]^buf[j+1];
}
}
}
if(no>5)
{
cut_no=no/5;
}

//求平均
tmp=0;
for(i=cut_no;i<no-cut_no;i++) //只取中间n-2*cut_no个求平均
tmp+=buf[i];
return(tmp/(no-2*cut_no));
}

//重新允许DMA,
void DMAReConfig(void)
{
DMA_DeInit(DMA1_Channel1);
DMA_Init(DMA1_Channel1, &DMA_InitStructure);
DMA_ITConfig(DMA1_Channel1, DMA_IT_TC, ENABLE);
DMA_Cmd(DMA1_Channel1, ENABLE);
}

bf75581d6ab0f7f755c255b3c01f08d0.jpeg下边的便是分压小板

void DMA1_Channel1_IRQHandler(void)
{
if(DMA_GetITStatus(DMA1_IT_TC1))
{
DMA_ClearITPendingBit(DMA1_IT_GL1); //清除全部中断标志
ADC_Ok=TRUE;// DMA_Cmd(DMA1_Channel1, DISABLE);
}
}

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值