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

 更新时间:2024年01月04日 14:45:52   作者:Joyce_Ng  
这篇文章主要介绍了Matlab中如何实现将长字符串换行写问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

太长不看版

举例如下:

% 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多的矩阵表示对应关系。

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

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

举个栗子:

fprintf(fID,'Hello world!');

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

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

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

但是如果我把每个功能块单独写在一个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 ')

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

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Python手机号码归属地查询代码

    Python手机号码归属地查询代码

    这篇文章主要介绍了Python手机号码归属地查询代码的相关资料,需要的朋友可以参考下
    2016-05-05
  • python rsa 加密解密

    python rsa 加密解密

    本篇文章主要介绍了python rsa加密解密 (编解码,base64编解码)的相关知识。具有很好的参考价值,下面跟着小编一起来看下吧
    2017-03-03
  • Python基础练习之用户登录实现代码分享

    Python基础练习之用户登录实现代码分享

    这篇文章主要介绍了Python基础练习之用户登录实现代码分享,还是比较不错的,这里分享给大家,供需要的朋友参考。
    2017-11-11
  • Python crypto包功能的使用解读

    Python crypto包功能的使用解读

    文章概述了Python中常用的加密库(如cryptography、pycryptodome、hashlib、bcrypt)及其用途,强调选择合适工具的重要性,并指出安全实践如避免MD5/SHA-1、妥善保管密钥等关键注意事项
    2025-09-09
  • python实现石头剪刀布程序

    python实现石头剪刀布程序

    这篇文章主要为大家详细介绍了python实现石头剪刀布程序,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-01-01
  • python爬取王者荣耀全皮肤的简单实现代码

    python爬取王者荣耀全皮肤的简单实现代码

    在本篇文章里小编给大家分享的是一篇关于16行python代码 爬取王者荣耀全皮肤的知识点内容,有兴趣的朋友们学习下。
    2020-01-01
  • 基于SQLAlchemy实现操作MySQL并执行原生sql语句

    基于SQLAlchemy实现操作MySQL并执行原生sql语句

    这篇文章主要介绍了基于SQLAlchemy实现操作MySQL并执行原生sql语句,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-06-06
  • Python 网络爬虫--关于简单的模拟登录实例讲解

    Python 网络爬虫--关于简单的模拟登录实例讲解

    今天小编就为大家分享一篇Python 网络爬虫--关于简单的模拟登录实例讲解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-06-06
  • Python约瑟夫生者死者小游戏实例讲解

    Python约瑟夫生者死者小游戏实例讲解

    在本篇文章里小编给大家分享的是一篇关于Python约瑟夫生者死者小游戏实例讲解内容,有兴趣的朋友们可以测试学习下。
    2021-01-01
  • Python iter()函数用法实例分析

    Python iter()函数用法实例分析

    这篇文章主要介绍了Python iter()函数用法,结合实例形式详细分析了Python iter()函数的功能、使用方法及相关操作注意事项,需要的朋友可以参考下
    2018-03-03

最新评论