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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

奇偶位計算請問有什么好方法能實現

[復制鏈接]
跳轉到指定樓層
樓主
ID:12816 發表于 2015-9-30 19:41 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
最近在研究ID卡讀寫請問有什么好方法能實現將 五個字節的十六進制每半個字節計算出其對應的奇偶位,然后將每半個字節加奇偶位共 5BIT排列成十行再對每列奇偶位計算,
最后在得到的55BIT前面加上 9個1 共得到 64BIT再每8BIT為一個字節分成8個字節的十六進制數呢?謝謝!
例子:
              //如下為 ID = 3000F94989 轉碼過程
                      111111111 --->九個頭
                                       0011        0              3
                                       0000        0              0

                                   ---------------------------------------  
                                       0000        0              0  
                                       0000        0              0   

                                ------------------------------------------
                                       1111        0              F
                                       1001        0              9

                          --------------------------------------------------
                                       0100        1              4
                                       1001        0              9

                             -------------------------------------------------
                                       1000        1              8
                                       1001        0              9  

                           ---------------------------------------------      
                                       1001        0      --->列奇偶位

轉換結果為:0XFF / 0X98 / 0X00 / 0X07 / 0XA4 / 0X99 / 0X46 / 0X52
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:12816 發表于 2015-10-1 10:29 | 只看該作者
昨晚我也搞掂了,也是有很多行語句呀
void clqo()//行列奇偶位計算 并將五個字節的十六進制轉為卡的9個頭及奇偶位共64位即 八個字節的十六進制數據
{
        uchar kk;
        for(kk = 0;kk < 5;kk++)//將五個字節的十六進制分開半個字節
        {
                Buf_RF_Data[kk * 2 + 0] = ID_Code[kk] >> 4;
                Buf_RF_Data[kk * 2 + 1] = ID_Code[kk] & 0x0F;        
        }               
        for(kk = 0;kk < 10;kk++)//計算每半個字節的奇偶位
        {
                Buf_RF_Data[kk] &= 0x0F; //先屏蔽高4位
                if(((Buf_RF_Data[kk] >> 3) + (Buf_RF_Data[kk] >> 2) + (Buf_RF_Data[kk] >> 1) + (Buf_RF_Data[kk] & 0x01)) % 2)
                {
                        Buf_RF_Data[kk] <<= 1;
                        Buf_RF_Data[kk] |= 1;
                }
                else //為偶數個 1 則補 0
                {
                        Buf_RF_Data[kk] <<= 1;
                }
        }
        for(kk = 4;kk > 0;kk--)//列奇偶位
        {
                Buf_RF_Data[kk] &= 0x1F; //先屏蔽高3位
                if(((Buf_RF_Data[0] >> kk) + (Buf_RF_Data[1] >> kk) + (Buf_RF_Data[2] >> kk) + (Buf_RF_Data[3] >> kk) + (Buf_RF_Data[4] >> kk)
                + (Buf_RF_Data[5] >> kk) + (Buf_RF_Data[6] >> kk) + (Buf_RF_Data[7] >> kk) + (Buf_RF_Data[8] >> kk) + (Buf_RF_Data[9] >> kk)) % 2)
                {
                        Buf_RF_Data[10] |= 1;
                        Buf_RF_Data[10] <<= 1;
                }
                else //為偶數個 1 則補 0
                {
                        Buf_RF_Data[10] <<= 1;
                }        
        }        
        Buf_RF_Data[0] <<= 2;
        Buf_RF_Data[0] |= 0x80;
        Buf_RF_Data[0] |= Buf_RF_Data[1] >> 3;
        
        Buf_RF_Data[1] <<= 5;
        Buf_RF_Data[1] |= Buf_RF_Data[2];
        
        Buf_RF_Data[2] <<= 3;
        Buf_RF_Data[2] |= Buf_RF_Data[4] >> 2;
        
        Buf_RF_Data[3] = Buf_RF_Data[4] << 6;
        Buf_RF_Data[3] |= Buf_RF_Data[5] << 1;
        Buf_RF_Data[3] |= Buf_RF_Data[6] >> 4;
        
        Buf_RF_Data[4] = Buf_RF_Data[6] << 4;
        Buf_RF_Data[4] |= Buf_RF_Data[7] >> 1;
        
        Buf_RF_Data[5] = Buf_RF_Data[7] << 7;
        Buf_RF_Data[5] |= Buf_RF_Data[8] << 2;
        Buf_RF_Data[5] |=  Buf_RF_Data[9] >> 3;
        
        Buf_RF_Data[6] = Buf_RF_Data[9] << 5;
        Buf_RF_Data[6] |= Buf_RF_Data[10];
        
        for(kk = 7;kk > 0;kk--)
        {
                Buf_RF_Data[kk] = Buf_RF_Data[kk - 1];
        }
        Buf_RF_Data[0] = 0xFF;                //9個頭中的前8個1
        Buf_RF_Data[8] = Buf_RF_Data[9] = Buf_RF_Data[10] = 0;//這個可以不清 0
}
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 午夜精品在线 | 中文字幕国产精品 | 黄色一区二区三区 | 日本理论片午伦夜理片在线观看 | 欧美黄色片在线观看 | 午夜国产福利 | 99黄色| 国产一区在线观看视频 | 日韩成人精品 | 国产一区精品在线观看 | 欧美国产在线视频 | 亚洲va韩国va欧美va精品 | 国产精品999 | 亚洲视频在线播放 | 亚洲a在线观看 | 亚洲精品视频在线播放 | 亚洲影视一区 | 欧美va亚洲va| 日韩精品少妇 | 国产日韩免费 | 国产一级免费 | 国产黄色精品 | 欧美伊人久久 | 午夜在线观看视频网站 | 黄色片网站在线观看 | 精产国产伦理一二三区 | 午夜激情福利视频 | 糖心vlog精品一区二区 | 黄色免费av | 播播激情网 | 四虎黄色片 | 在线免费黄色 | 最新av在线播放 | 天天躁日日躁狠狠躁 | 午夜国产在线 | 黄色小视频免费观看 | 精品国产成人 | 国产网站免费 | av黄色网址 | 亚洲经典一区二区三区 | 亚洲怡春院 |