《FPGA全程進階---實戰演練》第十四章 蜂鳴器操作

来源:http://www.cnblogs.com/raymon-tec/archive/2016/03/21/5302028.html
-Advertisement-
Play Games

本實驗主要是實現蜂鳴器的操作,蜂鳴器的操作是非常簡單的,只有把簡單的事情做好,方可談其他複雜的事。本實驗部分會利用verilog一些巨集定義語句,其實在VGA實驗部分已經出現過,這裡為了鞏固,再次調用相關巨集定義命令,已達到最大化的可移植性,請讀者務必掌握這種用法,很實用。 談及蜂鳴器或者LED,多多少


1 基礎理論部分

  本實驗主要是實現蜂鳴器的操作,蜂鳴器的操作是非常簡單的,只有把簡單的事情做好,方可談其他複雜的事。本實驗部分會利用verilog一些巨集定義語句,其實在VGA實驗部分已經出現過,這裡為了鞏固,再次調用相關巨集定義命令,已達到最大化的可移植性,請讀者務必掌握這種用法,很實用。

談及蜂鳴器或者LED,多多少少會有一個概念,PWM(pulse  width  modulation),即脈寬調製,PWM的輸出只有高電平1和低電平0,PWM不斷重覆輸出周期T,高電平所占用的時間為t,則占空比 = t / T ;頻率 = 1 / T,如圖14.1所示。

wps94F6.tmp

圖14.1 PWM脈衝圖

2 Verilog代碼實現部分

  對於實現不同的占空比,可以去建立一個parameter模塊,用來定義不同的PWM脈衝信號。主要是從兩方面去定義,一個是占空比相同(這裡是占空比為50%),頻率不同,一個是頻率相同,不同的占空比。下麵是FM_param.v中的各參數的設置。

wps9507.tmp

上述是巨集定義個參數,分別定義了不同的占空比和頻率。

wps9508.tmp

上述是對定義的巨集參數具體執行的參數設置。

下麵是FM_PWM.v文件中的內容。

wps9518.tmp

24行調用參數文件,然後定義各巨集參數,

wps9519.tmp

此部分是執行巨集定義後的具體執行的內容。

3 Modelsim模擬部分

3.1 測試程式

wps952A.tmp

上述的測試程式很簡單,和之前的部分一樣。

3.2 模擬結果

圖14.2是占空比為50%,周期為40ms的情況。圖14.3是腳本文件的輸出,其他的模擬類似。

wps952B.tmp

圖14.2 模擬波形

wps953C.tmp

圖14.3 腳本輸出


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 我做的是登錄界面。用了JButton(按鈕),JComboBox(組合框),JOptionPane(提示面板),JPasswordField(密碼框),JTextField(文本框),用監聽器實現了事件相應。當輸入帳號和密碼都是123時候,提示登錄成功,否則登錄失敗! 還添加了java中的顏色和字體
  • scala如果你想實現像if ,while等類似的控制結構,根本沒有值要傳入花括弧{}直接的代碼里。要怎麼實現。 比如說,我們要實現一個斷言的控制結構,myAssert(), myAssert函數參考自帶參數和一個標示變數,如果標示位為false,則什麼都不做,如果為true則進行正常判斷。 下麵是
  • 用autohotkey腳本,調整常用按鍵,另外定義常用代碼塊為巨集。來實現快速輸入powershell腳本。
  • scala是一種函數式編程風格的語言,除了常見的if......else ,for ,while等傳統的流程式控制制結構,也可以自定義流程式控制制的控制結構。 再瞭解scala如何實現編寫新的流程結構,我們瞭解一下頭等函數的概念; scala的函數是頭等函數(first-class function).你不
  • 輸出為1
  • 一、順序結構(從上往下依次執行) 順序結構語法比較簡單,從上往下依次執行即可。 二、選擇結構(選擇性執行,如果....則.....) 1.if 語句 if語句,作用是根據判斷結果為真或假,選擇其中一個分支執行。 if (條件判斷,結果為布爾值){ 條件判斷為真時的執行語句(只能是一句語句,如果是多句
  • 迭代器模式,在不需要瞭解內部實現的前提下,遍歷一個聚合對象的內部元素。相比於傳統的編程模式,迭代器模式可以隱藏遍歷元素所需要的操作。 AllHacl.php index.php Hacl類相關內容參考數據對象映射模式。http://www.cnblogs.com/tianxintian22/p/52
  • (一)變數的命名及賦值: var=value (1)、其中var是變數名,value是變數的值。如果value不包含任何空白字元(空格),就不需要包含單引號或雙引號 (2)、var=value不同於var (空格)=(空格)value,前者是賦值操作,後者是相等操作 (3)、在變數名前加$或者$(v
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...