在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

FPGA學習系列:33. 二進制轉(zhuǎn)格雷碼轉(zhuǎn)二進制的設計

FPGA學習交流 ? 2018-08-28 16:16 ? 次閱讀

設計背景:

典型的二進制格雷碼(Binary Gray Code)簡稱格雷碼,因1953年公開的弗蘭克·格雷(Frank Gray,18870913-19690523)專利“Pulse Code Communication”而得名,當初是為了通信,現(xiàn)在則常用于模擬-數(shù)字轉(zhuǎn)換和位置-數(shù)字轉(zhuǎn)換中。法國電訊工程師波特(Jean-Maurice-émile Baudot,18450911-19030328)在1880年曾用過的波特碼相當于它的一種變形。1941年George Stibitz設計的一種8元二進制機械計數(shù)器正好符合格雷碼計數(shù)器的計數(shù)規(guī)律。

設計原理:

在一組數(shù)的編碼中,若任意兩個相鄰的代碼只有一位二進制數(shù)不同,則稱這種編碼為格雷碼(GrayCode),另外由于最大數(shù)與最小數(shù)之間也僅一位數(shù)不同,即“首尾相連”,因此又稱循環(huán)碼或反射碼。在數(shù)字系統(tǒng)中,常要求代碼按一定順序變化。例如,按自然數(shù)遞增計數(shù),若采用8421碼,則數(shù)0111變到1000時四位均要變化,而在實際電路中,4位的變化不可能絕對同時發(fā)生,則計數(shù)中可能出現(xiàn)短暫的其它代碼(1100、1111等)。在特定情況下可能導致電路狀態(tài)錯誤或輸入錯誤。使用格雷碼可以避免這種錯誤。格雷碼有多種編碼形式。
格雷碼(GrayCode)曾用過GreyCode、葛萊碼、格萊碼、戈萊碼、循環(huán)碼、反射二進制碼、最小差錯碼等名字,它們有的不對,有的易與其它名稱混淆,建議不要再使用這些曾用名。

1位格雷碼有兩個碼字

(n+1)位格雷碼中的前2n個碼字等于n位格雷碼的碼字,按順序書寫,加前綴0

(n+1)位格雷碼中的后2n個碼字等于n位格雷碼的碼字,按逆序書寫,加前綴1

設計代碼:

設計模塊

0moduleb_g_b(bin,bo);//端口列表

1

2 input[7:0]bin;//8位二進制輸入

3

4 reg[8:0]bi;

5 outputreg[8:0]bo;//8位二進制輸出

6 reg[8:0]g;

7

8 //二進制轉(zhuǎn)格雷碼

9 integeri;

10 always@(*)

11 begin

12 bi =bin;

13 bi[8]=0;

14 for(i =7;i >=0;i =i -1)

15 g[i]=bi[i]^bi[1+i];

16

17 end

18

19 //格雷碼轉(zhuǎn)二進制

20 always@(*)

21 begin

22 bo[8]=0;

23 for(i =7;i >=0;i =i -1)

24 bo[i]=g[i]^bo[i +1];

25 end

26

27endmodule

測試模塊

0`timescale1ns/1ps//仿真時標

1

2moduletb;

3

4 reg[7:0]bi;

5 wire[7:0]bo;

6

7 initialbegin

8 bi =0;

9

10 #50bi =8'haa;//二進制模擬

11 #50bi =8'hff;

12 #50bi =8'h55;

13 #50bi =8'hff;

14

15 #200$stop;//停止

16

17 end

18

19 b_g_b dut(.bin(bi),.bo(bo));//端口例化

20

21endmodule

仿真圖:

設計背景:

典型的二進制格雷碼(Binary Gray Code)簡稱格雷碼,因1953年公開的弗蘭克·格雷(Frank Gray,18870913-19690523)專利“Pulse Code Communication”而得名,當初是為了通信,現(xiàn)在則常用于模擬-數(shù)字轉(zhuǎn)換和位置-數(shù)字轉(zhuǎn)換中。法國電訊工程師波特(Jean-Maurice-émile Baudot,18450911-19030328)在1880年曾用過的波特碼相當于它的一種變形。1941年George Stibitz設計的一種8元二進制機械計數(shù)器正好符合格雷碼計數(shù)器的計數(shù)規(guī)律。

設計原理:

在一組數(shù)的編碼中,若任意兩個相鄰的代碼只有一位二進制數(shù)不同,則稱這種編碼為格雷碼(GrayCode),另外由于最大數(shù)與最小數(shù)之間也僅一位數(shù)不同,即“首尾相連”,因此又稱循環(huán)碼或反射碼。在數(shù)字系統(tǒng)中,常要求代碼按一定順序變化。例如,按自然數(shù)遞增計數(shù),若采用8421碼,則數(shù)0111變到1000時四位均要變化,而在實際電路中,4位的變化不可能絕對同時發(fā)生,則計數(shù)中可能出現(xiàn)短暫的其它代碼(1100、1111等)。在特定情況下可能導致電路狀態(tài)錯誤或輸入錯誤。使用格雷碼可以避免這種錯誤。格雷碼有多種編碼形式。
格雷碼(GrayCode)曾用過GreyCode、葛萊碼、格萊碼、戈萊碼、循環(huán)碼、反射二進制碼、最小差錯碼等名字,它們有的不對,有的易與其它名稱混淆,建議不要再使用這些曾用名。

1位格雷碼有兩個碼字

(n+1)位格雷碼中的前2n個碼字等于n位格雷碼的碼字,按順序書寫,加前綴0

(n+1)位格雷碼中的后2n個碼字等于n位格雷碼的碼字,按逆序書寫,加前綴1

設計代碼:

設計模塊

0moduleb_g_b(bin,bo);//端口列表

1

2 input[7:0]bin;//8位二進制輸入

3

4 reg[8:0]bi;

5 outputreg[8:0]bo;//8位二進制輸出

6 reg[8:0]g;

7

8 //二進制轉(zhuǎn)格雷碼

9 integeri;

10 always@(*)

11 begin

12 bi =bin;

13 bi[8]=0;

14 for(i =7;i >=0;i =i -1)

15 g[i]=bi[i]^bi[1+i];

16

17 end

18

19 //格雷碼轉(zhuǎn)二進制

20 always@(*)

21 begin

22 bo[8]=0;

23 for(i =7;i >=0;i =i -1)

24 bo[i]=g[i]^bo[i +1];

25 end

26

27endmodule

測試模塊

0`timescale1ns/1ps//仿真時標

1

2moduletb;

3

4 reg[7:0]bi;

5 wire[7:0]bo;

6

7 initialbegin

8 bi =0;

9

10 #50bi =8'haa;//二進制模擬

11 #50bi =8'hff;

12 #50bi =8'h55;

13 #50bi =8'hff;

14

15 #200$stop;//停止

16

17 end

18

19 b_g_b dut(.bin(bi),.bo(bo));//端口例化

20

21endmodule

仿真圖:

在仿真圖中可以得到,在設計文件中設計的輸入二進制為00 55 等等,在轉(zhuǎn)化后的輸出模塊中可以清楚的看到輸入和輸出是一樣的,通過仿真可以得到本次設計正確。



聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • FPGA
    +關注

    關注

    1644

    文章

    21993

    瀏覽量

    615358
收藏 人收藏

    評論

    相關推薦
    熱點推薦

    偏移二進制二進制補碼如何和實際數(shù)據(jù)對應,如何轉(zhuǎn)換?

    偏移二進制二進制補碼如何和實際數(shù)據(jù)對應,如何轉(zhuǎn)換,請哪位高手解惑
    發(fā)表于 01-16 06:01

    bcd編碼的應用 bcd與二進制的區(qū)別

    BCD(Binary-Coded Decimal)編碼是一種二進制編碼形式,用于表示十進制數(shù)字。它將每個十進制數(shù)字(0-9)直接編碼為一個四位二進制數(shù)。BCD編碼的主要優(yōu)點是易于閱讀和
    的頭像 發(fā)表于 12-20 17:11 ?2924次閱讀

    hex格式和二進制的區(qū)別

    。 它以ASCII文本形式表示的十六進制數(shù)據(jù),每兩個十六進制字符對應一個字節(jié)。 HEX文件包含了記錄類型、數(shù)據(jù)長度、地址、數(shù)據(jù)以及校驗和等信息,具有結(jié)構化且包含校驗的特點。 二進制
    的頭像 發(fā)表于 11-18 15:24 ?1611次閱讀

    在線二進制編碼器:數(shù)據(jù)轉(zhuǎn)換的快捷通道

    在數(shù)字時代,數(shù)據(jù)的快速轉(zhuǎn)換與處理至關重要。二進制編碼,作為計算機內(nèi)部數(shù)據(jù)表示的基礎,將信息轉(zhuǎn)化為0和1的序列,為數(shù)字世界構建了溝通的橋梁。然而,對于非專業(yè)用戶來說,手動進行二進制編碼既繁瑣又易出錯
    的頭像 發(fā)表于 11-15 09:01 ?1683次閱讀

    base64字符串轉(zhuǎn)換為二進制文件

    Base64是一種編碼方法,用于將二進制數(shù)據(jù)轉(zhuǎn)換為ASCII字符串。這種編碼通常用于在不支持二進制數(shù)據(jù)的系統(tǒng)中傳輸數(shù)據(jù),例如電子郵件或網(wǎng)頁。將Base64字符串轉(zhuǎn)換為二進制文件的過程相對簡單,但需要
    的頭像 發(fā)表于 11-10 10:55 ?2726次閱讀

    ASCII二進制的轉(zhuǎn)換關系

    。ASCII使用7位二進制數(shù)來表示128個不同的字符,包括大小寫英文字母、數(shù)字0-9以及一些控制字符和標點符號。后來,ASCII被擴展到了8位,即ASCII-8BIT,可以表示256個不同的字符。
    的頭像 發(fā)表于 11-10 09:50 ?3781次閱讀

    二進制編碼器的精度與分辨率

    編碼器是一種將模擬信號(如電壓、溫度等)轉(zhuǎn)換為二進制代碼的設備。它通常包含一個模數(shù)轉(zhuǎn)換器(ADC),該轉(zhuǎn)換器通過比較輸入信號與一系列參考電壓來確定輸入信號的值。編碼器的輸出是一個二進制數(shù),表示輸入信號的數(shù)字等價。
    的頭像 發(fā)表于 11-06 09:56 ?1126次閱讀

    二進制編碼器在自動化領域的作用

    二進制編碼器是一種將二進制信號轉(zhuǎn)換為數(shù)字信號的電子設備,廣泛應用于自動化領域。 一、二進制編碼器的工作原理 二進制編碼器是一種將二進制信號轉(zhuǎn)
    的頭像 發(fā)表于 11-06 09:53 ?867次閱讀

    二進制編碼器在機器人中的應用

    隨著科技的不斷進步,機器人技術已經(jīng)成為現(xiàn)代工業(yè)、服務業(yè)乃至家庭生活中不可或缺的一部分。機器人的智能化程度不斷提高,這在很大程度上依賴于其傳感器系統(tǒng)。二進制編碼器作為一種傳感器,能夠?qū)⑽锢砹哭D(zhuǎn)換
    的頭像 發(fā)表于 11-06 09:48 ?954次閱讀

    二進制編碼器的種類及特點

    二進制編碼器是一種電子電路,用于將二進制信號轉(zhuǎn)換為其他格式,如十進制等。以下是一些常見的
    的頭像 發(fā)表于 11-06 09:47 ?1351次閱讀

    二進制編碼器應用場景 二進制編碼器與模擬編碼器比較

    編碼器是將信息從一種形式或格式轉(zhuǎn)換為另一種形式的設備。在數(shù)字和模擬系統(tǒng)中,編碼器扮演著至關重要的角色。二進制編碼器和模擬編碼器是兩種常見的編碼器類型,它們在不同的應用場景中有著各自的優(yōu)勢和局
    的頭像 發(fā)表于 11-06 09:45 ?1187次閱讀

    二進制編碼器工作原理 如何選擇二進制編碼器

    二進制編碼器是一種數(shù)字電路,它將輸入的二進制代碼轉(zhuǎn)換為對應的輸出信號。在數(shù)字系統(tǒng)中,編碼器用于將數(shù)據(jù)從一種形式轉(zhuǎn)換為另一種形式,以便于處理和傳輸。 二進制編碼器工作原理 輸入與輸出關系 :
    的頭像 發(fā)表于 11-06 09:44 ?2385次閱讀

    二進制補碼及與原碼的互相轉(zhuǎn)換方法

    大沙把一些基礎的知識說清楚,本文介紹二進制補碼及與原碼的轉(zhuǎn)換方法。 先說原碼,原碼?是一種計算機中對數(shù)字的二進制定點表示方法。在原碼表示法中,數(shù)值前面增加了一位符號位,最高位為符號位,0表示正數(shù),1
    的頭像 發(fā)表于 09-19 22:25 ?1377次閱讀

    計算機采用二進制的原因不包括什么

    計算機采用二進制的原因主要是基于其物理實現(xiàn)的簡便性、邏輯運算的簡化、以及電子元件的穩(wěn)定性。然而,這個問題要求我們探討計算機采用二進制的原因不包括什么,這實際上是一個反向思考的問題。在回答這個問題之前
    的頭像 發(fā)表于 09-04 17:03 ?1164次閱讀

    二進制處理中的一些技巧

    二進制和十進制的處理中,有時候一些小技巧是很有用的。 1、把十進制數(shù)轉(zhuǎn)換成二進制數(shù) (1)在MATLAB中有一個函數(shù)dec2bin,可以把正整數(shù)轉(zhuǎn)換為2
    的頭像 發(fā)表于 07-05 11:51 ?915次閱讀
    主站蜘蛛池模板: 国产精品天天操 | 色婷婷综合网 | 男男浪荡性受高hnp肉 | 男女做性无遮挡免费视频 | 日本不卡在线视频 | 黄色w站 | 国产婷婷色一区二区三区 | 免费视频国产 | ww欧洲ww在线视频看 | 一级黄色毛毛片 | 天堂中文在线最新版地址 | 亚洲一级影院 | 亚洲午夜久久久精品影院 | 极品美女洗澡后露粉嫩木耳视频 | 你懂得国产 | 夜夜摸视频网 | 亚洲国产日韩女人aaaaaa毛片在线 | 一区二区三区四区视频在线观看 | 久久精品国产精品亚洲精品 | 亚洲伊人成人网 | 57pao成人永久免费视频 | 久久第一页| 国产亚洲新品一区二区 | 视频三区 | 午夜tv| 中文字幕在线观看第一页 | 91牛牛 | ts人妖在线观看 | 免费精品99久久国产综合精品 | 亚洲一区二区综合 | 亚洲不卡免费视频 | 亚洲天堂网站 | 久久深夜福利 | 在线高清一级欧美精品 | 国产精品伦子一区二区三区 | 亚洲综合成人网 | 免费观看高清视频 | 狠狠色丁香婷婷第六色孕妇 | 天天好b| 亚洲男人精品 | 五月婷婷综合网 |