乘法器——booth編碼

来源:https://www.cnblogs.com/wangkai2019/archive/2019/07/06/11144367.html
-Advertisement-
Play Games

博主最近在學習加法器、乘法器、IEEE的浮點數標準,作為數字IC的基礎。當看到booth編碼的乘法器時,對booth編碼不是很理解,然後在網上找各種理解,終於豁然開朗。現將一個很好的解釋分享給大家,希望能對大家有所幫助。 首先,看看這幾個公式: 可以證明的是,這三個公式是相等的,一個有符號的二進位數 ...


    博主最近在學習加法器、乘法器、IEEE的浮點數標準,作為數字IC的基礎。當看到booth編碼的乘法器時,對booth編碼不是很理解,然後在網上找各種理解,終於豁然開朗。現將一個很好的解釋分享給大家,希望能對大家有所幫助。

    首先,看看這幾個公式:

    可以證明的是,這三個公式是相等的,一個有符號的二進位數的補碼用公式1來表示,可以等價地寫成公式2和公式3。

    布斯編碼可以減少部分積的數目(即減少乘數中1的個數),用來計算有符號乘法,提高乘法運算的速度。

    

    如上圖所示為二進位乘法的過程,也是符合我們正常計算時的邏輯,我們假設有一個8位乘數(Multiplier),它的二進位值為0111_1110,它將產生6行非零的部分積,因為它有6個非零值(即1)。如果我們利用公式2將這個二進位值改為1000_00-10,其中低四位中的-1表示負1,可以證明兩個值是相等的。可以這樣簡單理解,那就是現在原值得末尾加輔助位0,變為0111_1110_0,然後利用低位減去高位,即得到1000_00-10。這樣一變換可以減少0的數目,從而減少加的次數,我們只需相加兩個部分積,但是終的加法器必須也能執行減法。這種形式的變換稱為booth encoding(即booth編碼),它保證了在每兩個連續位中最多只有一個是1或-1。部分積數目的減少意味著相加次數的減少,從而加快了運算速度(並減少了面積)。從形式上來說,這一變換相當於把乘數變換成一個四進位形式。

    最經常使用的是改進的booth編碼。乘數按三位一組進行劃分,相互重疊一位。其實就是把公式1重寫為公式3。每一組按下表編碼,並形成一個部分積。

    再考慮前面提及的8位二進位數0111_1110。從msb到lsb,可以把它分為三位一組首尾重疊的四組:01(1),11(1),11(1),10(0),末尾補了一個輔助位0。根據上表編碼得到:10(2),00(0),00(0),-10(-2),或者表示為1000_000-10,這與前面得到結果是一樣的。這時,乘2就是移位。所以布斯演算法僅涉及加法,減法和移位操作。     這樣一來就很容易理解了。       
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Struts2 配置文件result元素 作用:為動作指定結果視圖 name屬性:邏輯視圖的名稱,對應著動作方法的返回值。預設值是success type屬性:結果類型,指的就是用什麼方式轉到定義的頁面,預設是dispatcher result中type的取值有四種類型 | | | | | : | ...
  • >>,>>>,<<的用法: * <<:左移 左邊最高位丟棄,右邊補齊0 * >>:右移 最高位是0,左邊補齊0;最高為是1,左邊補齊1 * >>>:無符號右移 無論最高位是0還是1,左邊補齊0 代碼: 結果: ...
  • 源文件的字元編碼 預設情況下,Python 源碼文件以 UTF 8 編碼方式處理。如果不使用預設編碼,要聲明文件所使用的編碼,源碼文件的 第一行要寫成特殊的註釋。語法如下所示: 其中 encoding 可以是 Python 支持的任意一種 codecs。比如,要聲明使用 Windows gbk 編碼 ...
  • 記錄 2019-07-06: Python是一門解釋型語言,擁有許多強大的標準庫,是完全面向對象語言 如果需要一段關鍵代碼運行得更快或者希望某些演算法不公開,可以把部分程式用c或c++編寫,然後在python程式中使用它們 缺點: 運行速度慢 國內市場較小 中文資料匱乏 中文資料匱乏 可以使用任意文本 ...
  • 一、 偏函數 二、 1.定義:參數固定的函數,相當於一個有特定參數的函數體。 2.格式:functools.partial(函數,固定參數) 3.返回值:把一個函數某些參數固定,返回一個新的函數。 二、zip函數 1.定義:把兩個可迭代的內容生成一個可以迭代的tuple元素組成的內容 2.格式:zi ...
  • 9-7 管理員: 管理員是一種特殊的用戶。編寫一個名為Admin的類,並讓它繼承練習9-3或者9-5的User類。添加一個名為privileges的屬性,用於存儲一個由字元串(如"can add post"、"can delete post"、"can ban user"等)組成的列表。編寫一個名為 ...
  • 開發環境: Windows操作系統開發工具:MyEclipse/Eclipse + JDK+ Tomcat + MySQL 資料庫項目截圖: 獲取源碼請聯繫博主-Q:782827013 ...
  • 世界是物質的,物質是運動的,運動是有規律的,規律是可以被認識的 二項式反演 $$ g_n=\sum_{i=0}^n \binom{n}if_i\Rightarrow f_n=\sum_{i=0}^n( 1)^{n i}\binom{n}ig_i $$ 證明如下 $$ \begin{aligned} ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...