Proteus8.9 仿真STM32407ZGT6系列010_PWM多路可变频率可调占空比输出

今日头条

1151人已加入

描述

 一,打开文件(可以随文下载放置在文档中打开)。(如下图1所示)
STM32 
图1

二,调整虚拟器件,另存工程文件。(如下图2,3,4所示)
 STM32图2

STM32 
图3

STM32 
图4

三,点击Source Code标签。(如下图5所示)
STM32 
图5

四,编辑main.c,timer.c,timer.h, key.c,key.h, led.c,led.h 代码如Proteus8.9 仿真STM32407ZGT6系列001(如下图6所示)
STM32 
图6

五,Main.c 代码:
/* Main.c file generated by New Project wizard
 * Author:   Ziegler Yin
 * Created:   周四 一月 16 2020
 * Processor: STM32F407ZGT6ZGT6
 * Compiler:  GCC for ARM
 */

#include "mfuncs.h"
#include "delay.h"
#include "usart.h"
#include "led.h"
#include "key.h"
#include "timer.h"

#define RT(A , B) (A> 300)?  (B= 0):  (B=1)

uint32_t gt_fig(u8 sts){
 if(1== sts) return TIM_GetCapture1(TIM4);
 if(2== sts) return TIM_GetCapture2(TIM4);
 if(3== sts) return TIM_GetCapture3(TIM4);
 if(4== sts) return TIM_GetCapture4(TIM4);
}

void st_fig(u8 sts, uint32_t gt){
 if(1== sts) TIM_SetCompare1(TIM4, gt);
 if(2== sts) TIM_SetCompare2(TIM4, gt);
 if(3== sts) TIM_SetCompare3(TIM4, gt);
 if(4== sts) TIM_SetCompare4(TIM4, gt);
}

void new_Pwm(u16 *tmbuf, u16 * mdc) {
 Pwm_Init(*(tmbuf+0), *(tmbuf+1));
 TIM_SetCompare1(TIM4, mdc[0]);
 TIM_SetCompare2(TIM4, mdc[1]);
 TIM_SetCompare3(TIM4, mdc[2]);

 Pwm_Init3(*(tmbuf+2), *(tmbuf+3));
 TIM_SetCompare2(TIM3, mdc[1]);
}

int main(void)
{
 u16 psc=840, per=600, idc[4]= {500, 200, 300, 400};
 u16 umd, pwmval=0, tm43[2][2]= {840, 600, 1680, 1200};   
 u8 status= 0, dir= 1, chgFry[1]= {0, 0};
 int gtln= 0;
 char *wd, *wds, *lnslt[7]={"未选", "A线路", "B线路", "C线路", "D线路", "变频1-A,B,C倍频或初始状态", "变频2-D四倍频或初始状态"};
 NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//设置系统中断优先级分组2
 delay_init(168);  //初始化延时函数
 uart_init(9600);//初始化串口波特率为115200
    LED_Init();
    KEY_Init();
 uprint("大家好!!!\r\n");
 uprint("大家来造呼吸机-----。\r\n");
   gtln= nmtoa(wd, 10, psc);
   uprint(wd); uprint("\r\n");
   gtln= nmtoa(wd, 10, (psc+10000));
   uprint(wd); uprint("\r\n");

 LED0= LED1= LED2= 1;

 chgFry[0]= 0; 
 chgFry[1]= 4;
 new_Pwm(tm43, idc); 
 
 uprint("控制芯片STM32F407ZGT6_008_PWM仿真开始了。\r\n");
  delay_ms(100); 

   while(1)
 {
   wd= lnslt[status]; ;
  uprint("Arm运行时......占空比:\r\n"); 
  uprint(wd);
  uprint("线路可调整状态:\r\n");
  if(1==ReadKey(GPIOC, 0x0080)) {
   status++; 
      delay_ms(20);
   if(status> 6) status= 0;
   wd= lnslt[status]; ;
   uprint("线路调整状态......占空比"); 
   uprint(wd);
   uprint("线路可调整状态:\r\n");
  }
  if(1==ReadKey(GPIOC, 0x0010)) {
   LED0= 1; 
   pwmval= gt_fig(status);
   gtln= nmtoa(wds, 10, pwmval);
   if(status>0){
    if(per< (pwmval+ 50)) {     
      uprint("线路调整, 占空值到达最高值 ......\r\n");
      st_fig(status, (per+ 1));
    }
    else{
     LED0= 1;
     pwmval= gt_fig(status);
     gtln= nmtoa(wds, 10, pwmval);
     umd= pwmval +50;
     uprint("线路调整, 占空值由 ");
     uprint(wds);
     uprint(" 增加50 至");
     uprint(numtoa(10, umd));
     uprint(" ...\r\n ");
     st_fig(status, umd);
    }
   }
  }
  if(1==ReadKey(GPIOC, 0x0020)) {
   LED1= 1; 
   if(status==5) {
    if(chgFry[0]==0) {
     chgFry[0]= 2;
     tm43[0][0]= 1680;
     new_Pwm(tm43, idc); 
     uprint("线路A,B,C频率调整到倍频...\r\n");
     delay_ms(200);
    }
    else{
     chgFry[0]= 0;
     tm43[0][0]= 840;
     new_Pwm(tm43, idc); 
     uprint("线路A,B,C频率调整到初始状态...\r\n");
     delay_ms(200);
    }
   }
   if(status==6) {
    if(chgFry[1]==0) {
     chgFry[1]= 4;
     tm43[1][0]= 1680; tm43[1][1]= 1200;
     new_Pwm(tm43, idc); 
     uprint("线路D频率调整到四倍频...\r\n");
     delay_ms(200);
    }
    else{
     chgFry[1]= 0;
     tm43[1][0]= 840; tm43[1][1]= 600;
     new_Pwm(tm43, idc); 
     uprint("线路D频率调整到初始状态...\r\n");
     delay_ms(200);
    }
   }
       delay_ms(20);
   pwmval= gt_fig(status);
   gtln= nmtoa(wds, 10, pwmval);
   uprint("Arm运行时......占空比"); 
   uprint(wd);
   uprint("线路调整, 由 ");
   uprint(wds);
   uprint(" 清零 ");
   uprint(" ...\r\n ");
   st_fig(status, 0);
  }
  if(1==ReadKey(GPIOC, 0x0040)) {
   LED2= 1;
   pwmval= gt_fig(status);
   gtln= nmtoa(wds, 10, pwmval);
   if(pwmval> 50) {
   umd= pwmval -50;
   uprint("线路调整, 占空值由 ");
   uprint(wds);
   uprint(" 减少50 至 ");
   uprint(numtoa(10, umd));
   uprint(" ...\r\n ");
   st_fig(status, umd);
   }
   else {
    umd= 1;
    uprint("线路调整, 占空值到达最低值 ......\r\n");
    st_fig(status, 1);
   }
  }
  LED0= LED1= LED2= 0;
   delay_ms(100); 
 }
}

 
key.c,key.h, led.c led.h,time.c,time.h之前的代码都可借鉴,不在多列,以后不再一一罗列,只列main.c 与相关功能的.c, .h代码。

六,点击构建工程按钮,编译工程。(如下图7所示)
STM32 
图7

七,点击窗口左下方仿真按钮,可见红,黄,绿灯点亮后一会灭,仿真开始,按下SELECT按钮,选择"变频1-A,B,C倍频或初始状态", "变频2-D四倍频或初始状态",按下按下KEY_ZERO按钮,倍频, 四倍频或初始状态。占空比的调试,参见:博主的Proteus8.9 仿真STM32407ZGT6系列009_PWM多路可调占空比输出文。虚拟串口,示波器将的状态变化显示在屏。 (如下图8,9,10,11所示)
 STM32图8

STM32 
图9
STM32 
图10

STM32

图11

八,选择release,点击构建工程按钮,编译工程生成Hex文件。(如下图12所示)
 STM32图12

lw

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分