Thông báo

Collapse
No announcement yet.

[Verilog] Hỏi về lệnh "Readmemb"

Collapse
X
 
  • Lọc
  • Giờ
  • Show
Clear All
new posts

  • [Verilog] Hỏi về lệnh "Readmemb"

    Mình đang mới học viết testbench cho verilog bằng Modelsim và có dính đến lệnh Readmemb, mọi người cho mình hỏi lệnh này cách sử dụng như thế nào? Ví dụ như đoạn chương trình sau thì file "example.txt" mình đặt nó ở đâu? Có sai gì thì nhờ mọi người chỉ dùm

    Code module
    module example(a, b, c, y);
    input a, b, c;
    output y;
    assign y = ~a & ~b & ~c | a & ~b & ~c | a & ~b & c;
    endmodule
    Code testbench
    module testbench3();
    reg clk, reset;
    reg a, b, c, yexpected;
    wire y;
    reg [31:0] vectornum, errors;
    reg [3:0] testvectors[10000:0];
    // instantiate device under test
    example DUT(.a(a), .b(b), .c(c), .y(y));
    // generate clock
    always #5 clock = ~clock;
    // at start of test, load vectors
    // and pulse reset
    initial
    begin
    $readmemb("example.txt", testvectors);
    vectornum = 0; errors = 0;
    reset = 1; #27; reset = 0;
    end

    // apply test vectors on rising edge of clk
    always @(posedge clk)
    begin
    #1; {a, b, c, yexpected} = testvectors[vectornum];
    end
    // check results on falling edge of clk
    always @(negedge clk)
    if (~reset) begin // skip cycles during reset
    if (y !== yexpected) begin // check result
    $display("Error: inputs = %b",
    {a, b, c});
    $display(" outputs = %b (%b expected)",
    y, yexpected);
    errors = errors + 1;
    end
    vectornum = vectornum + 1;
    if (testvectors[vectornum] === 4'bx) begin
    $display("%d tests completed with %d errors",
    vectornum, errors);
    //$finish;
    end
    end
    endmodule
    File example.txt
    000_1
    001_0
    010_0
    011_0
    100_1
    101_1
    110_0
    111_0
    Last edited by knight1301; 05-03-2013, 19:29.

  • #2
    ban để file example.txt chung thư mục với file chứa testbench của bạn

    Comment

    Về tác giả

    Collapse

    knight1301 Tìm hiểu thêm về knight1301

    Bài viết mới nhất

    Collapse

    • Andrea14
      Vấn đề về tốc độ quay
      bởi Andrea14
      Chào mọi người,

      Tôi muốn mô phỏng sự thay đổi các mùa bằng cách từ từ nghiêng một quả địa cầu 16 inch bằng một động cơ bước nhỏ. Một động cơ bước khác sẽ quay quả địa cầu theo thời gian thực. Hệ thống truyền động...
      hôm nay, 12:42
    • bqviet
      Trả lời cho Đấu tắt điện cho máy tính bảng
      bởi bqviet
      Bqv cáo lỗi vì chưa đủ khả năng diễn giải để người đọc hiểu. Người làm kỹ thuật sâu đôi khi như thế đó. Về việc nạp pin không vào dù cell mới, khả năng cái mạch quản lý đó đã hỏng - cũng chính là nguyên nhân đám cell cũ hỏng từ đầu.
      06-12-2025, 17:17
    • nguyendinhvan
      Trả lời cho Xin hỏi về mạch thu FM/AM trong catsette
      bởi nguyendinhvan
      Theo tôi, nó chỉ là cái Tuy- ê - nơ, hoặc là khối Trung Văn Tần, nó một phần trong cái Da đì ô thôi. Vì có thấy một chỗ có ba chân hàn, giiống như chân Cờ rít sờ tăng 455 ki nô hẹc. Còn khối Tuy ê nơ thì không nhìn thây cái Di ốt Va di cáp...
      05-12-2025, 19:59
    • afrendly
      Trả lời cho Đấu tắt điện cho máy tính bảng
      bởi afrendly
      Có vẻ ngoài hiểu biết của mình rồi. Cuối cùng mình quyết định tìm mua 2 pin trên Shopee, giá 200K thay vào. Tuy nhận pin được 1%, sạc mãi không vào nhưng cũng mở được máy lên. Vậy cũng tạm. Cảm ơn bạn đã hỗ trợ nhé....
      04-12-2025, 01:27
    Đang tải...
    X