<abbr id="kc8ii"><menu id="kc8ii"></menu></abbr>
  • <input id="kc8ii"><tbody id="kc8ii"></tbody></input><table id="kc8ii"><source id="kc8ii"></source></table><kbd id="kc8ii"></kbd>
    <center id="kc8ii"><table id="kc8ii"></table></center>
  • <input id="kc8ii"></input>
    <abbr id="kc8ii"></abbr>
  • <abbr id="kc8ii"></abbr>
  • <center id="kc8ii"><table id="kc8ii"></table></center>
    <abbr id="kc8ii"></abbr>
    你的位置:首頁 > 測試測量 > 正文

    數字日歷的面世,以軟件方式設計硬件的“新坐標”

    發布時間:2014-12-11 責任編輯:echolady

    【導讀】本文設計的數字日歷是建立在FPGA的技術之上,實現了以軟件方式設計硬件的目的。與傳統的數字日歷相比,其設計靈活、成本低廉、計時精度高、開發速度快、功能強大,在很多性能上得到了大幅度的提升。

    基于FPGA 設計數字日歷可以實現以軟件方式設計硬件的目的,無需購買專用數字芯片,從而克服了傳統利用多片數字集成電路設計數字日歷存在焊接麻煩、調試繁瑣、成本較高等問題。而且,基于FPGA 的數字日歷與傳統系統相比,在設計靈活、開發速度、降低成本、計時精度、功能實現上都得到大幅度提升,能夠更好地滿足人們日常生活的需要。

    本文介紹如何利用VHDL 硬件描述語言設計一個具有年、月、日、星期、時、分、秒計時顯示功能,時間調整功能和整點報時功能的數字日歷。在Quartus Ⅱ開發環境下,采用自頂向下的設計方法,建立各個基本模塊,再構建成一個完整的基于FPGA 設計的數字日歷的頂層模塊,然后對其進行編譯、仿真、引腳鎖定,最終下載到可編程邏輯器件上進行結果驗證。

    1 數字日歷整體設計方案


    基于FPGA 的數字日歷設計分為硬件設計和軟件設計兩大部分。其原理框圖如圖1所示。整個數字日歷由六個部分組成:顯示控制部分,時分秒部分,年月日部分,定時與整點報時部分,星期部分,調整控制部分。秒、分、時分別由兩個60進制的計數器和一個24進制的計數器組成。當個計數器達到進位的條件時向下一計數器進位。同樣日、月、年也是由不同的計數器組成,當達到所需進位的條件時向下一計數器進位,各計數器在進位的同時分別把各自的結果輸出給顯示部分進行實時顯示。

    數字日歷的面世,以軟件方式設計硬件的“新坐標”
    圖1 數字日歷原理框圖
     
    2 數字日歷的工作原理

    首先由外部振蕩器產生穩定的高頻脈沖信號,作為數字日歷的時間基準,然后經過分頻器輸出標準秒脈沖,輸入到FPGA的CLOCK端,實現計數。當秒計數器滿60后向分計數器進位,分計數器滿60后向小時計數器進位,小時計數器按照“24進1”規律計數。計滿后各計數器清零,重新計數。日部分由于日有28天、29天、30天、31天4種情況,故日由年和月共同判斷其天數,日計滿后向月進位,月滿后向年進位。計數器的輸出分別經譯碼器送數碼管顯示。計時出現誤差時,可以用校時電路校時、校分、校秒和校年、校月、校日。

    設計中用到了6 個按鍵K1,K2,K3,K4,ZHENG,NAO。其中K1用于切換顯示,剛開始時顯示日期,按兩次K1顯示星期+時間,再按兩次K1顯示定時時間,再按兩次重新顯示日期,以此循環。K2、K3和K4配合進行調節:開始正常顯示不進行調節;當按兩下K2 鍵切換到對分鐘進行調節,此時每按兩下K3 鍵分鐘加1;再按兩下K2 鍵切換到對小時進行調節,此時每按兩下K3 鍵小時加1;依照分鐘→小時→星期→天→月→年→定時→正常→分鐘的次序循環調節,每按兩下K2 鍵切換到調節相應顯示,此時每按下K3鍵兩次,對應顯示加1;當切換到定時調節時,每按兩下K3鍵,定時的分鐘加1,此時按兩下K4 鍵,切換到定時小時調節,每按兩下K3 鍵,定時的小時加1。按鍵ZHENG和NAO為整點報時和定時鬧鐘的使能端(低電平有效)。

    3 軟件設計

    軟件設計分為秒分時、年月日、按鍵調整、控制顯示、鬧鐘等幾大模塊。設計好各子模塊,然后在原理圖編輯窗口創建頂層原理圖文件shuzirili.bdf,將各子模塊按照邏輯關系連接起來得到數字日歷電路核心部分的原理圖。下面對各子模塊設計及仿真進行介紹。

    3.1 時分秒模塊

    分和秒都是60進制的計數器,小時則是24進制的計數器,先對各個子模塊進行設計編譯,驗證無誤后再將其組織到一起。外部時鐘信號通過秒模塊的clk 輸入,產生的進位信號輸送到分模塊的clk,分模塊產生的進位信號輸送到小時模塊的clk,構成時分秒模塊。其結構圖如圖2所示。

    數字日歷的面世,以軟件方式設計硬件的“新坐標”
    圖2 時分秒原理圖
     
    [page]
     
    3.2 星期模塊

    星期模塊為七進制計數器。其計數時鐘信號來自于調時電路產生的星期進位脈沖信號,計數至6 瞬間,計星期模塊返回0 重新開始計數。

    3.3 年月日模塊

    年月日模塊有daycounter 模塊、days-control 模塊、monthcounter模塊、yearcounter模塊組成,具有大小月判斷和閏年判斷功能,其結構圖如圖3所示。

    數字日歷的面世,以軟件方式設計硬件的“新坐標”
    圖3 年月日連接框圖
     
    3.4 定時模塊

    定時模塊通過按鍵K4來切換調節定時的分鐘和小時,調整功能由調時模塊的按鍵K3來完成,每按兩下K3對應的顯示加1。

    3.5 調時模塊

    調時模塊設計思想是:通過把整個設計中的上一個模塊(比如:分的上一個模塊是秒;年的上一個模塊是月,等等)的進位輸出接到本模塊的輸入in,out接到下一個模塊的時鐘輸入。正常狀態下sout=fin,fout=hin,hout=din,dout=min,mout=yin ,win=hout;當每按下兩次K2鍵,產生一個上升沿分別對fin,hin,win,din,min,yin,dingshi調節,調節信號由K3 給出。其中定義一個信號w,計數到7 返0,對應正常狀態,fin,hin,win,din,min,yin,dingshi 7個狀態。

    當K2 每來一個上升沿時,分別對分,時,星期,天,月,年以及定時調整,調整信號由K3 給出,經仿真調時模塊結果與系統設計要求符合。

    3.6 控制模塊

    控制模塊通過K1按鍵進行切換顯示調整,起初顯示年月日,按下2次K1顯示時間,再按下2次顯示定時時間。

    若仿真參數設置數值為:2013 年05 月15 日,星期三,15:28(33 s),定時為07:19。仿真后結果如圖4所示。

    從圖4可以看出,通過K1 按鍵控制顯示,開始顯示年月日:20130515,當按下K1 兩下,顯示星期+時間:03152833;再按兩下顯示定時時間:00000719。仿真結果與預期設計一致,設計正確。

    數字日歷的面世,以軟件方式設計硬件的“新坐標”
    圖4 仿真結果
     
    3.7 鬧鐘模塊

    鬧鐘模塊設計為當定時時間到或者整點時鬧鈴響,分別有ZHENG,NAO 兩個控制端子控制,低電平有效。經驗證,定時和整點報時仿真結果均符合設計要求。

    3.8 頂層模塊

    將各個子模塊設計好之后,并創建各自文件的圖元,以供原理圖設計文件中調用。然后在原理圖編輯窗口創建頂層原理圖文件shuzirili.bdf,即將各圖元的引線端子按照邏輯關系連接起來,得到如圖5所示的完整原理圖,也即頂層模塊。

    對頂層文件分別進行時間、日期、鬧鈴功能的波形仿真,得到的仿真結果和預想設計一致,表明設計正確。

    數字日歷的面世,以軟件方式設計硬件的“新坐標”
    圖5 頂層原理圖
     
    [page]
     
    4 硬件驗證

    在Quartus Ⅱ開發環境中完成上述軟件設計及仿真后,最后還需將程序下載到FPGA器件中進行硬件測試,以進一步驗證所設計程序是否正確。硬件驗證時,還需對頂層文件進行管腳分配、并編譯,然后將編譯好的目標文件通過下載電纜下載到FPGA 開發板中進行驗證和調試。

    采用GW48-SPOC/EDA 實驗開發系統并設置在工作模式0來驗證設計結果。下面僅給出部分驗證結果。剛完成下載,數碼管顯示20000000,按兩下K1切換到時間顯示,才剛剛開始計數,同時揚聲器發出“滴答滴答”的頻率為1 Hz的響聲(為整點報時)60 s,然后通過按鍵8(K1)、鍵7(K2)、鍵6(K3)、鍵5(K4)對各個功能進行驗證。首先調整時間,按兩下K2鍵切換到分的調整,此時每按兩下K3 鍵,分鐘加1,驗證過程中看到加到59就變為00;再按兩下K2鍵切換到小時的調整,此時每按兩下K3鍵,分鐘加1;用同樣的方法調整星期,天,月,年以及定時的分鐘和小時。

    調整日期為2013年7月31號,當再調整天時,就變為2013年7月1號,結果如圖9所示。其他月份實驗結果也符合生活規律,與設計要求一致。

    其他的測試結果,數碼管能夠正確顯示計時時間,定時驗證及時間調節、整點報時均能夠正常工作,實驗結果符合設計要求。

    數字日歷的面世,以軟件方式設計硬件的“新坐標”
    圖6 實際電路驗證
     
    總結

    本文基于FPGA 環境設計了一個具有年、月、日、星期、時、分、秒計時顯示功能,時間調整功能和整點報時功能的數字日歷系統,并將之下載到FPGA 芯片EP1C3T144-3 上進行結果驗證,實驗驗證表明:數碼管能夠正確顯示計時時間,能夠通過按鍵調整時間,能夠設定時間并調整,整點報時能夠正常工作,實驗結果符合設計要求。由于設計中利用硬件描述語言和FPGA芯片相結合進行數字日歷的研究,即利用EDA 技術在一定程度上實現了硬件設計軟件化,使設計過程變得相對簡單,易于修改。

    相關閱讀:

    FPGA有門道?一款軟件無線電平臺的設計
    利用CPLD數字邏輯和FPGA實現ADC
    基于FPGA的航空電子系統的設計

    要采購焊接么,點這里了解一下價格!
    特別推薦
    技術文章更多>>
    技術白皮書下載更多>>
    熱門搜索
    ?

    關閉

    ?

    關閉

    一二三四社区在线中文视频| 久久久无码一区二区三区| 亚洲av无码乱码国产精品| 国产成A人亚洲精V品无码性色 | 无码人妻AⅤ一区二区三区水密桃 无码欧精品亚洲日韩一区夜夜嗨 无码免费又爽又高潮喷水的视频 无码毛片一区二区三区中文字幕 无码毛片一区二区三区视频免费播放 | 亚洲成a人片在线观看无码| 无码精品前田一区二区| 国内精品无码一区二区三区| 亚洲AV永久无码精品一区二区| 精品国产V无码大片在线看| 亚洲免费无码在线| 亚洲精品无码Av人在线观看国产| 亚洲中文字幕无码久久2020 | 日本精品自产拍在线观看中文| 精品久久久无码中文字幕天天| 亚洲日韩AV一区二区三区中文| 精品无码国产自产拍在线观看蜜| 精品久久久无码21p发布| 亚洲乱码中文字幕久久孕妇黑人| 精品日韩亚洲AV无码一区二区三区| 亚洲美日韩Av中文字幕无码久久久妻妇 | 中文字幕在线资源| 日韩免费a级毛片无码a∨| 午夜人性色福利无码视频在线观看 | 久久久久久亚洲Av无码精品专口| 中文亚洲日韩欧美| 亚洲成a人片在线观看中文动漫| 色欲香天天综合网无码| 少妇无码一区二区三区| 中文字幕亚洲图片| 中文字幕日本在线观看| 亚洲Av无码乱码在线观看性色| 无码137片内射在线影院| 国产av无码专区亚洲av果冻传媒| а天堂中文在线官网| 中文字幕亚洲精品无码| 国产成人无码一区二区三区| 无码国产精品一区二区免费模式 | 最近最新中文字幕高清免费| 无码超乳爆乳中文字幕久久 | 成在线人AV免费无码高潮喷水 |