該項目描述了如何設(shè)計一個7段1位LED顯示屏的從1到6的真正隨機數(shù)發(fā)生器。
硬件部件
Dialog Semiconductor GreenPAK高級開發(fā)板SLG4DVKADV× 1個
Dialog Semiconductor SLG46826× 1個
該項目描述了如何設(shè)計Digital Dice,這是一個從1到6的真實隨機數(shù)生成器。可以使用此設(shè)備代替常用的骰子。它具有一個1位數(shù)的7段LED顯示屏和兩個按鈕:“運行”和“顯示上一個”。數(shù)碼骰子可以由單個CR2032電池供電。它沒有開機開關(guān),因為閑置時的功耗極低。
圖1:數(shù)字骰子示意圖
下面我們描述了了解解決方案如何設(shè)計數(shù)字骰子所需的步驟。但是,如果您只想獲取編程結(jié)果,請下載GreenPAK軟件以查看已完成的GreenPAK設(shè)計文件。將GreenPAK開發(fā)套件插入計算機,然后點擊程序來設(shè)計解決方案。
設(shè)備架構(gòu)
圖2:GreenPAK6 Designer項目
該設(shè)計包含以下塊:
熵產(chǎn)生器
熵發(fā)生器由四個異步振蕩器組成。其中兩個是使用具有延遲(1 MHz和6.5 MHz)的反向閉環(huán)LUT構(gòu)建的。另外兩個是GreenPAK的OSC1(2.048 MHz,除以3)和OSC2(25 MHz,除以2)。
向XNOR門輸入一些異步時鐘信號足以在其輸出上獲得不可預(yù)測的信號(噪聲或熵)。但是SLG46826V中的宏單元可以使解決方案更加復雜。再使用一個振蕩器和DFF,我們得到一個完全隨機的信號。
圖3:熵產(chǎn)生器
線性反饋移位寄存器
3位LFSR使用三個DFF和一個XNOR門構(gòu)建。每個輸入時鐘的該塊都會生成一個3位的偽隨機數(shù)。此處,噪聲信號代替時鐘脈沖進入LFSR的輸入,從而生成一個真正的隨機3位數(shù)字。
圖4:LFSR
二進制至7段解碼器
為了轉(zhuǎn)換由LSFR生成的3位隨機數(shù),使用了二進制至7段解碼器,請參見圖3。解碼器由3位LUT構(gòu)建。
圖5:二進制到7段解碼器
控制單元
控制單元是設(shè)備的一部分,旨在在3秒鐘后啟動并停止。兩個引腳被配置為輸入,并且兩個按鈕必須從VDD連接到這些引腳。按下“運行”按鈕時,設(shè)備將連續(xù)生成隨機數(shù)。釋放按鈕后,立即停止生成,LFSR鎖存其輸出。解碼器隨后驅(qū)動7段顯示器。3秒鐘后,數(shù)字骰子將進入空閑狀態(tài)。該設(shè)備仍處于開機狀態(tài),但是由于所有振蕩均已關(guān)閉,因此電流消耗極低。這使設(shè)備可以“記住”最后生成的隨機數(shù)。如果按下“顯示上一個”按鈕,將顯示最后生成的隨機數(shù),直到釋放該按鈕。因為數(shù)字骰子旨在替代普通骰子,所以當出現(xiàn)“ 0”或“ 7”時,將使用3位LUT12重新啟動它。這樣可以確保設(shè)備生成1到6之間的隨機數(shù)。
圖6:控制單元
宏單元設(shè)置
對于每個宏單元,設(shè)置請參考下表。
表1. LUT設(shè)置
表2:DFF設(shè)置
表3:CNT / DLY設(shè)置
表6:OSC設(shè)置
表7:PIN設(shè)置
結(jié)論
數(shù)字骰子可以替代賭場中的普通骰子,也可以在需要骰子的任何其他游戲中使用。它具有一個熵生成器,該熵生成器在按下“運行”按鈕時會不斷生成3位隨機數(shù)。它僅在釋放按鈕時停止并顯示結(jié)果,因此人為因素也會影響所生成的隨機數(shù)。四個異步振蕩器以及人為按下按鈕的可變性使該設(shè)備完全不可預(yù)期地不可預(yù)測
編輯:hfy
-
led
+關(guān)注
關(guān)注
242文章
23343瀏覽量
662332 -
解碼器
+關(guān)注
關(guān)注
9文章
1146瀏覽量
40864 -
振蕩器
+關(guān)注
關(guān)注
28文章
3845瀏覽量
139267 -
隨機數(shù)發(fā)生器
+關(guān)注
關(guān)注
0文章
21瀏覽量
11017 -
dff
+關(guān)注
關(guān)注
0文章
26瀏覽量
3428
發(fā)布評論請先 登錄
相關(guān)推薦
評論