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中SyntaxError: invalid syntax報錯解決
在編寫Python代碼時,常見的SyntaxError錯誤通常由括號不匹配、關(guān)鍵字拼寫錯誤或不正確的縮進引起,本文詳細介紹了錯誤原因及多種解決方案,包括檢查括號、關(guān)鍵字,以及使用IDE的語法檢查功能等,感興趣的可以了解一下2024-09-09Python模塊結(jié)構(gòu)與布局操作方法實例分析
這篇文章主要介紹了Python模塊結(jié)構(gòu)與布局操作方法,結(jié)合實例形式分析了Python模塊與布局的相關(guān)概念、使用方法與相關(guān)注意事項,需要的朋友可以參考下2017-07-07