学习笔记:关于上拉输入、下拉输入、模拟输入、浮空输入、推挽输出、开漏输出、复用输出的区别

1、上拉输入:上拉就是把电位拉高,比如拉到Vcc。上拉就是将不确定的信号通过一个电阻嵌位在高电平!电阻同时起限流作用!弱强只是上拉电阻的阻值不同,没有什么严格区分。

2、下拉输入:就是把电压拉低,拉到GND。与上拉原理相似。

3、浮空输入:浮空(floating)就是逻辑器件的输入引脚即不接高电平,也不接低电平。由于逻辑器件的内部结构,当它输入引脚悬空时,相当于该引脚接了高电平。一般实际运用时,引脚不建议悬空,易受干扰。 通俗讲就是让管脚什么都不接,浮空着。

4、模拟输入:模拟输入是指传统方式的输入.数字输入是输入PCM数字信号,即0,1的二进制数字信号,通过数模转换,转换成模拟信号,经前级放大进入功率放大器,功率放大器还是模拟的。

5、推挽输出:可以输出高,低电平,连接数字器件; 推挽结构一般是指两个三极管分别受两互补信号的控制,总是在一个三极管导通的时候另一个截止。高低电平由IC的电源低定。

6、开漏输出:输出端相当于三极管的集电极. 要得到高电平状态需要上拉电阻才行. 适合于做电流型的驱动,其吸收电流的能力相对强(一般20mA以内).

7、复用输出:可以理解为GPIO口被用作第二功能时的配置情况(即并非作为通用IO口使用)。端口必须配置成复用功能输出模式(推挽或开漏)。

在STM32中选用IO模式,下面是参考网上的总结一下。

(1)GPIO_Mode_AIN 模拟输入—应用ADC模拟输入,或者低功耗下省电

(2)GPIO_Mode_IN_FLOATING 浮空输入—可以做KEY识别

(3)GPIO_Mode_IPD 下拉输入— IO内部下拉电阻输入

(4)GPIO_Mode_IPU 上拉输入—IO内部上拉电阻输入

(5)GPIO_Mode_Out_OD 开漏输出—IO输出0接GND,IO输出1,悬空,需要外接上拉电阻,才能实现输出高电平。当输出为1时,IO口的状态由上拉电阻拉高电平,但由于是开漏输出模式,这样IO口也就可以由外部电路改变为低电平或不变。可以读IO输入电平变化,实现C51的IO双向功能
(6)GPIO_Mode_Out_PP 推挽输出—IO输出0-接GND, IO输出1 -接VCC,读输入值是未知的
(7)GPIO_Mode_AF_OD 复用开漏输出—片内外设功能(TX1,MOSI,MISO.SCK.SS)
(8)GPIO_Mode_AF_PP 复用推挽输出—片内外设功能(I2C的SCL,SDA)

1.推挽输出

可以输出高、低电平,连接数字器件;推挽结构一般是指两个三极管分别受两个互补信号的控制,总是在一个三极管导通的时候另一个截止。高低电平由IC的电源决定。
推挽电路是两个参数相同的三极管或MOSFET,以推挽方式存在于电路中,各负责正负半周的波形放大任务,电路工作时,两只对称的功率开关管每次只有一个导通,所以导通损耗小、效率高。输出既可以向负载灌电流,也可以从负载抽取电流。推拉式输出级既提高电路的负载能力,又提高开关速度。

2.开漏输出

输出端相当于三极管的集电极,要得到高电平状态需要上拉电阻才行。适合于做电流型的驱动,其吸收电流的能力相对强(一般20mA以内)。开漏形式的电路有以下几个特点:
1、利用外部电路的驱动能力,减少IC内部的驱动。当IC内部MOSFET导通时,驱动电流是从外部的VCC流经上拉电阻、MOSFET到GND。IC内部仅需很小的栅极驱动电流。

2、一般来说,开漏是用来连接不同电平的器件,匹配电平用的,因为开漏引脚不连接外部的上拉电阻时,只能输出低电平,如果需要同时具备输出高电平的功能,则需要接上拉电阻,很好的一个优点是通过改变上拉电源的电压,便可以改变传输电平。比如加上上拉电阻就可以提供TTL/CMOS电平输出等。(上拉电阻的阻值决定了逻辑电平转换的速度。阻值越大,速度越低功耗越小,所以负载电阻的选择要兼顾功耗和速度。)

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

4、可以将多个开漏输出连接到一条线上。通过一只上拉电阻,在不增加任何器件的情况下,形成“与逻辑”关系,即“线与”。可以简单的理解为:在所有引脚连在一起时,外接一上拉电阻,如果有一个引脚输出为逻辑0,相当于接地,与之并联的回路“相当于被一根导线短路”,所以外电路逻辑电平便为0,只有都为高电平时,与的结果才为逻辑1。

3.浮空输入

由于浮空输入一般多用于外部按键输入,结合图上的输入部分电路,我理解为浮空输入状态下,IO的电平状态是不确定的,完全由外部输入决定,如果在该引脚悬空的情况下,读取该端口的电平是不确定的。

4.上拉输入/下拉输入/模拟输入

这几个概念很好理解,从字面便能轻易读懂。
5.复用开漏输出、复用推挽输出

可以理解为GPIO口被用作第二功能时的配置情况(即并非作为通用IO口使用)
6.总结在STM32中选用IO模式

1、浮空输入GPIO_IN_FLOATING ——浮空输入,可以做KEY识别,RX1
2、带上拉输入GPIO_IPU——IO内部上拉电阻输入
3、带下拉输入GPIO_IPD—— IO内部下拉电阻输入
4、模拟输入GPIO_AIN ——应用ADC模拟输入,或者低功耗下省电
5、开漏输出GPIO_OUT_OD ——IO输出0接GND,IO输出1,悬空,需要外接上拉电阻,才能实现输出高电平。当输出为1时,IO口的状态由上拉电阻拉高电平,但由于是开漏输出模式,这样IO口也就可以由外部电路改变为低电平或不变。可以读IO输入电平变化,实现C51的IO双向功能
6、推挽输出GPIO_OUT_PP ——IO输出0-接GND, IO输出1 -接VCC,读输入值是未知的
7、复用功能的推挽输出GPIO_AF_PP ——片内外设功能(I2C的SCL,SDA)
8、复用功能的开漏输出GPIO_AF_OD——片内外设功能(TX1,MOSI,MISO.SCK.SS)

7.STM32设置实例

1、模拟I2C使用开漏输出_OUT_OD,接上拉电阻,能够正确输出0和1;读值时先GPIO_SetBits(GPIOB, GPIO_Pin_0);拉高,然后可以读IO的值;使用GPIO_ReadInputDataBit(GPIOB,GPIO_Pin_0);
2、如果是无上拉电阻,IO默认是高电平;需要读取IO的值,可以使用带上拉输入_IPU和浮空输入_IN_FLOATING和开漏输出_OUT_OD;
8.通常有5种方式使用某个引脚功能,它们的配置方式如下:

1、作为普通GPIO输入:根据需要配置该引脚为浮空输入、带弱上拉输入或带弱下拉输入,同时不要使能该引脚对应的所有复用功能模块。
2、作为普通GPIO输出:根据需要配置该引脚为推挽输出或开漏输出,同时不要使能该引脚对应的所有复用功能模块。
3、作为普通模拟输入:配置该引脚为模拟输入模式,同时不要使能该引脚对应的所有复用功能模块。
4、作为内置外设的输入:根据需要配置该引脚为浮空输入、带弱上拉输入或带弱下拉输入,同时使能该引脚对应的某个复用功能模块。
5、作为内置外设的输出:根据需要配置该引脚为复用推挽输出或复用开漏输出,同时使能该引脚对应的所有复用功能模块。

注意如果有多个复用功能模块对应同一个引脚,只能使能其中之一,其它模块保持非使能状态。比如要使用STM32F103VBT6的47、48脚的USART3功能,则需要配置47脚为复用推挽输出或复用开漏输出,配置48脚为某种输入模式,同时使能USART3并保持I2C2的非使能状态。如果要使用STM32F103VBT6的47脚作为TIM2_CH3,则需要对TIM2进行重映射,然后再按复用功能的方式配置对应引脚。

  • 6
    点赞
  • 70
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 费曼学习法是一种高效的学习方法,它强调将学习内容通过输出来加深理解和记忆。学习者首先将所学知识以自己的方式解释出来,并以教授他人的态度去表达,从而深入理解并巩固所学的知识。 这种方法有助于发现知识的漏洞和不足之处。当我们试图将所学内容用简洁明了的语言表达给他人时,我们会发现自己对知识的理解可能还不够深刻。因此,我们会被迫回到输入环节,重新学习和理解相关的知识点,以更好地表达并解释清楚。通过这个过程,我们可以发现自己对知识的理解有哪些不足之处,并修正和完善。 费曼学习法通过输出倒逼输入,使我们在学习的过程中保持主动,不断追求更深入的理解。这种学习方式不仅有助于加深记忆,还能帮助我们形成更系统和全面的知识结构。通过将知识进行输出,我们可以更好地检验自己对知识的理解程度,并在不断修正中提高自己的学习效果。 总而言之,费曼学习法通过输出倒逼输入,促使学习者更深入地理解和掌握所学的知识。它不仅提升了学习效果,还培养了我们的表达能力和思维逻辑。这种学习方法可以应用于各个领域,帮助我们更好地学习和成长。 ### 回答2: 费曼学习法是一种学习方法,其基础理念是通过将所学知识以自己的方式加以“输出”,来倒逼自己的“输入”过程。具体而言,费曼学习法的步骤如下: 第一步是选择一个特定的主题或概念进行学习。这可能是一个你感兴趣的课程、一本书或一个研究领域。 第二步,将你所学的知识用自己的话重新表达出来。这可以通过简单地用纸和笔写下来的方式进行,也可以口头表达给他人听。这一步是整个方法的核心,帮助你加深对知识的理解。 第三步,检查你的表达是否准确。这可以通过查阅教科书、参考资料或与他人讨论来完成。通过找出自己的表达中不准确或含糊的地方,你可以明确知识中的弱点和需要进一步学习的领域。 第四步,重新整理你的表达。根据你的学习成果和所获取的反馈,重新调整你的表达方式,使其更加准确和完整。 费曼学习法的独特之处在于强调“输出”而非“输入”的重要性。通过将知识以自己的方式表达出来,我们不仅加深了对知识的理解,还能够更好地发现和纠正自己的知识盲点。同时,这种输出也可以作为对自己学习成果的检验和总结,有助于我们更好地掌握所学知识。 在实践费曼学习法的过程中,我们可以使用PDF文件作为输出的一种形式。通过将学习内容整理成PDF文档,我们可以更方便地进行记录和分享。此外,PDF格式的文档具有易读易传播的特点,可以更好地达到输出知识的目的。 总之,费曼学习法以输出倒逼输入的方式,帮助我们更好地理解和掌握所学知识。无论是以PDF文件形式还是其他方式的输出,都能够提高学习效果,加深对知识的理解。 ### 回答3: 费曼学习法是一种高效学习方法,其核心是通过将知识进行输出,从而倒逼自己对知识的深度理解和内化。这种方法可以应用于各种学习任务中,包括阅读材料、听课、解决问题等。 费曼学习法的步骤如下:首先,通过阅读或听课等方式获取知识输入,了解学习的主要内容。然后,将所学的知识以自己的语言写成笔记或教材,将其输出成为一个“费曼教程”。在编写费曼教程时,要用简单的语言解释复杂的概念,使其易于理解。接下来,根据自己对知识的理解程度,进行反思和回顾。通过讲解、演示、思考等方式,整理出不懂或不熟悉的部分,并梳理出重点和难点。最后,根据反馈的内容,进行输入和再次学习,直到对知识有深入的理解。 费曼学习法的核心思想是通过将知识输出,来检验自己的掌握程度。通过输出的过程,我们不仅能发现自己对知识的理解程度,还能发现知识中的漏洞和不足之处。这样一来,我们就能够有针对性地进行学习,填补知识的空白或深化对知识的理解。 输出倒逼输入的过程中,我们需要不断提高自己的表达和理解能力。通过把知识输出成教程的方式,我们需要将复杂的概念转化为简单易懂的语言,从而更好地理解和记忆知识。同时,通过与他人交流和分享自己的输出,我们还能够接受他人的反馈和指导,加深对知识的理解。 总之,费曼学习法通过输出倒逼输入,在知识学习上起到了指导和加强作用。通过不断输出和反思,我们能够更好地理解和掌握知识,提高学习效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值