日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

【教程分享】FPGA零基礎(chǔ)學(xué)習(xí):LED流水燈設(shè)計(jì)

電子發(fā)燒友論壇 ? 來源:未知 ? 2023-03-14 09:20 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

本系列將帶來FPGA的系統(tǒng)性學(xué)習(xí),從最基本的數(shù)字電路基礎(chǔ)開始,最詳細(xì)操作步驟,最直白的言語描述,手把手的“傻瓜式”講解,讓電子、信息、通信類專業(yè)學(xué)生、初入職場小白及打算進(jìn)階提升的職業(yè)開發(fā)者都可以有系統(tǒng)性學(xué)習(xí)的機(jī)會(huì)。

系統(tǒng)性的掌握技術(shù)開發(fā)以及相關(guān)要求,對(duì)個(gè)人就業(yè)以及職業(yè)發(fā)展都有著潛在的幫助,希望對(duì)大家有所幫助。后續(xù)會(huì)陸續(xù)更新 Xilinx 的 Vivado、ISE 及相關(guān)操作軟件的開發(fā)的相關(guān)內(nèi)容,學(xué)習(xí)FPGA設(shè)計(jì)方法及設(shè)計(jì)思想的同時(shí),實(shí)操結(jié)合各類操作軟件,會(huì)讓你在技術(shù)學(xué)習(xí)道路上無比的順暢,告別技術(shù)學(xué)習(xí)小BUG卡破腦殼,告別目前忽悠性的培訓(xùn)誘導(dǎo),真正的去學(xué)習(xí)去實(shí)戰(zhàn)應(yīng)用,這種快樂試試你就會(huì)懂的。話不多說,上貨。

LED流水燈設(shè)計(jì)

在學(xué)習(xí)軟件設(shè)計(jì)時(shí),第一個(gè)例程總是“hello world!”,那么學(xué)習(xí)硬件時(shí),也會(huì)有硬件的“hello world”------流水燈。本篇硬件基于叁芯智能科技的 SANXIN-B01開發(fā)板,如有想要入手,可查看以下鏈接,官方淘寶店已上架。

在FPGA開發(fā)板上有四個(gè)LED,我們要做的流水燈,顧名思義就是要LED像流水一樣的點(diǎn)亮熄滅。直白點(diǎn)說就是,點(diǎn)亮第一個(gè)一段時(shí)間,然后熄滅第一個(gè)的同時(shí),點(diǎn)亮第二個(gè)·····。在此,我們?cè)O(shè)置每一個(gè)LED點(diǎn)亮的時(shí)間為1秒鐘。

硬件介紹

在我們的開發(fā)板上有四個(gè)LED,設(shè)計(jì)邏輯為:FPGA輸出高電平時(shí),LED點(diǎn)亮;FPGA輸出低電平時(shí),LED熄滅。

da425626-c205-11ed-bfe3-dac502259ad0.png

架構(gòu)設(shè)計(jì)和信號(hào)說明

da5cd5fa-c205-11ed-bfe3-dac502259ad0.png

本設(shè)計(jì)的模塊名稱為ledrun。

da638f76-c205-11ed-bfe3-dac502259ad0.png


建立工程、新建文件等步驟在專輯前篇中已經(jīng)明確羅列,以后將不再敘述。這里給出超鏈接,方便參考學(xué)習(xí)。

FPGA零基礎(chǔ)學(xué)習(xí):Intel FPGA 開發(fā)流程

設(shè)計(jì)代碼

da7f116a-c205-11ed-bfe3-dac502259ad0.png

parameter可以定義一個(gè)參數(shù)(默認(rèn)是32位)。在寫代碼時(shí),對(duì)于某些數(shù)字,設(shè)計(jì)者經(jīng)常利用定義參數(shù)的方式進(jìn)行編寫,方便修改,也方便閱讀。

在硬件電路中,使用計(jì)數(shù)器當(dāng)做計(jì)時(shí)器,每記錄一個(gè)數(shù)字等于過去一個(gè)時(shí)鐘周期。由于本設(shè)計(jì)中采用的clk為50MHz,所以經(jīng)過50_000_000(在verilog中,如果是描述數(shù)字,中間的下劃線只起到分隔的作用,不影響數(shù)值的大小)個(gè)周期正好為1秒鐘。由于計(jì)數(shù)器是從0開始計(jì)數(shù),所以計(jì)數(shù)器只需要記錄到50_000_000-1即可。

為了能夠記錄到50_000_000-1這么大的數(shù)字,所以定義了一個(gè)26位的計(jì)數(shù)器cnt(參考附錄1:設(shè)計(jì)中位寬的概念和計(jì)算位寬的小技巧)。

在verilog中,“{}”( 大括號(hào))的第一個(gè)特殊作用為位拼接。{a,b}相當(dāng)于將a和b拼接為一個(gè)整體,并且是高位為a,低位為b。

當(dāng)led輸出為4’b0001時(shí),第一個(gè)led點(diǎn)亮;經(jīng)過1秒鐘,輸出4’b0010時(shí),第二個(gè)led點(diǎn)亮;經(jīng)過1秒鐘,輸出4’b0100時(shí),第三個(gè)led點(diǎn)亮;經(jīng)過1秒鐘,輸出4’b1000時(shí),第四個(gè)led點(diǎn)亮;經(jīng)過1秒鐘,輸出4’b0001時(shí),第一個(gè)led點(diǎn)亮······按照上述的過程周而復(fù)始,就形成了流水燈。

不難發(fā)現(xiàn),led的輸出,一直為3個(gè)0,1個(gè)1。并且1的位置每1秒鐘移動(dòng)一次,從頭到尾,然后又到頭。這種現(xiàn)象可以利用移位的思想進(jìn)行實(shí)現(xiàn)。即:led[3]<=led[2]; led[2]<=led[1]; led[1]<=led[0]; led[0]<=led[3];如果將被賦值的組成一個(gè)整體,那就是led,賦值的組成一個(gè)整體就是{led[2:0], led[3]}。

仿真代碼

da8e9bc6-c205-11ed-bfe3-dac502259ad0.png

$stop是一個(gè)系統(tǒng)任務(wù),功能為將modelsim的仿真停止。

設(shè)置好testbench后,運(yùn)行分析綜合后,打開RTL仿真。

波形分析

在modelsim中,打開sim窗口,選擇ledrun_tb下的ledrun_inst。

daa7a602-c205-11ed-bfe3-dac502259ad0.png

打開objects,將cnt選中。

dabaa478-c205-11ed-bfe3-dac502259ad0.png

objects窗口中顯示在sim窗口中選中模塊中所有的信號(hào)。

右擊,將其添加入波形窗口。

dac2e110-c205-11ed-bfe3-dac502259ad0.png

返回到wave窗口中,cnt信號(hào)已經(jīng)添加到wave窗口中。由于新添加進(jìn)來,沒有數(shù)據(jù)(no data)。

dacbdd88-c205-11ed-bfe3-dac502259ad0.png

點(diǎn)擊restart。

daecd9a2-c205-11ed-bfe3-dac502259ad0.png

restart按鈕為重新運(yùn)行波形,點(diǎn)擊后,軟件會(huì)詢問是否保持各種屬性,點(diǎn)擊ok即可。

db08dd8c-c205-11ed-bfe3-dac502259ad0.png

wave窗口中所有的波形都處于no data 狀態(tài)。點(diǎn)擊run –all按鈕,開始運(yùn)行波形。

db23072a-c205-11ed-bfe3-dac502259ad0.png

運(yùn)行后,會(huì)自動(dòng)停止。停止在tb文件中的$stop處。

返回wave窗口,各個(gè)信號(hào)都會(huì)有波形。

設(shè)置cnt的信號(hào)進(jìn)制為無符號(hào)的十進(jìn)制:右擊cnt信號(hào),選擇radix中的unsigned。

db396dee-c205-11ed-bfe3-dac502259ad0.png

把光標(biāo)放到復(fù)位結(jié)束時(shí),選擇放大波形。

放大按鈕的左側(cè)第一個(gè)按鈕為全局縮放,功能為將所有運(yùn)行波形,顯示到目前的窗口里;左側(cè)第二個(gè)為縮小。最左邊和最右邊的按鈕暫時(shí)用不到,這里不再介紹。

db433f4a-c205-11ed-bfe3-dac502259ad0.png

可以看到,在復(fù)位結(jié)束后,cnt信號(hào)每一個(gè)時(shí)鐘周期都會(huì)增加1。

由于我們?cè)O(shè)計(jì)的流水燈是每1秒鐘流動(dòng)一個(gè),在上述的仿真中,led數(shù)值是不會(huì)變化的。如果仿真幾秒鐘的話,仿真的時(shí)間會(huì)比較長。在此不建議仿真幾秒鐘的時(shí)長,有可能會(huì)導(dǎo)致電腦卡住。

仿真時(shí),可以將T_1s的值,改成一個(gè)較小值。例如:5。然后在此編譯仿真。

quartus的編譯器中,修改完后。進(jìn)行綜合分析,保證沒有任何語法錯(cuò)誤。在之前打開的modelsim中,打開library窗口,找到最上面的work,打開其前面的“+”。

db490ace-c205-11ed-bfe3-dac502259ad0.png

選中剛才修改過的文件,右擊,選擇recompile。此時(shí),modelsim會(huì)重新編譯此文件。

回到wave窗口中,點(diǎn)擊restart,run-all。運(yùn)行波形。

能夠清楚的看到,led在進(jìn)行移位,并且都是5個(gè)周期移動(dòng)一次。

db635e4c-c205-11ed-bfe3-dac502259ad0.png

仿真通過后,關(guān)閉modelsim。回到quartus中,將參數(shù)修改成為50_000_000,綜合分析后,分配管腳。布局布線,生成配置文件,進(jìn)行下板測試。

開發(fā)板上的四個(gè)LED開始做流水狀點(diǎn)亮。


本文由電子發(fā)燒友社區(qū)發(fā)布,轉(zhuǎn)載請(qǐng)注明以上來源。如需社區(qū)合作及入群交流,請(qǐng)?zhí)砑?/span>微信EEFans0806,或者發(fā)郵箱liuyong@huaqiu.com。

db7f1e70-c205-11ed-bfe3-dac502259ad0.png

熱門推薦干貨好文

1、RK3568!四核64位ARMv8.2A架構(gòu),匯聚編譯源碼及實(shí)戰(zhàn)樣例

2、開源作品秀,教你如何DIY一款自己的聲源跟蹤小車

3、從零入門物聯(lián)網(wǎng)OH開源平臺(tái),從簡單到高階項(xiàng)目,創(chuàng)客、電子愛好者都愛用!

4、低成本ESP32方案,支持OpenHarmony系統(tǒng)開發(fā)(附10+項(xiàng)目樣例Demo)

5、從0到1玩轉(zhuǎn)瑞薩RA4系列開發(fā)板,教你變著花樣玩板子

6、四核64位,超強(qiáng)CPU ,看RK3568“競”開發(fā)板DEMO!

7、人工智能也能這么玩, 簡單快速入手,還能自定義AI運(yùn)算

8、全部開源 | 基于全志V85X的運(yùn)動(dòng)相機(jī),工業(yè)網(wǎng)關(guān),可穿戴式攝像頭

9、高性能雙核RISC-V,滿足大多數(shù)開發(fā),這款國產(chǎn)MCU工程師都愛


原文標(biāo)題:【教程分享】FPGA零基礎(chǔ)學(xué)習(xí):LED流水燈設(shè)計(jì)

文章出處:【微信公眾號(hào):電子發(fā)燒友論壇】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴

原文標(biāo)題:【教程分享】FPGA零基礎(chǔ)學(xué)習(xí):LED流水燈設(shè)計(jì)

文章出處:【微信號(hào):gh_9b9470648b3c,微信公眾號(hào):電子發(fā)燒友論壇】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    零基礎(chǔ)手寫大模型資料2026

    零基礎(chǔ)純代碼手寫大模型:從數(shù)學(xué)原理到工程實(shí)踐的技術(shù)解析 在深度學(xué)習(xí)框架高度封裝的今天,理解大模型底層原理的開發(fā)者愈發(fā)稀缺。本文將剝離復(fù)雜框架的依賴,從數(shù)學(xué)基礎(chǔ)出發(fā),解析如何用基礎(chǔ)代碼實(shí)現(xiàn)一個(gè)具備
    發(fā)表于 05-01 17:44

    零基礎(chǔ)玩轉(zhuǎn)Linux+Ubuntu實(shí)戰(zhàn)視頻課程

    極速拆解《小白也能學(xué)會(huì):Linux+Ubuntu 零基礎(chǔ)實(shí)戰(zhàn)通關(guān)課程》 面對(duì)這種標(biāo)榜“零基礎(chǔ)”、“通關(guān)”的 Linux 長篇大論,絕大多數(shù)人的死穴是:把它當(dāng)成“字典”去啃。他們?cè)噲D記住 ls -l
    發(fā)表于 04-18 16:16

    2小時(shí)搞定鴻蒙應(yīng)用!零基礎(chǔ)做出你的鴻蒙“處女作”

    當(dāng)下,低門檻開發(fā)正成為生態(tài)擴(kuò)張的最強(qiáng)推力,而鴻蒙生態(tài)的快速壯大,也讓越來越多零基礎(chǔ)小白蠢蠢欲動(dòng),想加入開發(fā)大軍。但繁瑣的配置流程、深?yuàn)W的代碼,也讓很多人打起了退堂鼓。近日,鴻蒙開發(fā)者官網(wǎng)全新上線
    的頭像 發(fā)表于 04-17 14:04 ?127次閱讀
    2小時(shí)搞定鴻蒙應(yīng)用!<b class='flag-5'>零基</b>礎(chǔ)做出你的鴻蒙“處女作”

    使用FPGA控制上千顆RGB LED流水燈

    國內(nèi)還有一個(gè)FPGA技術(shù)在特定垂直的領(lǐng)域-LED 顯示。今天就從開源項(xiàng)目展開講講這個(gè)領(lǐng)域中FPGA扮演的角色。
    的頭像 發(fā)表于 03-25 17:52 ?981次閱讀

    學(xué)習(xí)單片機(jī)快速方法

    要知道流水燈是怎么和單片機(jī)連接的(一般學(xué)習(xí)板都配有電路圖)。然后你要能編寫不同的程序去控制LED的亮滅,花樣就隨你遍了。 有時(shí)間的話可以去網(wǎng)上下載些流水燈的源程序看看。看看人家有什么
    發(fā)表于 01-14 07:42

    蜂鳥E203在黑金XC7A200T型FPGA上點(diǎn)亮LED并實(shí)現(xiàn)流水燈

    一、隊(duì)伍介紹 本篇介紹的內(nèi)容是蜂鳥E203在黑金XC7A200T型FPGA上點(diǎn)亮LED并實(shí)現(xiàn)流水燈。 二、前言 在此之前我們已經(jīng)將蜂鳥E203在黑金XC7A200T型FPGA開發(fā)
    發(fā)表于 10-31 09:04

    免焊BNC接頭接法:零基礎(chǔ)快速安裝指南與信號(hào)穩(wěn)定技巧

    通過以上步驟,即使零基礎(chǔ)用戶也能快速完成免焊BNC接頭的安裝,確保視頻、音頻信號(hào)穩(wěn)定傳輸,滿足監(jiān)控、音視頻工程等場景需求。
    的頭像 發(fā)表于 08-28 16:59 ?2550次閱讀
    免焊BNC接頭接法:<b class='flag-5'>零基</b>礎(chǔ)快速安裝指南與信號(hào)穩(wěn)定技巧

    【沁恒CH585開發(fā)板免費(fèi)試用體驗(yàn)】GPIO 流水燈

    開發(fā)環(huán)境: IDE:MounRiver Studio MCU:CH585 1 GPIO工作原理 熟悉單片機(jī)的朋友都知道,學(xué)習(xí)的第一個(gè)例程就是流水燈,要想實(shí)現(xiàn)流水燈,首先必須了解GPIO的工作原理
    發(fā)表于 07-04 22:55

    【教程】零基礎(chǔ)!手把手教你使用STM32F4進(jìn)行E22-400T22S編程通信

    通過本文帶大家零基礎(chǔ)使用STM32F407VET6單片機(jī)進(jìn)行E22-400T22S模塊編程并進(jìn)行簡單的通信,當(dāng)然如果學(xué)會(huì)了,也可以舉一反三應(yīng)用于E22、E220、E32所有模塊上。一STM32環(huán)境
    的頭像 發(fā)表于 07-03 19:32 ?1867次閱讀
    【教程】<b class='flag-5'>零基</b>礎(chǔ)!手把手教你使用STM32F4進(jìn)行E22-400T22S編程通信

    零基礎(chǔ)學(xué)習(xí)LuatOS編程:快速上手開發(fā)實(shí)戰(zhàn)教程!

    無論你是剛接觸物聯(lián)網(wǎng)編程的新手,還是希望拓展技能的技術(shù)愛好者,本教程將為零基礎(chǔ)的讀者提供一條清晰的LuatOS學(xué)習(xí)路徑。從安裝開發(fā)工具到編寫第一個(gè)程序,我們將通過實(shí)例講解核心概念,助你快速實(shí)現(xiàn)從理論
    的頭像 發(fā)表于 06-13 17:27 ?765次閱讀
    <b class='flag-5'>零基</b>礎(chǔ)<b class='flag-5'>學(xué)習(xí)</b>LuatOS編程:快速上手開發(fā)實(shí)戰(zhàn)教程!

    STC8H 單片機(jī) + RA8889/RA6809:重新定義嵌入式觸控交互_高流暢、低延遲、零基礎(chǔ)的人機(jī)界面(一)

    STC8H 單片機(jī) + RA8889/RA6809:重新定義嵌入式觸控交互_高流暢、低延遲、零基礎(chǔ)的人機(jī)界面
    的頭像 發(fā)表于 05-28 16:01 ?1513次閱讀
    STC8H 單片機(jī) + RA8889/RA6809:重新定義嵌入式觸控交互_高流暢、低延遲、<b class='flag-5'>零基</b>礎(chǔ)的人機(jī)界面(一)

    死角玩轉(zhuǎn)STM32——初級(jí)篇

    ,從裸奔到系統(tǒng),讓您死角玩轉(zhuǎn) STM32。 目錄內(nèi)容: 1、如何編譯和下載程序 2、JLINK 驅(qū)動(dòng)安裝與 MDK 環(huán)境搭建 3、如何新建工程模板 4、初識(shí) STM32 庫 5、流水燈
    發(fā)表于 05-21 13:48

    一技在手,醫(yī)療無憂!零基礎(chǔ)轉(zhuǎn)行高薪醫(yī)療維修工程師

    ,剩下的就看個(gè)人能力了,對(duì)醫(yī)療器械維修感興趣但迷茫的可聯(lián)系我們,幫你解決疑難問題,帶你入門醫(yī)療維修行業(yè)! 一技在手,醫(yī)療無憂!零基礎(chǔ)轉(zhuǎn)行高薪醫(yī)療維修工程師!” “缺口40萬+,月薪過萬!搶占醫(yī)療行業(yè)
    發(fā)表于 05-15 10:22

    【「零基礎(chǔ)開發(fā)AI Agent」閱讀體驗(yàn)】+讀《零基礎(chǔ)開發(fā)AI Agent》掌握扣子平臺(tái)開發(fā)智能體方法

    收到發(fā)燒友網(wǎng)站寄來的《零基礎(chǔ)開發(fā)AI Agent》這本書已經(jīng)有好些天了,這段時(shí)間有幸拜讀了一下全書,掌握了一個(gè)開發(fā)智能體的方法。 該書充分從零基礎(chǔ)入手,先闡述了Agent是什么,它的基本概念和知識(shí)
    發(fā)表于 05-14 19:51

    Air8000+G-sensor:零基礎(chǔ)開發(fā)者的傳感器入門課!

    無需復(fù)雜理論,本文專為零基礎(chǔ)開發(fā)者設(shè)計(jì),從Air8000核心板硬件特性入手,一步步演示G-sensor的注冊(cè)、配置與數(shù)據(jù)解析。結(jié)合趣味實(shí)例(如傾斜控制LED),讓你30分鐘內(nèi)完成首個(gè)傳感項(xiàng)目,夯實(shí)
    的頭像 發(fā)表于 05-06 14:36 ?1068次閱讀
    Air8000+G-sensor:<b class='flag-5'>零基</b>礎(chǔ)開發(fā)者的傳感器入門課!
    晋江市| 合川市| 衡阳市| 竹山县| 永德县| 连山| 布尔津县| 崇信县| 黑水县| 六盘水市| 寿宁县| 故城县| 石泉县| 潍坊市| 兰坪| 平昌县| 交口县| 米泉市| 德庆县| 密云县| 靖宇县| 潮安县| 隆林| 廉江市| 渝北区| 嘉定区| 高邮市| 桓台县| 漯河市| 东港市| 平塘县| 隆尧县| 商水县| 焉耆| 广安市| 绥棱县| 秦皇岛市| 垣曲县| 昭通市| 西林县| 龙口市|