初級模擬電路:3-9 BJT三極體實現邏輯門

来源:https://www.cnblogs.com/initcircuit/archive/2019/11/06/11803007.html
-Advertisement-
Play Games

回到目錄 BJT晶體管可以實現邏輯門,事實上,在場效應管被髮明用於集成電路以前,各種邏輯門晶元中的電路就是用BJT晶體管來實現的。最早人們使用二極體與BJT組合來實現邏輯門,這個稱為二極體-晶體管邏輯(Diode-Transistor Logic),簡稱DTL;後來改進為全部用BJT晶體管來實現邏輯 ...


回到目錄

      BJT晶體管可以實現邏輯門,事實上,在場效應管被髮明用於集成電路以前,各種邏輯門晶元中的電路就是用BJT晶體管來實現的。最早人們使用二極體與BJT組合來實現邏輯門,這個稱為二極體-晶體管邏輯(Diode-Transistor Logic),簡稱DTL;後來改進為全部用BJT晶體管來實現邏輯門,這個稱為晶體管-晶體管邏輯(Transistor-Transistor Logic),簡稱TTL。早期廣為人知的TTL電平,就是基於這種用BJT晶體管實現的邏輯門。TTL的優點是響應速度比較快,缺點是功耗較大,所以後來基本被功耗更低的場效應管取代。

      我們這裡僅介紹幾個最簡單的邏輯門的實現:反相器、或非門、與非門,主要是用來說明概念。除非你是專門設計邏輯門晶元的,否則一般平時也不太可能用分立元件去搭建邏輯門,還有就是在電路修補中萬不得已時應急用一下。

      在前面幾小節的放大電路中,BJT都工作於放大區。而在用BJT實現邏輯門時,卻要使用飽和區和截止區,而不能使用放大區,這個是邏輯電路和放大電路的在使用BJT時的根本區別。

 

 

1. 反相器

      反相器的功能很簡單,就是將輸入的電平反向輸出:輸入高電平-輸出低電平、輸入低電平-輸出高電平。下麵是反相器的實現電路:

圖3-9.01 

      在作邏輯分析時,我們一般做如下近似:將VBE的導通值視為0.7V,將典型值為0.1V~0.3V的飽和電壓VCEsat近似視為0.2V。

      下麵是反相器電路工作原理:

      • 當vi輸入為0V時,BJT截止,vo輸出電平即為5V。

      • 當vo輸入為5V時,BJT的CE端導通,產生電流IC,若此時BJT處於飽和區,VCE近似可視為飽和電壓0.2V,此時輸出電平vo即為0.2V。

      這個電路的關鍵點在於如何選取合適的RB與RC值以確保BJT在導通時確實工作於飽和區。一般可以先根據外部負載條件定出一個符合輸出阻抗要求的RC,然後再根據飽和要求,用公式原理推算出能使BJT進入臨界飽和的大致RB值,再加點餘量。最後驗證在高電平輸入條件下,BJT在此RB配置下是否確實工作於飽和區。具體方法可參看下麵的案例:

案例3-9-1:在下圖的反相器中,已知β=100,根據外部負載匹配,要求RC為500Ω,請選取合適的RB值使反相器能正常工作。

圖3-09.a1 

 

解:先計算出,在這個RC條件下,當BJT處於臨界飽和時的ICsat值:

      然後計算臨界飽和時的IBsat值(當處於臨界飽和時,β仍視為100):

      使此IBsat成立的RBsat為:

      為使BJT進入更深度的飽和,我們選取RB為比RBsat更小的值,假定選取為20kΩ。

 

驗證:當RB為20kΩ時,IB為:

      此時電流放大倍數為:

      可知,在此RB值下,BJT導通時確實處於飽和區,原假設正確。

 

 

2. 或非門

      或非門BJT實現電路和輸入輸出真值表如下圖所示(其中1表示高電平,0表示低電平):

圖3-9.02 

      • 當vi1和vi2輸入都為0V時,晶體管Q1和Q2都截止,vo輸出電平為5V。

      • 當vi1輸入為5V、vi2輸入為0V時,晶體管Q1導通、Q2截止,由於Q1工作於飽和區,VCE1=VCEsat≈0.2V,故vo輸出電平為0.2V。

      • 同樣的,當vi2輸入為5V時、vi1輸入為0V時,晶體管Q2導通、Q1截止,VCE2=VCEsat≈0.2V,故vo輸出電平為0.2V。

      • 當vi1和vi2都輸入0V時,晶體管Q1和Q2都導通,VCE1=VCE2=VCEsat≈0.2V,故vo輸出電平為0.2V。

      關於如何配置RB1、RB2、RC的值使BJT晶體管工作於飽和區,這個和前面反相器的計算方法是類似的,可參看上面的案例3-9-1。

 

 

3. 與非門

      與非門的實現需要二極體的配合,其實現電路和真值表如下圖所示:

圖3-9.03 

      • 當vi1和vi2輸入中有任一個為0V時,輸入二極體Di1或Di2就會導通,此時v1點的電壓即為二極體的導通閾值電壓0.7V。這個電壓無法使右邊的D1和Q1都導通,因為若要使D1和Q1的發射結都導通,vB點的電壓起碼需要0.7V,而v1點的電壓需要0.7+0.7=1.4V。而在v1只有0.7V的情況下,右邊的D1和Q1的發射結每個只能分到0.35V左右的電壓,故D1和Q1都截止,輸出vo保持5V的高電平。

      • 當vi1和vi2輸入全都為5V時,輸入二極體Di1和Di2全都截止,此時VCC會使R1、D1和Q1形成通路,vB點的電壓為0.7V,v1點的電壓為1.4V。由於Q1導通時工作於飽和狀態,故輸出vo為VCEsat約等於0.2V。

      至於如何配置R1、RB、RC,原理和前面是一樣的:根據輸出阻抗匹配先定RC,然後計算為使Q1進入飽和區的R1,具體方法可參看前面的案例3-9-1。

      順便提一下,RB稱作下拉電阻,其主要作用是當Q1從飽和狀態切換到截止狀態時,使基區過剩的少數載流子有個渠道流掉,以減少切換開關時間。這個稍微瞭解一下即可,一般選一個大約的幾千歐的阻值就差不多了,在要求不高的場合下,即使不用RB也問題不大。

 

 

4. 關於TTL

      在上面電路中,我們用DTL(二極體-晶體管邏輯)實現了與非門。如果你想知道傳說中的TTL(晶體管-晶體管邏輯)到底是什麼樣的,那麼本小節可以稍稍滿足一下你的好奇心。

      我們仍以上面的與非門為例,假設先去掉Di2,那麼,在圖中兩個背靠背的二極體Di1和D1,其實可以看成是一個NPN型三極體,如下圖所示:

圖3-9.04 

      我們前面說過,在分立元器件的BJT晶體管中,C極和E極的摻雜濃度是不對稱的,所以分立元器件中不能像上圖這樣等效,但是在製作集成電路晶元時,是可以在片上做成像上面右圖那樣的對稱管的。

      而且,在集成電路製作時還可以加入多個發射極,如下圖所示:

圖3-9.05 

      如此,就實現了一個二輸入與非門的TTL電路。如果要實現n個輸入的與非門,還可以加入n多個發射極。當然,這種多發射極的BJT晶體管只能在集成電路晶元中實現,分立元器件的話是沒有這種器件的。

     

回到目錄

 

 

( end of 3-9)



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

-Advertisement-
Play Games
更多相關文章
  • 總結下麵幾點 1.與下位機的連接儘量保持長連接,每次用到的時候去連接的話,過一段時間速度明顯下降,什麼問題並沒有找到 2.C#中的BitConverter 類可以非常方便的在位元組與其他類型之間進行轉換 3.周期性操作使用while迴圈,避免使用timer定時器 4.操作一些標誌位的操作,儘量放到一個 ...
  • VS2017打開項目時提示未能正確載入CSharpPackage包, 可以使用 devenv命令工具來解決,操作如下 打開vs2017開發人員命令提示符(請使用管理員身份運行),如圖 敲入 devenv /setup 回車執行 最後重啟vs解決。 有的再重啟vs時還會出現 未能正確載入“Micros ...
  • KindEditor使用JavaScript編寫,可以無縫的於Java、.NET、PHP、ASP等程式接合。 KindEditor非常適合在CMS、商城、論壇、博客、Wiki、電子郵件等互聯網應用上使用,2006年7月首次發佈2.0以來,KindEditor依靠出色的用戶體驗和領先的技術不斷擴大編輯 ...
  • 一、簡介 方法可以稱為函數,函數又可以稱為方法,方法主要的作用是將一堆代碼進行重用的一種機制,避免太多的冗餘的代碼,還有方便後期維護。 二、語法 函數的語法: 描述: public:訪問修飾符,公開的; static:靜態的; 返回值類型:比如int 、string 、double等的類型,如果不寫 ...
  • 上一篇隨筆記錄到RabbitMQ的安裝,安裝完成,我們就開始使用吧。 RabbitMQ簡介 AMQP,即Advanced Message Queuing Protocol,高級消息隊列協議,是應用層協議的一個開放標準,為面向消息的中間件設計。消息中間件主要用於組件之間的解耦,消息的發送者無需知道消息 ...
  • Ubuntu下經常遇到無法用快捷鍵關閉觸控板的情況,博主的電腦安裝Ubuntu18.04後便出現了該問題。 解決辦法: 首先查看輸入設備的id,命令行輸入: xinput ,如圖,博主的TouchPad的id=17,電腦不同id各異, 知道了id=17之後,就可以通過命令關閉/開啟觸控板, 關閉命令 ...
  • 文本處理工具awk awk:(Aho, Weinberger, Kernighan,)報告生成器,格式化文本輸出 有多種版本:New awk(nawk),GNU awk( gawk) @[toc] gawk:模式掃描和處理語言 awk語言 ⽣成需要的測試數據: [root@magedu ~] hea ...
  • Shell內置命令、外部命令、別名、函數、保留關鍵字的優先順序 在Shell中,有5種可調用的東西:別名(alias)、函數(function)、shell保留關鍵字、shell內置命令、外部命令。 如果它們同名了,那麼優先調用誰呢?可使用 查看。 內置命令、別名、函數、外部命令 $ alias ki ...
一周排行
    -Advertisement-
    Play Games
  • 前言 插件化的需求主要源於對軟體架構靈活性的追求,特別是在開發大型、複雜或需要不斷更新的軟體系統時,插件化可以提高軟體系統的可擴展性、可定製性、隔離性、安全性、可維護性、模塊化、易於升級和更新以及支持第三方開發等方面的能力,從而滿足不斷變化的業務需求和技術挑戰。 一、插件化探索 在WPF中我們想要開 ...
  • 歡迎ReaLTaiizor是一個用戶友好的、以設計為中心的.NET WinForms項目控制項庫,包含廣泛的組件。您可以使用不同的主題選項對項目進行個性化設置,並自定義用戶控制項,以使您的應用程式更加專業。 項目地址:https://github.com/Taiizor/ReaLTaiizor 步驟1: ...
  • EDP是一套集組織架構,許可權框架【功能許可權,操作許可權,數據訪問許可權,WebApi許可權】,自動化日誌,動態Interface,WebApi管理等基礎功能於一體的,基於.net的企業應用開發框架。通過友好的編碼方式實現數據行、列許可權的管控。 ...
  • Channel 是乾什麼的 The System.Threading.Channels namespace provides a set of synchronization data structures for passing data between producers and consume ...
  • efcore如何優雅的實現按年分庫按月分表 介紹 本文ShardinfCore版本 本期主角: ShardingCore 一款ef-core下高性能、輕量級針對分表分庫讀寫分離的解決方案,具有零依賴、零學習成本、零業務代碼入侵適配 距離上次發文.net相關的已經有很久了,期間一直在從事java相關的 ...
  • 前言 Spacesniffer 是一個免費的文件掃描工具,通過使用樹狀圖可視化佈局,可以立即瞭解大文件夾的位置,幫助用戶處理找到這些文件夾 當前系統C盤空間 清理後系統C盤空間 下載 Spacesniffer 下載地址:https://spacesniffer.en.softonic.com/dow ...
  • EDP是一套集組織架構,許可權框架【功能許可權,操作許可權,數據訪問許可權,WebApi許可權】,自動化日誌,動態Interface,WebApi管理等基礎功能於一體的,基於.net的企業應用開發框架。通過友好的編碼方式實現數據行、列許可權的管控。 ...
  • 一、ReZero簡介 ReZero是一款.NET中間件 : 全網唯一開源界面操作就能生成API , 可以集成到任何.NET6+ API項目,無破壞性,也可讓非.NET用戶使用exe文件 免費開源:MIT最寬鬆協議 , 一直從事開源事業十年,一直堅持開源 1.1 純ReZero開發 適合.Net Co ...
  • 一:背景 1. 講故事 停了一個月沒有更新文章了,主要是忙於寫 C#內功修煉系列的PPT,現在基本上接近尾聲,可以回頭繼續更新這段時間分析dump的一些事故報告,有朋友微信上找到我,說他們的系統出現了大量的http超時,程式不響應處理了,讓我幫忙看下怎麼回事,dump也抓到了。 二:WinDbg分析 ...
  • 開始做項目管理了(本人3年java,來到這邊之後真沒想到...),天天開會溝通整理需求,他們講話的時候忙裡偷閑整理一下常用的方法,其實語言還是有共通性的,基本上看到方法名就大概能猜出來用法。出去打水的時候看到外面太陽好好,真想在外面坐著曬太陽,回來的時候好兄弟三年前送給我的鍵盤D鍵不靈了,在打"等待 ...