码迷,mamicode.com
首页 > 其他好文 > 详细

Matlab对Modelsim仿真生成的数据进行分析

时间:2016-08-11 20:59:09      阅读:306      评论:0      收藏:0      [点我收藏+]

标签:

Matlab对Modelsim仿真生成数据的处理也是通过文件读写实现的。即通过Verilog语句,将仿真过程中的某个信号写入文件,然后在Matlab中在把这个文件的数据读出来,就可以在Matlab中进行分析了。


下图也通过一个简单的例子,说明一下整个过程。


以下的Verilog语句实现将信号data_out的数据写入data_out.txt文件


integer w_file;


initial w_file = $fopen("data_out.txt");


always @(i)


begin


$fdisplay(w_file,"%h",data_out);


if(i == 8‘d255) //共写入256个数据


$stop;


end


下图是截取的data_out.txt的部分内容:



然后就可以编一小段Matlab的程序将data_out.txt中的数据读取进行分析了。下面一段Matlab的程序是将数据读取,并通过图形显示出数据的波形。


fid = fopen(‘data_out.txt‘,‘r‘);


for i = 1 : 256;


num(i) = fscanf(fid, ‘%x‘, 1); %这句话的意思是从fid所指的文件以16进制方式读出一个数据。


end


fclose(fid);


plot(num);


当利用fscanf函数时要注意两点,


第一:保证读取的数据格式和文件中保存的数据格式是相同的,例如这里文件中保存的格式是十六进制,所以读取的时候也应该以十六进制的形式读出。


第二:要保证文件中数据的个数和设定的读取的数目(这里是256)保持一致。例如,要将生成文件data_out.txt中多余的换行符去掉(一般最后会多出一行),否则Matlab会将空的行也当做一个数据,从而两个数目不一致,导致Matlab报错。


下图是Matlab将data_out.txt中的数据读出,并显示出的波形:



当然,有了Matlab这个强大的工具,也就可以很方便的看信号的频谱等信息了。


另外在说一点,就是关于通过Verilog将数据写入文件有多种方法,上面用的是$fdisplay这个系统函数,当然还有$fmonitor和$fwrite等几个命令,下面简单说一下这几个命令的不同。

Matlab对Modelsim仿真生成的数据进行分析

标签:

原文地址:http://www.cnblogs.com/waimen/p/5762445.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!