一、定义:
1、上拉就是将不确定的信号通过一个电阻嵌位在高电平!电阻同时起限流作用!下拉同理
 
2、上拉是对器件注入电流,下拉是输出电流
 
3、弱强只是上拉电阻的阻值不同,没有什么严格区分
 
4、对于非集电极(或漏极)开路输出型电路(如普通门电路)提升电流和电压的能力是有限的,上拉电阻的功能主要是为集电极开路输出型电路输出电流通道。
 
二、拉电阻作用:
1、一般作单键触发使用时,如果 IC 本身没有内接电阻,为了使单键维持在不被触发的状态或是触发后回到原状态,必须在 IC 外部另接一电阻。
 
2、数字电路有三种状态:高电平、低电平、和高阻状态,有些应用场合不希望出现高阻状态,可以通过上拉电阻或下拉电阻的方式使处于稳定状态,具体视设计要求而定!
 
3、一般说的是 I/O 端口,有的可以设置,有的不可以设置,有的是内置,有的是需要外接,I/O 端口的输出类似与一个三极管的 C,当 C 接通过一个电阻和电源连接在一起的时候,该电阻成为上 C 拉电阻,也就是说,如果该端口正常时为高电平,C 通过一个电阻和地连接在一起的时候,该电阻称为下拉电阻,使该端口平时为低电平,其作用主要是确保某端口常态时有确定电平:用法示例:当一个接有上拉电阻的端口设为输入状态时,他的常态就为高电平,用于检测低电平的输入。
 
4、上拉电阻是用来解决总线驱动能力不足时提供电流的。一般说法是拉电流,下拉电阻是用来吸收电流的,也就是我们通常所说的灌电流。
 
5、接电阻就是为了防止输入端悬空。
 
6、减弱外部电流对芯片产生的干扰。
 
7、保护 cmos 内的保护二极管,一般电流不大于 10mA。
 
8、通过上拉或下拉来增加或减小驱动电流。
 
9、改变电平的电位,常用在 TTL-CMOS 匹配。
 
10、在引脚悬空时有确定的状态。
 
11、增加高电平输出时的驱动能力。
 
12、为 OC 门提供电流。
 
三、上拉电阻应用原则:
1、当 TTL 电路驱动 COMS 电路时,若 TTL 电路输出的高电平低于 COMS 电路的最低高电平(一般为 3.5V),这时就需要在 TTL 的输出端接上拉电阻,以提高输出高电平值。注:此时上拉电阻连接的电压值应不低于 CMOS 电路的最低高电压,同时又要考虑 TTL 电路方电流(如某端口最大输入或输出电流)的影响。
 
2、OC 门电路必须加上拉电阻,才能使用。
 
3、为加大输出引脚的驱动能力,有的单片机管脚上也常使用上拉电阻。
 
4、在 COMS 芯片上,为了防止静电造成损坏,不用的管脚不能悬空,一般接上拉电阻产生降低输入阻抗,提供泄荷通路。
 
5、芯片的管脚加上拉电阻来提高输出电平,从而提高芯片输入信号的噪声容限增强抗干扰能力。
 
6、提高总线的抗电磁干扰能力,管脚悬空就比较容易接受外界的电磁干扰。
 
7、长线传输中电阻不匹配容易引起反射波干扰,加上下拉电阻是电阻匹配,有效的抑制反射波干扰。
 
8、在数字电路中不用的输入脚都要接固定电平,通过 1k 电阻接高电平或接地。
 
四、上拉电阻阻值选择原则:
1、从节约功耗及芯片的灌电流能力考虑应当足够大;电阻大,电流小。
 
2、从确保足够的驱动电流考虑应当足够小;电阻小,电流大。
 
3、对于高速电路,过大的上拉电阻可能边沿变平缓。综合考虑以上三点,通常在 1k 到 10k 之间选取。对下拉电阻也有类似道理。
 
对上拉电阻和下拉电阻的选择应结合开关管特性和下级电路的输入特性进行设定,主要需要考虑以下几个因素:
 
1、驱动能力与功耗的平衡。以上拉电阻为例,一般地说,上拉电阻越小,驱动能力越强,
但功耗越大,设计是应注意两者之间的均衡。
 
2、下级电路的驱动需求。同样以上拉电阻为例,当输出高电平时,开关管断开,上拉电阻
应适当选择以能够向下级电路提供足够的电流。
 
3、高低电平的设定。不同电路的高低电平的门槛电平会有不同,电阻应适当设定以确保能
输出正确的电平。以上拉电阻为例,当输出低电平时,开关管导通,上拉电阻和开关管导通电阻分压值应确保在零电平门槛之下。
 
4、频率特性。以上拉电阻为例,上拉电阻和开关管漏源级之间的电容和下级电路之间的输入电容会形成 RC 延迟,电阻越大,延迟越大。上拉电阻的设定应考虑电路在这方面的需求。
 
在集成电路中,吸电流、拉电流输出和灌电流输出是一个很重要的概念。拉电流:拉即泄,主动输出电流,是从输出口输出电流。
 
关于电阻的参数不能一概而定,要看电路其他参数而定,比如通常用在输入脚上的上拉电阻如果是为了抬高峰峰值,就要参考该引脚的内阻来定电阻值的!
 
1、一般 LED 的电流有几个 mA 就够了,最大不超过 20mA,根据这个你就应该可以算出上拉电阻值来了。(5-0.7)/20mA=200ohm,差不多吧,保险起见考虑到功耗问题就用 1~2k 左右的电阻较为合适以上 4 图表示的是上拉电阻从 220 欧到 5.1K 欧的 LED 亮度变化,当然实际还是有出入的,我们实验室开发板 10K 的电阻依然把 LED 点的很亮~(当然根据我们的计算电阻最小不要小于 200 欧姆,否则电流太大)
 
2、对于驱动光耦合器,如果是高电位有效,即耦合器输入端接端口和地之间,那么和 LED 的情况是一样的;如果是低电位有效,即耦合器输入端接端口和 VCC 之间,那么除了要串接一个 1~4.7k 之间的电阻以外,同时上拉电阻的阻值就可以用的特别大,用 100k~500K 之间的都行,当然用 10K 的也可以,但是考虑到省电问题,没有必要用那么小的。
 
3、对于驱动晶体管,又分为 PNP 和 NPN 管两种情况:
 
a、对于 NPN:毫无疑问 NPN 管是高电平有效的,因此上拉电阻的阻值用 2K~20K 之间的。具体的大小还要看晶体管的集电极接的是什么负载,对于 LED 类负载,由于发管电流很小,因此上拉电阻的阻值可以用 20k 的,但是对于管子的集电极为继电器负载时,由于集电极电流大,因此上拉电阻的阻值最好不要大于 4.7K,有时候甚至用 2K 的。
 
b、对于 PNP 管,毫无疑问 PNP 管是低电平有效的,因此上拉电阻的阻值用 100K 以上的就行了,且管子的基极必须串接一个 1~10K 的电阻,阻值的大小要看管子集电极的负载是什么,对于 LED 类负载,由于发光电流很小,因此基极串接的电阻的阻值可以用 20k 的,但是对于管子的集电极为继电器负载时,由于集电极电流大,因此基极电阻的阻值最好不要大于 4.7K。
 
4、对于驱动 TTL 集成电路,上拉电阻的阻值要用 1~10K 之间的,有时候电阻太大的话是拉不起来的,因此用的阻值较小。但是对于 CMOS 集成电路,上拉电阻的阻值就可以用的很大,一般不小于 20K,通常用 100K 的,实际上对于 CMOS 电路,上拉电阻的阻值用 1M 的也是可以的,但是要注意上拉电阻的阻值太大的时候,容易产生干扰,尤其是线路板的线条很长的时候,这种干扰更严重,这种情况下上拉电阻不宜过大,一般要小于 100K,有时候甚至小于 10K。
 
5、关于 I2C 的上拉电阻:因为 I2C 接口的输出端是漏极开路或集电极开路,所以必须在接口外接上拉。上拉电阻的取值和 I2C 总线的频率有关,工作在 standard mode 时,其典型值为 10K。在 FAST mode 时,为减少时钟上升时间,满足上升时间的要求,一般为 1K。电阻的大小对时序有一定影响,对信号的上升时间和下降时间也有影响。总之一般情况下电压在 5V 时选 4.7K 左右,3.3V 在 3.3K 左右 . 这样可加大驱动能力和加速边沿的翻转
 
I2C 上拉电阻确定有一个计算公式:
 
Rmin={Vdd(min)-o.4V}/3mA
 
Rmax=(T/0.874) *c, T=1us 100KHz, T=0.3us 400KHz
 
C 是 Bus capacitance
 
五、下面通过场效应管的漏极开路门电路的例子简单说明一下上拉电阻:
TTL 电平标准:
 
输出 L: <0.8V ; H:>2.4V。 
 
输入 L: <1.2V ; H:>2.0V。 
 
CMOS 电平标准:
 
输出 L: <0.1*Vcc ; H:>0.9*Vcc。 
 
输入 L: <0.3*Vcc ; H:>0.7*Vcc。 
 
注:管子导通或截止可以理解为单片机的软件对端口置 1 或 0.
 
(1)如果没有上拉电阻(10k),将 5V 电源直接与场效应管相连。
 
当管子导通时,管子等效一电阻,大小为 1k 左右,因此 5v 电压全部加在此等效电阻上,输出端 Vout=5v。
当管子截止时,管子等效电阻很高,可以理解为无穷大,因此 5v 的电压也全部加在此等效电阻上,Vout=5v。在这两种情况下,输出都为高电平,没有低电平。
 
(2)如果有上拉电阻(10k),将 5v 电源通过此上拉电阻与与场效应管相连。
 
当管子导通时,管子等效一电阻,大小为 1k 左右,与上拉电阻串联,输出端电压为加在此等效电阻上的电压,其大小为 Vout = 5v * 管子等效电阻 /(上拉电阻+管子等效电阻)=5v * 1/(10+1)=低电平。
 
当管子截止时,管子等效电阻很高,可以理解为无穷大,其与上拉电阻串联,输出端电压为加在此等效电阻上的电压,其大小为 Vout = 5v * 管子等效电阻 /(上拉电阻+管子等效电阻)=5v*无穷大 /(无穷大+1)=高电平。
 
 
在前极输出高电平时,Vout 输出电流,U 为高电平。有两种情况:
 
A、当 I0 >= I1 + I2
   
这种情况下,RL1 和 RL2 两个负载不会通过 R 取电流,因此对 R 阻值大小要求不高,通常 4.7 KΩ<R<20KΩ即可。此时 R 的主要作用是增加信号可靠性,当 Vout 连线松动或脱落时,抑制电路产生鞭状天线效应吸收干扰。
 
B、当 I0 < I1 + I2
   
I0 +I= I1 + I2
   
U=VCC-IR
   
U>=VHmin
   
由以上三式计算得出,R<=(VCC- VHmin)/I
   
其中,I0、I1、I2 都是可以从 datasheet 查到的,I 就可以求出来,VHmin 也是可以查到的。
 
当前极 Vout 输出低电平时,各管脚均为灌电流,则:
   
I’= I1’ + I2’ +I0’
   
U’ =VCC-I’ R
   
U’ <=VLmax
 
以上三式可以得出:R>=(VCC- VLmax)/I’
 
由以上二式计算出 R 的上限值和下限值,从中取一个较靠近中间状态的值即可。注意,如果负载的个数大小不定的话,要按照最坏的情况计算,上限值要按负载最多的时候计算,下限值要按负载最少的计算。
 
另一种选择方式是基于功耗的考虑。根据电路实际应用时,输出信号状态的频率或时间比选择。若信号 Vout 长期处于低电平,宜选择下拉电阻;若长期处于高电平,宜选择上拉电阻。为的是静态电流小。
 
 
六、灌电流
灌电流:灌即充,被动输入电流,是从输出端口流入吸电流:
 
吸则是主动吸入电流,是从输入端口流入吸电流和灌电流就是从芯片外电路通过引脚流入芯片内的电流,区别在于吸收电流是主动的,从芯片输入端流入的叫吸收电流。灌入电流是被动的,从输出端流入的叫灌入电流。拉电流是数字电路输出高电平给负载提供的输出电流,灌电流时输出低电平是外部给数字电路的输入电流,它们实际就是输入、输出电流能力。
 
吸收电流是对输入端(输入端吸入)而言的;而拉电流(输出端流出)和灌电流(输出端被灌入)是相对输出端而言的。