找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4037|回复: 2
打印 上一主题 下一主题
收起左侧

stm32单片机测占空比源代码

[复制链接]
跳转到指定楼层
楼主
ID:225297 发表于 2017-8-6 20:57 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
可以直接使用的

实验目的:
    学习定时器的输入捕获功能
   
硬件资源:
    1,DS0(连接在PA8)
    2,KEY_UP按键(PA0)
    3,定时器2(TIM2),TIM2的通道1(TIM2_CH1,连接在PA0上面),使用定时器的输入捕获功能来
    捕捉PA0上面的高电平脉宽.
   
实验现象:
    本实验利用TIM2_CH1来做输入捕获,我们将捕获PA0上的高电平脉宽,并将脉宽时间通过串
    口打印出来,大家可以通过按WK_UP按键,模拟输入高电平。同时,本实验将保留上一个实
    验的PWM输出,DS0还是会由暗-->亮的循环变化,大家可以通过杜邦线连接PA0和PA8,来观
    测PWM输出的高电平时间。
   
注意事项:
    1,不要把1820和PA0的跳线帽跳上,否则可能导致按键"不灵".

单片机源程序如下:
  1. #include "led.h"
  2. #include "delay.h"
  3. #include "sys.h"
  4. #include "timer.h"
  5. #include "usart.h"
  6. #include "time1.h"
  7. #include "lcd.h"
  8. //ALIENTEK Mini STM32开发板范例代码9
  9. //输入捕获实验   
  10. //技术支持:www.openedv.com
  11. //广州市星翼电子科技有限公司


  12. extern u8  TIM2CH1_CAPTURE_STA;                //输入捕获状态                                                   
  13. extern u16        TIM2CH1_CAPTURE_VAL;        //输入捕获值
  14. extern u16        TIM2CH1_CAPTURE_SUM;
  15. extern u8  TIM4CH1_CAPTURE_STA;                //输入捕获状态                                                   
  16. extern u16        TIM4CH1_CAPTURE_VAL;

  17. int main(void)
  18. {       
  19.         u8 *str;
  20.         u8 cha[100];
  21.         u32 temp=0;
  22.         u32 temp1=0;
  23.     u32 temp2=0;
  24.         NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);// 设置中断优先级分组2
  25.         delay_init();                     //延时函数初始化       
  26.         uart_init(9600);                                 //9600         
  27.         LED_Init();                          //初始化与LED连接的硬件接口
  28.          LCD_Init();
  29.         POINT_COLOR=RED;//设置字体为红色
  30.         LCD_ShowString(60,50,200,16,16,"Mini STM32");       
  31.         LCD_ShowString(60,70,200,16,16,"ADC TEST");       
  32.         LCD_ShowString(60,90,200,16,16,"ATOM@ALIENTEK");
  33.         LCD_ShowString(60,110,200,16,16,"2014/3/9");       
  34.         LCD_ShowString(60,130,200,16,16,"ADC_CH1_VAL:");
  35.          
  36.             TIM1_PWM_Init(899,0);                         //不分频。PWM频率=72000/(899+1)=80Khz
  37.          // TIM1_PWM_Init(7199,999);
  38.          //TIM_GetITStatus(TIM1,3600);
  39.         // TIM_SetCompare1(TIM1,3600);
  40.     TIM2_Cap_Init(0xffff,72-1);                //以1Mhz的频率计数
  41.     TIM4_Cap_Init(0xffff,72-1);       
  42.            while(1)
  43.         {
  44.                 delay_ms(10);
  45.                 TIM_SetCompare1(TIM1,TIM_GetCapture1(TIM1)+1);
  46.                 if(TIM_GetCapture1(TIM1)==300)TIM_SetCompare1(TIM1,0);                 
  47.                 if(TIM2CH1_CAPTURE_STA&0X80)//成功捕获到了一次高电平
  48.                 {
  49.                         temp=TIM2CH1_CAPTURE_STA&0X3F;
  50.                         temp*=65536;                                        //溢出时间总和
  51.                         temp1=temp+TIM2CH1_CAPTURE_VAL;                //得到总的高电平时间
  52.                         printf("HIGH:%d us\r\n",temp1);        //打印总的高点平时间
  53.                         LCD_ShowxNum(60,130,temp1,16,16,0);
  54. //                  for(int i=0;i<10;i++)
  55. //                        {
  56. //                                cha[i]=
  57. //                        }
  58. //                        str=&cha;
  59. //                        LCD_ShowString(60,130,200,16,16,str);
  60.                         TIM2CH1_CAPTURE_STA=0;                        //开启下一次捕获
  61.                 }
  62.                 if(TIM4CH1_CAPTURE_STA&0X40)//成功捕获到了一次高电平
  63.                 {
  64.                         temp2=TIM4CH1_CAPTURE_STA&0X3F;
  65.                         temp2*=65536;                                        //溢出时间总和
  66.                         temp2+=TIM4CH1_CAPTURE_VAL;                //得到总的高电平时间
  67.                         printf("LOW:%d us\r\n",temp2);        //打印总的高点平时间
  68.                         TIM4CH1_CAPTURE_STA=0;                        //开启下一次捕获
  69.                 }
  70.                 printf("SUM:%d us\r\n",temp1+temp2);
  71.                 printf("DUTY:%0.2lf\r\n ",temp1*1.0/(temp1+temp2));
  72.         }
  73. }
复制代码

所有资料51hei提供下载:
占空比lcd.rar (349.84 KB, 下载次数: 44)



评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:452636 发表于 2018-12-23 15:02 | 只看该作者
不错!
回复

使用道具 举报

板凳
ID:716172 发表于 2020-3-26 13:52 | 只看该作者
非常不错 路过
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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