久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 4057|回復: 1
打印 上一主題 下一主題
收起左側

STM32F103正弦逆變輸出源碼與工具 25v,50HZ,頻率可調

[復制鏈接]
跳轉到指定樓層
樓主
STM32單相正弦逆變

單片機源程序如下:
  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, 下載次數: 90)


評分

參與人數 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏2 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:243168 發表于 2018-8-23 10:53 | 只看該作者
好東西,贊一個
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 美女天堂 | 99色综合 | 欧美一级片免费看 | 美女黄18岁以下禁止观看 | 一本一道久久a久久精品蜜桃 | 在线观看国产wwwa级羞羞视频 | 精品国产99 | 在线午夜 | 黑人精品 | 久久精品一区二区 | 米奇7777狠狠狠狠视频 | 午夜tv免费观看 | 国产欧美一区二区三区久久手机版 | 国产一伦一伦一伦 | 久久久91精品国产一区二区精品 | 精品国产一区二区三区久久影院 | 免费av在线| 激情一区 | 男人天堂色 | 黄色a视频 | 日韩精品一区二区三区中文字幕 | av一级在线观看 | 欧美video | 久久com| 国产乱码精品1区2区3区 | 国产精品一区二区久久 | 美国十次成人欧美色导视频 | 国产1区2区3区 | 国产成人综合av | 99爱国产| 亚洲美女一区 | 精品成人佐山爱一区二区 | 四虎成人av | 真人女人一级毛片免费播放 | 国产日韩欧美 | 黄色激情毛片 | 成人做爰www免费看视频网站 | 久久久一区二区三区四区 | 久久这里只有精品首页 | 国产在线精品一区二区三区 | 久久手机在线视频 |