152-基于stm32单片机PWM输出波形频率可调Proteus仿真+源程序

资料编号:152

一:功能介绍

1、采用stm32单片机+LCD1602显示屏+独立按键,制作一个基于stm32单片机PWM波形输出频率可调Proteus仿真;

2、通过2个独立按键进行频率加减调节,

3、将实时频率显示到LCD1602显示屏上;

4、可以通过示波器对频率进行测量显示;

二:仿真演示视频+程序简要讲解(程序有中文注释,新手容易看懂)

152-基于stm32单片机PWM输出波形频率可调Proteus仿真+源程序

三:设计软件介绍

本设计使用C语言编程设计,程序代码采用keil5编写,程序有中文注释,新手容易看懂,仿真采用Proteus软件进行仿真,演示视频使用的是Proteus8.9版本;资料包里有相关软件包,可自行下载安装。

四:程序打开方法

特别注意:下载资料包以后一定要先解压! !!(建议解压到桌面上,文件路径太深会导致程序打开异常),解压后再用keil5打开。

28a44db8d2a52aa51e7a32a1413b3a10.png

b6149d61c898cf4d21e593e80465ee54.png

程序部分展示,有中文注释,新手容易看懂
void GPIO_Configuration(void)
{
  GPIO_InitTypeDef GPIO_InitStructure;
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB,ENABLE);
  //LCD1602 管脚      
  GPIO_InitStructure.GPIO_Pin =  GPIO_Pin_8| GPIO_Pin_9| GPIO_Pin_10| GPIO_Pin_11| GPIO_Pin_12| GPIO_Pin_13| GPIO_Pin_14| GPIO_Pin_15;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_2MHz;  
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_OD;
  GPIO_Init(GPIOB, &GPIO_InitStructure);
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_7 |GPIO_Pin_6|GPIO_Pin_5;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_2MHz;  
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  GPIO_Init(GPIOB, &GPIO_InitStructure);  
}


int main()
{  
  RCC_Configration();
  Key_Configration();
  NVIC_Configration();
  bsp_InitSysTick();
  SoftTimerInit();  
  EXTI_Configration();
  TIM2_Configuration(5000);
  USART1_Configration();
  GPIO_Configuration();//初始化
  Init1602();   
  WrByte1602(0,1,'F'); //字符显示
  WrByte1602(0,2,'r'); 
  WrByte1602(0,3,'e'); 
  WrByte1602(0,4,'='); 
  WrByte1602(0,9,'H'); 
  WrByte1602(0,10,'z'); 
while(1)
 {
     WrByte1602(0,5,AsciiCode[1000000/(TIM2->ARR)%10000/1000]);//显示频率
    WrByte1602(0,6,AsciiCode[1000000/(TIM2->ARR)%1000/100]);
    WrByte1602(0,7,AsciiCode[1000000/(TIM2->ARR)%100/10]);
    WrByte1602(0,8,AsciiCode[1000000/(TIM2->ARR)%10]);
     if( bsp_CheckTimer(Key_Scan_TMR_ID) )//识别按键
   {
     Key_Value = Key_Prosse();
   }
   if(gKey.KeyStatu == 1)//频率+
   {
     if(Key_Value == 1)
     {
       Key_Value=0;
       
       if(TIM2->ARR < 10000)
       {
         TIM2->ARR += 500;
       }
       else if(TIM2->ARR >= 10000)
       {
         printf("超过范围\r\n");
       }
     }       
     else if(Key_Value == 2)//频率-
     {
        Key_Value=0;
       
       if(TIM2->ARR > 500)
       {
         TIM2->ARR -= 500;
       }
        else if(TIM2->ARR <= 500)
       {
         printf("超过范围\r\n");
       }  
     }
     TIM2->CCR2=(TIM2->ARR)/2;
   }

五:仿真文件(采用Proteus打开)

941851312cb5deaa5f380b2502e673b9.png

ac54fabcb24b808c1232ecca965a1016.png

1db9b4db934cfb1f51aa339da0b97163.png

b108060484b1a6373257765b2606c5fc.png

六:资料清单展示(文件中包含的相关资料)

fcea5c750038f67c597710a319c17676.png

百度云盘资料下载链接

### 如何在Proteus中实现STM32 PWM波形仿真 #### 准备工作 为了能够在Proteus中成功模拟STM32PWM功能,需先准备好必要的工具和文件。这包括但不限于安装好Keil MDK环境用于编译代码以及配置好Proteus ISIS作为电路图绘制平台并加载相应的固件。 #### 创建项目与设置定时器 启动CubeMX软件来初始化一个新的STM32 HAL库工程项目[^1]。在此过程中要特别注意选择合适的微控制器型号,并开启TIM模块以便后续操作能够顺利调用其API接口函数完成PWM信号的发生逻辑构建。对于具体的定时器参数设定,则依据实际需求调整预分频系数(PSC),自动重装载寄存器(ARR)等数值以满足期望频率的要求。 #### 编写PWM控制代码 接下来,在生成的基础框架之上补充自定义的功能实现部分——即PWM输出的相关处理流程。这里可以参照已有的头文件`PWM.h`中的声明[^3],具体实现在对应的`.c`文件内完成。主要涉及两个方面的工作: - 初始化服务:通过调用`HAL_TIM_PWM_Start()`等相关API使能指定通道上的PWM模式; - 动态修改占空比:提供外部接口允许应用程序层改变比较值(CCRx),从而达到实时调控脉宽的目的。 ```c void PWM_Init(void){ /* 配置GPIO引脚 */ /* 设置定时器参数 */ /* 启动PWM */ } void SET_Compare(uint16_t num){ /* 更新CCR寄存器 */ } ``` #### 构建仿真模型 当上述准备工作完成后便可以在Proteus环境下搭建物理连接关系了。按照原理图指示正确放置各组件实例(如LED灯、电阻),并将MCU对象属性里的“Program File”字段指向由Keil导出的目标二进制映像(.hex/.bin)[^4]。此外还需确保所选器件支持该特性并且版本兼容性良好。 #### 运行测试 最后一步就是执行整个系统的联合调试环节啦!点击播放按钮让虚拟仪器开始运作起来吧~此时应该能在示波器界面上观察到预期形态的理想化方波曲线哦!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值