在好例子网,分享、交流、成长!
您当前所在位置:首页C/C++ 开发实例嵌入式开发 → STM32dac模拟量输出实验程序

STM32dac模拟量输出实验程序

嵌入式开发

下载此实例
  • 开发语言:C/C++
  • 实例大小:3.81M
  • 下载次数:9
  • 浏览次数:81
  • 发布时间:2021-07-15
  • 实例类别:嵌入式开发
  • 发 布 人:wangzaiwzanzhou
  • 文件格式:.zip
  • 所需积分:2
 相关标签: STM32 STM3 模拟量 DAC stm

实例介绍

【实例简介】stm32AD转换
【实例截图】from clipboard
【核心代码】#include "bsp_wt_adc.h"
#include "lcd.h"

__IO uint16_t ADC_ConvertValue[8]={0};
__IO uint16_t ADC_AvgValue[8]={0};


float Waveguide_Water_Temp = 0.0;
float Waveguide_Water_Flow = 0.0;
float Sample_Watertemp = 0.0;
float Sample_Waterflow = 0.0;
float Cavity_Watertemp = 0.0;
float Cavity_Waterflow = 0.0;
float M_Changer_Watertemp = 0.0;
float M_Changer_Waterflow = 0.0;



u16 Alarm_Msg_Error = 0;

void Waterflow_Sw_Init(void)
{
    GPIO_InitTypeDef GPIO_InitStructure;
RCC_AHB1PeriphClockCmd (RCC_AHB1Periph_GPIOF, ENABLE); 

GPIO_InitStructure.GPIO_Mode  = GPIO_Mode_OUT;   
GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
GPIO_InitStructure.GPIO_PuPd  = GPIO_PuPd_UP ;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_2MHz;

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_13;
GPIO_Init(GPIOF, &GPIO_InitStructure);

GPIO_SetBits(GPIOF, GPIO_Pin_13);
}

void ADC_GPIO_Init(void)
{
    GPIO_InitTypeDef GPIO_InitStructure;

RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOC,ENABLE);
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOB,ENABLE);
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA,ENABLE);

    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
    GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL ;

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2 |  GPIO_Pin_3 | GPIO_Pin_6 | GPIO_Pin_7 ;
GPIO_Init(GPIOA, &GPIO_InitStructure);

    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4 |  GPIO_Pin_5 ;
    GPIO_Init(GPIOC, &GPIO_InitStructure);
    
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_1;
GPIO_Init(GPIOB, &GPIO_InitStructure);
    
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_13;
    GPIO_Init(GPIOF, &GPIO_InitStructure);
    GPIO_ResetBits(GPIOF, GPIO_Pin_13);
    
}
void ADC_DMA_Mode_Init(void)
{
    DMA_InitTypeDef DMA_InitStructure;
    ADC_InitTypeDef ADC_InitStructure;
    ADC_CommonInitTypeDef ADC_CommonInitStructure;

    // ------------------DMA Init ½á¹¹Ìå²ÎÊý ³õʼ»¯--------------------------
    // ADC1ʹÓÃDMA2£¬Êý¾ÝÁ÷0£¬Í¨µÀ0£¬Õâ¸öÊÇÊÖ²á¹Ì¶¨ËÀµÄ

    RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_DMA2, ENABLE); 
RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1 , ENABLE);                   // ¿ªÆôADCʱÖÓ

DMA_InitStructure.DMA_PeripheralBaseAddr = ((u32)ADC1 0x4c); // ÍâÉè»ùַΪ£ºADC Êý¾Ý¼Ä´æÆ÷µØÖ·
DMA_InitStructure.DMA_Memory0BaseAddr = (u32)ADC_ConvertValue;     // ´æ´¢Æ÷µØÖ·£¬Êµ¼ÊÉϾÍÊÇÒ»¸öÄÚ²¿SRAMµÄ±äÁ¿
DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralToMemory;              // Êý¾Ý´«Êä·½ÏòΪÍâÉèµ½´æ´¢Æ÷
DMA_InitStructure.DMA_BufferSize = 1;                                // »º³åÇø´óСΪ£¬Ö¸Ò»´Î´«ÊäµÄÊý¾ÝÁ¿
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_Circular;
DMA_InitStructure.DMA_Priority = DMA_Priority_High;                          // DMA ´«ÊäͨµÀÓÅÏȼ¶Îª¸ß£¬µ±Ê¹ÓÃÒ»¸öDMAͨµÀʱ£¬ÓÅÏȼ¶ÉèÖò»Ó°Ïì// Ñ­»·´«Êäģʽ
    DMA_InitStructure.DMA_FIFOMode = DMA_FIFOMode_Disable;             // ½ûÖ¹DMA FIFO £¬Ê¹ÓÃÖ±Á¬Ä£Ê½
    DMA_InitStructure.DMA_FIFOThreshold = DMA_FIFOThreshold_HalfFull;  // FIFO ´óС£¬FIFOģʽ½ûֹʱ£¬Õâ¸ö²»ÓÃÅäÖÃ
    DMA_InitStructure.DMA_MemoryBurst = DMA_MemoryBurst_Single;
    DMA_InitStructure.DMA_PeripheralBurst = DMA_PeripheralBurst_Single;  
    DMA_InitStructure.DMA_Channel = DMA_Channel_0;     // Ñ¡Ôñ DMA ͨµÀ£¬Í¨µÀ´æÔÚÓÚÁ÷ÖÐ
    DMA_Init(DMA2_Stream0, &DMA_InitStructure);        //³õʼ»¯DMAÁ÷£¬Á÷Ï൱ÓÚÒ»¸ö´óµÄ¹ÜµÀ£¬¹ÜµÀÀïÃæÓкܶàͨµÀ
    DMA_Cmd(DMA2_Stream0, ENABLE);// ʹÄÜDMAÁ÷

    // -------------------ADC Common ½á¹¹Ìå ²ÎÊý ³õʼ»¯------------------------
    ADC_CommonInitStructure.ADC_Mode = ADC_Mode_Independent;                       // ¶ÀÁ¢ADCģʽ
    ADC_CommonInitStructure.ADC_Prescaler = ADC_Prescaler_Div2;                    // ʱÖÓΪfpclk x·ÖƵ
    ADC_CommonInitStructure.ADC_DMAAccessMode = ADC_DMAAccessMode_Disabled;        // ½ûÖ¹DMAÖ±½Ó·ÃÎÊģʽ
    ADC_CommonInitStructure.ADC_TwoSamplingDelay = ADC_TwoSamplingDelay_5Cycles;  // ²ÉÑùʱ¼ä¼ä¸ô
    ADC_CommonInit(&ADC_CommonInitStructure);
    
    // -------------------ADC Init ½á¹¹Ìå ²ÎÊý ³õʼ»¯--------------------------
     ADC_InitStructure.ADC_Resolution = ADC_Resolution_12b;                       // ADC ·Ö±æÂÊ
    ADC_InitStructure.ADC_ScanConvMode = ENABLE;                                 // ɨÃèģʽ£¬¶àͨµÀ²É¼¯ÐèÒª
    ADC_InitStructure.ADC_ContinuousConvMode = ENABLE;                           // Á¬Ðøת»»  
    ADC_InitStructure.ADC_ExternalTrigConvEdge = ADC_ExternalTrigConvEdge_None;  //½ûÖ¹Íⲿ±ßÑØ´¥·¢
    ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_T1_CC1;        //ʹÓÃÈí¼þ´¥·¢£¬Íⲿ´¥·¢²»ÓÃÅäÖã¬×¢Ê͵ô¼´¿É
    ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;                       //Êý¾ÝÓÒ¶ÔÆë
    ADC_InitStructure.ADC_NbrOfConversion = 8;                                                     
    ADC_Init(ADC1, &ADC_InitStructure);
    
    ADC_RegularChannelConfig(ADC1, ADC_Channel_2,  1, ADC_SampleTime_56Cycles);
    ADC_RegularChannelConfig(ADC1, ADC_Channel_3,  2, ADC_SampleTime_56Cycles); 
    ADC_RegularChannelConfig(ADC1, ADC_Channel_6,  3, ADC_SampleTime_56Cycles);
    ADC_RegularChannelConfig(ADC1, ADC_Channel_7,  4, ADC_SampleTime_56Cycles);
    ADC_RegularChannelConfig(ADC1, ADC_Channel_14, 5, ADC_SampleTime_56Cycles);
    ADC_RegularChannelConfig(ADC1, ADC_Channel_15, 6, ADC_SampleTime_56Cycles);
    ADC_RegularChannelConfig(ADC1, ADC_Channel_8,  7, ADC_SampleTime_56Cycles);
    ADC_RegularChannelConfig(ADC1, ADC_Channel_9,  8, ADC_SampleTime_56Cycles);

    ADC_DMARequestAfterLastTransferCmd(ADC1, ENABLE); // ʹÄÜDMAÇëÇó after last transfer (Single-ADC mode)
    ADC_DMACmd(ADC1, ENABLE);    // ʹÄÜADC DMA
    ADC_Cmd(ADC1, ENABLE);       // ʹÄÜADC
    ADC_SoftwareStartConv(ADC1); // ¿ªÊ¼adcת»»£¬Èí¼þ´¥·¢
}
void ADC_Init_Config(void)
{
ADC_GPIO_Init();
ADC_DMA_Mode_Init();
}
void ADC_Calculate(void)
{
    float Adc_Wave_WaterFlow = 0.0;
    float Adc_Wave_WaterTemp = 0.0;  
    float Adc_Sample_Watertemp = 0.0;
    float Adc_Sample_Waterflow = 0.0;     
    float Adc_Cavity_Watertemp = 0.0;
    float Adc_Cavity_Waterflow = 0.0;
    float Adc_M_Changer_Watertemp = 0.0;
    float Adc_M_Changer_Waterflow = 0.0;
    static u16 Adc_count = 0,ErrorWave_WaterFlow=0,ErrorWave_WaterTemp = 0;
    static u16 ErrorSample_Watertemp = 0,ErrorSample_Waterflow = 0;
    static u16 ErrorCavity_Watertemp = 0,ErrorCavity_Waterflow = 0;
    static u16 ErrorM_Changer_Watertemp = 0,ErrorM_Changer_Waterflow = 0;
    static vu16 max[4] = {0}, min[4] = {0}, sum[4] = {0};
    int i = 0;
    if(Adc_count == 0)
{
        for(i=0;i<8;i )
        {
     min[i]=max[i]=sum[i]=ADC_ConvertValue[i];
        }
}
    else
    {
        for(i = 0; i < 8; i )
        {
            sum[i] = ADC_ConvertValue[i];
            if(max[i] <= ADC_ConvertValue[i])   /* ±£´æ×î´óÖµ */
                max[i] = ADC_ConvertValue[i];
            if(min[i] >= ADC_ConvertValue[i])   /* ±£´æ×îСֵ */
                min[i] = ADC_ConvertValue[i];    
        }  
    }
    Adc_count ;
    if(Adc_count == 10)
    {
        sum[i] -= min[i] max[i];               /* ³ýÈ¥×î´óÖµºÍ×îСֵ */
        ADC_AvgValue[i] = sum[i] >> 3;
    }
    
    Adc_Wave_WaterFlow = (float)(ADC_AvgValue[0] * 3.3f/4096);
    Waveguide_Water_Flow = (float)(Adc_Wave_WaterFlow  * 4.00f - 4.00 )*10;
    
    Adc_Sample_Waterflow = (float)(ADC_AvgValue[1] * 3.3f/4096);
    Sample_Waterflow = (float)(Adc_Sample_Waterflow  * 4.00f - 4.00 )*10;
    
    Adc_Cavity_Waterflow = (float)(ADC_AvgValue[2] * 3.3f/4096);
    Cavity_Waterflow = (float)(Adc_Cavity_Waterflow  * 4.00f - 4.00 )*10;
    
    Adc_M_Changer_Waterflow = (float)(ADC_AvgValue[3] * 3.3f/4096);
    M_Changer_Waterflow = (float)(Adc_M_Changer_Waterflow  * 4.00f - 4.00 )*10;
    
    Adc_Wave_WaterTemp = (float)(ADC_AvgValue[4]* 3.3f/4096);
    Waveguide_Water_Temp =  (float)(Adc_Wave_WaterTemp  * 25.00f - 25.00f )*10;
    Adc_Sample_Watertemp = (float)(ADC_AvgValue[5]* 3.3f/4096);
    Sample_Watertemp =  (float)(Adc_Sample_Watertemp * 25.00f - 25.00f )*10;
    Adc_Cavity_Watertemp = (float)(ADC_AvgValue[6]* 3.3f/4096);
    Cavity_Watertemp = (float)(Adc_Cavity_Watertemp * 25.00f - 25.00f )*10;
    Adc_M_Changer_Watertemp =(float)(ADC_AvgValue[7]* 3.3f/4096);
    M_Changer_Watertemp = (float)(Adc_M_Changer_Watertemp * 25.00f - 25.00f )*10;
    
    if(Waveguide_Water_Flow < Alarm_Waveguide_Flow)
    {
        ErrorWave_WaterFlow ;
        if(ErrorWave_WaterFlow > 1000)
        {
           Alarm_Msg_Error = 0x0040;
           ErrorWave_WaterFlow = 1001;
           //alarm led 
        }
    }
    else if(Sample_Waterflow < Alarm_Sample_Waterflow)
    {
        ErrorSample_Waterflow ;
        if(ErrorSample_Waterflow > 1000)
        {
           Alarm_Msg_Error = 0x0041;
           ErrorSample_Waterflow = 1001;
           //alarm led 
        }
    }
    else if(Cavity_Waterflow < Alarm_Cavity_Waterflow)
    {
        ErrorCavity_Waterflow ;
        if(ErrorCavity_Waterflow > 1000)
        {
           Alarm_Msg_Error = 0x0042;
           ErrorCavity_Waterflow = 1001;
           //alarm led 
        }
    }
    else if(M_Changer_Waterflow < Alarm_M_Changer_Waterflow)
    {
        ErrorM_Changer_Waterflow ;
        if(ErrorM_Changer_Waterflow > 1000)
        {
           Alarm_Msg_Error = 0x0043;
           ErrorCavity_Waterflow = 1001;
           //alarm led 
        }
    }
    else if(Waveguide_Water_Temp > Alarm_Waveguide_Temp)
    {
        ErrorWave_WaterTemp ;
        if(ErrorWave_WaterTemp > 1000)
        {
            Alarm_Msg_Error = 0X0080;
            ErrorWave_WaterTemp = 1001;
            //alarm led 
        }
    }
    else if(Sample_Watertemp > Alarm_Sample_Watertemp)
    {
        ErrorSample_Watertemp ;
        if(ErrorSample_Watertemp > 1000)
        {
            Alarm_Msg_Error = 0X0081;
            ErrorSample_Watertemp = 1001;
            //alarm led 
        }
    }
    else if(Cavity_Watertemp > Alarm_Cavity_Watertemp)
    {
        ErrorCavity_Watertemp ;
        if(ErrorCavity_Watertemp > 1000)
        {
            Alarm_Msg_Error = 0X0081;
            ErrorCavity_Watertemp = 1001;
            //alarm led 
        }
    }
    else if(M_Changer_Watertemp > Alarm_M_Changer_Watertemp)
    {
        ErrorM_Changer_Watertemp ;
        if(ErrorM_Changer_Watertemp > 1000)
        {
            Alarm_Msg_Error = 0X0081;
            ErrorM_Changer_Watertemp = 1001;
            //alarm led 
        }
    } 

}


标签: STM32 STM3 模拟量 DAC stm

实例下载地址

STM32dac模拟量输出实验程序

不能下载?内容有错? 点击这里报错 + 投诉 + 提问

好例子网口号:伸出你的我的手 — 分享

网友评论

发表评论

(您的评论需要经过审核才能显示)

查看所有0条评论>>

小贴士

感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。

  • 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
  • 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
  • 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
  • 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。

关于好例子网

本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明

;
报警