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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

用Arduino做BP機編碼程序

  [復制鏈接]
跳轉到指定樓層
樓主
ID:18867 發表于 2019-6-4 15:39 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
用Arduino做BP機POCSAG編碼程序,配合寶峰5R成功呼響大顧問機,用串口助手發送字符,發送格式a+1234567+b+信息(a=N或P向位,1234567為呼機在7位地址碼,b=1-4,為鈴聲)如:N12345671測試!

Arduino源程序如下:
  1. #define uchar unsigned char
  2. #define uint unsigned int
  3. String comdata = "";
  4. unsigned long addr;

  5. int PTT = 10; //PTT控制端
  6. int TX=9;//數據輸出端
  7. int ys=819;//延時
  8. unsigned long tem;
  9. uchar  Tx_Num;
  10. unsigned long  calc_bch_and_parity(unsigned long cw_e) //BCH校驗和奇偶校驗函數
  11. {
  12.     uchar i;
  13.    uchar  parity = 0; //奇偶校驗計數   
  14.    unsigned long local_cw; //臨時存放數         
  15.    local_cw=cw_e;//保存cw_e參數值
  16.    for(i=1;i<=21; i++,cw_e<<=1)           
  17.        if (cw_e & 0x80000000) cw_e ^= 0xED200000;  
  18.    cw_e=cw_e&0xFFC00000;//保留前10位,BCH校驗值共11位,只保留前10位有效數據         
  19.    local_cw |= (cw_e >> 21); //BCH校驗數移至第22位到31位,BCH共10位,并和原始數據相加
  20.    cw_e=local_cw;         
  21.    for(i=0; i<31; i++, cw_e<<=1) if(cw_e&0x80000000) parity++;        
  22.    if(parity%2) local_cw+=1;//從1至31位判斷為奇數則后面加1補充為偶數
  23.    return local_cw;
  24.       
  25. }  
  26. unsigned long  calc_addr( unsigned long add,uchar fun ) //地址轉換,第1參數為地址,第2參數為功能
  27. {
  28.   unsigned long adr;
  29.   unsigned long tem;   
  30.   Tx_Num=(uchar)(add&0x00000007);//獲取地址發射的幀位次,111位第7幀,后3位地址數據隱藏不發送,接收按幀位還原
  31.   adr=0x00;
  32.   adr=add&0xFFFFFFF8;        //去掉地址碼后3位
  33.   adr=adr<<10;  //地址左移10位
  34.   tem=0x00;
  35.   tem=fun;  //功能位
  36.   tem=tem<<11;//功能位左移11位,功能位為00 01 10 11四種狀態,代表4個地址碼
  37.   adr=adr|tem; //地址碼和功能位合成地址碼;
  38.   return adr;
  39. }

  40. void Send_start(unsigned long s)
  41. {
  42.     uchar i,n;
  43.     unsigned long tem;
  44.     for(i=0; i<20; i++)//發送576個前導10101010101010
  45.     {
  46.         tem=s;
  47.         for (n=0; n<32; n++)
  48.         {
  49.             if(tem&0x80000000)
  50.             {
  51.                 digitalWrite(TX,HIGH);
  52.             }
  53.             else
  54.             {
  55.                 digitalWrite(TX,LOW);
  56.             }
  57.             delayMicroseconds(ys);//等待延時結束 0.833ms
  58.             tem<<=1;
  59.         }
  60.     }
  61. }
  62. void Send_nill()//發送閑置位
  63. {
  64.     uchar n;
  65.     unsigned long s=0x7A89C197;
  66.     for(n=0; n<32; n++)
  67.     {
  68.         if(s&0x80000000)
  69.         {
  70.             digitalWrite(TX,LOW);
  71.         }
  72.         else
  73.         {
  74.             digitalWrite(TX,HIGH);
  75.         }
  76.         delayMicroseconds(ys);//等待延時結束 0.833ms
  77.         s<<=1;
  78.     }
  79. }
  80. void Send_Num(unsigned long s,char npi)         //發送數據
  81. {
  82.     uchar n;
  83.     int xx0,xx1;
  84.     if(npi=='P'){xx1=1;xx0=0;}
  85.     if(npi=='N'){xx1=0;xx0=1;}
  86.     for (n=0; n<32; n++)
  87.     {
  88.         if(s&0x80000000)
  89.         {
  90.             digitalWrite(TX,xx1);
  91.             //Serial.print(xx1);
  92.         }
  93.         else
  94.         {
  95.             digitalWrite(TX,xx0);
  96.             //Serial.print(xx0);
  97.         }
  98.         delayMicroseconds(ys);//等待延時結束 0.833ms
  99.         s<<=1;
  100.     }
  101. }
  102. void setup() {
  103.   Serial.begin(9600); //設置波特率為9600,一般是這個波特率
  104.   pinMode(TX,OUTPUT);   
  105.   pinMode(PTT,OUTPUT);
  106. }

  107. void loop() {
  108.    while (Serial.available() > 0)  //讀取串口數據
  109.     {
  110.       comdata += char(Serial.read());
  111.       delay(2);
  112.       }
  113.       if (comdata.length() > 0) //如果有數據進入處理
  114.       {
  115.         String np = comdata.substring(0,1);         
  116.         char npzf=toupper(np[0]);
  117.         String ly=comdata.substring(8,9);
  118.         int lyi=ly[0];
  119.         String dz = comdata.substring(1,8);         //獲取地址碼
  120.         unsigned long az=dz.toInt();                //地址碼s轉類型
  121.         tem=calc_addr(az,lyi-48);                        //地址碼移位處理
  122.         addr=calc_bch_and_parity(tem);              //地址碼BCH校驗
  123.         String msgdata = comdata.substring(9,200);  //截取信息碼內容
  124.         int len = msgdata.length()+10;               //獲取信息碼字節長度(+4為了讓長度大于1幀,就不用1個漢字還用做判斷了)
  125.         byte hui[200]={0};
  126.         digitalWrite(PTT,LOW);                      //對講機ppt
  127.         delay(500);                                 //延時500ms                              
  128.         unsigned long mess[200]={0};                //信息碼數組         
  129.                                             //信息碼數組元素
  130.         unsigned long msg;
  131.         int ll=0;
  132.         int wz=0;
  133.         if(!(msgdata[0]&0x80)){hui[wz]=0x0f;wz++;}
  134.         for(int i=0;i<len;i++)
  135.         {
  136.          if(!(msgdata[i]&0x80) && msgdata[i-1]&0x80 && i>0){hui[wz]=0x0f;wz++;}
  137.           hui[wz]=msgdata[i];
  138.           wz++;
  139.           if(!(msgdata[i]&0x80) && msgdata[i+1]&0x80){hui[wz]=0x0e;wz++;}
  140.          }
  141.           wz=0;
  142.           int k=1;
  143.           for(int n=0;n<=len;n++)
  144.           {
  145.             for(int j=0;j<7;j++)
  146.             {
  147.               if(hui[wz]&0x01){msg|=0x00000001;}
  148.               msg<<=1;
  149.               hui[wz]>>=1;
  150.               ll++;
  151.               if(ll%20==0)
  152.               {
  153.                 msg<<=10;
  154.                 msg|=0x80000000;
  155.                 mess[k]=calc_bch_and_parity(msg);
  156.                 msg=0;
  157.                 k++;
  158.               }
  159.             }
  160.             wz++;
  161.           }
  162.             Send_start(0xAAAAAAAA);                 //發送前言碼
  163.             Send_Num(0x7CD215D8,npzf);                   //發送同步碼
  164.             mess[0]=addr;                           //地址碼放入信息碼第一碼字
  165.             for(int j=0;j<120;j++)                  //循環發送信息碼
  166.             {
  167.               if(mess[j]!=0){Send_Num(mess[j],npzf);}    //數組元素不為0的發送
  168.               Serial.println(mess[j],BIN);

  169.               if((j+1)%16==0 && j!=0){Send_Num(0x7CD215D8,npzf);}  //每隔8幀發送一個同步碼
  170.             }
  171.           Send_Num(0x7A89C197,npzf);                   //末尾發送閑置碼
  172.           comdata="";
  173.           msgdata="";
  174.           }
  175.           digitalWrite(PTT,HIGH);
  176.           }

復制代碼


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

使用道具 舉報

沙發
ID:328014 發表于 2019-6-5 05:50 | 只看該作者
好東東啊 家里剛好還有一個bp機,不知道樓主的電路該如何連接啊?
回復

使用道具 舉報

板凳
ID:452731 發表于 2019-7-8 16:13 | 只看該作者
有詳細電路連接就是最好不過了
回復

使用道具 舉報

地板
ID:373684 發表于 2019-10-10 20:30 | 只看該作者
把壓縮文件下了,,可能在那里有吧
回復

使用道具 舉報

5#
ID:617305 發表于 2019-10-13 11:05 | 只看該作者
這個BP機不是已經淘汰了嗎?做這個有實際用處嗎?
回復

使用道具 舉報

6#
ID:688099 發表于 2020-1-25 10:33 | 只看該作者
樓主,你好,請問怎么配合寶峰5R,有具體的接線圖或說明嗎,非常感謝!
回復

使用道具 舉報

7#
ID:686444 發表于 2020-1-29 19:34 | 只看該作者
看 代碼應該是9腳連對講機輸出 , 10腳連對講機輸出控制
回復

使用道具 舉報

8#
ID:934976 發表于 2021-6-8 18:33 | 只看該作者
請問一下有沒有連線實物圖呢?
回復

使用道具 舉報

9#
ID:1031190 發表于 2022-5-31 10:15 | 只看該作者
請問一下有沒有連線實物圖呢?
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 99久久婷婷国产综合精品电影 | 狠狠躁躁夜夜躁波多野结依 | 欧美激情欧美激情在线五月 | 亚洲精品国产电影 | 91 在线| www.亚洲| 国产精品揄拍一区二区 | 成人日韩 | 毛片毛片毛片毛片 | 欧美一区视频 | 女同久久另类99精品国产 | 成年人精品视频在线观看 | 亚洲视频在线看 | 午夜av电影院 | 日本h片在线观看 | 中文在线视频观看 | 中文字幕在线观看一区 | 天天操综合网站 | 日日摸夜夜添夜夜添精品视频 | 成人国产在线观看 | 国产1区2区在线观看 | 国产精品123区 | 久久国产精品72免费观看 | 美女国内精品自产拍在线播放 | 91 久久| 精品av久久久久电影 | 波多野吉衣久久 | 日韩精品一区二区三区中文字幕 | 欧美精品1区 | 在线观看国产精品视频 | 2019天天操 | 亚洲精品久久久蜜桃 | 密色视频 | 欧美天堂| 亚洲精品一区二区三区 | 国产精品视频一区二区三区 | 亚洲成人精品一区二区 | 久久久久久久久久一区 | 夜夜久久| 欧美成年网站 | 欧美中文在线 |