电子技术——晶体管尺寸

news2025/1/11 6:00:34

电子技术——晶体管尺寸

在本节我们介绍关于IC设计的一个重要的参数晶体管尺寸(例如长度和长宽比)。我们首先考虑MOS反相器。

反相器尺寸

为了说明 ( W / L ) (W/L) (W/L) 的尺寸大小以及 ( W / L ) p (W/L)_p (W/L)p ( W / L ) n (W/L)_n (W/L)n 的比例问题对于MOS的性能问题。

  1. 为了缩小尺寸,所有沟道的长度在工艺允许的情况下应该设计成一样以来缩小IC尺寸。
  2. 对于给定的反相器,如果我们希望严格减小最小面积,则 ( W / L ) n (W/L)_n (W/L)n 通常选择为 1 到 1.5 。对于 ( W / L ) p (W/L)_p (W/L)p 的选择相对于 ( W / L ) n (W/L)_n (W/L)n 会影响噪声容限和 t P L H t_{PLH} tPLH 。设计师应该优化 Q P Q_P QP Q N Q_N QN 的匹配问题,我们之前知道越好的匹配就会造成IC硅面积的浪费而且还会增加有效的容抗 C C C ,所以尽管 t P L H = t P H L t_{PLH} = t_{PHL} tPLH=tPHL 此时两个值均大于没有完美匹配的情况。因此选择 ( W / L ) p = ( W / L ) n (W/L)_p = (W/L)_n (W/L)p=(W/L)n 是一种选择,但是 ( W / L ) p = 2 ( W / L ) n (W/L)_p = 2(W/L)_n (W/L)p=2(W/L)n 通常是在权衡利弊的情况下的一种更优的选择。
  3. 解决完 ( W / L ) p (W/L)_p (W/L)p ( W / L ) n (W/L)_n (W/L)n 的比例匹配问题,我们需要选择 ( W / L ) n (W/L)_n (W/L)n 来减小 t P t_P tP 从而提高数字系统的响应时间。增加 ( W / L ) n (W/L)_n (W/L)n 就会增加MOS的面积,进而导致电容 C C C 的增加。为了更精确的说明,我们将 C C C 表示为 C = C i n t + C e x t C = C_{int} + C_{ext} C=Cint+Cext 其中 C i n t C_{int} Cint 是MOS管的内部电容,而 C e x t C_{ext} Cext 是MOS的外部电容,包括线间电容和负载输入容抗。

增加MOS的长宽比 W / L W/L W/L 为最小尺寸反相器的 S S S 倍,会导致:

C = S C i n t 0 + C e x t C = SC_{int0} + C_{ext} C=SCint0+Cext

这里 C i n t 0 C_{int0} Cint0 是最小尺寸反相器的内部电容。

现在,若我们使用RC方法计算 t P t_P tP ,等效的电阻为:

R e q = 1 2 ( R N + R P ) R_{eq} = \frac{1}{2}(R_N + R_P) Req=21(RN+RP)

那么:

t P = 0.69 R e q C t_P = 0.69R_{eq}C tP=0.69ReqC

若我们定义最小尺寸反相器的等效电阻为 R e q 0 R_{eq0} Req0 ,增加MOS的长宽比 W / L W/L W/L 为最小尺寸反相器的 S S S 倍会导致:

R e q = R e q 0 / S R_{eq} = R_{eq0} / S Req=Req0/S

带入所有的表达式可以得到:

t P = 0.69 ( R e q 0 S ) ( S C i n t 0 + C e x t ) = 0.69 ( R e q 0 C i n t 0 + 1 S R e q 0 C e x t ) t_P = 0.69(\frac{R_{eq0}}{S}) (SC_{int0} + C_{ext}) = 0.69(R_{eq0}C_{int0} + \frac{1}{S} R_{eq0}C_{ext}) tP=0.69(SReq0)(SCint0+Cext)=0.69(Req0Cint0+S1Req0Cext)

这说明放大比例 S S S 并不会影响内部电容对于 t P t_P tP 的影响,然而,会降低外部电容的分量值。我们可以使用上式来选择一个合适的 S S S 来将 t P t_P tP 保持在最小值,同时要注意增加 S S S 会增加MOS的硅面积。

CMOS逻辑门中的晶体管尺寸

当决定使用CMOS电路的时候,唯一的重要的事情就是决定所有器件的 W / L W/L W/L 比例。最好情况下,我们必须让CMOS逻辑门电路的电流驱动能力必须等于相同的反相器的电流驱动能力。对于基本反相器,我们记 ( W / L ) n = n (W/L)_n = n (W/L)n=n 并且 ( W / L ) p = p (W/L)_p = p (W/L)p=p ,这里 n = 1 ≃ 1.5 n = 1 \simeq 1.5 n=11.5 ,对于匹配设计 p = ( μ n / μ p ) n p = (\mu_n/\mu_p) n p=(μn/μp)n 通常 p = 2 n p = 2n p=2n 对于最小尺寸设计 p = n p = n p=n 。因此,我们在设计PDN的时候,我们必须选择每一个MOS的长宽比让其PDN的泄放电流能力至少等于一个 W / L = n W/L = n W/L=n 的NMOS的泄放电流能力。同样的对于PUN来说,我们必须选择每一个MOS的长宽比让其PUN的提供电流能力至少等于一个 W / L = p W/L = p W/L=p 的PMOS的提供电流能力。这保证了逻辑门电路延迟的最坏情况——等同于基本反相器。

基于上述的讨论,我们必须强调“最坏情况”是什么。这意味着,我们在选择晶体管尺寸的时候,我们需要找到一种输入的组合方式使得最低输出电流等于基本反相器的电流。在我们讨论具体的例子之前,我们首先要解决如何决定多个MOS管组合逻辑门电路的电流的驱动能力,也就是找到等价单个MOS W / L W/L W/L 的值。首先我们考虑MOS串联和并联时候的情况。

基于 R o n R_{on} Ron W / L W/L W/L 反比的事实,若多个MOS管串联,每个MOS的宽长比分别为 ( W / L ) 1 , ( W / L ) 2 , … (W/L)_1,(W/L)_2,\ldots (W/L)1,(W/L)2, 等价的电阻为:

R s e r i e s = R N 1 + R N 2 + … = c o n s t ( W / L ) 1 + c o n s t ( W / L ) 2 + … = c o n s t [ 1 ( W / L ) 1 + 1 ( W / L ) 2 + … ] = c o n s t ( W / L ) e q R_{series} = R_{N1} + R_{N2} + \ldots = \frac{const}{(W/L)_1} + \frac{const}{(W/L)_2} + \ldots = const[\frac{1}{(W/L)_1} + \frac{1}{(W/L)_2} + \ldots] = \frac{const}{(W/L)_{eq}} Rseries=RN1+RN2+=(W/L)1const+(W/L)2const+=const[(W/L)11+(W/L)21+]=(W/L)eqconst

那么等价的长宽比为:

( W / L ) e q = 1 1 ( W / L ) 1 + 1 ( W / L ) 2 + … (W/L)_{eq} = \frac{1}{\frac{1}{(W/L)_1} + \frac{1}{(W/L)_2} + \ldots} (W/L)eq=(W/L)11+(W/L)21+1

同样的方法,能够导出并联时候的情况:

( W / L ) e q = ( W / L ) 1 + ( W / L ) 2 + … (W/L)_{eq} = (W/L)_1 + (W/L)_2 + \ldots (W/L)eq=(W/L)1+(W/L)2+

现在,考虑下图的一个四变量输入的或非门:

或非门
其中对于PDN来说,最坏的情况(最小电流)是四个NMOS只有一个导通,因此,我们对于每一个NMOS都选择 W / L = n W/L = n W/L=n 即可。对于PUN来说最坏的情况(也是唯一的情况)是四个PMOS均导通,根据串联MOS公式,我们让每个PMOS的 W / L = 4 p W/L = 4p W/L=4p 即可。

另外一个例子是四变量输入的与非门,如图:

与非门
需要注意的是,通常 p p p n n n 的2到3倍,因此或非门的体积要大于与非门的体积。基于此原因,设计师更愿意使用NAND来实现组合逻辑。

扇入扇出效应与传播延迟

每一个CMOS们电路的每一个输入变量都需要提供给两个晶体管,一个NMOS和一个PMOS。相比于另外一种只需要一种输入链接到一个晶体管的MOS逻辑门电路来说,例如伪NMOS逻辑门电路,额外的晶体管不仅增加了芯片的面积,而且还增加总有效阻抗从而增加了传播延迟。增加MOS的宽长比可以在一定程度上补偿这种传播延迟。特别的,通过增大元件的尺寸,我们可以保留电流驱动能力,然而却增加了总有效容抗。因此 t P t_P tP 仍然会受到扇入数的影响,扇入数指的实际的接入晶体管数量,例如NAND的扇入数是4。如果需要更多的输入变量,明智的电路设计者会通过巧妙的变换或者设计让输入变量的个数不超过4个。这通常意味着需要增加联级的数量,这同样会增加传播延迟。然而,相比之下,这种方法的传播延迟增加总比之前未优化的情况要小。

同样的,对于扇出数来说,其直接关系到负载的容抗,因此扇出数越大,则负载的容抗越大,传播延迟越大。

因此尽管CMOS有许多优点,当扇入和扇出数增加的时候,同样会受到电路复杂性的影响,导致芯片面积和传播延迟的增加。

驱动大电容

在一些特别的CMOS电路中,需要驱动较大的容性负载。例如,在IC中较长的走线,或是需要通过片外PCB走线的信号,此时的容抗要比普通情况下的容抗大上百倍。

我们需要一种在可以忍受的传播延迟下驱动大容抗的方法。下图展示了一个标准反相器驱动电容 C L C_L CL 的演示图:

电容驱动

上面的模型,我们简单的总结为从输入端看过去容值为 C C C 等效电容为 R R R 的CR模型,因为 C L C_L CL 为负载容抗,根据估算:

t P = τ = C L R t_P = \tau = C_LR tP=τ=CLR

延迟将会非常大。

一种解决方法是,放大反相器的体积,如图:

增大体积
这里的反相器是参考反相器的 m m m 倍,此时输出电阻将会是 R / m R/m R/m ,此时的传播延迟为:

τ = C L ( R / m ) \tau = C_L(R/m) τ=CL(R/m)

传播延迟将会降低 m m m 倍,但是这并不是一个方法。观察到输入的容抗变成了原来的 m m m 倍,这需要一个更大的反相器来驱动他,并没从根本上解决问题,而是把负担交给了其他反相器。

但是,这种方法给我们了一种解决问题的思路,即使用联级反相器,如图:

联级反相器
观察上图,我们发现反相器的尺寸成等比数列,我们发现每一级之间的传播延迟都为:

τ = x C R \tau = xCR τ=xCR

特别的,可以证明当满足:

τ n ≡ C L ( R x n − 1 ) = x C R \tau_n \equiv C_L(\frac{R}{x^{n-1}}) = xCR τnCL(xn1R)=xCR

的时候,也就是:

x n = C L C x^n = \frac{C_L}{C} xn=CCL

整体延迟最小为:

t P = τ t o t a l = n x C R t_P = \tau_{total} = nxCR tP=τtotal=nxCR

问题是如何选定 x x x n n n 。在数学中可以证明,当 x = e ≃ 2.718 x = e \simeq 2.718 x=e2.718 的时候,传播延迟最小。实际上,在2.5-4之间都可以提升性能。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

CENTO OS上的网络安全工具(十八)ClickHouse及编程环境部署

这篇其实去年就写好了,孰知就在12月31日那一天打进决赛圈,一躺,二过年,三休假,四加班,居然到了三个月以后,才有机会将它发出来…… 一年也就四个季度不是,实在是光阴荏苒&#xff0c…

代码随想录|day6|哈希表篇-- 242.有效的字母异位词 、349. 两个数组的交集 、202. 快乐数、1. 两数之和

总链接https://docs.qq.com/doc/DUEtFSGdreWRuR2p4?u329948d2f0044f34b7cbe72503f0b572 242.有效的字母异位词 链接:代码随想录 class Solution { public:bool isAnagram(string s, string t) {//两种做法,一种是int f[26]的数组,一种是map /*第一种&a…

历史大讲堂:这是真·图形化 苹果系统历史回顾(上)

众所周知,米国有个非常牛掰的公司叫苹果,想必大家对这个logo不陌生吧。 目前已发布的苹果产品有iPhone、iPad、iPod等等,简直花样繁多,而且各种功能很好用,我的手机就是一部苹果iPhone X。 等一下,似乎扯远…

14个Python处理Excel的常用操作,非常好用

自从学了Python后就逼迫用Python来处理Excel,所有操作用Python实现。目的是巩固Python,与增强数据处理能力。 这也是我写这篇文章的初衷。废话不说了,直接进入正题。 数据是网上找到的销售数据,长这样: 一、关联公式:…

第十四届蓝桥杯第三期模拟赛 【python】

第十四届蓝桥杯第三期模拟赛 【python】 文章目录第十四届蓝桥杯第三期模拟赛 【python】✨最小的十六进制(python的16进制)❓️问题描述答案提交🧠思路🖥︎参考答案✨Excel的列(进制转化)❓️问题描述答案…

Java学习笔记 --- Tomcat

一、JavaWeb 的概念 JavaWeb 是指,所有通过 Java 语言编写可以通过浏览器访问的程序的总称,叫 JavaWeb。 JavaWeb是基于请求和响应来开发的。请求是指客户端给服务器发送数据,叫请求 Request。 响应是指服务器给客户端回传数据,叫…

【Pytorch】AutoGrad个人理解

前提知识:[Pytorch] 前向传播和反向传播示例_友人小A的博客-CSDN博客 目录 简介 叶子节点 Tensor AutoGrad Functions 简介 torch.autograd是PyTorch的自动微分引擎(自动求导),为神经网络训练提供动力。torch.autograd需要对…

线性表的合并

线性表的应用 线性表的合并 问题描述: 假设利用两个线性表La和Lb表示两个集合A和B,现要求一个新的集合AA∪B 即: La(7,5,3,11) Lb(2,6,3) A(7,8,3,11,2,6) 算法步骤(A既是参数,也是操作的结果) 依次…

全志V853芯片 Tina Linux下网络ADB内存泄露如何修复?

1.主题 Tina Linux 网络ADB内存泄露修复 2.问题背景 硬件:V853 软件:Tina4.0 Linux-4.9 背景:使用网络adb时,反复connect disconnect,会发生内存泄露的问题。 3.问题描述 3.1复现步骤 1、首先使能网络ADB功能。 …

Async注解使用和CompletableFuture注解获取返回值

举栗个现实问题: 需求:拉取 业务数据不能超过 5秒。 拉取第三方数据 ,分别需要拉取 A业务数据(需要2秒) 、拉取 B业务数据(需要2秒)、拉取 C业务数据(需要2秒) &#xff…

模电学习11 运算放大器学习入门

一、基本概念 运算放大器简称运放,是一种模拟电路实现的集成电路,可以对信号进行很高倍数的放大。一般有正相输入端、反相输入端、输出端口、正电源、负电源等接口。 运放可工作在饱和区、放大区,其中放大区极其陡峭,因为运放的放…

【深度学习】BERT变体—SpanBERT

SpanBERT出自Facebook,就是在BERT的基础上,针对预测spans of text的任务,在预训练阶段做了特定的优化,它可以用于span-based pretraining。这里的Span翻译为“片段”,表示一片连续的单词。SpanBERT最常用于需要预测文本…

c++11 标准模板(STL)(std::unordered_map)(四)

定义于头文件 <unordered_map> template< class Key, class T, class Hash std::hash<Key>, class KeyEqual std::equal_to<Key>, class Allocator std::allocator< std::pair<const Key, T> > > class unordered…

【3.6】链表、操作系统CPU是如何执行程序的、Redis数据类型及其应用

链表 题目题型203. 移除链表元素 - 力扣&#xff08;LeetCode&#xff09;辅助头节点解决移出head问题707. 设计链表 - 力扣&#xff08;LeetCode&#xff09;辅助头节点206. 反转链表 - 力扣&#xff08;LeetCode&#xff09;迭代 / 递归19. 删除链表的倒数第 N 个结点 - 力扣…

什么?年终奖多发1块钱竟要多缴9.6W的税

对于大多数的工薪阶级来说&#xff0c;目前现行的个人所得税适用于全年累计收入一次性税收优惠。 有可能有的人不理解一次性税收优惠是什么意思&#xff0c;所以这里我首先解释下什么是一次性税收优惠&#xff0c;然后在讲一下为什么明明公司多发了钱&#xff0c;到手反而会更…

Kotlin中的destructuring解构声明

开发中有时只是想分解一个包含多个字段的对象来初始化几个单独的变量。要实现这一点&#xff0c;可以使用Kotlin的解构声明。本文主要了解&#xff1a;“1、如何使用解构声明这种特性 2、底层是如何实现的 3、如何在你自己的类中实现它1、解构声明的使用解构声明&a…

hutool XML反序列化漏洞(CVE-2023-24162)

漏洞简介 Hutool 中的XmlUtil.readObjectFromXml方法直接封装调用XMLDecoder.readObject解析xml数据&#xff0c;当使用 readObjectFromXml 去处理恶意的 XML 字符串时会造成任意代码执行。 漏洞复现 我们在 maven 仓库中查找 Hutool ​https://mvnrepository.com/search?…

基于EB工具的TC3xx_MCAL配置开发01_WDG模块配置介绍

目录 1.概述2. WDG 配置2.1 General部分配置2.2 WdgSettingsConfig配置2.2.1 配置概述2.2.2 CPU WDG具体配置2.3 WdgDemEventParameterRefs3. WDG配置注意事项1.概述 本篇开始我们基于EB Tresos工具对英飞凌TC3xx系列MCU的MCAL开发进行介绍,结合项目经验对各MCAL外设的开发及…

C++回顾(七)—— 面向对象模型

7.1 静态成员变量和静态成员函数 7.1.1 静态成员变量 关键字 static 可以用于说明一个类的成员&#xff1b;静态成员提供了一个同类对象的共享机制&#xff1b;把一个类的成员说明为 static 时&#xff0c;这个类无论有多少个对象被创建&#xff0c;这些对象共享这个 static …

ubuntu C++调用python

普通 目录结构 main.py 等会用c调用func() #!/usr/bin/env python # _*_ coding:utf-8 _*_ import osdef func():print(hello world)if __name__ __main__:func()main.cpp 其中Py_SetPythonHome的路径是anaconda中环境的路径&#xff0c;最开始的L一定要加&#xff08;因为…