为了实现测量数据的实时显示,电子测量系统常用到二-十进制(BCD)转码器来完成数据的实时转换。目前,电子系统中的二-十进制(BCD)数制转换有三类实现方法,一是采用软件算法的实现方式,传统的方法是用DAA调节指令实现,但效率较低;其次是纯硬件运算实现方式,这种实现方式从数据转换运算到硬件的直接映射,常采用逻辑运算和数据移位来实现数据转换,转换效率较高,但是在转换数据位数较多时,运算量会显著增加,硬件实现代价也较大;三是基于数据查找表LUT(Lookup Table)的实现方式。
下面为一左移加3算法的思想与实例:
http://blog.sina.com.cn/s/blog_6c31e1650100pyqx.html
非常简单的一个6bit的BCD转换器实现:
module ConvertToBCD(
input [5:0] bin_in,
output [3:0] ones,
output [3:0] tens
);
wire [3:0] add1,add2,add3;
assign add1 = {1'b0,bin_in[5:3]}>=5 ? {1'b0,bin_in[5:3]}+4'd3:{1'b0,bin_in[5:3]};
assign add2 = {add1[2:0],bin_in[2]}>=5 ? {add1[2:0],bin_in[2]}+4'd3:{add1[2:0],bin_in[2]};
assign add3 = {add2[2:0],bin_in[1]}>=5 ? {add2[2:0],bin_in[1]}+4'd3:{add2[2:0],bin_in[1]};
assign ones = {add3[2:0],bin_in[0]};
assign tens = {1'b0,add1[3],add2[3],add3[3]};
endmodule
我要赚赏金打赏帖 |
|
|---|---|
| 基于MCP23S17的输入输出功能模块控制被打赏¥20元 | |
| 【S32K3XX】SPD 软件包使用Link文件修改被打赏¥22元 | |
| Switch-Case局部变量定义问题被打赏¥23元 | |
| 基于米尔TIAM62L开发板的串口通信及应用被打赏¥20元 | |
| PCF8574功能模块及其使用被打赏¥20元 | |
| 传感器LSM6DSO及LIS3MDL的功能检测被打赏¥18元 | |
| LPS25HB气压传感器及其检测被打赏¥18元 | |
| HTS221温湿度传感器及其检测被打赏¥18元 | |
| 【S32K3XX】HSE FW 版本更新被打赏¥21元 | |
| 基于ArduinoUNO开发板的AT24C02读写测试被打赏¥16元 | |
我要赚赏金
