標(biāo)題: pic單片機(jī)軟件計(jì)算奇偶校驗(yàn),出錯(cuò) [打印本頁(yè)]

作者: fengxiaoliang    時(shí)間: 2022-7-12 10:34
標(biāo)題: pic單片機(jī)軟件計(jì)算奇偶校驗(yàn),出錯(cuò)
pic軟件計(jì)算奇偶校驗(yàn),發(fā)送1,2,3,4,5。顯示3F,3F,03,3F,05。請(qǐng)大家?guī)兔纯?/font>
uint add (uint data)        //奇校驗(yàn) 1的個(gè)數(shù)為奇數(shù)
{
        uint i = 0;
        int cnt = 0;
        int temp = 0;
        for(i = 0;i < 8;i++)
        {
                temp = ((data >> i) & 1);
                cnt += temp;
        }
        if(cnt%2 == 0)
        {
                return 1;
        }
        else
        {
                return 0;
        }


}





void Usart_Init (void)               
{        
        RCSTA = 0xD0;                //9位接收               
        TXSTAbits.TX9 = 1;  //9位發(fā)送
        TXSTAbits.TXEN = 1;        //使能發(fā)送
        TXSTAbits.SYNC = 0;        //異步
        TXSTAbits.BRGH = 1;        //高速

        BAUDCONbits.BRG16 = 0; //SYNC = 0, BRGH = 1, BRG16 = 0
                                       
        SP1BRGH = 0;
        SP1BRGL = 0x19;                        //25,波特率9600
        RCIE = 1;
        RCIF = 0;
//        TXIE = 1;
}


void Usart_SEND (uint TX)
{        
        TXSTAbits.TX9D = add(TX);
        TXREG = TX;
        while(!TXSTAbits.TRMT);
        delayus(50);
}




作者: Hephaestus    時(shí)間: 2022-7-12 22:30
本帖最后由 Hephaestus 于 2022-7-12 22:37 編輯

奇偶校驗(yàn)不用循環(huán)那么麻煩。
  1.                 k=c^(c>>1);
  2.                 k=k^(k>>2);
  3.                 k=k^(k>>4);
  4.                 return(k&1);
復(fù)制代碼

作者: fengxiaoliang    時(shí)間: 2022-7-13 16:07
Hephaestus 發(fā)表于 2022-7-12 22:30
奇偶校驗(yàn)不用循環(huán)那么麻煩。

首先謝謝回復(fù)啊。
我感覺(jué)不是奇偶校驗(yàn)返回值的問(wèn)題啊,因?yàn)槲野l(fā)了1,隨后我又打印了1的校驗(yàn)位顯示是0。發(fā)了2,又打印了2的校驗(yàn)位顯示是0。發(fā)了3,打印了校驗(yàn)位顯示是1。所以奇校驗(yàn)的返回值,我感覺(jué)是對(duì)的。
作者: fengxiaoliang    時(shí)間: 2022-7-13 16:11
fengxiaoliang 發(fā)表于 2022-7-13 16:07
首先謝謝回復(fù)啊。
我感覺(jué)不是奇偶校驗(yàn)返回值的問(wèn)題啊,因?yàn)槲野l(fā)了1,隨后我又打印了1的校驗(yàn)位顯示是0。 ...

也就是這個(gè)奇校驗(yàn)函數(shù),我入?yún)⑹?,返回的是0。入?yún)⑹?,返回值是0,入?yún)⑹?。返回值是1。符合奇校驗(yàn)的校驗(yàn)位的規(guī)則啊。
作者: daemondong    時(shí)間: 2022-7-13 16:55
從程序邏輯上看,算法麻煩了點(diǎn),但是沒(méi)錯(cuò)。只能看邏輯分析儀了,看看你收發(fā)的波形到底是什么? 算法簡(jiǎn)化代碼如下:
  1. uint add (uint data)        //奇校驗(yàn) 1的個(gè)數(shù)為奇數(shù)
  2. {
  3.         uint i = 0;
  4.         int cnt = 1;
  5.         for(i = 0;i < 8;i++)
  6.             if ((data >> i) & 1) cnt =1-cnt;

  7.         return cnt;

  8. }
復(fù)制代碼

作者: fengxiaoliang    時(shí)間: 2022-7-13 18:45
daemondong 發(fā)表于 2022-7-13 16:55
從程序邏輯上看,算法麻煩了點(diǎn),但是沒(méi)錯(cuò)。只能看邏輯分析儀了,看看你收發(fā)的波形到底是什么? 算法簡(jiǎn)化代 ...

謝謝回復(fù)。




歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1