這篇文章主要介紹python中g(shù)enerate的使用方法,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
創(chuàng)新互聯(lián)專注于泗陽企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站,商城系統(tǒng)網(wǎng)站開發(fā)。泗陽網(wǎng)站建設(shè)公司,為泗陽等地區(qū)提供建站服務(wù)。全流程按需開發(fā)網(wǎng)站,專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)
generate語句允許細(xì)化時(shí)間(Elaboration-time)的選取或者某些語句的重復(fù)。這些語句可以包括模塊實(shí)例引用的語句、連續(xù)賦值語句、always語句、initial語句和門級(jí)實(shí)例引用語句等。細(xì)化時(shí)間是指仿真開始前的一個(gè)階段,此時(shí)所有的設(shè)計(jì)模塊已經(jīng)被鏈接到一起,并完成層次的引用。
1.generate語法
定義genvar,作為generate中的循環(huán)變量。
generate語句中定義的for語句,必須要有begin,為后續(xù)增加標(biāo)簽做準(zhǔn)備。
begin必須要有名稱,也就是必須要有標(biāo)簽,因?yàn)闃?biāo)簽會(huì)作為generate循環(huán)的實(shí)例名稱。
可以使用在generate語句中的類型主要有:
·ü module(模塊)
·ü UDP(用戶自定義原語)
·ü 門級(jí)原語
·ü 連續(xù)賦值語句
·ü initial或always語句
基本結(jié)構(gòu)如下:
genvar 循環(huán)變量名; generate // generate循環(huán)語句 // generate 條件語句 // generate 分支語句 // 嵌套的generate語句 endgenerate
下面將就generate常用的幾種情況舉例說明。
2. generate-loop循環(huán)語句
3.generate-conditional條件語句
generate允許對(duì)語句進(jìn)行條件選擇,即將條件選擇加入到generate中的for循環(huán)中,只例化條件成立時(shí)對(duì)應(yīng)的語句或者module。
4.generate-case分支語句
generate-case分支語句與generate-條件語句類似,只不過將原來的分支語句換做了case語句。
結(jié)論
genvar與generate是Verilog 2001才有的,功能非常強(qiáng)大,可以配合條件語句、分支語句等做一些有規(guī)律的例化或者賦值等操作,對(duì)于提高簡(jiǎn)潔代碼很有幫助,同時(shí)也減少了人為的影響。
以上是python中g(shù)enerate的使用方法的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!