找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3276|回复: 1
收起左侧

STM32F103正弦逆变输出源码与工具 25v,50HZ,频率可调

[复制链接]
ID:341701 发表于 2018-7-24 14:04 | 显示全部楼层 |阅读模式
STM32单相正弦逆变
0.png
单片机源程序如下:
  1. #include "delay.h"
  2. #include "key.h"
  3. #include "sys.h"
  4. #include "SPWM.h"
  5. #include "keyboard.h"
  6. #include "bsp_usart1.h"
  7. #include "OLED_I2C.h"
  8. #include "bsp_i2c_gpio.h"


  9.   /*把这个SPWM调一下   6路,其中3路一样,另外3路一样,这两组之间互补
  10. 2018/5/10 16:52:06
  11. 2018/5/10 16:52:06
  12. 死区300ns   载频20K左右,可以自己定   正弦频率50HZ   三相正弦之间相差120°   
  13. **/
  14. vu8  key = 0;                                                                        //按键值        
  15. vu16 freq =20000, Period=0;                //PWM与定时器中断频率;自动重装载值
  16. __IO float Period_percent;                 //PWM占空比变化因子,用于修改脉宽
  17. int k=0;
  18. int BUFF1[4];
  19. int BUFF2[4];
  20. int result;
  21. float  Kp =     0.32  ; //比例常数
  22. float  Ti =                0.09 ; //积分时间常数
  23. float Td =                0.0028 ;  //微分时间常数
  24. #define T                  0.02 //采样周期
  25. #define Ki     Kp*(T/Ti)        // Kp Ki Kd 三个主要参数
  26. #define Kd                Kp*(Td/T)
  27. int main(void)
  28. {        
  29.         unsigned char i,j;
  30.         unsigned char u[17]={0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16};
  31.         SystemInit();
  32.         NVIC_Configuration();
  33.         delay_init();
  34.         //USART1_Config();
  35.         KeyBoard_Config();
  36.         /*KEY_Init();        */

  37.         Period_percent = ((SystemCoreClock / freq) - 1) / 32767.0;          //0.11s
  38.         
  39.         TIM1_PWM_Init(freq,0);         //输出PWM的频率为8KHz(一周期400个点,正弦波的频率为8000/400=20Hz)         
  40.         TIM2_Int_Init(freq,0);         //定时器中断的频率为8KHz
  41.         if(i2c_CheckDevice(OLED_ADDRESS)==0)
  42.         {
  43.                 printf("OLED OK\r\n");
  44.                 OLED_Init();
  45.                 OLED_Fill(0xFF);//全屏点亮
  46.                 delay_us(20000);
  47.                 OLED_Fill(0x00);//全屏灭
  48.                 delay_us(20000);                        
  49.         }
  50.         //PID_set(Kp,Ki,Kd);
  51.         while(1)                                
  52.         {
  53.                 i=Read_KeyValue();
  54.                 if (i>0)
  55.     j = u[i-1];
  56.                 switch(j)
  57.                 {  
  58.                 case 0:                        
  59.                 OLED_ShowStr(0,4,(unsigned char*)"Hello 1 ",2);                //测试8*16字符        
  60.     BUFF1[k]=1;
  61.                 k++;
  62.                 break;
  63.                
  64.                 case 1:                 
  65.                 OLED_ShowStr(0,4,(unsigned char*)"Hello 2 ",2);                                //测试8*16字符                                          
  66.                 BUFF1[k]=2;
  67.                 k++;
  68.                 break;
  69.                
  70.                 case 2:                                 
  71.                 OLED_ShowStr(0,4,(unsigned char*)"Hello 3 ",2);                //测试8*16字符        
  72.                 BUFF1[k]=3;
  73.                 k++;
  74.                 break;
  75.                
  76.                 case 3:                 
  77.                 OLED_ShowStr(0,4,(unsigned char*)"Hello 4 ",2);                                //测试8*16字符                        
  78.                 BUFF1[k]=4;        
  79.                 k++;               
  80.                 break;
  81.                
  82.                 case 4:                 
  83.                 OLED_ShowStr(0,4,(unsigned char*)"Hello 5 ",2);                                //测试8*16字符        
  84.                 BUFF1[k]=5;
  85.                 k++;               
  86.                 break;
  87.                
  88.                 case 5:                        
  89.                 OLED_ShowStr(0,4,(unsigned char*)"Hello 6 ",2);                                //测试8*16字符        
  90.                 BUFF1[k]=6;
  91.                 k++;               
  92.                 break;
  93.                
  94.                 case 6:                        
  95.                 OLED_ShowStr(0,4,(unsigned char*)"Hello 7 ",2);                                //测试8*16字符               
  96.                 BUFF1[k]=7;
  97.                 k++;               
  98.                 break;
  99.                
  100.                 case 7:                        
  101.                 OLED_ShowStr(0,4,(unsigned char*)"Hello 8 ",2);                                //测试8*16字符                        
  102.                 BUFF1[k]=8;
  103.                 k++;               
  104.                 break;
  105.                
  106.                 case 8:                        
  107.                 OLED_ShowStr(0,4,(unsigned char*)"Hello 9 ",2);                                //测试8*16字符               
  108.                 BUFF1[k]=9;
  109.                 k++;               
  110.                 break;
  111.                
  112.                 case 9:                        
  113.                 OLED_ShowStr(0,4,(unsigned char*)"Hello 10 ",2);                                //测试8*16字符                        
  114.                 BUFF1[k]=0;
  115.                 k++;               
  116.                 break;
  117.                
  118.                 case 10:                        
  119.                 OLED_ShowStr(0,4,(unsigned char*)"Hello 11 ",2);                                //测试8*16字符                                       
  120.                 break;
  121.                
  122. //                case 11:                        
  123. //                OLED_ShowStr(0,4,(unsigned char*)"Hello 12 ",2);                                //测试8*16字符                                       
  124. //                break;
  125. //               
  126. //                case 12:         
  127. //                OLED_ShowStr(0,4,(unsigned char*)"Hello 13 ",2);                                //测试8*16字符                                       
  128. //                break;
  129. //               
  130. //                case 13:                        
  131. //                OLED_ShowStr(0,4,(unsigned char*)"Hello 14 ",2);                                //测试8*16字符                                       
  132. //                break;
  133. //               
  134. //                case 14:                 
  135. //                OLED_ShowStr(0,4,(unsigned char*)"Hello 15 ",2);                                //测试8*16字符                                       
  136. //                break;
  137. //               
  138. //                case 15:                        
  139. //                OLED_ShowStr(0,4,(unsigned char*)"Hello 16 ",2);                                //测试8*16字符                                       
  140. //                break;
  141.                
  142.         /*        case 16:
  143.                 LED1_TOGGLE;               
  144.                 OLED_ShowStr(0,4,(unsigned char*)"Hello g ",2);                                //测试8*16字符                                       
  145.                 break;         */
  146.                
  147.                 default:
  148.                 OLED_ShowStr(0,4,(unsigned char*)"no  key ",2);                                //测试8*16字符
  149.                 }

  150.         }
  151.         /*        key=KEY_Scan(0);
  152.                 if(key == 1 )
  153.                 {
  154.                         freq += 400;                        //sin频率 = freq/400
  155.                         Period = (SystemCoreClock / freq) - 1; //算出自动重装载值,Tout(溢出时间)= ((arr+1)*(psc+1))/Tclk= 1/freq;
  156.                         TIM1->ARR = Period;
  157.                         TIM2->ARR = Period;
  158.                         Period_percent = Period / 32767.0;
  159.                         
  160.                 }
  161.                 else if(key == 2)
  162.                 {
  163.                         freq -= 400;
  164.                         Period = (SystemCoreClock / freq) - 1;
  165.                         TIM1->ARR = Period;
  166.                         TIM2->ARR = Period;
  167.                         Period_percent = Period / 32767.0;
  168.                 } */
  169.         }
复制代码

所有资料51hei提供下载:
STM32F103正弦逆变输出25v,50HZ,频率可调.rar (380.72 KB, 下载次数: 88)

评分

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

查看全部评分

回复

使用道具 举报

ID:243168 发表于 2018-8-23 10:53 | 显示全部楼层
好东西,赞一个
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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