版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、如題,再附加上程序的控制說(shuō)明.是用GW48教學(xué)實(shí)驗(yàn)箱仿真的如果對(duì)你有幫助,請(qǐng)大家頂上.程序直接貼上了控制說(shuō)明:1、電子琴:程序設(shè)計(jì)采用八個(gè)輸入端口,分別與實(shí)驗(yàn)箱上的按鍵81引腳相連接,采用一個(gè)輸出端口,與揚(yáng)聲器的引腳連接,時(shí)鐘頻率采用6MHz和4Hz。按鍵71分別用于中音的七個(gè)音符的發(fā)音(DO,RE,MI,F(xiàn)A,SO,LA,SI),按鍵8用于控制樂(lè)曲的播放。程序的編寫(xiě)采用狀態(tài)機(jī)的編寫(xiě)方法,對(duì)按鍵的狀態(tài)進(jìn)行判斷,對(duì)應(yīng)相應(yīng)的音符或樂(lè)曲。2、電子鐘:程序的設(shè)計(jì)模塊有:時(shí)鐘初始化模塊、時(shí)鐘工作模塊、時(shí)鐘設(shè)置模塊、鬧鐘設(shè)置模塊、閏年的月份天數(shù)判斷模塊、數(shù)碼管顯示模塊、鬧鐘鈴聲模塊及其它的設(shè)置模塊。程序使
2、用8個(gè)輸入分別與8個(gè)按鍵連接,用按鍵8對(duì)應(yīng)時(shí)鐘工作狀態(tài)(work_state),當(dāng)work_state為0時(shí),時(shí)鐘正常工作,當(dāng)work_state為1時(shí),進(jìn)入時(shí)鐘設(shè)置狀態(tài)。按鍵7對(duì)應(yīng)輸入端口display_set控制時(shí)鐘顯示狀態(tài)(display_state),每按2次(用于產(chǎn)生上升沿觸發(fā))則數(shù)碼管的輸出不同。Display_state與work_state相結(jié)合使用,以區(qū)分設(shè)置的參數(shù)。按鍵64對(duì)應(yīng)輸入個(gè)腳in_set,該參數(shù)共有三位,用以表示三個(gè)狀態(tài):state_yorh (設(shè)置年或小時(shí))、state_morm(設(shè)置月份或分鐘)、 state_dors(設(shè)置日期或秒鐘)。按鍵32對(duì)應(yīng)數(shù)值設(shè)置端
3、口up各down。Up用于產(chǎn)生上升沿觸發(fā),當(dāng)down為0時(shí),則每一個(gè)上升沿產(chǎn)生時(shí),相應(yīng)的參數(shù)加1,當(dāng)down為1時(shí),則每一個(gè)上升沿產(chǎn)生時(shí),相應(yīng)的參數(shù)減1。按鍵1與輸入端口clock_on相連,用于鬧鐘的開(kāi)與關(guān),當(dāng) clock_on為1時(shí)開(kāi)鬧鐘,否則關(guān)鬧鐘。揚(yáng)聲器與輸出端口speaker相連,用于輸出鬧鐘鈴聲。附錄:源程序一、 電子琴:module piano(in,clk_6MHz,clk_4Hz,song,speaker); input in,clk_6MHz,clk_4Hz,song; output speaker; reg speaker; reg7:0 state; reg song_
4、on; wire6:0 in; reg3:0 high,med,low; reg13:0 divider,origin; reg7:0 counter; reg out; wire carry; reg20:0 i; parameter zero=8b0000_0000, one=8b0000_0001, two=8b0000_0010, three=8b0000_0100, four=8b0000_1000, five=8b0001_0000, six=8b0010_0000, seven=8b0100_0000; initial begin song_on=0; end always (p
5、osedge song) begin song_on=song_on; end always (posedge clk_6MHz) begin if(song_on) speaker=out; else begin case(in) zero:begin speaker=0; i=11451) begin speaker=!speaker; i=0; end else i=10204) begin speaker=!speaker; i=0; end else i=9091) begin speaker=!speaker; i=0; end else i=8596) begin speaker
6、=!speaker; i=0; end else i=7653) begin speaker=!speaker; i=0; end else i=6818) begin speaker=!speaker; i=0; end else i=6073) begin speaker=!speaker; i=0; end else i=i+1; end default:begin speaker=0; i=0; end endcase end end assign carry=(divider=16383); always (posedge clk_6MHz) begin if(carry) divi
7、der=origin; else divider=divider+1; end always (posedge carry) begin out=out; /2 分頻產(chǎn)生方波信號(hào) end always (posedge clk_4Hz) begin case(high,med,low) /分頻比預(yù)置 b1: origin=7281; b1: origin=8730; b0: origin=9565; b1: origin=10310; b0: origin=10647; b0: origin=11272; b0: origin=11831; b0: origin=12556; b0: orig
8、in=12974; b0: origin=13516; b0: origin=16383; endcase end always (posedge clk_4Hz) begin if(counter=63) counter=0; /計(jì)時(shí),以實(shí)現(xiàn)循環(huán)演奏 else counter=counter+1; case(counter) /記譜 0: high,med,low=b1; /低音“3” 1: high,med,low=b1; /持續(xù)4 個(gè)時(shí)鐘節(jié)拍 2: high,med,low=b1; 3: high,med,low=b1; 4: high,med,low=b1; /低音“5” 5: hig
9、h,med,low=b1; /發(fā)3 個(gè)時(shí)鐘節(jié)拍 6: high,med,low=b1; 7: high,med,low=b0; /低音“6” 8: high,med,low=b0; /中音“1” 9: high,med,low=b0; /發(fā)3 個(gè)時(shí)鐘節(jié)拍 10: high,med,low=b0; 11: high,med,low=b0; /中音“2” 12: high,med,low=b0; /低音“6” 13: high,med,low=b0; 14: high,med,low=b1; 15: high,med,low=b1; 16: high,med,low=b0; /中音“5” 17:
10、high,med,low=b0; /發(fā)3 個(gè)時(shí)鐘節(jié)拍 18: high,med,low=b0; 19: high,med,low=b0; /高音“1” 20: high,med,low=b0; 21: high,med,low=b0; 22: high,med,low=b0; 23: high,med,low=b0; 24: high,med,low=b0; /中音“2” 25: high,med,low=b0; /持續(xù)11 個(gè)時(shí)鐘節(jié)拍 26: high,med,low=b0; 27: high,med,low=b0; 28: high,med,low=b0; 29: high,med,low
11、=b0; 30: high,med,low=b0; 31: high,med,low=b0; 32: high,med,low=b0; 33: high,med,low=b0; 34: high,med,low=b0; 35: high,med,low=b0; /中音“3” 36: high,med,low=b1; /低音“7” 37: high,med,low=b1; 38: high,med,low=b0; /低音“6” 39: high,med,low=b0; 40: high,med,low=b1; /低音“5” 41: high,med,low=b1; 42: high,med,lo
12、w=b1; 43: high,med,low=b0; /低音“6” 44: high,med,low=b0; /中音“1” 45: high,med,low=b0; 46: high,med,low=b0; /中音“2” 47: high,med,low=b0; 48: high,med,low=b1; /低音“3” 49: high,med,low=b1; 50: high,med,low=b0; /中音“1” 51: high,med,low=b0; 52: high,med,low=b0; 53: high,med,low=b1; /低音“5” 54: high,med,low=b0; 55: high,med,low=b0; /中音“1” 56: high,med,lo
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2026年有限空間作業(yè)安全生產(chǎn)管理制度考核辦法含答案
- 2026年人工智能體育分析認(rèn)證考試題含答案
- 機(jī)械前沿技術(shù)
- 2026年劇本殺運(yùn)營(yíng)公司劇本道具采購(gòu)管理制度
- 河南省南陽(yáng)市2025-2026學(xué)年高三上學(xué)期1月期末考試政治試題(含答案)
- 中醫(yī)養(yǎng)生與保健方法
- 2025年教育培訓(xùn)行業(yè)個(gè)性化學(xué)習(xí)方案創(chuàng)新報(bào)告
- 柏鄉(xiāng)輔警面試題目及答案
- 2025-2026學(xué)年廣東深圳實(shí)驗(yàn)學(xué)校七年級(jí)(上)期中考英語(yǔ)試題含答案
- 傳染病病例登記制度
- 北京通州產(chǎn)業(yè)服務(wù)有限公司招聘?jìng)淇碱}庫(kù)必考題
- 2026南水北調(diào)東線山東干線有限責(zé)任公司人才招聘8人筆試模擬試題及答案解析
- 伊利實(shí)業(yè)集團(tuán)招聘筆試題庫(kù)2026
- 2026年基金從業(yè)資格證考試題庫(kù)500道含答案(完整版)
- 動(dòng)量守恒定律(教學(xué)設(shè)計(jì))-2025-2026學(xué)年高二物理上冊(cè)人教版選擇性必修第一冊(cè)
- 網(wǎng)絡(luò)素養(yǎng)與自律主題班會(huì)
- 波形護(hù)欄工程施工組織設(shè)計(jì)方案
- 非靜脈曲張性上消化道出血管理指南解讀課件
- 內(nèi)窺鏡護(hù)理不良事件分析與防范措施
- 2025年《電信業(yè)務(wù)投訴處理》知識(shí)考試題庫(kù)及答案解析
- 術(shù)后惡心嘔吐(PONV)診療指南解讀
評(píng)論
0/150
提交評(píng)論