設計背景:
二進制轉十進制在設計應用中十分的廣泛。尤其在AD轉化中是必須所用到的一個小知識點,學習二進制轉十進制的方法顯的非常的重要。今天就和筆者來學習二進制轉十進制的方法,通過簡單的學習來掌握這么一門知識。
設計原理:
本次的設計主要是一個簡單的二選一數據選擇器,我們的設計主
二進制中只有 0 和 1 兩個狀態,可以表示 0、1 兩種狀態的電 子器件很多,如開關的接通和斷開,晶體管的導通和截止、磁元 件的正負剩磁、電位電平的低與高等都可表示 0、1 兩個數碼。使 用二進制,電子器件具有實現的可行性。
二進制數的運算法則少,運算簡單,使計算機運算器的硬件結 構大大簡化。由于二進制 0 和 1 正好和邏輯代數的假(false)和 真(true)相對應,有邏輯代數的理論基礎,用二進制表示二值 邏輯很自然。電子器件中,所有的數據都是用二進制來表示的。
2.BCD碼
BCD 碼(Binary-Coded Decimal)亦稱二進碼十進數或二-十進制代碼。用4位二進制數來表示1位十進制數中的0~9這10個 數碼。BCD 碼是一種二進制的數字編碼形式,用二進制編碼的十 進制代碼。BCD 碼這種編碼形式利用了四個位元來儲存一個十進 制的數碼,使二進制和十進制之間的轉換得以快捷的進行。
3.實現方法
1)對10求余法
將需要轉換的數字除以“權”,然后對10求余,得出數字各個 位上的數字。例如:8’b1000_0000(10進制中的128),將此數 字對10求余,得出個位“8”,然后將“8”賦給最低的4位。將 此數字(128)除以10,得出12(在FPGA計算中,自動取整), 對10求余,然后得出十位“2”,把“2”賦給次低的4位。將此 數字(128)除以100,得出1,對10求余,然后得出百位“1”, 把“1”賦給另外的4位。這樣就轉換出了BCD碼。
這類方法中,利用了大量的除法和求余,占用了大量的邏輯資 源。但是,實現比較簡單,如果芯片的邏輯資源足夠的話,可以 采取使用這種方法。
2)大四加三法
進行移位,然后進行判斷。如果大于四,則加三。最后得出我們想要的BCD碼(下述是按照轉換7位講解的原理)。
架構圖如下
bin_data[7:0]:輸入的二進制數據。
bin_data[11:0]:輸出的BCD碼(輸入的二進制數據為8位,最大 為8’b1111_1111(255),每四位二進制表示一個BCD碼,故而12位)。
設計代碼:
設計模塊
module bin_to_bcd(bin, bcd);
input [7:0] bin;
output [11:0] bcd;
wire [19:0] shift_reg [5:0];
assign shift_reg[5] = {9'b0,bin,3'b0};
bcd_modify u1(.bcd_in(shift_reg[5]), .bcd_out(shift_reg[4]));
bcd_modify u2(.bcd_in(shift_reg[4]), .bcd_out(shift_reg[3]));
bcd_modify u3(.bcd_in(shift_reg[3]), .bcd_out(shift_reg[2]));
bcd_modify u4(.bcd_in(shift_reg[2]), .bcd_out(shift_reg[1]));
bcd_modify u5(.bcd_in(shift_reg[1]), .bcd_out(shift_reg[0]));
assign bcd = shift_reg[0][19:8];
endmodule
module bcd_modify(bcd_in, bcd_out);
input [19:0] bcd_in;
output [19:0] bcd_out;
wire [19:0] bcd_reg;
bcd_sigle_modify u1(.bcd_in(bcd_in[19:16]), .bcd_out(bcd_reg[19:16]));
bcd_sigle_modify u2(.bcd_in(bcd_in[15:12]), .bcd_out(bcd_reg[15:12]));
bcd_sigle_modify u3(.bcd_in(bcd_in[11:8]), .bcd_out(bcd_reg[11:8]));
assign bcd_reg[7:0] = bcd_in[7:0];
assign bcd_out = {bcd_reg[18:0],1'b0};
endmodule
module bcd_sigle_modify(bcd_in, bcd_out);
input [3:0] bcd_in;
output reg [3:0] bcd_out;
always @ (*)
begin
if (bcd_in > 4)
bcd_out = bcd_in + 3;
else
bcd_out = bcd_in;
end
endmodule
測試模塊
`timescale 1ns/1ps
module tb();
reg [7:0] bin;
wire [11:0] bcd;
initial begin
bin = 255;
#500 bin = 20;
#500 bin = 125;
#500 $stop;
end
bin_to_bcd bin_to_bcd_dut(
.bin(bin),
.bcd(bcd)
);
endmodule
仿真圖:
從仿真中可以看出本次設計的正確性,測試中我們輸出的二進制和為8個1也就是255,轉化為10進制后 按16進制顯示,也就是255,通過驗證設計正確。
-
二進制
+關注
關注
2文章
795瀏覽量
41674 -
BCD
+關注
關注
1文章
88瀏覽量
29766 -
十進制
+關注
關注
0文章
67瀏覽量
13229
原文標題:FPGA學習系列:32. 二進制轉十進制的設計
文章出處:【微信號:FPGAer_Club,微信公眾號:FPGAer俱樂部】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論