开漏输出、开集输出

开漏输出、开集输出

推挽输出:可以输出高,低电平,连接数字器件;

开漏输出:输出端相当于三极管的集电极. 要得到高电平状态需要上拉电阻才行. 适合于做电流型的驱动,其吸收电流的能力相对强(一般20ma以内).
推挽结构一般是指两个三极管分别受两互补信号的控制,总是在一个三极管导通的时候另一个截止.

我们先来说说集电极开路输出的结构。集电极开路输出的结构如图1所示,右边的那个三极管集电极什么都不接,所以叫做集电极开路(左边的三极管为反相之用,使输入为“0”时,输出也为“0”)。对于图1,当左端的输入为“0”时,前面的三极管截止(即集电极C跟发射极E之间相当于断开),所以5V电源通过1K电阻加到右边的三极管上,右边的三极管导通(即相当于一个开关闭合);当左端的输入为“1”时,前面的三极管导通,而后面的三极管截止(相当于开关断开)。

单片机IO口设置推挽和开漏的区别 - 冷水泡茶 - 冷水泡茶

我们将图1简化成图2的样子。图2中的开关受软件控制,“1”时断开,“0”时闭合。很明显可以看出,当开关闭合时,输出直接接地,所以输出电平为0。而当开关断开时,则输出端悬空了,即高阻态。这时电平状态未知,如果后面一个电阻负载(即使很轻的负载)到地,那么输出端的电平就被这个负载拉到低电平了,所以这个电路是不能输出高电平的。

再看图三。图三中那个1K的电阻即是上拉电阻。如果开关闭合,则有电流从1K电阻及开关上流过,但由于开关闭其它三个口带内部上拉),当我们要使用输入功能时,只要将输出口设置为1即可,这样就相当于那个开关断开,而对于P0口来说,就是高阻态了。

对于漏极开路(OD)输出,跟集电极开路输出是十分类似的。将上面的三极管换成场效应管即可。这样集电极就变成了漏极,OC就变成了OD,原理分析是一样的。

另一种输出结构是推挽输出。推挽输出的结构就是把上面的上拉电阻也换成一个开关,当要输出高电平时,上面的开关通,下面的开关断;而要输出低电平时,则刚好相反。比起OC或者OD来说,这样的推挽结构高、低电平驱动能力都很强。如果两个输出不同电平的输出口接在一起的话,就会产生很大的电流,有可能将输出口烧坏。而上面说的OC或OD输出则不会有这样的情况,因为上拉电阻提供的电流比较小。如果是推挽输出的要设置为高阻态时,则两个开关必须同时断开(或者在输出口上使用一个传输门),这样可作为输入状态,AVR单片机的一些IO口就是这种结构。

 

开漏电路特点及应用


     在电路设计时我们常常遇到开漏(open drain)和开集(open collector)的概念。
  所谓开漏电路概念中提到的“漏”就是指MOSFET的漏极。同理,开集电路中的“集”就是指三极管的集电极。开漏电路就是指以MOSFET的漏极为输出的电路。一般的用法是会在漏极外部的电路添加上拉电阻。完整的开漏电路应该由开漏器件和开漏上拉电阻组成。如图1所示:  

单片机I/O口推挽输出与开漏输出的区别(转) - lastnight1034 - lastnight1034的博客

                                图1


组成开漏形式的电路有以下几个特点:
       1. 利用外部电路的驱动能力,减少IC内部的驱动(或驱动比芯片电源电压高的负载)。当IC内部MOSFET导通时,驱动电流是从外部的VCC流经R pull-up ,MOSFET到GND。IC内部仅需很下的栅极驱动电流。如图1。

2. 可以将多个开漏输出的Pin,连接到一条线上。形成 “与逻辑” 关系。如图1,当PIN_A、PIN_B、PIN_C任意一个变低后,开漏线上的逻辑就为0了。这也是I2C,SMBus等总线判断总线占用状态的原理。如果作为输出必须接上拉电阻。接容性负载时,下降延是芯片内的晶体管,是有源驱动,速度较快;上升延是无源的外接电阻,速度慢。如果要求速度高电阻选择要小,功耗会大。所以负载电阻的选择要兼顾功耗和速度。
       3. 可以利用改变上拉电源的电压,改变传输电平。如图2, IC的逻辑电平由电源Vcc1决定,而输出高电平则由Vcc2(上拉电阻的电源电压)决定。这样我们就可以用低电平逻辑控制输出高电平逻辑了(这样你就可以进行任意电平的转换)。(例如加上上拉电阻就可以提供TTL/CMOS电平输出等。)

单片机I/O口推挽输出与开漏输出的区别(转) - lastnight1034 - lastnight1034的博客

      图2

4. 开漏Pin不连接外部的上拉电阻,则只能输出低电平(因此对于经典的51单片机的P0口而言,要想做输入输出功能必须加外部上拉电阻,否则无法输出高电平逻辑)。一般来说,开漏是用来连接不同电平的器件,匹配电平用的。
       5. 标准的开漏脚一般只有输出的能力。添加其它的判断电路,才能具备双向输入、输出的能力。


       6.正常的CMOS输出级是上、下两个管子,把上面的管子去掉就是OPEN-DRAIN了。这种输出的主要目的有两个:电平转换、线与。

7.线与功能主要用于有多个电路对同一信号进行拉低操作的场合,如果本电路不想拉低,就输出高电平,因为OPEN-DRAIN上面的管子被拿掉,高电平是靠外接的上拉电阻实现的。(而正常的CMOS输出级,如果出现一个输出为高另外一个为低时,等于电源短路。)

8.OPEN-DRAIN提供了灵活的输出方式,但是也有其弱点,就是带来上升沿的延时。因为上升沿是通过外接上拉无源电阻对负载充电,所以当电阻选择小时延时就小,但功耗大;反之延时大功耗小。所以如果对延时有要求,则建议用下降沿输出。

应用中需注意:
             1.   开漏和开集的原理类似,在许多应用中我们利用开集电路代替开漏电路。例如,某输入Pin要求由开漏电路驱动。则我们常见的驱动方式是利用一个三极管组成开集电路来驱动它,即方便又节省成本。如图3。

单片机I/O口推挽输出与开漏输出的区别(转) - lastnight1034 - lastnight1034的博客


             2. 上拉电阻R pull-up的阻值决定了逻辑电平转换的沿的速度。阻值越大,速度越低功耗越小。反之亦然。


   Push-Pull输出就是一般所说的推挽输出,在CMOS电路里面应该较CMOS输出更合适,因为在CMOS里面的push-pull输出能力不可能做得双极那么大。输出能力看IC内部输出极N管P管的面积。和开漏输出相比,push-pull的高低电平由IC的电源低定,不能简单的做逻辑操作等。push-pull是现在CMOS电路里面用得最多的输出级设计方式。

当然open drain也不是没有代价,这就是输出的驱动能力很差。输出的驱动能力很差的说法不准确,驱动能力取决于IC中的末级晶体管功率。OD只是带来上升沿的延时,因为上升沿是通过外接上拉无源电阻对负载充电的,当电阻选择小时延时就小、但功耗大,反之延时大功耗小。OPEN DRAIN提供了灵活的输出方式,但也是有代价的,如果对延时有要求,建议用下降沿输出。

电阻小延时小的前提条件是电阻选择的原则应在末级晶体管功耗允许范围内,有经验的设计者在使用逻辑芯片时,不会选择1欧姆的电阻作为上拉电阻。在脉冲的上升沿电源通过上拉无源电阻对负载充电,显然电阻越小上升时间越短,在脉冲的下降沿,除了负载通过有源晶体管放电外,电源也通过上拉电阻和导通的晶体管对地 形成通路,带来的问题是芯片的功耗和耗电问题。电阻影响上升沿,不影响下降沿。如果使用中不关心上升沿,上拉电阻就可选择尽可能的大点,以减少对地通路的 电流。如果对上升沿时间要求较高,电阻大小的选择应以芯片功耗为参考。

<think>好的,我现在需要帮助用户理解输出的工作原理、电路设计以及在嵌入式发中的应用。首先,我需要回忆一下输出的基本概念。输出是一种常见的电路配置,常用于数字信号输出,特别是在需要电平转换或总线连接的场景中。 用户提到了可能与硬件电路设计和嵌入式发相关,所以我要结合这些领域来组织回答。根据引用[2]中的信息,输出的关键点在于使用MOS管的结构,通过外部上拉电阻来实现不同电压的适配,避免烧坏低压外设。我需要详细解释这一部分的工作原理。 接下来,我需要确保回答的结构清晰。先从工作原理始,解释输出的电路结构,比如MOS管Q1和Q2的状态,以及如何通过外部上拉电阻调整电平。然后,讨论在电路设计中的注意事项,比如上拉电阻的选择、驱动能力、总线应用等。最后,在嵌入式发中的应用,比如I2C、电平转换、中断共享等。 同时,需要引用提供的参考资料中的相关内容。例如,引用[2]中提到了输出如何通过外接上拉电阻输出不同电平,避免损坏3.3V器件,这应该放在工作原理或应用部分。引用[3]提到了EMC设计,可能和滤波电路有关,但用户的问题更关注输出,所以这部分可能相关性不大,但可以简要提到EMC设计中的考虑。 用户可能的问题可能包括与推挽的区别、上拉电阻的计算、总线冲突处理等,这些问题应该在相关问题部分列出,帮助用户进一步学习。 需要检查是否所有数学公式和术语都正确使用LaTeX格式,比如MOS管的符号可能不需要,但如果有方程的话,比如计算上拉电阻的值,需要用$...$包裹。例如,计算上拉电阻的公式$R = \frac{V_{CC} - V_{OL}}{I_{OL}}$,这里需要正确使用LaTeX。 最后,确保回答使用中文,结构清晰,分点说明,并自然地插入引用标记。例如,在解释输出避免烧坏外设时,引用[2],在讨论总线应用时也可以引用[2]中的内容。同时,生成的三个相关问题需要覆盖原理、设计和应用的不同方面,帮助用户深入理解。</think>### 输出详解 #### 一、工作原理 输出(Open-Drain Output)是一种通过MOS管控制输出状态的电路结构。其核心特点为: 1. **电路结构**:由单个NMOS管(Q1)构成输出级,极直接连接到引脚(无内置上拉电阻)[^2]。 2. **输出状态**: - **低电平**:Q1导通,引脚通过MOS管接地,输出$V_{OL} \approx 0V$。 - **高阻态**:Q1关闭,引脚呈高阻态,需外接上拉电阻(如$3.3V$或$5V$电源)实现高电平输出[^2]。 #### 二、电路设计要点 1. **上拉电阻选择**: - 电阻值需满足$R = \frac{V_{CC} - V_{OL}}{I_{OL}}$,其中$I_{OL}$为负载电流。 - 典型取值范围$1k\Omega \sim 10k\Omega$,过小会增大功耗,过大会降低上升速度。 2. **电平兼容设计**: - 通过外接不同电压的上拉电阻(如$3.3V$),实现与低压器件的直接连接[^2]。 3. **总线应用**: - 允许多设备共享同一总线(如I²C),避免推挽输出导致的短路风险。 #### 三、嵌入式发中的应用 1. **I²C通信协议**: - SDA/SCL线采用输出,支持多主机仲裁和电平转换[^2]。 2. **电平转换接口**: - 实现$5V$ MCU与$3.3V$传感器间的安全通信(如图1)。 3. **中断信号共享**: - 多个中断源通过输出连接至同一MCU引脚,任一设备拉低即可触发中断。 4. **EMC优化**: - 输出结合RC滤波电路可减少信号边沿的电磁辐射[^3]。 ```c // 示例:STM32配置GPIO为输出 GPIO_InitTypeDef GPIO_InitStruct = {0}; GPIO_InitStruct.Pin = GPIO_PIN_6; GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_OD; // 模式 GPIO_InitStruct.Pull = GPIO_NOPULL; // 禁用内部上拉 HAL_GPIO_Init(GPIOB, &GPIO_InitStruct); ``` #### 四、对比推挽输出 | 特性 | 输出 | 推挽输出 | |--------------|------------------------|------------------------| | 电平驱动能力 | 仅主动拉低 | 可主动拉高/拉低 | | 总线兼容性 | 支持多设备共享 | 易导致总线冲突 | | 功耗 | 高阻态时静态功耗低 | 电平切换时动态功耗较高 | | 电平灵活性 | 可通过上拉适配任意电压 | 固定为电源电压 |
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值