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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

PIC16F877A單片機PPM調制的激光通信Proteus仿真及源程序

[復制鏈接]
跳轉到指定樓層
樓主
幫一個畢業生做的《PIC16F877A基于PPM的激光通信》仿真。
軟件:
MPLAB X IDE v4.15編譯    proteus 8.6仿真.
1、仿真電路圖;
2、發送和接收源程序加注釋。
請看注釋。
原理:
1)ADC讀取并用led顯示ADC讀數,并通過usart進行輸出。
2)通過PPM原理進行通訊傳輸到另外一個單片機,LED顯示接收的值。
具體請看附件
希望大家頂一下。
仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)

1、發送模塊:讀取ADC數值,LED顯示10位ADC值。并通過PPM發送。
2、接收模塊:PPM接收到的數據。LED顯示接收的ADC值(10bits)

基于PIC單片機的PPM調制激光通信收發器
PPM (pulse position modulation) 脈沖位置調制。
  • 通過改變脈沖的位置來傳輸不同的數據。
如圖1、
  • PPM的編碼:
如圖、利用單片機的PWM功能產生PWM1和PWM2連個脈沖。
利用數字電路合成PPM脈沖。
可以看出當PWM1的占空比是0時,PPM如下圖的A,
PWM1的占空比是1時,PPM如下圖的B,


  • PPM的合成:
如第一個圖可知,PPM可以將PPM1求反后和PWM2相與得到。
故設計如上發送模塊。接收模塊結果波形整形送到單片機處理。
  • PPM發送的數據(16位的雙字節數)。
定義占空比一定的脈沖為發送的數據。
發送0,   0,   0,   0-3, 4-7,   8-11, 12-15
前面是頭,可以提供接收PPM的單個周期。
  • PPM接收。
PPM接收到的數據是:
由圖中知道
  • 不用,作為啟動接收。
  • 就是波形的周期
    (3-2)即3測量的寬度減去波形的周期的等于0-3對應的PWM脈寬1
(4+脈寬1-2)即4測量的寬度加上脈寬1減去波形的周期的等于4-7對應的PWM脈寬2
(5+脈寬2-2)即5測量的寬度加上脈寬2減去波形的周期的等于8-11對應的PWM脈寬3
(6+脈寬3-2)即6測量的寬度加上脈寬3減去波形的周期的等于12-15對應的PWM脈寬4
在將四個半字節數合成2個字節16位的值。

單片機源程序如下:
  1. #include "sys.h"
  2. #include <stdint.h>        /* For uint8_t definition */
  3. #include <stdbool.h>       /* For true/false definition */
  4. #include <stdio.h>
  5. #define AKING PORTCbits.RC0
  6. const uint8_t uart_disp1[]={"ADC result(DEC) is:"};      //uart DISP
  7. void usart_send_8bits(uint8_t send_data);
  8. void ppm_send_unit(uint8_t send_data);
  9. void time1_init();

  10. uint16_t adc_read()                        
  11. {
  12.     ADCON1=0x80;                //fosc/2,A口都是AD口,Vref=VDD
  13.            ADCON0=0x01;                //AN0進行轉換,允許轉換
  14.                                 //ADFM  ADCS2 --  --  PCFG3   PCFG2   PCFG1  PCFG0
  15.                                 //        1      0             0      0      0      0
  16.                                 //ADCS1 ADCS0  CHS2 CHS1 CHS0  GO/DONE  --  ADON
  17.                                 //  0     0     0    0     0     0            1
  18.     __delay_ms(2);              //delay
  19.         GO=0x01;                                                          //開始AD轉換
  20.     while(GO);                                                        //是否轉換完畢,GO=0轉換完畢  
  21.         uint16_t adc_result=(uint16_t)ADRESH<<8 |ADRESL;    //轉換結果,10bits
  22.     return adc_result;                  //return ADC results
  23. }
  24. void sys_init()                        //SYS INIT
  25. {   
  26.     TRISC=0;                            //PORTC is output
  27.     PORTC=0;                            //Clear PORTC
  28.     TRISD=0;                            //PORTD is output
  29.     PORTD=0;                            //Clear PORTD
  30. }
  31. void uart_init()                        //UART INIT
  32. {
  33.     TXSTA =0x24;                            //TXEN=1,TX enable
  34.                                             //BRGH=1,high speed baud
  35.     RCSTA =0b10010000;                      //SPEN=1,receive enable
  36.                                             //CREN=1
  37.     TRISB=0x00;                             //PORTB is output
  38.     SPBRG=103;                              //SPBRG=FOSC/(16*baud)-1;      (high speed baud)
  39.                                             //     =16000000/(16*9600)-1
  40.                                             //     =104-1=103
  41.     INTCON=0;                               //no interrupt
  42.     PIE1=0;                                 //PIE1 disable
  43.     PIE2=0;                                 //PIE2 disable
  44.     PIR1=0;                                 //Clear PIR1(flag of interrupt)
  45.     PIR2=0;                                 //Clear PIR2(flag of interrupt)
  46. }
  47. void usart_send_16bits(uint16_t send_data)            //send 2 bytes
  48. {
  49.      uint16_t send_buffer;                     
  50.       send_buffer=send_data;                           
  51.       usart_send_8bits((uint8_t)(send_buffer>>8));      //send high byte
  52.       usart_send_8bits((uint8_t)(send_data));           //send low  byte
  53. }
  54. void usart_send_8bits(uint8_t send_data)            //send one bytes
  55. {
  56.       TXREG=(uint8_t)(send_data);                       
  57.       while(TRMT==0);                                 //send is over
  58. }
  59. void TMR1_init()                                    //TMR1 INIT
  60. {
  61.     T1CON=0;                                         //TMR1 is TIMR
  62.     TMR1=(uint16_t)(65535-985);                      //delay is 1000*FOSC=1000*0.25=250us
  63.     TMR1IF=0;                                        //Clear TMR1IF
  64. }
  65. void PWM_init()                                     //PWM INIT
  66. {
  67.     PR2=0xff;                                        //寫入PR2寄存器設置PWM周期,PWM周期=[(PR2)+1]*4*TOSC*(TMR2預分頻比)
  68.                                                      //                               =[255+1]*4*4/16=256us

  69.     CCPR1L=0;                                       //Clear CCPR1L
  70.     T2CON=0x01;                                     //TMR2預分頻比=1:4
  71.     CCP1CON=0;                                      //Clear CCP1CON
  72.     CCP2CON=0;                                      //Clear CCP2CON
  73.     TMR2ON=1;                                       //TMR2 enable
  74. }
  75. void PPM_unit(uint8_t send_data)                   //PPM send half byte
  76. {
  77.     TMR1_init();                                    //TMR1 delay 250us
  78.     TMR1ON=1;                                       //TMR1 enable
  79.     TMR2=0xF0;                                      //to start PWM
  80.     CCPR1L=(uint8_t)(send_data<<3);                 //CCPR1L
  81.     CCPR2L=(uint8_t)(CCPR1L+8);                     //CCPR2L=CCPR1L+8
  82.     CCP1CON=0x0c;                                   //CCP1 PWM enable
  83.     CCP2CON=0x0c;                                   //CCP2 PWM enable
  84.     while(TMR1IF==0);                               //250us delay is over
  85.     TMR1IF=0;                                       //clear TMR1IF
  86.     CCP1CON=0x0;                                    //CCP1 PWM disable
  87.     CCP2CON=0x0;                                    //CCP2 PWM disable
  88.    
  89. }
  90. void PPM_send(uint16_t send_data)                 //PPM send 2 byte
  91. {
  92.     uint8_t send_buffer[7];
  93.     send_buffer[3]=(uint8_t)send_data;              //half byte
  94.     send_buffer[4]=(uint8_t)send_data;              //half byte
  95.     send_buffer[5]=(uint8_t)(send_data>>8);         //half byte
  96.     send_buffer[6]=(uint8_t)(send_data>>8);         //half byte
  97.     send_buffer[0]=0;                               //head
  98.     send_buffer[1]=0;                               //head                             
  99.     send_buffer[2]=0;                               //head   
  100.     send_buffer[3]=(uint8_t)(send_buffer[3] & 0x0f);    //half byte
  101.     send_buffer[4]=(uint8_t)(send_buffer[4]>>4);        //half byte
  102.     send_buffer[5]=(uint8_t)(send_buffer[5] & 0x0f);    //half byte
  103.     send_buffer[6]=(uint8_t)(send_buffer[6]>>4);        //half byte
  104.     for(uint8_t i=0;i<7;i++)
  105.     {
  106.         PPM_unit(send_buffer[i]);                       //PPM send head(0,0,0) & half byte,half byte,half byte,half byte      7 bytes
  107.     }      
  108. }
  109. void UART_disp(uint16_t uart_data)                     //UART DISP
  110. {
  111.     for(uint8_t i=0;i<19;i++)
  112.     {
  113.         usart_send_8bits(uart_disp1[i]);                //PRINT"ADC result(DEC) is:"
  114.     }
  115.     uint8_t buff[4];
  116.     sprintf(buff,"%d",uart_data);                       //ADC result Dec
  117.     for(uint8_t i=0;i<4;i++)
  118.     {
  119.         usart_send_8bits(buff[i]);                      //
  120.     }
  121.     usart_send_8bits(0x0d);                             //send "enter"
  122. }
  123. void main(void)
  124. ……………………

  125. …………限于本文篇幅 余下代碼請從51黑下載附件…………
復制代碼


所有資料51hei提供下載:
sendrece2.rar (499.06 KB, 下載次數: 90)




評分

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

查看全部評分

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

使用道具 舉報

沙發
ID:109235 發表于 2019-11-13 12:58 | 只看該作者
好樣的,學習一下1
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 久久精品久久久久久 | 91视频入口 | 91高清视频在线 | 国产日韩欧美在线观看 | 免费的色网站 | 一区二区三区av | 亚洲一区二区精品视频 | 精品久久久久久久久久久久久久 | 激情 一区 | 午夜影院操 | 国产亚洲一区二区精品 | 欧美一级久久 | 在线观看第一区 | 亚洲免费观看 | 国产成人精品免费 | 日韩中文不卡 | 久久国产精品-国产精品 | 久草在线中文888 | 欧美精品福利 | 电影在线 | 成人午夜电影网 | 成人激情视频 | 6080yy精品一区二区三区 | 日韩aⅴ片 | 国产午夜精品理论片a大结局 | 成人毛片网| 四虎影 | a级片在线 | 成人精品国产一区二区4080 | 黑人精品欧美一区二区蜜桃 | 免费黄色a级毛片 | 欧美精品一区久久 | 四虎成人免费视频 | 一本色道久久综合亚洲精品高清 | 天堂资源最新在线 | 亚洲免费人成在线视频观看 | 久久无毛| 久久久九九| 99久久婷婷国产综合精品电影 | 国产精品综合久久 | 成人在线精品视频 |