打印二维数组

需求

给定行数和列数,写3个函数分别输出如下的二维数组(假设给的行数是5,列数是4):

1 2 3 4
5 6 7 8 
9 10 11 12
13 14 15 16
17 18 19 20 

1 6 11 16
2 7 12 17
3 8 13 18
4 9 14 19
5 10 15 20

1 10 11 20 
2 9 12 19
3 8 13 18
4 7 14 17
5 6 15 16

解法

// 横书
function rowFirst(rows,cols){
    n = 1
    arr = []
    for (i=0; i < rows; i++){
        s = ''
        arr[i] = []
        for(j=0;j<cols;j++,n++){
            arr[i].push(n)
            s += n + ' '
        }
        console.log(s+"\n")
    }
    return arr;
}

// lineFirst(5,4)


// 竖版
function colsFirst(rows,cols){
    arr = []
    for (i=0; i < rows; i++){
        s = ''
        arr[i] = []
        for(j=0;j<cols;j++){
            arr[i].push(i+1+rows*j)
            s += arr[i][j] + ' '
        }
        console.log(s+"\n")
    }
    return arr;
}
// colsFirst(5,4)

// 之走
function reverseFisrt(rows,cols){
    arr = []
    for (i=0; i < rows; i++){
        s = ''
        arr[i] = []
        for(j=0;j<cols;j++){
            if(j%2==1){
                arr[i].push(rows*(j+1)-i)
            }else{
                arr[i].push(i+1+rows*j)
            }
            s += arr[i][j] + ' '
        }
        console.log(s+"\n")
    }
    return arr;
}

console.log(reverseFisrt(5,4))

效果

[ [ 1, 10, 11, 20 ],
  [ 2, 9, 12, 19 ],
  [ 3, 8, 13, 18 ],
  [ 4, 7, 14, 17 ],
  [ 5, 6, 15, 16 ] ]
在Verdi中使用`fsdb`打印二维数组,需要确保在仿真过程中正确地将二维数组的值记录到`fsdb`文件中。这可以通过在testbench中添加特定的系统任务来实现。 首先,在testbench的initial块中,除了基本的`$fsdbDumpfile`和`$fsdbDumpvars`命令外,还需要添加`$fsdbDumpMDA()`来确保能够记录二维数组的值。以下是修改后的testbench示例代码: ```verilog initial begin $fsdbDumpfile("tb.fsdb"); $fsdbDumpvars; $fsdbDumpMDA(); end ``` 这里,`$fsdbDumpfile("tb.fsdb")`用于指定生成的`fsdb`文件名,`$fsdbDumpvars`用于保存所有变量的波形,而`$fsdbDumpMDA()`则是关键,它使得仿真器能够在`fsdb`文件中记录二维数组的值[^1]。 接下来,使用VCS进行编译时,需要带上一些特定的参数以确保能够生成`fsdb`文件,并且支持SystemVerilog特性。具体的编译命令如下: ```shell vcs *.v -LDFLAGS -Wl,--no-as-needed -timescale=1ns/1ps -fsdb -full64 -R +vc +v2k -sverilog -debug_all ``` 编译完成后,启动Verdi并加载生成的`fsdb`文件,就可以查看二维数组的波形了。启动Verdi的命令如下: ```shell verdi -nologo +v2k -sverilog *.v -ssf tb.fsdb & ``` 在Verdi界面中,可以通过点击信号并使用快捷键(如Ctrl+W)来添加信号波形。对于二维数组,可能需要特别注意信号的层次结构,以便正确地找到并查看二维数组的值[^2]。 ### 示例代码 为了更好地理解如何在Verdi中查看二维数组的值,下面提供了一个简单的测试模块示例,该模块定义了一个二维数组,并在initial块中对其进行初始化,然后使用`$display`和`$write`系统任务输出数组的值: ```verilog module tb_dut; byte two_data[4][6]; initial begin foreach(two_data[i,j]) begin two_data[i][j] = i*10 + j; end #1ns; $display("(@%d)time", $time); foreach(two_data[i]) begin $write("%2d:", i); foreach(two_data[,j]) begin $write("%3d:", two_data[i][j]); end $display(""); end end endmodule ``` 这段代码展示了如何初始化一个二维数组,并在仿真过程中输出其值,这对于调试和验证设计是非常有用的[^5]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值