国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

如何使用Python實現(xiàn)FPGA編程“自動化”

這篇具有很好參考價值的文章主要介紹了如何使用Python實現(xiàn)FPGA編程“自動化”。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

如何使用Python實現(xiàn)FPGA編程“自動化”

之前讀到過一個公眾號文章,寫了關(guān)于《使用Python實現(xiàn)Vivado和Modelsim仿真的自動化》,連接https://mp.weixin.qq.com/s/2YR_LjpQNtJr9beqnCz7CA。根據(jù)該文章,基于自己的編程習慣和工作需要,我做了一些修改和便于自己編程的一些python代碼,這里和大家介紹一下。



一、自動生成tb文件

1、對于被生成的模塊的端口格式,必須按照以下格式,才能自動生成。

##    entity top is
##       Port ( 
##          clk_in  : in std_logic;
##          rst     : in std_logic;
##          data_in : in std_logic;
##          data_out: out std_logic_vector(7 downto 0);
##          data_v  : out std_logic_vector(7 downto 0);
##       );
##    end top;

2、預(yù)定義字符串列表,用于生成tb文件的基本框架,如下:

str1 = ['----------------------------------------------------------------------------------'
'-- Company: \n',
'-- Engineer: \n',
'-- \n',
'-- Create Date: \n',
'-- Design Name: \n',
'-- Module Name:  - Behavioral\n',
'-- Project Name: \n',
'-- Target Devices: \n',
'-- Tool Versions: \n',
'-- Description: \n',
'-- \n',
'-- Dependencies: \n',
'-- \n',
'-- Revision:\n',
'-- Revision 0.01 - File Created\n',
'-- Additional Comments:\n',
'-- \n',
'----------------------------------------------------------------------------------\n',
'\n',
'\n',
'library IEEE;\n',
'use IEEE.STD_LOGIC_1164.ALL;\n',
'\n',
'-- Uncomment the following library declaration if using\n',
'-- arithmetic functions with Signed or Unsigned values\n',
'--use IEEE.NUMERIC_STD.ALL;\n',
'\n',
'-- Uncomment the following library declaration if instantiating\n',
'-- any Xilinx leaf cells in this code.\n',
'--library UNISIM;\n',
'--use UNISIM.VComponents.all;\n',
'\n',
'entity top is\n',
'-- port ();\n',
'end top;\n',
'\n',
'architecture Behavioral of top is\n',
'\n',
'   constant period  : TIME                          := 20 NS;  --時鐘周期設(shè)置\n',
'   constant CNT_MAX : INTEGER                       := 100  ;  --cnt計數(shù)器最大值\n',
'   signal   cnt     : INTEGER RANGE 0 TO CNT_MAX    := 0    ;  --復(fù)位設(shè)置\n',
'begin\n',
'-----------------------復(fù)位和時鐘生成----------------------------------------\n',
'   clk_gen1 : PROCESS \n',
'   BEGIN\n',
'      clk_in <= \'1\';\n',
'      WAIT FOR period/2;\n',
'      clk_in <= \'0\';\n',
'      WAIT FOR period/2;\n',
'   END PROCESS;\n',
' \n',
'   cnt : process(clk)\n',
'   begin\n',
'      if ( clk_in\'event and clk_in = \'1\') then\n',
'         if (cnt = CNT_MAX) then\n',
'            cnt <= 0;\n',
'         else\n',
'            cnt <= cnt + 1;\n',
'         end if;\n',
'      end if;\n',
'   end process; \n',
'\n',
'   reset : process(clk)\n',
'   begin\n',
'      if ( clk_in\'event and clk_in = \'1\') then\n',
'         if cnt > CNT_MAX then\n',
'            reset <= \'0\';  \n',
'         else\n',
'            reset <= \'1\';  --復(fù)位\n',
'         end if;\n',
'      end if;\n',
'   end process;\n',
'\n',
'----------------------------UUT instantiate--------------------------\n',
'   Port map(\n',
'   );\n',
'\n',
'end Behavioral;']

3、讀取需要仿真的模塊頂層文件,讀取到環(huán)境列表中

vhdfile = open('\xxx.vhd','r')                #讀取文件
vhdfilelines = vhdfile.readlines()           #將文件列表寫入vhdfilelines中
vhdfile.close()     


4、從vhdfilelines中循環(huán)查找端口、模塊名稱

entitystr = 'entity'                            #實體-識別字符串
endstr = 'end '                                 #實體結(jié)束部分-識別字符串
numend = 0                                      #端口開始的行號
numstart = 0                                    #端口結(jié)束的行號

for listline in vhdfilelines:                   #循環(huán)讀取文件列表
   if entitystr in listline:                    
      strline = listline                        
      numstart = vhdfilelines.index(strline)    #根據(jù)‘實體-識別字符串’查找對應(yīng)的行號
      strline = strline.split(' ')              #按照空格來分割
      entityname = strline[1]                   #模塊名稱賦值
      endstr = endstr + entityname              #重新定義:實體結(jié)束部分-識別字符串
      continue                                  #跳出本次循環(huán)
   if endstr in listline:                       #查找結(jié)束位置行號
      strline = listline                        
      numend = vhdfilelines.index(strline)      
      break                                     #結(jié)束循環(huán)

5、提取要仿真的模塊端口信息

portlist = vhdfilelines[numstart+2:numend-1]                       #提取模塊實體部分
row_n = len(portlist)                                              #確定長度
column_n = 2                                                       #列表的列數(shù)
portmap = [['' for columns in range(2)] for rows in range(row_n)]  #定義一個n行2列的空列表

for i in range(0,row_n):                                           #for循環(huán)查找對應(yīng)信息
   strline = portlist[i].split(':')                                
   strline1 = strline[0].split(' ')                                
   for j in range(0,len(strline1)):                                
      if strline1[j] != '':                                        
         portmap[i][0] = strline1[j]                               #端口名稱賦值
         break                                                     
   portmap[i][1] = strline[1]

6、修改實體、結(jié)構(gòu)體部分的模塊名稱,如下:

ModuleName = "tb_" + entityname
str1[5] = "-- Module Name: " + ModuleName + " - Behavioral\n"
str1[32] = "entity " + ModuleName + " is\n"
str1[34] = "end " + ModuleName + ";\n"
str1[36] = "architecture Behavioral of " + ModuleName + " is\n"

7、生成tb文件中調(diào)試模塊的信號定義

for i in range(row_n-1,-1,-1):                     #逆序循環(huán)插入
   strline = portmap[i][0]                         #信號名稱
   strline = " "*tabnum + "signal " + strline      #生成:"   signal clk_in"
   if portnamenum > len(strline):                  #判斷是否超出最大數(shù)
      kongnum = portnamenum - len(strline)         
   else:                                           
      kongnum = 1                                  
   strline = strline + " "*kongnum + ":"           #補入空格,對其到":"
   if "in " in portmap[i][1]:                      #去掉第二段字符串的in、out方向關(guān)鍵字
      strline1 = portmap[i][1].replace("in ","")   
   elif "out" in portmap[i][1]:                    
      strline1 = portmap[i][1].replace("out","")   
   strline = strline + strline1                    #拼接
   str1.insert(38,strline)                         #插入

8、生成測試實體說明部分

str1.insert(38," "*tabnum + "end component;\n")              
str1.insert(38,"   );\n")                                    
for i in range(row_n-1,-1,-1):                               #倒序插入
   strline = portmap[i][0]                                   #
   strline = " "*tabnum*2 + strline                          #
   if portnamenum > len(strline):                            #判斷是否超出最大數(shù)
      kongnum = portnamenum - len(strline)         
   else:                                           
      kongnum = 1 
   strline = strline + " "*kongnum + ":"                     #
   strline = strline + portmap[i][1]                         #
   str1.insert(38,strline)                                   #
str1.insert(38,"   port(\n")                                 #
str1.insert(38," "*tabnum + "component "+ entityname +"\n")  #

9、生成測試實體的例化部分信號連接

numinst = str1.index('   Port map(\n')                  #由于上述插入多行,這里需要重新定為行號
str1.insert(numinst,"   UUT : "+ entityname +"\n")           # 

for i in range(row_n-1,-1,-1):                               #倒序插入
   strline = portmap[i][0]                                   #
   strline = " "*tabnum*2 + strline                          #
   if portnamenum > len(strline):                            #判斷是否超出最大數(shù)
      kongnum = portnamenum - len(strline)         
   else:                                           
      kongnum = 1 
   strline = strline + " "*kongnum + "=> "                   #
   strline = strline + portmap[i][0] + " "*(20-len(portmap[i][0]))#
   if i != row_n-1:
      strline = strline + ',\n'
   else:
      strline = strline + '\n'
   str1.insert(numinst+2,strline)                            #

10、將修改好的激勵文件寫入到對應(yīng)的tb文件中

fileName= source_path + '\\' + ModuleName + '.vhd'
with open(fileName,'w',encoding='utf-8')as file:
   file.writelines(str1)

二、對于vivado使用modelsim仿真時修改代碼不退出重新加載的方法

1、修改修改xxxxxxxx_Compile.do腳本,刪除quit -force,防止重新啟動仿真時關(guān)閉軟件

CompileDoFile = open('.\xxx_Compile.do', 'r')
CompileDoFileAllLines = CompileDoFile.readlines()
CompileDoFile.close()
CompileDoFile = open('.\xxx_Compile.do', 'w')
for EachLine in CompileDoFileAllLines:
    if EachLine.find('quit -force') == -1:
        CompileDoFile.writelines(EachLine)
CompileDoFile.close()

2、修改xxxxxxxx_simulate.do腳本,刪除run 1000ns和quit -force,添加log -r ./*,并且添加do {xxxx_compile.do}

SimulateDoFile = open('.\xxx_ simulate.do', 'r')
SimulateDoFileAllLines = SimulateDoFile.readlines()
SimulateDoFile.close()

dowrite = SimulateDoFileAllLines[8]
if "vsim" in dowrite:
   SimulateDoFileAllLines.insert(8,"do {xxxx_compile.do}\n")

SimulateDoFile = open('.\xxx_ simulate.do', 'w')
for EachLine in SimulateDoFileAllLines:
    #EachLine.find('run 1000ns')表示列表的某一元素中存在該find字符串,如果不存在,則返回-1
    if EachLine.find('run 1000ns') == -1 and EachLine.find('quit -force') == -1:
        SimulateDoFile.writelines(EachLine)
if ('log -r ./*\n' not in SimulateDoFileAllLines) == True:
   SimulateDoFile.writelines('\nlog -r ./*\n')
SimulateDoFile.close()

總結(jié)

對于生成的tb文件使用了基本的python語言,對文件讀寫操作的語法,我以前也沒有怎么學(xué)過Python,但是經(jīng)過2天的學(xué)習,就掌握了基本語法,可以看懂程序。并進行編寫上述代碼。第一個程序解決了我們每次編寫仿真激勵時的麻煩,在自動生成的tb文件中,會自動生成時鐘和復(fù)位的代碼,也會將測試的模塊例化到tb文件中,開發(fā)人員只需完成模塊的其它輸入信號的仿真編寫。在自動重啟時加載修改后的代碼,并不會關(guān)閉modelsim界面,這樣也節(jié)省了我們開發(fā)人員的仿真時間??梢愿痈咝У霓k公。文章來源地址http://www.zghlxwxcb.cn/news/detail-412960.html

到了這里,關(guān)于如何使用Python實現(xiàn)FPGA編程“自動化”的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔相關(guān)法律責任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • 如何使用 Selenium 實現(xiàn)自動化操作?

    如何使用 Selenium 實現(xiàn)自動化操作?

    本篇咱們來談?wù)凷elenium自動化腳本是如何工作的,以及如何實現(xiàn)一個簡單的自動化示例; 一、關(guān)于Selenium 1.1、為什么選擇它作為web自動化的測試工具? 選擇Selenium作為web自動化測試工具的原因(面試也許會問): 1. 開源免費; 2. 支持多瀏覽器,如Chrome、 Firefox、IE瀏覽器等;

    2024年02月02日
    瀏覽(30)
  • 使用【Python+Appium】實現(xiàn)自動化測試

    使用【Python+Appium】實現(xiàn)自動化測試

    一、環(huán)境準備 1.腳本語言:Python3.x ? ?IDE:安裝Pycharm 2.安裝Java JDK 、Android SDK 3.adb環(huán)境,path添加E:SoftwareAndroid_SDKplatform-tools 4.安裝Appium for windows,官網(wǎng)地址 Redirecting ?點擊下載按鈕會到GitHub的下載頁面,選擇對應(yīng)平臺下載 ??安裝完成后,啟動Appium,host和port默認的即可,然

    2024年02月08日
    瀏覽(19)
  • 使用Python實現(xiàn)產(chǎn)品圖片自動化處理

    大家好,在當今的數(shù)字化時代,產(chǎn)品圖片在電子商務(wù)和市場營銷中發(fā)揮著至關(guān)重要的作用。然而,為在線平臺準備產(chǎn)品圖片可能是一項耗時的任務(wù),本文將分享一個Python腳本,用于自動化產(chǎn)品圖片的圖像處理工作流程。通過使用 Python Imaging Library(PIL) 和 rembg 庫,可以實現(xiàn)刪

    2024年02月16日
    瀏覽(19)
  • python接口自動化之request請求,如何使用 Python調(diào)用 API?

    python接口自動化之request請求,如何使用 Python調(diào)用 API?

    ? ? 尊重原創(chuàng),轉(zhuǎn)載請注明出處,謝謝?。?/p>

    2024年02月08日
    瀏覽(38)
  • 如何使用Docker實現(xiàn)分布式Web自動化!

    如何使用Docker實現(xiàn)分布式Web自動化!

    01、前言 順著docker的發(fā)展,很多測試的同學(xué)也已經(jīng)在測試工作上使用docker作為環(huán)境基礎(chǔ)去進行一些自動化測試,這篇文章 主要講述在docker中使用瀏覽器進行自動化測試如果可以實現(xiàn)可視化,同時可以對瀏覽器進行相關(guān)的操作。 0 2、開篇 首先我們先了解什么是有頭瀏覽器和無

    2024年02月13日
    瀏覽(15)
  • 從零開始學(xué)習:如何使用Selenium和Python進行自動化測試?

    從零開始學(xué)習:如何使用Selenium和Python進行自動化測試?

    安裝selenium 打開命令控制符輸入:pip install -U selenium 火狐瀏覽器安裝firebug:www.firebug.com,調(diào)試所有網(wǎng)站語言,調(diào)試功能 Selenium IDE 是嵌入到Firefox 瀏覽器中的一個插件,實現(xiàn)簡單的瀏覽器操 作的錄制與回放功能,IDE 錄制的腳本可以可以轉(zhuǎn)換成多種語言,從而幫助我們快速的開

    2024年04月23日
    瀏覽(38)
  • Python+Appium實現(xiàn)自動化測試的使用步驟

    這篇文章主要介紹了Python+Appium實現(xiàn)自動化測試的使用步驟,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧 1.腳本語言:Python3.x IDE:安裝Pycharm 2.安裝Java JDK 、Android SDK 3.adb環(huán)境,path添加E:

    2024年02月03日
    瀏覽(26)
  • 如何使用機器人和物聯(lián)網(wǎng)實現(xiàn)倉庫自動化

    自動化和機器人化不再僅限于制造過程; 現(xiàn)代倉庫也正在采用大量新技術(shù)。 物聯(lián)網(wǎng) (IoT) 的出現(xiàn)使得極其精確的室內(nèi)地理定位成為可能; 倉庫工作人員正在使用智能倉儲車; 先進的傳感器確保存儲貨物的質(zhì)量。 了解倉庫自動化以及它如何保護并加快您的物流流程。 什么是物聯(lián)網(wǎng)

    2024年02月20日
    瀏覽(23)
  • 使用Python+selenium實現(xiàn)第一個自動化測試腳本

    這篇文章主要介紹了使用Python+selenium實現(xiàn)第一個自動化測試腳本,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧 最近在學(xué)web自動化,記錄一下學(xué)習過程。 此處我選用python3.6+selenium3.0,均用

    2024年02月03日
    瀏覽(25)
  • Python使用HTTP代理實現(xiàn)網(wǎng)絡(luò)請求的自動化

    Python使用HTTP代理實現(xiàn)網(wǎng)絡(luò)請求的自動化

    隨著網(wǎng)絡(luò)技術(shù)的發(fā)展,網(wǎng)絡(luò)請求成為了許多應(yīng)用的重要組成部分。然而,手動發(fā)送網(wǎng)絡(luò)請求不僅效率低下,而且容易出錯。為了解決這個問題,我們可以使用Python來實現(xiàn)網(wǎng)絡(luò)請求的自動化。而HTTP代理可以幫助我們更好地控制和管理這些請求。 在Python中,有許多庫可以用來發(fā)

    2024年01月19日
    瀏覽(24)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包