欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Matlab中如何實現(xiàn)將長字符串換行寫

 更新時間:2024年01月04日 14:45:52   作者:Joyce_Ng  
這篇文章主要介紹了Matlab中如何實現(xià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);
  • 加上中括號;
  • 將長字符串分割成多個子字符串;
  • 子字符串之間至少隔一個空格;
  • 換行符用...

正文

最近在搞畢設(shè)的東西,其中有一個需要寫很麻煩的verilog文件。

麻煩但是卻不復(fù)雜,LDPC的編碼器,大概就是一個200多bits寬的輸入信號,500多bit寬的輸出信號,輸出每個bit都是由某些輸入的bit進行相同的運算得到的,用一個200多*500多的矩陣表示對應(yīng)關(guān)系。

如果要單純寫verilog,會死人的,如果在verilog里寫生成邏輯,又要占用很大的內(nèi)存來存放生成矩陣,而且邏輯難寫。于是就想到用Matlab代碼來生成verilog代碼。

Matlab里有fprintf函數(shù)可以輸出數(shù)據(jù)到文件。

舉個栗子:

fprintf(fID,'Hello world!');

就可以把“Hello world!”輸出到fID對應(yīng)的文件中。

打開文件的函數(shù)是fID = fopen('filepath/filename.postfix','w');其中w表示寫入,如果是讀取則換成r,更多用法請help fopen

那么問題來了,如果我把verilog代碼的每一行分別用一個fprintf輸出,那么我的.m文件就會充斥著一大堆fprintf,我這個強迫癥對這種高度重復(fù)的代碼簡直不能忍。

但是如果我把每個功能塊單獨寫在一個fprintf里,可讀性確實高很多,但是fprintf那行就會很長,同樣不能忍,并且修改的時候會非常痛苦!

于是我就去找有沒有類似Linux腳本中‘\’的換行符,讓解釋器把多行代碼當成一行去執(zhí)行。

確實有這個換行符,

... ←三個點就是Matlab里的換行符。可以將該行的尾部和下一行的頭部連接起來。

但是另一個問題就出來了,這個換行符沒辦法用在字符串中間,我把一整塊的代碼當成一個字符串,如果中間加上換行符,那么解釋器會把換行符也當做要輸出的內(nèi)容,一起輸出去了。

由于 fprintf 的參數(shù)分別為:文件handler、輸出array、輸出數(shù)據(jù)(如有)。

舉栗子:

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)。

中括號必不可少,是將各子字符串結(jié)合為一個array的標識。

另外因為verilog里經(jīng)常需要輸出類似 3b'101之類的東西,而單引號會被當做元素的起/止符。想要輸出單引號,就需要連續(xù)打2個單引號。

比如:

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

這也是為什么兩個子字符串中間至少要有一個空格的原因,如果沒有空格就會被連接起來,并且中間多了個單引號。

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python 字典的使用詳解及實例代碼

    Python 字典的使用詳解及實例代碼

    今天小編幫大家簡單介紹下Python的一種數(shù)據(jù)結(jié)構(gòu): 字典,字典是 另一種可變?nèi)萜髂P?,且可存儲任意類型對象,它用于存放具有映射關(guān)系的數(shù)據(jù),通讀本篇對大家的學(xué)習(xí)或工作具有一定的價值,需要的朋友可以參考下
    2021-11-11
  • 關(guān)于Python中的空值問題及解決

    關(guān)于Python中的空值問題及解決

    這篇文章主要介紹了關(guān)于Python中的空值問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • Python+ChatGPT制作一個AI實用百寶箱

    Python+ChatGPT制作一個AI實用百寶箱

    ChatGPT最近在互聯(lián)網(wǎng)掀起了一陣熱潮,其高度智能化的功能能夠給我們現(xiàn)實生活帶來諸多的便利。本文就來用Python和ChatGPT制作一個AI實用百寶箱吧
    2023-02-02
  • Python 保持登錄狀態(tài)進行接口測試的方法示例

    Python 保持登錄狀態(tài)進行接口測試的方法示例

    這篇文章主要介紹了Python 保持登錄狀態(tài)進行接口測試的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-08-08
  • 在SAE上部署Python的Django框架的一些問題匯總

    在SAE上部署Python的Django框架的一些問題匯總

    這篇文章主要介紹了在SAE上部署Python的Django框架的一些問題匯總,SAE是新浪的一個在線APP部署平臺,并且對Python應(yīng)用提供相關(guān)支持,需要的朋友可以參考下
    2015-05-05
  • Django框架實現(xiàn)的分頁demo示例

    Django框架實現(xiàn)的分頁demo示例

    這篇文章主要介紹了Django框架實現(xiàn)的分頁demo,結(jié)合實例形式分析了Django框架分頁的步驟、原理、相關(guān)操作技巧與注意事項,需要的朋友可以參考下
    2019-05-05
  • python中內(nèi)置類型添加屬性問題詳解

    python中內(nèi)置類型添加屬性問題詳解

    這篇文章主要介紹了python中內(nèi)置類型添加屬性問題詳解,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09
  • Python中SyntaxError: invalid syntax報錯解決

    Python中SyntaxError: invalid syntax報錯解決

    在編寫Python代碼時,常見的SyntaxError錯誤通常由括號不匹配、關(guān)鍵字拼寫錯誤或不正確的縮進引起,本文詳細介紹了錯誤原因及多種解決方案,包括檢查括號、關(guān)鍵字,以及使用IDE的語法檢查功能等,感興趣的可以了解一下
    2024-09-09
  • 用實例解釋Python中的繼承和多態(tài)的概念

    用實例解釋Python中的繼承和多態(tài)的概念

    這篇文章主要介紹了用實例解釋Python中的繼承和多態(tài)的概念,繼承和多臺是學(xué)習(xí)每一門面對對象的編程語言時都必須掌握的重要知識,需要的朋友可以參考下
    2015-04-04
  • Python模塊結(jié)構(gòu)與布局操作方法實例分析

    Python模塊結(jié)構(gòu)與布局操作方法實例分析

    這篇文章主要介紹了Python模塊結(jié)構(gòu)與布局操作方法,結(jié)合實例形式分析了Python模塊與布局的相關(guān)概念、使用方法與相關(guān)注意事項,需要的朋友可以參考下
    2017-07-07

最新評論