数字逻辑电路入门:从晶体管到逻辑门

2024-01-06 11:52

本文主要是介绍数字逻辑电路入门:从晶体管到逻辑门,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

数字逻辑电路入门:从晶体管到逻辑门

这是数字逻辑电路中最基础的部分。但是并非那么容易理解。

1、晶体管

  1. mosfet:场效应晶体管,是电压控制元件。
  2. cmos:是指由mos管构成的门级电路通常是互补的。
  3. BJT:一种三极管,是电流控制元件,用来放大电流,功耗大于mos管。
  4. nmos:衬底是p型半导体,源极和漏极是n型掺杂区域。适合用来导通低电压,不适合导通高电压。
  5. pmos:和nmos相反,衬底是n型半导体,源极和漏极是p型掺杂区域。适合用来导通高电压,不适合导通低电压。
  6. pmos用在上拉网络,nmos用在下拉网络。

2、逻辑门

互补传导规则:nmos串联,pmos必须并联;nmos并联,pmos必须串联。保证上拉网络和下拉网络不会同时导通,即不出现短路。

  1. 非门:输入a,输出y,消耗2个晶体管
    1. 一个pmos,栅极接a,源极接vcc,漏极接y
    2. 一个nmos,栅极接a,源级接y,漏极接gnd
    3. 分析,a=1,mos的栅极上表面聚集正电荷,下表面聚集负电荷。pmos衬底是n型半导体,本身有自由电子,因此源极和漏极仍然断开。nmos衬底是p型半导体,本身有自由空穴,聚集负电荷之后,源极和漏极接通,因此y=0。
  2. 与门:消耗6个晶体管
    1. 一个与非门
    2. 级联一个非门
  3. 或门:消耗6个晶体管
    1. 一个或非门
    2. 级联一个非门
  4. 或非门:消耗4个晶体管
    1. 两个pmos串联,栅极接a,b,源极接vcc,漏极接y
    2. 两个nmos并联,栅极接a,b,源极接vcc,漏极接y
    3. 分析,a=0,b=0,pmos均导通,nmos均断开,y=1;a、b有一个为1,下拉网络导通,上拉网络断开,y=0
  5. 与非门:消耗4个晶体管
    1. 两个pmos并联,栅极接a,b,源极接vcc,漏极接y
    2. 两个nmos串联,栅极接a,b,源极接vcc,漏极接y
    3. 分析,a=1,b=1,pmos均断开,nmos均导通,y=0;a、b有一个为0,下拉网络断开,上拉网络导通,y=1
  6. 异或门:
    1. 实现方式两种,一个使用10个晶体管,一个使用12个晶体管
    2. 参考:COMS门电路的设计及其优化–以异或门为例
  7. 同或门
  8. 三态门

3、卡诺图化简

以下图为例:

image-20240104222749508
  1. 画出卡诺图,注意格雷码序;
  2. 画圈:
    1. 从大到小画圈,16格、8格、4格、2格、1格;
    2. 每个圈都要圈住1,最终圈住所有1;
    3. 可环绕画圈。
  3. 写出SOP(sum-of-products)
    1. 每个圈代表一个product,读法是“相异相消”;
    2. 将所有product相加;
    3. Y = b+c+a;(按照红、绿、蓝的顺序写的product)
  4. 补充:“相异相消”
    1. 比如 Y = A B + A B ˉ = A ( B + B ˉ ) = A Y = AB+A \bar B = A(B+\bar B) = A Y=AB+ABˉ=A(B+Bˉ)=A
    2. B + B ˉ = 1 B+\bar B =1 B+Bˉ=1恒成立;
    3. 圈中变量相异的,则无需管,相同的如实记录。
    4. 比如红圈,c相异,a相异,b相同且为1,则记录为b。

另一个例子:

image-20240104224105776
  1. 画圈
  2. 读SOP
    1. 红: b ˉ c ˉ \bar b \bar c bˉcˉ
    2. 绿: a ˉ d ˉ \bar a \bar d aˉdˉ
    3. 粉: a c d a cd acd
    4. 蓝: b c d bcd bcd
    5. Y = b ˉ c ˉ + a ˉ d ˉ + a c d + b c d Y= \bar b \bar c+\bar a \bar d+a cd+bcd Y=bˉcˉ+aˉdˉ+acd+bcd

可以想到:

  1. 圈1则是SOP
  2. 圈0则是POS
  3. 因此,谁少圈谁。
  4. 注意,圈0写出POS之后取反,利用布尔代数则得到圈0的POS。

4、复用器

使用逻辑门可以搭建一个复用器

  1. Y = D 0 S ˉ + D 1 S Y=D_0 \bar S + D_1 S Y=D0Sˉ+D1S
  2. 两个与门、一个非门、一个或门
  3. 优化:减少晶体管, Y = D 0 S ˉ + D 1 S = ( D ˉ 0 + S ) ( D 1 S ) ˉ Y = D_0 \bar S + D_1 S = (\bar D_0+S)\bar {(D_1S)} Y=D0Sˉ+D1S=(Dˉ0+S)(D1S)ˉ
  4. 一个与非门、一个与门、一个或门、一个非门

这篇关于数字逻辑电路入门:从晶体管到逻辑门的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/576270

相关文章

从入门到精通MySQL联合查询

《从入门到精通MySQL联合查询》:本文主要介绍从入门到精通MySQL联合查询,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下... 目录摘要1. 多表联合查询时mysql内部原理2. 内连接3. 外连接4. 自连接5. 子查询6. 合并查询7. 插入查询结果摘要前面我们学习了数据库设计时要满

从入门到精通C++11 <chrono> 库特性

《从入门到精通C++11<chrono>库特性》chrono库是C++11中一个非常强大和实用的库,它为时间处理提供了丰富的功能和类型安全的接口,通过本文的介绍,我们了解了chrono库的基本概念... 目录一、引言1.1 为什么需要<chrono>库1.2<chrono>库的基本概念二、时间段(Durat

解析C++11 static_assert及与Boost库的关联从入门到精通

《解析C++11static_assert及与Boost库的关联从入门到精通》static_assert是C++中强大的编译时验证工具,它能够在编译阶段拦截不符合预期的类型或值,增强代码的健壮性,通... 目录一、背景知识:传统断言方法的局限性1.1 assert宏1.2 #error指令1.3 第三方解决

从入门到精通MySQL 数据库索引(实战案例)

《从入门到精通MySQL数据库索引(实战案例)》索引是数据库的目录,提升查询速度,主要类型包括BTree、Hash、全文、空间索引,需根据场景选择,建议用于高频查询、关联字段、排序等,避免重复率高或... 目录一、索引是什么?能干嘛?核心作用:二、索引的 4 种主要类型(附通俗例子)1. BTree 索引(

Redis 配置文件使用建议redis.conf 从入门到实战

《Redis配置文件使用建议redis.conf从入门到实战》Redis配置方式包括配置文件、命令行参数、运行时CONFIG命令,支持动态修改参数及持久化,常用项涉及端口、绑定、内存策略等,版本8... 目录一、Redis.conf 是什么?二、命令行方式传参(适用于测试)三、运行时动态修改配置(不重启服务

MySQL DQL从入门到精通

《MySQLDQL从入门到精通》通过DQL,我们可以从数据库中检索出所需的数据,进行各种复杂的数据分析和处理,本文将深入探讨MySQLDQL的各个方面,帮助你全面掌握这一重要技能,感兴趣的朋友跟随小... 目录一、DQL 基础:SELECT 语句入门二、数据过滤:WHERE 子句的使用三、结果排序:ORDE

Python中OpenCV与Matplotlib的图像操作入门指南

《Python中OpenCV与Matplotlib的图像操作入门指南》:本文主要介绍Python中OpenCV与Matplotlib的图像操作指南,本文通过实例代码给大家介绍的非常详细,对大家的学... 目录一、环境准备二、图像的基本操作1. 图像读取、显示与保存 使用OpenCV操作2. 像素级操作3.

POI从入门到实战轻松完成EasyExcel使用及Excel导入导出功能

《POI从入门到实战轻松完成EasyExcel使用及Excel导入导出功能》ApachePOI是一个流行的Java库,用于处理MicrosoftOffice格式文件,提供丰富API来创建、读取和修改O... 目录前言:Apache POIEasyPoiEasyExcel一、EasyExcel1.1、核心特性

Python中模块graphviz使用入门

《Python中模块graphviz使用入门》graphviz是一个用于创建和操作图形的Python库,本文主要介绍了Python中模块graphviz使用入门,具有一定的参考价值,感兴趣的可以了解一... 目录1.安装2. 基本用法2.1 输出图像格式2.2 图像style设置2.3 属性2.4 子图和聚

Python实现特殊字符判断并去掉非字母和数字的特殊字符

《Python实现特殊字符判断并去掉非字母和数字的特殊字符》在Python中,可以通过多种方法来判断字符串中是否包含非字母、数字的特殊字符,并将这些特殊字符去掉,本文为大家整理了一些常用的,希望对大家... 目录1. 使用正则表达式判断字符串中是否包含特殊字符去掉字符串中的特殊字符2. 使用 str.isa