我有一个文件data.txt,它有1200行,每行表示一个16位的二进制字符串,如下所示。
"0001111111000000“
我正在尝试使用Icarus Verilog编写一个测试台,它读取文件的每一行,并将每一行发送到一个.v文件,该文件将对文件的每一行运行一些简单的if语句(一种简单的分类算法)。
我的代码如下。
// Verilog test bench for generate.v
`timescale 1ns/100ps
`include "generate.v"
module generate_tb;
$display('running test bench')
integer data_file ; // file handler
integer scan_file ; // file handler
logic signed [21:0] captured_data;
`define NULL 0
initial begin
$dumpfile("generate.vcd");
$dumpvars(0, generate_tb);
data_file = $fopen("./data.txt", "r");
if (data_file == `NULL) begin
$display("data_file handle was NULL");
$finish;
end
end
always @(posedge clk) begin
scan_file = $fscanf(data_file, "%b\n", captured_data);
if (!$feof(data_file)) begin
generate the_circuit(output, captured_data); // HERE
end
end
$finish;
endmodule和我的generate.v文件:
module generate(actual_class, data_row);
output actual_class;
input data_row;
wire stby_flag ;
wire [0:15] vect;
reg [0:1] classe;
assign vect = data_row;
always @(posedge clk) begin
if (vect[3] == 0) begin
classe = 2'b10;
end
if (vect[11] == 0) begin
classe = 2'b01;
end
if (vect[8] == 1 && vect[4] + vect[5] + vect[6] + vect[7] >= 3) begin
classe = 2'b00;
end
if (vect[0] + vect[1] + vect[2] + vect[3] + vect[4] + vect[5] + vect[6] + vect[7] + vect[8] + vect[9] + vect[10] + vect[11] + vect[12] + vect[13] + vect[14] + vect[15] <= 1) begin
classe = 2'b11;
end
end
assign actual_class = classe;
endmodule我被这部分代码卡住了。我不确定如何为文件的每一行调用generate.v文件。
if (!$feof(data_file)) begin
generate the_circuit(output, captured_data); // HERE
end一种更好的方法是将我的数据保存到$readmemb中并使用它,但我希望这样做。
任何建议都是非常感谢的。
发布于 2018-01-03 05:15:37
首先:以保留字'generate‘命名你的模块是一个非常糟糕的主意。
我不确定如何调用generate.v
它是一个模块,而不是一个函数。你不能“调用”一个模块。
从文件中读取每一行,并将其分配给模块的一个输入变量。确保在读取模块(和所有后续触发模块)的下一行之前等待足够长的时间,以完成对输入的处理。您可以等待一定数量的时钟周期或使用“就绪”信号。
更好的方法是..
也许吧。如果你的模式变得很大,你需要一个大内存。
https://stackoverflow.com/questions/48067453
复制相似问题