99在线精品免费视频九九视-99在线精品视频-99在线精品视频免费观里-99在线精品视频在线观看-99在线免费播放



官方論壇
官方淘寶
官方博客
微信公眾號
點(diǎn)擊聯(lián)系吳工 點(diǎn)擊聯(lián)系周老師
您的當(dāng)前位置:主頁 > FPGA原創(chuàng) >

運(yùn)用至簡設(shè)計法進(jìn)行呼吸燈設(shè)計(附設(shè)計表)

發(fā)布時間:2019-12-24   作者:魚丸粗面 瀏覽量:

本文為明德?lián)P原創(chuàng)文章,轉(zhuǎn)載請注明出處!

呼吸燈是指燈光在微電腦的控制之下完成由亮到暗的逐漸變化,感覺好像是人在呼吸。其廣泛應(yīng)用于手機(jī)、電腦等電子產(chǎn)品之上,并成為各大品牌新款手機(jī)的賣點(diǎn)之一,起到一個通知提醒的作用。每個人都應(yīng)該使用過帶有呼吸燈的手機(jī),看著燈光由暗淡逐漸一點(diǎn)點(diǎn)變亮,繼而在最亮的時刻開始逐漸變暗、熄滅最后歸于虛無,就像酣睡中隨著人的呼吸而起伏的胸膛。每當(dāng)看到手機(jī)屏幕上的呼吸燈閃爍時,你是否想過,如何自己設(shè)計一個呼吸燈,讓它伴隨著你的呼吸變亮變暗。沒有做過呼吸燈的同學(xué)不要緊,我將會為大家展示一個使用清晰整潔的代碼設(shè)計出來的呼吸燈。認(rèn)真看完這篇文章,我可以保證你能夠真正了解呼吸燈是使用怎樣的原理設(shè)計的,并且可以自己獨(dú)立設(shè)計出自己的呼吸燈。快去點(diǎn)亮它吧!

介紹一下呼吸燈設(shè)計的基本原理:

呼吸燈是通過控制led燈閃爍的頻率來控制其亮度的。什么是閃爍的頻率?比如我們讓led燈在1s內(nèi)持續(xù)為亮,那么這個led燈將會一直以最大的亮度閃亮,亮的頻率就是1;當(dāng)我們讓led燈在1s內(nèi)持續(xù)為暗,那么led燈將會一直熄滅,亮的頻率就是0;若是我們讓led燈在1s中前0.5s內(nèi)為亮、后0.5s內(nèi)為滅,那么led燈將會一直一閃一滅,持續(xù)下去...我們可以大膽的想象一下,如果我們能夠控制led燈在1s內(nèi)一開始亮的頻率為0,然后一點(diǎn)一點(diǎn)的增大亮的頻率直至為1,那么led燈是否就可以由暗慢慢變到最亮。道理已經(jīng)明白了,那么我們要怎樣控制led燈亮的頻率?通過控制led燈亮的時間長度。怎樣控制燈亮的時間?通過計數(shù)FPGA的時鐘個數(shù)。該怎樣計數(shù)FPGA的時鐘個數(shù)?

下面講一下本設(shè)計的基本思想:

我們讓led燈在1s內(nèi)由暗慢慢點(diǎn)亮,那么我們不妨將1s先分成1000等份,每一等份就是1ms,用一個計數(shù)ms個數(shù)的計數(shù)器cnt_ms來計數(shù)。1ms分成1000等份,每一等份就是1us,用計數(shù)器cnt_us來標(biāo)示。由于MP801開發(fā)板的FPGA時鐘頻率是20ns,那么我們就將1us分成50份,每一份就是20ns,即一個時鐘周期。通過計數(shù)時鐘周期的個數(shù),計數(shù)到第50個時,就到達(dá)了1us,計數(shù)器cnt_us就開始加1;cnt_us計數(shù)到1000個時,就到達(dá)了1ms,接著計數(shù)到1s...時間已經(jīng)劃分好了,那么我們該怎么控制led燈亮的時間?

通過PWM原理來控制led亮滅。不了解PWM原理不重要,只要能讀懂下面一句話即可:

0-1S內(nèi):讓led燈在第0-1ms之間亮的時間為0us;在第1-2ms內(nèi)亮1us,在第2-3ms內(nèi)亮2us...在第999-1000Ms內(nèi)亮999us。

思路已經(jīng)很清晰了,接下來我們就可以進(jìn)行電路設(shè)計。

信號列表:

信號名稱

信號類型

位寬

功能描述

clk

I

1

時鐘信號

rst_n

I

1

復(fù)位信號

led

O

1

輸出led信號

 

led_bright

wire

1

控制led亮滅

cnt_ns

reg

10

用來計數(shù)20ns的時鐘周期數(shù),計數(shù)到50個即到達(dá)1us,計數(shù)器清零

add_cnt_ns

wire

1

計數(shù)器cnt_ns加一指示信號,一直為1

end_cnt_ns

wire

1

計數(shù)器cnt_ns清零指示信號,當(dāng)cnt_ns計數(shù)到第50時為1

cnt_us

reg

10

用來計數(shù)產(chǎn)生1us的個數(shù)

add_cnt_us

wire

1

計數(shù)器cnt_us加一指示信號,end_cnt_ns拉高時有效

end_cnt_us

wire

1

計數(shù)器cnt_us清零指示信號,cnt_us計數(shù)到第1000個時拉高

cnt_ms

reg

10

用來計數(shù)1ms的個數(shù),加一條件是end_cnt_us有效

add_cnt_ms

wire

1

cnt_ms加一指示信號,end_cnt_us拉高時有效

end_cnt_ms

wire

1

計數(shù)器cnt_ms清零指示信號,當(dāng)cnt_ms計數(shù)到第1000個時拉高

cnt_s

reg

1

用來計數(shù)1s的個數(shù)

cdd_cnt_s

wire

1

cnt_s加一指示信號,當(dāng)end_cnt_ms拉高有效

cnd_cnt_s

wire

1

計數(shù)器Cnt_s清零指示信號,cnt_s計數(shù)到2拉高

計數(shù)us信號:

計數(shù)ms信號:

控制led亮的指示信號:

按照我上面的設(shè)計思想,在100ms內(nèi),控制亮的時間不大于100us;在200ms內(nèi),控制亮的時間不大于200us。

led輸出信號:

在亮的時間區(qū)域內(nèi)led給低電平,led亮;其他時間給led高電平,led滅。

OK,將工程綜合編譯,分配好管腳,燒錄到MP801開發(fā)板中,即可觀察到屬于你自己的呼吸燈。

可以看出,使用至簡設(shè)計法設(shè)計出的代碼,思路清晰,代碼簡潔干凈、有跡可循,只要設(shè)計的思路清晰,設(shè)計出的代碼也同樣是易讀易懂,每個信號都有其特定的功能。因此FPGA設(shè)計的核心是設(shè)計思路,而不是設(shè)計代碼,代碼只是用來告訴編譯器我們的設(shè)計思路,再由編譯器綜合成硬件電路。使用一種規(guī)范簡潔的代碼設(shè)計方法可以幫助我們更好的表現(xiàn)出我們的設(shè)計思路,這在我們進(jìn)行FPGA設(shè)計過程中可以極大提高我們的設(shè)計效率。

以上就是設(shè)計呼吸燈的思考與步驟,需要此工程明德?lián)P設(shè)計的源碼的朋友可以加我的QQ:3358622769無償獲取,也歡迎大家與我進(jìn)行深入討論,期待與大家一起學(xué)習(xí)進(jìn)步!

  •   
  •   
  •   
  •  
  • FPGA教育領(lǐng)域第一品牌
  • 咨詢熱線:020-39002701
  • 技術(shù)交流Q群:544453837
主站蜘蛛池模板: 欧美a级成人淫片免费看 | 青青爽国产手机在线观看免费 | 澳门久久 | 美国一级片在线 | 外国激情视频 | 小明永久免费大陆在线观看 | 免费爱爱视频 | 在线观看免费黄色 | 黄短视频在线观看免费版 | 国产精品麻豆传媒 | 日本一级毛片不卡免费 | 久久久久久极精品久久久 | 免费一级欧美性大片 | 特级aa一级欧美毛片 | 成人国产网站 | 久久在线免费观看视频 | 成人午夜视频一区二区国语 | 亚洲成熟中国女人毛茸茸 | 欧美激情特级黄aa毛片 | 免费高清国产 | 成人精品一区二区www | 午夜视频久久 | 久久久久国产亚洲日本 | 看草逼| 欧美国产亚洲一区 | 8888四色奇米在线观看免费看 | 在线观看av网站永久 | 国产美腿丝袜福利视频在线观看 | 高清成年美女xx免费网站黄 | 国产黄色影片 | 亚洲青青青网伊人精品 | 日韩性视频网站 | 综合网在线视频 | 一级片毛片 | 精精国产www视频在线观看免费 | 一级一毛片a级毛片欧美 | 91久久九九精品国产综合 | 国产免费一区二区三区免费视频 | 日日麻批视频 | 日本最新伦中文字幕 | 欧美一区二区三区免费高 |