找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3125|回复: 3
收起左侧

脉冲信号测量仪的stm32单片机程序

[复制链接]
ID:194367 发表于 2017-11-30 22:19 | 显示全部楼层 |阅读模式
脉冲信号测量stm32单片机源程序如下:
  1. #include "led.h"
  2. #include "delay.h"
  3. #include "sys.h"
  4. #include "timer.h"
  5. #include "lcd.h"
  6. #include "usart.h"
  7. #include "adc.h"


  8. u32 Cnt=0;
  9. u32 fre=0;
  10. u8  TIM3CH1_CAPTURE_STA=0;        //输入捕获状态                                                   
  11. u16        TIM3CH1_CAPTURE_VAL;        //输入捕获值
  12. u16        IC2Value,DutyCycle;        //输入捕获值
  13. void show(void);
  14. void dis_fre(void);
  15. void dis_zkb(void);
  16. int main(void)
  17. {        
  18.         u16 adcx;
  19.         float v;
  20.         u8 dat[7];
  21.         NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
  22.         delay_init();                    
  23.   uart_init(9600);                  
  24.   Adc_Init();                 
  25.         LCD_Init();
  26.   POINT_COLOR=BLUE;
  27.         LED_Init();                  
  28.          TIM1_PWM_Init(899,0); //不分频。PWM频率=72000/(899+1)=80Khz
  29.          TIM2_Cap_Init(0xFFFF,0x00);
  30.   TIM3_Cap_Init();         
  31.   show();         
  32.            while(1)
  33.         {
  34.                 TIM2->CR1 |= 1 << 0;
  35.                 delay_ms(1000);
  36.                 TIM2->CR1 &= ~(1<<0);
  37.                 fre = Cnt*10*65535+TIM2->CNT*10;
  38.                 Cnt=0;
  39.                 TIM2->CNT=0;     //PA0频率输入
  40.                 dis_fre();
  41.                
  42.                 dis_zkb();
  43.                 adcx=Get_Adc(ADC_Channel_1);     //幅度采样PA1
  44.                 v=(float)adcx*(3.3/4096);
  45.                 adcx=(u16)(v*100);
  46.                 if(adcx>0)
  47.                 {
  48.                  dat[0]=adcx/100+0x30;
  49.                  dat[1]='.';
  50.                  dat[2]=adcx%100/10+0x30;
  51.                  dat[3]=adcx%10+0x30;
  52.                  dat[4]='V';
  53.                  dat[5]='\0';
  54.                 }
  55.                  LCD_ShowString(54,145,200,16,16,dat);
  56.         }
  57. }
  58. void TIM2_IRQHandler(void) //测频率,PA0
  59. {  
  60.    if(TIM_GetITStatus(TIM2, TIM_IT_Update) != RESET)
  61.    {  
  62.                   Cnt++;
  63.       TIM_ClearITPendingBit(TIM2, TIM_IT_Update);
  64.    }
  65. }
  66. void TIM3_IRQHandler(void)      //占空比,PA7
  67. {         
  68.                 if (TIM_GetITStatus(TIM3, TIM_IT_Update) != RESET)         
  69.                 {         
  70.                          if(TIM_GetCapture1(TIM3)==65535)//已经捕获到高电平了
  71.                    {
  72.                                         TIM3CH1_CAPTURE_VAL=65535;
  73.                          }
  74.                               
  75.                 }
  76.         if (TIM_GetITStatus(TIM3, TIM_IT_CC2) != RESET)//捕获1发生捕获事件
  77.         {        
  78.      IC2Value = TIM_GetCapture2(TIM3);
  79.      if(IC2Value!=0)
  80.      {
  81.                           DutyCycle=(TIM_GetCapture1(TIM3)*10000)/IC2Value;
  82.                  }
  83.      else
  84.      {
  85.                     DutyCycle = 0;
  86.                  }                        
  87.         }                                                                                    
  88.   TIM_ClearITPendingBit(TIM3, TIM_IT_CC2|TIM_IT_Update); //清除中断标志位
  89. }
  90. void show(void)
  91. {
  92.     Test_Show_CH_Font16(15,80,6,BLACK);
  93.           Test_Show_CH_Font16(31,80,7,BLACK);
  94.           LCD_ShowChar(47,80,':',16,0);
  95.           Test_Show_CH_Font16(15,100,3,BLACK);
  96.           Test_Show_CH_Font16(31,100,4,BLACK);
  97.           Test_Show_CH_Font16(47,100,5,BLACK);
  98.           LCD_ShowChar(63,100,':',16,0);
  99. }
  100. void dis_fre(void)
  101. {   u8 dat1[12];
  102.     dat1[0]=fre/10000000+0x30;
  103.     if(dat1[0]==0x30)dat1[0]=' ';        
  104.           dat1[1]=fre%10000000/1000000+0x30;
  105.           if(dat1[0]==' '&&dat1[1]==0x30)dat1[1]=' ';        
  106.           dat1[2]=fre%1000000/100000+0x30;
  107.           if(dat1[2]==0x30&&dat1[1]==' ')dat1[2]=' ';        
  108.           dat1[3]=fre%100000/10000+0x30;
  109.           if(dat1[3]==0x30&&dat1[2]==' ')dat1[3]=' ';        
  110.           dat1[4]=fre%10000/1000+0x30;
  111.           if(dat1[4]==0x30&&dat1[3]==' ')dat1[4]=' ';        
  112.           dat1[5]=fre%1000/100+0x30;
  113.           if(dat1[5]==0x30&&dat1[4]==' ')dat1[5]=' ';        
  114.           dat1[6]=fre%100/10+0x30;
  115.           dat1[7]='.';
  116.           dat1[8]=fre%10+0x30;
  117.           dat1[9]='H';
  118.                 dat1[10]='z';
  119. ……………………

  120. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
脉冲信号测量仪.rar (342.33 KB, 下载次数: 50)
回复

使用道具 举报

ID:335813 发表于 2018-5-22 19:48 | 显示全部楼层
这个压缩包是脉冲信号测量仪的全部程序??
回复

使用道具 举报

ID:310744 发表于 2018-7-5 21:37 | 显示全部楼层
大神,这个可以直接测量频率嘛
回复

使用道具 举报

ID:369050 发表于 2018-7-11 11:10 | 显示全部楼层
大神,你这个可以测量上升时间和幅值吗?程序下载了,好多文件夹没怎么看懂额,,就等大神带我上车了
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表