ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

虎年新春快乐~~献上|祝福语波形生成器|

2022-02-02 15:01:52  阅读:268  来源: 互联网

标签:波形 祝福语 新春快乐 生成器 value file gogogo 点阵


使用方式

资源路径:祝福语波形生成器

下载解压于安装有vcs和verdi的linux虚拟机之中:

在script目录下,打开 hanzi_trans.py,修改祝福语:

好的,回到sim目录,键入make fun,等边编译仿真完成弹出verdi弹窗:

双击左侧的u_in_if0,然后中键把gogogo拖到波形窗(为啥结构这么乱,因为是拿之前的工程改的~):

 然后双击gogogo,并把波形缩放到最小:

换点其他的祝福语:

可以说是过年过节走亲访友表个白唠个嗑啥的必备良器!

工作原理

汉字转点阵字

参考并借用了这篇文章中的代码并稍作修改:

Python实现点阵字体读取与转换的方法

在hanzi_trans.py脚本中将汉字转为01代表的点阵字,当然了,初始转成的点阵(以*表示有值)是这样的:

 对应的01点阵即:

那么此时如果要把这些点阵字作为电路的信号输入,那么结合信号本身的波形展开顺序,显然应该是这么对应的:

从左到右每一列为一组32bit信号的每一比特,并且最下面为低比特,上面为高比特;再结合verilog的文件读取方式,显然我需要把数据整理为这种形式:

在脑海里我就想这两种排列方式,然后发现,这不就是数组转置么。。。。。 

 所以在脚本里做一步:

tp_rect_list = numpy.transpose(rect_list)

 脚本最终输出为gogogo.cfg文件,就是上面这个转置后的01点阵图;

用例改造

找个用例复制替换一下,然后加这么一段:

task gogogo_case_seq::body();
    integer file;
    file = $fopen("../script/gogogo.cfg","r");
    while(!$feof(file))begin
        bit[31:0] value;
        $fscanf(file, "%b\n", value);
        `uvm_do_with(my_tr, {my_tr.gogogo == local::value;})
    end
	#100;
endtask: body

以二进制的方式读取gogogo.cfg的每一行,赋值给31bit的value,将tr的gogogo变量约束为value的值即可,每处理一行打出来一个transaction到interface中,也就实现了波形效果;

makefile改造

加一个make fun的指令,其实就是make run的固定参数版本,其他参数设置请参看【芯片前端】以vcs编译环境为例做一个适用于芯片前端的极简版Makefile实操教程

fun: clean
	@../script/hanzi_tran.py
	@$(PRE_PROC)
	@vcs $(CMP_OPTIONS)
	@$(EXEC_SIMV) $(RUN_OPTIONS)
	@verdi -ssf sim_base/wave/gogogo_case_0.fsdb &

clean:
	@-rm -rf $(SIM_PATH)/exec ucli.key csrc vc_hdrs.h novas.conf  novas_dump.log  novas.rc verdiLog

标签:波形,祝福语,新春快乐,生成器,value,file,gogogo,点阵
来源: https://blog.csdn.net/moon9999/article/details/122769148

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有