91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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

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

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

FPGA學(xué)習(xí)系列:38. 電子琴的設(shè)計

FPGA學(xué)習(xí)交流 ? 2018-09-26 12:51 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

設(shè)計背景:

FPGA的學(xué)習(xí)也算是是一種日積月累才能有成就的過程,前面我們學(xué)習(xí)了各個模塊,各個芯片的配置等等,之后筆者通過兩個簡單的例子來讓大家去系統(tǒng)的學(xué)習(xí)和認識FPGA。所學(xué)習(xí)的電子琴設(shè)計也算是一次簡單的各個模塊的聯(lián)系調(diào)用的一個過程,對以后工作中的學(xué)習(xí)有很好的幫助。

設(shè)計原理:

本次的設(shè)計主要是通過控制ps2鍵盤來使蜂鳴器發(fā)出哆來咪法嗦拉西7種音來,音符主要又高低音等等,本設(shè)計只選擇發(fā)出高音的多來咪發(fā)嗦啦西。本設(shè)計中還用到了VGA的設(shè)計,通過VGA來在顯示屏上畫出如下圖的黑白的電子琴鍵:


當(dāng)按下多來咪發(fā)嗦啦西時,對應(yīng)的鍵值變顏色表示按下,不變色表示不按下,顏色自己可以調(diào)節(jié),但是琴的按鍵必須為黑白色來顯示出來。

當(dāng)按下按鍵的時候,蜂鳴器來鳴響對應(yīng)時間的音符,本設(shè)計蜂鳴器響的時間為0.25S一個音符持續(xù)的時間。

本次設(shè)計用到的PS2和VGA的設(shè)計原理筆者在這里就不過多的介紹了,不明白的可以翻看前面發(fā)的文檔內(nèi)容。

在本設(shè)計中介紹蜂鳴器的使用和各音符發(fā)聲的頻率大小。本設(shè)計用的是無源蜂鳴器,原理圖如下:

image.png

由于FPGA的驅(qū)動能力不夠,我們添加了一個三極管來驅(qū)動這個無源蜂鳴器,而無源蜂鳴器的主要特點是內(nèi)部不帶振蕩源,所以如果使用直流信號是無法使無源蜂鳴器鳴叫的,必須使用方波去驅(qū)動它。

現(xiàn)在我們明白了,只要往蜂鳴器發(fā)送一定頻率的方波,就可以使得蜂鳴器發(fā)出聲音,然后現(xiàn)在的問題是,我們究竟要往蜂鳴器發(fā)送什么頻率的方波信號呢?具體的頻率可以查看下圖:

現(xiàn)在我們知道了如何讓蜂鳴器響起,又知道發(fā)送什么頻率可以讓蜂鳴器響起什么的聲音,所以我相信我們已經(jīng)有能力讓蜂鳴器響起我們需要的音樂了。

image.png


設(shè)計架構(gòu)圖:

image.png

設(shè)計代碼:

頂層模塊

0modulemusic_ps2(clk,rst_n,hs,vs,r_g_b,ps2_clk,ps2_data,beep);

1

2 inputclk;

3 inputrst_n;

4

5 outpuths;

6 outputvs;

7 output[7:0]r_g_b;

8 outputbeep;

9

10 inputps2_clk;

11 inputps2_data;

12

13 wireflag;

14 wire[7:0]data,data_n;

15 wireclk_1M;

16

17

18 frenp frep_dut(

19 .clk(clk),

20 .rst_n(rst_n),

21 .clk_1M(clk_1M)

22 );

23

24 ps2_rec rec_dut(

25 .clk(clk_1M),

26 .rst_n(rst_n),

27 .ps2_clk(ps2_clk),

28 .ps2_data(ps2_data),

29 .flag(flag),

30 .data(data)

31 );

32

33 decode decode_dut(

34 .clk(clk_1M),

35 .rst_n(rst_n),

36 .flag(flag),

37 .data(data),

38 .data_n(data_n)

39 );

40

41 music music_dut(

42 .clk(clk_1M),

43 .rst_n(rst_n),

44 .data_n(data_n),

45 .beep(beep)

46 );

47

48 vga vga_dut(

49 .clk(clk),

50 .rst_n(rst_n),

51 .hs(hs),

52 .vs(vs),

53 .r_g_b(r_g_b),

54 .data_n(data_n)

55 );

56

57endmodule

蜂鳴器模塊

0modulemusic(clk,rst_n,data_n,beep);端口列表

1

2 inputclk;

3 inputrst_n;

4 input[7:0]data_n;//輸入的鍵值

5 outputregbeep;//蜂鳴器

6

7 reg[10:0]music_data;

8 wire[10:0]data;

9

10 always@(posedgeclk)

11 if(!rst_n)

12 begin

13 music_data <=0;

14 end

15 else

16 case(data_n)

17 1 : music_data <=478;//蜂鳴器的高音1

18 2 : music_data <=425; //蜂鳴器的高音2

19 3 : music_data <=379; //蜂鳴器的高音3

20 4 : music_data <=358;//蜂鳴器的高音4

21

22 5 : music_data <=319; //蜂鳴器的高音5

23 6 : music_data <=284; //蜂鳴器的高音6

24 7 : music_data <=253; //蜂鳴器的高音7

25 default:music_data <=0;

26 endcase

27

28

29 reg[20:0]count,cnt;

30

31 always@(posedgeclk)

32 if(!rst_n &&!data_n)

33 begin

34 count <=0;

35 end

36 else

37 if(count <250_000-1)

38 begin

39 count <=count +1;

40 end

41 else

42 begin

43 count <=0;

44 end

45

46 //計數(shù)0.25S的時間

47 assigndata =(count ==250_000-1)?music_data :data;

48

49 always@(posedgeclk)

50 if(!rst_n)

51 begin

52 cnt <=1;

53 beep <=0;

54 end

55 else

56 if(data ==0)//控制蜂鳴器不響

57 begin

58 cnt <=1;

59 beep <=0;

60 end

61 elseif(cnt <data)//計數(shù)對應(yīng)的頻率

62 begin

63 cnt <=cnt +1;

64 end

65 else

66 begin

67 cnt <=1;//蜂鳴器響

68 beep <=~beep;

69 end

70

71

72

73endmodule

代碼驗證正確無誤,筆者在這邊就不過多的驗證,大家可以自主的補全代碼,后續(xù)代碼會在論壇中發(fā)出來供大家參考個學(xué)習(xí)。


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

    關(guān)注

    1660

    文章

    22415

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

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

    Atmel AT17LV系列FPGA配置EEPROM的全面解析

    Atmel AT17LV系列FPGA配置EEPROM的全面解析 在FPGA設(shè)計領(lǐng)域,配置存儲器的選擇至關(guān)重要。Atmel的AT17LV系列FPGA
    的頭像 發(fā)表于 02-27 16:15 ?180次閱讀

    STWLC38JRM:高效15W無線充電接收器的卓越之選

    STWLC38JRM:高效15W無線充電接收器的卓越之選 引言 在當(dāng)今電子設(shè)備飛速發(fā)展的時代,無線充電技術(shù)憑借其便捷性和創(chuàng)新性,成為了電子工程師們關(guān)注的焦點。STMicroelectronics推出
    的頭像 發(fā)表于 01-28 09:35 ?153次閱讀

    僅3.8cm!視覺 AI 迷你核心板:ICORE-1126BQ38

    ICORE-1126BQ38采用Rockchip四核AI視覺處理器RV1126B,集成3TOPSNPU,支持主流AI大模型和深度學(xué)習(xí)框架。內(nèi)置12MISP、8MPAI-ISP、集成多種算法加速器
    的頭像 發(fā)表于 01-20 17:03 ?1315次閱讀
    僅3.8cm!視覺 AI 迷你核心板:ICORE-1126BQ<b class='flag-5'>38</b>

    Altera Agilex 5系列FPGA與SoC產(chǎn)品榮膺2025全球電子成就獎

    近日,全球 FPGA 創(chuàng)新技術(shù)領(lǐng)導(dǎo)者 Altera 的 Agilex 5 FPGA 與 SoC 產(chǎn)品系列,榮獲 2025 年 AspenCore 全球電子成就獎(WEAA)的處理器/D
    的頭像 發(fā)表于 12-03 11:13 ?2485次閱讀

    DAC38RF83技術(shù)手冊

    DAC38RFxx 是一系列高性能、雙通道/單通道、14 位、9GSPS 射頻采樣數(shù)模轉(zhuǎn)換器 (DAC),能夠合成 0 至 4.5 GHz 的寬帶信號。高動態(tài)范圍使 DAC38RFxx 系列
    的頭像 發(fā)表于 11-10 09:37 ?505次閱讀
    DAC<b class='flag-5'>38</b>RF83技術(shù)手冊

    DAC38RF93技術(shù)手冊

    DAC38RFxx 是一系列高性能、雙通道/單通道、14 位、9GSPS 射頻采樣數(shù)模轉(zhuǎn)換器 (DAC),能夠合成 0 至 4.5 GHz 的寬帶信號。高動態(tài)范圍使 DAC38RFxx 系列
    的頭像 發(fā)表于 11-07 15:34 ?570次閱讀
    DAC<b class='flag-5'>38</b>RF93技術(shù)手冊

    DAC38RF80 系列技術(shù)文檔核心總結(jié)

    DAC38RFxx 是一系列高性能、雙通道/單通道、14 位、9GSPS 射頻采樣數(shù)模轉(zhuǎn)換器 (DAC),能夠合成 0 至 4.5 GHz 的寬帶信號。高動態(tài)范圍使 DAC38RFxx 系列
    的頭像 發(fā)表于 11-07 14:47 ?661次閱讀
    DAC<b class='flag-5'>38</b>RF80 <b class='flag-5'>系列</b>技術(shù)文檔核心總結(jié)

    DAC38RF86技術(shù)手冊

    DAC38RF86/96 是一系列高性能、雙通道、14 位、9GSPS、射頻采樣數(shù)模轉(zhuǎn)換器 (DAC),能夠合成 0 至 4.5 GHz 的寬帶信號。DAC38RF87/97 還是一個高性能、雙通道
    的頭像 發(fā)表于 11-07 14:18 ?683次閱讀
    DAC<b class='flag-5'>38</b>RF86技術(shù)手冊

    SkyOne? Ultra 2.0 前端模塊,用于 FDD/TDD LTE 頻段 7、30、38、40、41 skyworksinc

    電子發(fā)燒友網(wǎng)為你提供()SkyOne? Ultra 2.0 前端模塊,用于 FDD/TDD LTE 頻段 7、30、38、40、41相關(guān)產(chǎn)品參數(shù)、數(shù)據(jù)手冊,更有SkyOne? Ultra 2.0
    發(fā)表于 10-21 18:30
    SkyOne? Ultra 2.0 前端模塊,用于 FDD/TDD LTE 頻段 7、30、<b class='flag-5'>38</b>、40、41 skyworksinc

    FPGA在機器學(xué)習(xí)中的具體應(yīng)用

    隨著機器學(xué)習(xí)和人工智能技術(shù)的迅猛發(fā)展,傳統(tǒng)的中央處理單元(CPU)和圖形處理單元(GPU)已經(jīng)無法滿足高效處理大規(guī)模數(shù)據(jù)和復(fù)雜模型的需求。FPGA(現(xiàn)場可編程門陣列)作為一種靈活且高效的硬件加速平臺
    的頭像 發(fā)表于 07-16 15:34 ?2902次閱讀

    有沒有做電子樂器,電子琴,智能樂器軟硬件開發(fā)的團隊?

    有個項目想找個靠譜團隊合作~
    發(fā)表于 05-21 16:23

    小眼睛科技泰坦系列FPGA新品亮相2024紫光同創(chuàng)FPGA研討會武漢站&amp;amp;南京站

    近日,2024紫光同創(chuàng)FPGA研討會武漢站、南京站圓滿召開。小眼睛科技攜全新泰坦、盤古系列產(chǎn)品及多款FPGA解決方案亮相紫光同創(chuàng)研討會現(xiàn)場。本次研討會現(xiàn)場火爆,來自通信、工業(yè)控制、醫(yī)療、汽車、消費
    的頭像 發(fā)表于 04-14 09:57 ?981次閱讀
    小眼睛科技泰坦<b class='flag-5'>系列</b>等<b class='flag-5'>FPGA</b>新品亮相2024紫光同創(chuàng)<b class='flag-5'>FPGA</b>研討會武漢站&amp;amp;南京站

    Altera Agilex 7 M系列FPGA正式量產(chǎn)出貨

    近日,全球 FPGA 創(chuàng)新技術(shù)領(lǐng)導(dǎo)者 Altera 宣布, Agilex 7 M 系列 FPGA 正式量產(chǎn)出貨,這是現(xiàn)階段業(yè)界領(lǐng)先的集成高帶寬存儲器,并支持 DDR5 和 LPDDR5 存儲器技術(shù)
    的頭像 發(fā)表于 04-10 11:00 ?1444次閱讀

    進群免費領(lǐng)FPGA學(xué)習(xí)資料!數(shù)字信號處理、傅里葉變換與FPGA開發(fā)等

    進群免費領(lǐng)FPGA學(xué)習(xí)資料啦!小編整理了數(shù)字信號處理、傅里葉變換與FPGA開發(fā)等FPGA必看資料,需要的小伙伴可以加小助手(微信:elecfans123)或進 QQ 群:9135011
    發(fā)表于 04-07 16:41

    DS28E38 adi

    電子發(fā)燒友網(wǎng)為你提供ADI(ADI)DS28E38相關(guān)產(chǎn)品參數(shù)、數(shù)據(jù)手冊,更有DS28E38的引腳圖、接線圖、封裝手冊、中文資料、英文資料,DS28E38真值表,DS28E
    發(fā)表于 03-10 18:55
    DS28E<b class='flag-5'>38</b> adi