欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

51單片機波形發生器程序與Proteus仿真圖

[復制鏈接]
跳轉到指定樓層
樓主
原理說明

一、電源電路

輸入使用12V直流,直接給DAC0832數模轉換器和LM358運放供電。然后經過7805穩壓器穩壓輸出5V,給單片機系統,1602液晶部分供電。

二、 單片機最小系統部分


單片機最小系統部分,復位電路,電容C1實現上電自動復位。獨立按鍵部分,實現頻率加減調節,波形選擇,步進值調節。U2為10K排阻,給單片機P0口提供上拉電阻。Y1為12MHz晶振,給單片機提供時鐘。

三、1602液晶顯示模塊電路

1602液晶模塊電路使用8位并口進行控制。

四、 數模轉換電路


單片機P2口輸出數字信號給DAC0832,DAC0832配合LM358運放,把P2口數字量轉換成模擬量輸出。

     其中電位器R9用于調節波形幅值。幅值最大值為5V。

  
五、   波形產生原理
單片機P2口輸出按正弦等波形規律變化的數字量,例,正弦波一個周期取64個點。則單片機一次輸出64個按正弦規律變化的數字量,經DA轉換后就輸出了按正弦規律變化的模擬量。即產生了正弦波。其他波形原理一樣。

頻率控制:單片機控制數字信號輸出的快慢,可以控制波形頻率。控制中,單片機采用定時器定時一個時間t,時間t到達后產生定時器溢出中斷,中斷里單片機控制輸出一個數字量。64個中斷后,即輸出64個數字量,就輸出了一個波形完整的周期。由于單片機速度有限,12M晶振,指令周期是1us。例如t=5us,則波形一個周期是5*64=320uS,則波形周期是3.125KHZ。

單片機通過設置定時器時間t來控制波形輸出的頻率。



更過內容,可參考網上其他文檔說明:

https://wenku.baidu.com/view/b5deb046be1e650e52ea99e6.html

仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)


單片機源程序如下:
  1. #include<reg52.h>                                           //包含頭文件
  2. #include<intrins.h>
  3. #define uchar unsigned char                           //宏定義
  4. #define uint unsigned int

  5. sbit s1=P1^0;                                                    //定義按鍵的接口
  6. sbit s2=P1^1;
  7. sbit s3=P1^2;
  8. sbit s4=P1^3;
  9.                                                                            
  10. sbit lcdrs=P1^6;                                           //液晶控制位
  11. sbit lcden=P1^7;


  12. char num,boxing,u;                                           //定義全局變量
  13. int pinlv=50,bujin=10,bujin1=10;
  14. uchar geshu=1;                                                        //兩次DA輸出數組中的個數
  15. uchar code table[]="0123456789";                //定義顯示的數組
  16. uchar code table1[]="pinlv:boxing:";
  17. unsigned long int m;
  18. int n=0;
  19. float hc=0;
  20. int a,b,h,num1;
  21. uchar code sin[64]={
  22. 135,145,158,167,176,188,199,209,218,226,234,240,245,249,252,254,254,253,251,247,243,237,230,222,213,204,193,182,170,158,
  23. 146,133,121,108,96,84,72,61,50,41,32,24,17,11,7,3,1,0,0,2,5,9,14,20,28,36,45,55,66,78,90,102,114,128
  24. };                                          //正弦波取碼
  25. uchar code juxing[64]={
  26. 255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,
  27. 255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0
  28. };                                          //矩形波取碼
  29. uchar code juchi[64]={
  30. 0,4,8,12,16,20,24,28,32,36,40,45,49,53,57,61,65,69,73,77,81,85,89,93,97,101,105,109,113,117,121,125,130,134,138,142,
  31. 146,150,154,158,162,166,170,174,178,182,186,190,194,198,202,206,210,215,219,223,227,231,235,239,243,247,251,255
  32. };                                          //鋸齒波取碼
  33. uchar code sanjiao[64]={
  34. 0,8,16,24,32,40,48,56,64,72,80,88,96,104,112,120,128,136,144,152,160,168,176,184,192,200,208,216,224,232,240,248,
  35. 248,240,232,224,216,208,200,192,184,176,168,160,152,144,136,128,120,112,104,96,88,80,72,64,56,48,40,32,24,16,8,0
  36. };                                                //三角波取碼


  37. void delay(uint xms)         //延時函數
  38. {
  39.         int a,b;
  40.         for(a=xms;a>0;a--)
  41.                 for(b=110;b>0;b--);
  42. }
  43. void write_com(uchar com)                //寫命令函數
  44. {
  45.         lcdrs=0;
  46.         P0=com;        
  47.         delay(1);
  48.         lcden=1;
  49.         delay(1);                                                                           
  50.         lcden=0;
  51. }

  52. void write_date(uchar date)                //寫數據函數
  53. {
  54.         lcdrs=1;
  55.         P0=date;
  56.         delay(1);
  57.         lcden=1;
  58.         delay(1);
  59.         lcden=0;
  60. }

  61. void init_lcd()                                        //初始化函數
  62. {                                                                  
  63.         lcden=0;                                        //默認開始狀態為關使能端,見時序圖  
  64.         write_com(0x0f);
  65.         write_com(0x38);                        //顯示模式設置,默認為0x38,不用變。
  66.         write_com(0x01);                        //顯示清屏,將上次的內容清除,默認為0x01.
  67.         write_com(0x0c);                        //顯示功能設置0x0f為開顯示,顯示光標,光標閃爍;0x0c為開顯示,不顯光標,光標不閃
  68.         write_com(0x06);                        //設置光標狀態默認0x06,為讀一個字符光標加1.
  69.         write_com(0x80);                        //設置初始化數據指針,是在讀指令的操作里進行的
  70. }
  71. void initclock()                           //時鐘初始化
  72. {
  73.         uint i;
  74.         TMOD=0x01;
  75.         TH0=a;
  76.         TL0=b;
  77.         EA=1;
  78.         ET0=1;
  79.         TR0=1;
  80.         for(i=6;i<13;i++)                           //顯示初始化
  81.         {
  82.                 write_date(table1[i]);
  83.                 delay(2);
  84.         }
  85.         write_com(0x80+0x40);
  86.         for(i=0;i<6;i++)
  87.         {
  88.                 write_date(table1[i]);
  89.                 delay(2);
  90.         }
  91.         write_com(0x80+7);
  92.                 write_date('s');
  93.                 write_date('i');
  94.                 write_date('n');
  95.                 write_date(' ');
  96.                 write_date(' ');
  97.                 write_date(' ');
  98.                 write_date(' ');
  99.                 write_com(0x80+0x40+0xa);
  100.                 write_date(' ');
  101.                 write_date('1');
  102.                 write_date('0');
  103.                 write_date('H');
  104.                 delay(2);
  105.                 write_date('Z');
  106.                 delay(2);
  107. }
  108. void display()                                   //顯示函數
  109. {
  110.         uchar wan,qian,bai,shi,ge;
  111.         uint a=0;
  112.         a=pinlv;
  113.         wan=a/10000;
  114.         qian=a/1000%10;
  115.         bai=a/100%10;
  116.         shi=a%100/10;
  117.         ge=a%100%10;
  118.         write_com(0x80+0x40+8);
  119.         write_date(table[wan]);
  120.         delay(2);
  121.         write_date(table[qian]);
  122.         delay(2);
  123.         write_date(table[bai]);
  124.         delay(2);
  125.         
  126.         write_date(table[shi]);
  127.         delay(2);
  128.         write_date(table[ge]);
  129.         delay(2);
  130.         write_date('H');
  131.         delay(2);
  132.         write_date('Z');
  133.         delay(2);
  134.         if(boxing==0)
  135.         {
  136.                 write_com(0x80+7);
  137.                 write_date('s');
  138.                 write_date('i');
  139.                 write_date('n');
  140.                 write_date(' ');
  141.                 write_date(' ');
  142.                 write_date(' ');
  143.                 write_date(' ');
  144.         }
  145.         if(boxing==1)
  146.         {
  147.                 write_com(0x80+7);
  148.                 write_date('j');
  149.                 write_date('u');
  150.                 write_date('x');
  151.                 write_date('i');
  152.                 write_date('n');
  153.                 write_date('g');
  154.         }

  155.         if(boxing==2)
  156.         {
  157.                 write_com(0x80+7);
  158.                 write_date('s');
  159.                 write_date('a');
  160.                 write_date('n');
  161.                 write_date('j');
  162.                 write_date('i');
  163.                 write_date('a');
  164.                 write_date('o');
  165.         }
  166.         if(boxing==3)
  167.         {
  168.                 write_com(0x80+7);
  169.                 write_date('j');
  170.                 write_date('u');
  171.                 write_date('c');
  172.                 write_date('h');
  173.                 write_date('i');
  174.                 write_date(' ');
  175.                 write_date(' ');
  176.         }

  177. }
  178. uchar keyscan()                                        //鍵盤檢測函數
  179. {
  180. //        if(P1&0x0F==0x0F) return 0;
  181.         if(s1==0)
  182.         {         
  183.                 EA=0;
  184.                 delay(1);
  185.                 if(s1==0)
  186.                 {
  187.                         while(!s1);
  188.                         pinlv+=bujin;
  189.                         if(pinlv>30000)
  190.                         {
  191.                                 pinlv=30000;
  192.                         }
  193.                         geshu=pinlv/120+1;
  194.                         if(pinlv>960)
  195.                         {
  196.                                 geshu=8;
  197.                                 bujin=100;
  198.                                 bujin1=100;
  199.                         }
  200.                         if(pinlv>1080) geshu=10;
  201.                         if(pinlv>2000) geshu=11;

  202.                         hc=15625/pinlv;
  203.                         m=hc*geshu;
  204.                         m-=54;
  205.                         m/=15;
  206.                         
  207.                         EA=1;
  208.                         display();
  209.                         
  210.                 }
  211.         }
  212.         if(s2==0)
  213.         {         
  214.                
  215.                 delay(1);
  216.                 if(s2==0)
  217.                 {
  218.                         EA=0;        
  219.                         while(!s2);
  220.                         pinlv-=bujin;
  221.                         if(pinlv<0)
  222.                         {
  223.                                 pinlv=0;
  224.                         }
  225.                         geshu=pinlv/120+1;
  226.                         if(pinlv>960)
  227.                         {
  228.                                 geshu=8;
  229.                                 bujin=100;
  230.                                 bujin1=100;
  231.                         }
  232.                         if(pinlv>1080) geshu=10;
  233.                         if(pinlv>2000) geshu=11;
  234.                         if(pinlv<=3100)
  235.                                 {hc=15625/pinlv;
  236.                                 m=hc*geshu;
  237.                                 m-=54;
  238.                                 m/=15;}        
  239.                         else
  240.                         {
  241.                                 m=65276+(pinlv-480);
  242.                         }
  243.                         display();        
  244.                         EA=1;
  245.                 }
  246.         }
  247.         if(s3==0)
  248.         {         
  249.                 delay(1);
  250.                 if(s3==0)
  251.                 {
  252.                         EA=0;
  253.                         while(!s3);
  254.                         boxing++;
  255.                         if(boxing==4)
  256.                         {
  257.                                 boxing=0;
  258.                         }
  259.                         display();
  260.                         EA=1;
  261.                 }
  262.         }
  263.         return 1;        
  264. }
  265. void bujindisplay()
  266. {
  267.         uint bai,shi,ge;
  268.         bai=bujin1/100;
  269.         shi=bujin1%100/10;
  270.         ge=bujin1%100%10;
  271.         write_com(0x80+6);
  272.         write_date(table[bai]);
  273.         delay(1);
  274.         write_date(table[shi]);
  275.         delay(1);
  276.         write_date(table[ge]);
  277.         delay(1);
  278. }
  279. void bujinjiance()
  280. {
  281.         if(s4==0)
  282.         {
  283.                 delay(3);
  284.                 if(s4==0)
  285.                 {
  286.                          while(!s4);
  287.                          h++;
  288.                          if(h==1)
  289.                          {
  290.                                   write_com(0x01);
  291.                                  write_com(0x80);
  292.                                  write_date('b');delay(1);
  293.                                  write_date('u');delay(1);
  294.                                  write_date('j');delay(1);
  295.                                  write_date('i');delay(1);
  296.                                  write_date('n');delay(1);
  297.                                  write_date(':');delay(1);
  298.                                  bujin1=bujin;
  299.                                  
  300.                                  bujindisplay();
  301.                          }
  302.                          if(h==2)
  303.                          {
  304.                                  h=0;
  305.                                 bujin=bujin1;
  306.                                 
  307.                                 init_lcd();
  308.                                 initclock();
  309.                                 display();
  310.                          }
  311.                 }
  312.         }
  313.         if(h==1)
  314.         {
  315.                 if(s1==0)
  316.                 {
  317.                         delay(5);
  318.                         if(s1==0)
  319.                         {
  320.                                 while(!s1);
  321.                                 bujin1++;
  322.                                 if(bujin1==101)
  323.                                 {
  324.                                         bujin1=100;
  325.                                 }
  326.                                 bujindisplay();
  327.                         }
  328.                 }
  329.                 if(s2==0)
  330.                 {
  331.                         delay(5);
  332.                         if(s2==0)
  333.                         {
  334.                                 while(!s2);
  335.                                 bujin1--;
  336.                                 if(bujin1==0)
  337.                                 {
  338.                                         bujin1=100;
  339.                                 }
  340.                                 bujindisplay();
  341.                         }
  342.                 }
  343.         }
  344. }
  345. void main()                                         //主函數
  346. {        
  347.         
  348.         init_lcd();
  349.         hc=15625/pinlv;
  350.         m=hc*geshu;
  351.         m-=54;
  352.         m/=15;

  353.         initclock();
  354.         display();
  355. //        csda=0;
  356. //        wr=0;
  357.         while(1)
  358.         {
  359.                  
  360.                  switch(boxing)
  361.                  {
  362.                          case 0:        P2=sin[u];
  363.                                 break;
  364.                         case 1:         P2=juxing[u];
  365.                                 break;
  366.                         case 2:                 P2=sanjiao[u];
  367.                                 break;
  368.                         case 3:                 P2=juchi[u];
  369.                                 break;
  370.                  }
  371.                 u+=geshu;
  372.                 n=m;
  373.                 if(u>=64)
  374.                 {
  375.                         u=0;
  376.                 }
  377.                 while(n-->0);
  378.         }
  379. }
  380. void T0_time()interrupt 1                   //定時器
  381. {
  382.         
  383. //                TH0=a;
  384. //                TL0=b;
  385.                 TH0=0;
  386.                 TL0=0;
  387.                 if(h==0)
  388.                  {
  389.                           keyscan();
  390.                  }
  391.                  bujinjiance();
  392.                
  393.         

  394. }
復制代碼

Keil5代碼與Proteus8.13仿真下載:
信號發生器.7z (1.54 MB, 下載次數: 29)

評分

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

查看全部評分

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

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表