开发者

Matlab中如何实现将长字符串换行写

开发者 https://www.devze.com 2024-01-05 09:23 出处:网络 作者: Joyce_Ng
目录太长不看版正文总结太长不看版 举例如下: % Port definition fprintf(fID,[... \'\\n\'...
目录
  • 太长不看版
  • 正文
  • 总结

太长不看版

举例如下:

% Port definition
fprintf(fID,[...
    '\n'...
    'input clk;'                    '\n'...
    'input rst_n;'                  '\n'...
    'input [%d:0] msg;'             '\n'...%row-1
    'input in_valid;'               '\n'...
    'output reg [%d:0] codeword;'   '\n'...%col-1
    'output reg out_valid;'         '\n'...
    ],row-1,col-1);
  • 加上中括号;
  • 将长字符串分割成多个子字符串;
  • 子字符串之间至少隔一个空格;
  • 换行符用...

正文

最近在搞毕设的东西,其中有一个需要写很麻烦的verilog文件。

麻烦但是却不复杂,LDPC的编码器,大概就是一个200多bits宽的输入信号,500多bit宽的输出信号,输出每个bit都是由某些输入的bit进行相同的运算得到的,用一个200多*500多的矩阵表示对应关系。

如果要单纯写ve编程客栈rilog,会死人的,如果在verilog里写生成逻辑,又要占用很大的内存来存放生成矩阵,而且逻辑难写。于是就想到用Matlab代码来生成verilog代码。

Matlab里有fprintf函数可以输出数据到文件。

举个栗子:

fprintf(fID,'Hello world!');

就可javascript以把“Hello world!”输出到fID对应的文件中。

打开文件的函数是fID = fopen('f编程客栈ilepath/filename.postfix','w');其中w表示写入,如果是读取则换成r,更多用法请help fopen

那么问题来了,如果我把verilog代码的每一行分别用一个fprintf输出,那么我的.m文件就会充斥着一大堆fprintf,我这个强迫症对这种高度重复的代码简直不能忍。android

但是如果我把每个功能块单独写在一个fprintf里,可读性确实高很多,但是fprintf那行就会很长,同样不能忍,并且修改的时候会非常痛苦!

于是我就去找有没有类似linux脚本中‘\’的换行符,让解释器把多行代码当成一行去执行。

确实有这个换行符,

... ←三个点就是Matlab里的换行符。可以将该行的尾部和下一行的头部连接起来。

但是另一个问题就出来了,这个换行符没办法用在字符串中间,我把一整块的代码当成一个字符串,如果中间加上换行符,那么解释器会把换行符也当做要输出的内容,一起输出去了。

由于 fprintf 的参数分别为:文件handler、输出array、输出数据(如有)。

举栗子:

fprintf( fID, 'data1: %d\n', data1);

其中中间的字符串会被当成一个只有一个元素的array。

所以解决方法就来了,只要把中间的array多加几个元素,就可以分割长字符串,并在子字符串之间添加换行符。

举栗子:

% Port definition
fprintf(fID,[...
    '\n'...
    'input clk;'                    '\n'...
    'input rst_n;'                  '\n'...
    'input [%d:0] msg;'             '\n'...%row-1
    'input in_valid;'               '\n'...
    'output reg [%d:0] codeword;'   '\n'...%col-1
    'output reg out_valid;'         '\n'...
    ],row-1,col-1);

用单引号括起来的每一个小字符串会被解释为输出array的一个元素,子字符串之间用空格(可多个,至少一个) 或逗号隔开,即一个单行的矩阵(array)。

中括号必不可少,是将各子字符串结合为一个array的标识。

另外因为verilog里经常需要输出类似 3b'101之类的东西,而单引号会被当做元素的起/止符。想要输出单引号,就需要连续打2个单引号。

比如:

fprintf(fID, 'outdata <= 3''b101 ')

这也是为什么两个子字符串中间至少要有一个空格的原因,如果没有空格就会被连接起来,并且中间多了个单引号。

总结

以上为个人经验tiYIaPHk,希望能给大家一个参考,也希望大家多多支持编程客栈(www.devze.com)。

0

精彩评论

暂无评论...
验证码 换一张
取 消