边缘检测工程:Ascii转十六进制模块代码解析

​边缘检测工程:Ascii转十六进制模块代码解析

     本文为明德扬原创文章,转载请注明出处!

Ascii转十六进制模块的功能:将ASCII所对应的16进制数,转成实质的16进制数。

一、 设计架构
在这里插入图片描述
上图是Ascii码表对应的数据。我们从图中可以获取到如下关键信息。

1.Ascii码0~ 9对应的十六进制数为8’h30~ 8’h39,也就是说收到ASCII码的16进制数8’h30~ 8’h39时,就转成0~9,也就是减去8’h30。

2. Ascii码A~ F对应的十六进制数为8’h41~ 8’h46,也就是说收到ASCII码的16进制数8’h41~ 8’h46时,就转成A~F,也就是减去8’h37。

3.Ascii码a~ f对应的十六进制数为8’h61~ 8’h66,也就是说收到ASCII码的16进制数8’h61~ 8’h66时,就转成a~f,也就是减去8’h57。

本模块的功能,是对ASCII码的09,af,A~F进行转换,其他数据不转换,不在此范围的,数据无效。例如:

当din=8’h31(字符1),且din_vld = 1,则dout=4’h1,dout_vld=1;

当din=8’h41(大写字母A)时,且din_vld=1,则dout=4’d10,dout_vld=1;

如果输入的ASCII不在数字09,AF,a~f的时候,dout_vld就输出0。

当din=8’h49(大写字母I)时,且din_vld=1,则dout=0,dout_vld=0。

二、 信号的意义

在这里插入图片描述
三、参考代码

在这里插入图片描述

发布了43 篇原创文章 · 获赞 3 · 访问量 3410

猜你喜欢

转载自blog.csdn.net/MDYFPGA/article/details/103820389