Verilog语言实现读写txt文件方法
我的学记|刘航宇的博客

Verilog语言实现读写txt文件方法

刘航宇
1年前发布 /未收录,已推送

随着项目难度递增,例如AI芯片设计,不免需要验证Verilog的功能性,那么输入可以是测试集.txt,输出为预测结果/精确率.txt。下面讲解一下Verilog如何实现读写txt文件

一、读txt文件

1、准备一个txt文件
MATLAB上生成的txt文件的格式为每行一个数据,与coe文件不同的是,数据之间没有逗号。由于verilog的读txt的系统函数仅仅能识别十六进制和二进制数据,一般情况下,将数据转换为十六进制数比较方便。当数据为有符号数时,可以采用下面的方式生成txt文件:

% 生成20个随机的int16类型数据
data_signed = int16(randi([-32768, 32767], 1, 20));

% 打开文件准备写入
fid = fopen('data_signed.txt', 'w');

% 将data_signed数组中的数据转换为无符号整数并以16进制格式写入文件
fprintf(fid, '%04x\r\n', typecast(data_signed, 'uint16'));

% 关闭文件
fclose(fid);

图片[1] - Verilog语言实现读写txt文件方法 - 我的学记|刘航宇的博客
图片[2] - Verilog语言实现读写txt文件方法 - 我的学记|刘航宇的博客
其中,typecastint16(datasignedint16(data_signed,‘uint16’) 可以将数据转变为补码形式。同时,需要注意的是,在换行中,需要采用’\r\n‘,不能仅仅使用’\r’
2、在testbench上读写
读txt文件时,一般选择先将txt中的数据置入寄存器memory中,然后按照地址读出memory中的数据。

reg  [15:0] mem [0:1023];
reg  [9:0] addr ;
reg  [11:0]data_out ;
initial
begin
  $readmemh("E:/self-study/VIVADO_workspace/prj/data_signed.txt",mem);
  addr  = 10'd0;
end
always #10
begin
  data_out  =  mem[addr][11:0];
  addr = addr + 10'd1;
end

需要注意的是,txt文件的地址不能出错,另外,注意地址分隔符需要用’/‘,windos系统中的’\‘需要对应改过来才能使用。

二、写txt文件

integer handle;
initial
begin
 handle  =  $fopen("E:/self-study/VIVADO_workspace/prj/data_out.txt");
end
always@(posedge sys_clk)
begin
  if(data_in_valid)
    begin
      $fdisplay(handle,"%d",data_out);
    end
end

利用initial函数初始化handle的值,另外,地址分隔符同样要改回来。

如果仿真之后,txt文件中并没有内容,可以尝试刷新一下txt文件。如果还没有内容出现,则就是txt文件没有关闭造成的,解决方法有两种:
①直接关闭xsim仿真程序,此时txt文件自动关闭,内容出现。
②使用$fclose函数关闭文件,如果使能变量aagc_in_valid是一段高电平信号,则可以检测该信号的下降沿,在此时关闭文件即可:

  reg [2:0] valid_reg;
  always@(posedge sys_clk)
    begin
      valid_reg    <=    {valid_reg[1:0],data_in_valid};
      if(valid_reg  == 3'b110)
        begin
          $fclose(handle);
        end
    end

甚至于,直接写一个计数器,也是可以的。

$display语句的使用

在功能仿真阶段调试程序时,$display是很有用的一段程序,它和java,c语言中的打印语句使用方法是相似的,可以把变量和语句运行状况打在TCL log的窗口上,供调试者知晓代码运行情况。

$display("here is a debugging point.");
$display("%d", data_in);

demo案例

module wr_txt_tb;
  reg [15:0] mem [0:1023];
  reg [9:0] addr;
  reg [15:0] data_out;
  initial begin
    $readmemh("E:/Downloads/data_signed.txt", mem);
    addr = 10'd0;
  end

  always #10 begin
    if (addr < 10'd20) begin // 假设您只想读取前20个数据
      data_out = mem[addr][15:0];
      addr = addr + 10'd1;
      $display("here is a debugging point.");
      $display("%h", data_out); // 以十六进制形式打印
    end else begin
      $stop; // 结束仿真
    end
  end
endmodule

图片[3] - Verilog语言实现读写txt文件方法 - 我的学记|刘航宇的博客
图片[4] - Verilog语言实现读写txt文件方法 - 我的学记|刘航宇的博客

© 版权声明
THE END
喜欢就支持一下吧
点赞 1 分享 赞赏
严谨、务实和求真
评论 抢沙发
OωO
  • 惊讶
  • 撇嘴
  • 色
  • 发呆
  • 得意
  • 流泪
  • 害羞
  • 闭嘴
  • 睡
  • 大哭
  • 尴尬
  • 发怒
  • 调皮
  • 呲牙
  • 微笑
  • 难过
  • 酷
  • 抓狂
  • 吐
  • 偷笑
  • 可爱
  • 白眼
  • 傲慢
  • 饥饿
  • 困
  • 惊恐
  • 流汗
  • 憨笑
  • 悠闲
  • 奋斗
  • 咒骂
  • 疑问
  • 嘘
  • 晕
  • 折磨
  • 衰
  • 骷髅
  • 敲打
  • 再见
  • 发抖
  • 爱情
  • 跳跳
  • 猪头
  • 拥抱
  • 蛋糕
  • 炸弹
  • 刀
  • 便便
  • 咖啡
  • 玫瑰
  • 凋谢
  • 爱心
  • 心碎
  • 太阳
  • 月亮
  • 赞
  • 踩
  • 握手
  • 胜利
  • 飞吻
  • 怄火
  • 西瓜
  • 冷汗
  • 擦汗
  • 抠鼻
  • 鼓掌
  • 糗大了
  • 坏笑
  • 左哼哼
  • 右哼哼
  • 哈欠
  • 鄙视
  • 委屈
  • 快哭了
  • 阴险
  • 左亲亲
  • 吓
  • 可怜
  • 菜刀
  • 篮球
  • 示爱
  • 抱拳
  • 勾引
  • 拳头
  • 差劲
  • 爱你
  • NO
  • OK
  • 转圈
  • 挥手
  • 鞭炮
  • 喝彩
  • 爆筋
  • 棒棒糖
  • 喝奶
  • 手枪
  • 茶
  • 眨眼睛
  • 泪奔
  • 无奈
  • 卖萌
  • 小纠结
  • 喷血
  • 斜眼笑
  • doge
  • 惊喜
  • 戳一戳
  • 笑哭
  • 我最美
  • 羊驼
  • 幽灵
  • 大笑
  • 不开心
  • 呃
  • 求求
  • 点赞
  • 无聊
  • 托脸
  • 吃
  • 害怕
  • 飙泪
  • 我不看
  • 托腮
  • 啵啵
  • 糊脸
  • 拍头
  • 扯一扯
  • 舔一舔
  • 蹭一蹭
  • 顶呱呱
  • 抱抱
  • 暴击
  • 开枪
  • 撩一撩
  • 拍桌
  • 拍手
  • 干杯
  • 嘲讽
  • 哼
  • 佛系
  • 掐一掐
  • 颤抖
  • 偷看
  • 扇脸
  • 原谅
  • 喷脸
  • 生日快乐
  • 甩头
  • 扔狗
  • 脑阔疼
  • 沧桑
  • 捂脸
  • 辣眼睛
  • 哦哟
  • 头秃
  • 问号脸
  • 暗中观察
  • emm
  • 吃瓜
  • 呵呵哒
  • 我酸了
  • 汪汪
  • 汗
  • 无眼笑
  • 敬礼
  • 狂笑
  • 面无表情
  • 摸鱼
  • 魔鬼笑
  • 哦
  • 请
  • 睁眼
  • 敲开心
  • 让我康康
  • 摸锦鲤
  • 期待
  • 拿到红包
  • 拜谢
  • 元宝
  • 牛啊
  • 胖三斤
  • 好闪
  • 左拜年
  • 右拜年
  • 右亲亲
  • 牛气冲天
  • 喵喵
  • 打call
  • 变形
  • 仔细分析
  • 菜汪
  • 崇拜
  • 比心
  • 庆祝
  • 拒绝
  • 嫌弃
  • 吃糖
  • 惊吓
  • 生气
  • 举牌牌
  • 烟花
  • 虎虎生威
  • 豹富
  • 花朵脸
  • 我想开了
  • 舔屏
  • 打招呼
  • 酸Q
  • 我方了
  • 大怨种
  • 红包多多
  • 你真棒棒
  • 大展宏兔
  • 福萝卜
  • 坚强
  • 贴贴
  • 敲敲
  • 咦
  • 拜托
  • 尊嘟假嘟
  • 耶
  • 666
  • 裂开
  • 骰子
  • 包剪锤
  • 亲亲
  • 狗狗笑哭
  • 好兄弟
  • 狗狗可怜
  • 超级赞
  • 狗狗生气
  • 芒狗
  • 狗狗疑问
  • 奥特笑哭
  • 彩虹
  • 祝贺
  • 冒泡
  • 气呼呼
  • 忙
  • 波波流泪
  • 超级鼓掌
  • 跺脚
  • 嗨
  • 企鹅笑哭
  • 企鹅流泪
  • 真棒
  • 路过
  • emo
  • 企鹅爱心
  • 晚安
  • 太气了
  • 呜呜呜
  • 太好笑
  • 太头疼
  • 太赞了
  • 太头秃
  • 太沧桑
  • 龙年快乐
  • 新年中龙
  • 新年大龙
  • 略略略
  • 狼狗
  • 抛媚眼
  • 超级ok
  • tui
  • 快乐
  • 超级转圈
  • 别说话
  • 出去玩
  • 闪亮登场
  • 好运来
  • 姐是女王
  • 我听听
  • 臭美
  • 送你花花
  • 么么哒
  • 一起嗨
  • 开心
  • 摇起来
  • 划龙舟
经典
emoji
泡泡
阿鲁
颜文字
取消