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

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

搜索
查看: 4045|回復(fù): 1
打印 上一主題 下一主題
收起左側(cè)

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

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
STM32單相正弦逆變

單片機(jī)源程序如下:
  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.   /*把這個(gè)SPWM調(diào)一下   6路,其中3路一樣,另外3路一樣,這兩組之間互補(bǔ)
  10. 2018/5/10 16:52:06
  11. 2018/5/10 16:52:06
  12. 死區(qū)300ns   載頻20K左右,可以自己定   正弦頻率50HZ   三相正弦之間相差120°   
  13. **/
  14. vu8  key = 0;                                                                        //按鍵值        
  15. vu16 freq =20000, Period=0;                //PWM與定時(shí)器中斷頻率;自動(dòng)重裝載值
  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  ; //比例常數(shù)
  22. float  Ti =                0.09 ; //積分時(shí)間常數(shù)
  23. float Td =                0.0028 ;  //微分時(shí)間常數(shù)
  24. #define T                  0.02 //采樣周期
  25. #define Ki     Kp*(T/Ti)        // Kp Ki Kd 三個(gè)主要參數(shù)
  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個(gè)點(diǎn),正弦波的頻率為8000/400=20Hz)         
  40.         TIM2_Int_Init(freq,0);         //定時(shí)器中斷的頻率為8KHz
  41.         if(i2c_CheckDevice(OLED_ADDRESS)==0)
  42.         {
  43.                 printf("OLED OK\r\n");
  44.                 OLED_Init();
  45.                 OLED_Fill(0xFF);//全屏點(diǎn)亮
  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);                //測(cè)試8*16字符        
  60.     BUFF1[k]=1;
  61.                 k++;
  62.                 break;
  63.                
  64.                 case 1:                 
  65.                 OLED_ShowStr(0,4,(unsigned char*)"Hello 2 ",2);                                //測(cè)試8*16字符                                          
  66.                 BUFF1[k]=2;
  67.                 k++;
  68.                 break;
  69.                
  70.                 case 2:                                 
  71.                 OLED_ShowStr(0,4,(unsigned char*)"Hello 3 ",2);                //測(cè)試8*16字符        
  72.                 BUFF1[k]=3;
  73.                 k++;
  74.                 break;
  75.                
  76.                 case 3:                 
  77.                 OLED_ShowStr(0,4,(unsigned char*)"Hello 4 ",2);                                //測(cè)試8*16字符                        
  78.                 BUFF1[k]=4;        
  79.                 k++;               
  80.                 break;
  81.                
  82.                 case 4:                 
  83.                 OLED_ShowStr(0,4,(unsigned char*)"Hello 5 ",2);                                //測(cè)試8*16字符        
  84.                 BUFF1[k]=5;
  85.                 k++;               
  86.                 break;
  87.                
  88.                 case 5:                        
  89.                 OLED_ShowStr(0,4,(unsigned char*)"Hello 6 ",2);                                //測(cè)試8*16字符        
  90.                 BUFF1[k]=6;
  91.                 k++;               
  92.                 break;
  93.                
  94.                 case 6:                        
  95.                 OLED_ShowStr(0,4,(unsigned char*)"Hello 7 ",2);                                //測(cè)試8*16字符               
  96.                 BUFF1[k]=7;
  97.                 k++;               
  98.                 break;
  99.                
  100.                 case 7:                        
  101.                 OLED_ShowStr(0,4,(unsigned char*)"Hello 8 ",2);                                //測(cè)試8*16字符                        
  102.                 BUFF1[k]=8;
  103.                 k++;               
  104.                 break;
  105.                
  106.                 case 8:                        
  107.                 OLED_ShowStr(0,4,(unsigned char*)"Hello 9 ",2);                                //測(cè)試8*16字符               
  108.                 BUFF1[k]=9;
  109.                 k++;               
  110.                 break;
  111.                
  112.                 case 9:                        
  113.                 OLED_ShowStr(0,4,(unsigned char*)"Hello 10 ",2);                                //測(cè)試8*16字符                        
  114.                 BUFF1[k]=0;
  115.                 k++;               
  116.                 break;
  117.                
  118.                 case 10:                        
  119.                 OLED_ShowStr(0,4,(unsigned char*)"Hello 11 ",2);                                //測(cè)試8*16字符                                       
  120.                 break;
  121.                
  122. //                case 11:                        
  123. //                OLED_ShowStr(0,4,(unsigned char*)"Hello 12 ",2);                                //測(cè)試8*16字符                                       
  124. //                break;
  125. //               
  126. //                case 12:         
  127. //                OLED_ShowStr(0,4,(unsigned char*)"Hello 13 ",2);                                //測(cè)試8*16字符                                       
  128. //                break;
  129. //               
  130. //                case 13:                        
  131. //                OLED_ShowStr(0,4,(unsigned char*)"Hello 14 ",2);                                //測(cè)試8*16字符                                       
  132. //                break;
  133. //               
  134. //                case 14:                 
  135. //                OLED_ShowStr(0,4,(unsigned char*)"Hello 15 ",2);                                //測(cè)試8*16字符                                       
  136. //                break;
  137. //               
  138. //                case 15:                        
  139. //                OLED_ShowStr(0,4,(unsigned char*)"Hello 16 ",2);                                //測(cè)試8*16字符                                       
  140. //                break;
  141.                
  142.         /*        case 16:
  143.                 LED1_TOGGLE;               
  144.                 OLED_ShowStr(0,4,(unsigned char*)"Hello g ",2);                                //測(cè)試8*16字符                                       
  145.                 break;         */
  146.                
  147.                 default:
  148.                 OLED_ShowStr(0,4,(unsigned char*)"no  key ",2);                                //測(cè)試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; //算出自動(dòng)重裝載值,Tout(溢出時(shí)間)= ((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.         }
復(fù)制代碼

所有資料51hei提供下載:
STM32F103正弦逆變輸出25v,50HZ,頻率可調(diào).rar (380.72 KB, 下載次數(shù): 90)


評(píng)分

參與人數(shù) 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎(jiǎng)勵(lì)!

查看全部評(píng)分

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

使用道具 舉報(bào)

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

使用道具 舉報(bào)

本版積分規(guī)則

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

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 国产一级视频在线 | 国产成人一区二区三区电影 | 精品日韩一区二区三区 | 欧美日韩国产一区二区三区 | 国产一区二区三区 | 欧美在线一区二区三区 | 国产成人精品一区 | 国产精品国产成人国产三级 | 国产精品夜色一区二区三区 | 男女羞羞视频免费看 | 超碰人人爱 | 精品国产一区二区国模嫣然 | 日韩高清中文字幕 | 欧美一区二区三区在线观看 | 三级免费毛片 | 国内精品视频免费观看 | 雨宫琴音一区二区在线 | 亚洲网站在线播放 | 欧美色综合网 | aaaa网站 | 欧美日韩电影免费观看 | 欧美一区二区三区免费在线观看 | 午夜一区二区三区在线观看 | 久久精品国产久精国产 | 亚洲一av | 久久久久久久久久久高潮一区二区 | 瑟瑟视频在线看 | 久久激情视频 | 精区3d动漫一品二品精区 | 久久九九99| 九九在线精品视频 | 国产日韩欧美在线播放 | 久久久久久国模大尺度人体 | 成人黄色网址大全 | 日韩一区二区三区视频在线播放 | 日本三级日产三级国产三级 | 国产精品久久久久久久免费观看 | 精品国产欧美一区二区 | 麻豆天堂 | 久久久久网站 | 国产免国产免费 |