当前位置: 首页 > news >正文

电子技术——共模抑制

电子技术——共模抑制

Logo

我们在之前学习过,无论是MOS还是BJT的差分输入对,共模信号并不会改变漏极电流的大小,因此我们说差分输入对共模信号无响应。但是实际上由于各种客观非理想因素,例如电流源有限阻抗等,此时共模是影响差分输入对的。

MOS的情况

RSSR_{SS}RSS 的影响

下图是一个MOS的差分输入对,但是电流源是有限阻抗的,阻抗大小为 RSSR_{SS}RSS ,而且我们输入端有两个电压,一是信号本身固有的共模电压 VCMV_{CM}VCM ,另外一个是外界干扰的共模电压 vicmv_{icm}vicm 可能是干扰信号,也可能是噪波。我们的目的就是讨论 vicmv_{icm}vicm 对输出电压的影响:

有限阻抗电流源
首先我们讨论一下 RSSR_{SS}RSS 对偏置的影响,由于 RSSR_{SS}RSS 的存在,流过MOS的电流要比 I/2I/2I/2 稍稍大一些。然而一般情况下 RSSR_{SS}RSS 都是非常巨大的,因此超出 I/2I/2I/2 的那一部分几乎可以忽略。其次 RSSR_{SS}RSSAdA_dAd 也是没有影响的,这是因为假设MOS都是完全相同的,此时源极永远都是虚拟地, RSSR_{SS}RSS 无影响。

现在我们讨论 vicmv_{icm}vicm 存在的影响,考虑下面的电路:

干扰共模信号
我们移除了所有的DC分量,只考虑信号作用,此时电路仍然是完全对称的,我们将MOS的漏极信号电流记为 iii 则流过 RSSR_{SS}RSS 的电流为 2i2i2i 。我们使用等效T模型分析:

T模型
则有:

vicm=igm+2iRSSv_{icm} = \frac{i}{g_m} + 2iR_{SS} vicm=gmi+2iRSS

所以:

i=vicm1/gm+2RSSi = \frac{v_{icm}}{1/g_m + 2R_{SS}} i=1/gm+2RSSvicm

输出信号电压为:

vo1=vo2=−RD1/gm+2RSSvicmv_{o1} = v_{o2} = -\frac{R_D}{1/g_m + 2R_{SS}}v_{icm} vo1=vo2=1/gm+2RSSRDvicm

这就说明 vo1v_{o1}vo1vo2v_{o2}vo2 是受 vicmv_{icm}vicm 影响的,影响的比例大约为:

vovicm≃−RD2RSS\frac{v_o}{v_{icm}} \simeq -\frac{R_D}{2R_{SS}} vicmvo2RSSRD

这里我们假设 2RSS≫1/gm2R_{SS} \gg 1/g_m2RSS1/gm ,尽管如此,其差分输出信号仍然为零。

vod=vo2−vo1=0v_{od} = v_{o2} - v_{o1} = 0 vod=vo2vo1=0

MOS差分输入对抑制了全部的共模信号,是我们想要的结果。但是事实上并不总是如此,特别是电路不对称的情况。由于现在电路的对称性,我们仍然可以使用半电路分析:

半电路
这种半电路我们称为 共模半电路

RDR_DRD 不匹配的影响

另一种非理想因素是 RDR_DRD 不匹配,我们假设 Q1Q_1Q1RDR_DRDQ2Q_2Q2RD+ΔRDR_D + \Delta R_DRD+ΔRD ,此时的输出端信号电流为:

vo1≃−RD2RSSvicmv_{o1} \simeq -\frac{R_D}{2R_{SS}} v_{icm} vo12RSSRDvicm

vo2≃−RD+ΔRD2RSSvicmv_{o2} \simeq -\frac{R_D + \Delta R_D}{2R_{SS}} v_{icm} vo22RSSRD+ΔRDvicm

所以差分信号电压为:

vod=vo2−vo1=−ΔRD2RSSvicmv_{od} = v_{o2} - v_{o1} = -\frac{\Delta R_D}{2R_{SS}}v_{icm} vod=vo2vo1=2RSSΔRDvicm

我们记其 共模增益 为:

Acm≡vodvicm=−ΔRD2RSSA_{cm} \equiv \frac{v_{od}}{v_{icm}} = -\frac{\Delta R_D}{2R_{SS}} Acmvicmvod=2RSSΔRD

还可以表示为:

Acm=−(RD2RSS)(ΔRDRD)A_{cm} = -(\frac{R_D}{2R_{SS}})(\frac{\Delta R_D}{R_D}) Acm=(2RSSRD)(RDΔRD)

这说明 RDR_DRD 不匹配会影响 vodv_{od}vod 的输出,即 vodv_{od}vod 存在 vicmv_{icm}vicm 分量,这个分量是我们不想要的。为了衡量 vicmv_{icm}vicm 的占比,我们引入 共模抑制比 定义为:

CMRR≡∣Ad∣∣Acm∣CMRR \equiv \frac{|A_d|}{|A_{cm}|} CMRRAcmAd

经常使用分贝来表示:

CMRR(dB)=20log⁡∣Ad∣∣Acm∣CMRR(dB) = 20 \log{\frac{|A_d|}{|A_{cm}|}} CMRR(dB)=20logAcmAd

RDR_DRD 不匹配带来的共模抑制比为:

CMRR=(2gmRSS)/(ΔRDRD)CMRR = (2g_mR_{SS}) / (\frac{\Delta R_D}{R_D}) CMRR=(2gmRSS)/(RDΔRD)

为了获得更大的共模抑制比,我们可以增大偏置电流,或者增大电流源输出阻抗,以及尽可能使得电路匹配,即 (ΔRDRD)(\frac{\Delta R_D}{R_D})(RDΔRD) 尽量小。

gmg_mgm 不匹配的影响

另外一种非理想因素是两个MOS管本身不匹配,可以看做是 gmg_mgm 不匹配的影响。我们假设:

gm1=gm+12Δgmg_{m1} = g_m + \frac{1}{2}\Delta g_m gm1=gm+21Δgm

gm2=gm−12Δgmg_{m2} = g_m - \frac{1}{2}\Delta g_m gm2=gm21Δgm

也就是:

gm1−gm2=Δgmg_{m1} - g_{m2} = \Delta g_m gm1gm2=Δgm

虽然此时电路不对称,我们无法使用半电路法分析,我们可以使用直接计算得到:

Acm≃(RD2RSS)(Δgmgm)A_{cm} \simeq (\frac{R_D}{2R_{SS}})(\frac{\Delta g_m}{g_m}) Acm(2RSSRD)(gmΔgm)

则共模抑制比为:

CMRR=(2gmRSS)/(Δgmgm)CMRR = (2g_mR_{SS}) / (\frac{\Delta g_m}{g_m}) CMRR=(2gmRSS)/(gmΔgm)

这个形式和 RDR_DRD 不匹配的影响一样。同样的为了获得更大的共模抑制比,我们可以增大偏置电流,或者增大电流源输出阻抗,以及尽可能使得电路匹配,即 (Δgmgm)(\frac{\Delta g_m}{g_m})(gmΔgm) 尽量小。

差分输出和单端输出

以上的讨论都是基于差分输出而言的,如果使用的是单端输出,则CMRR会大大降低,这是因为在本节一开始我们就分析了,即使如果电路是对称的,那么 vicmv_{icm}vicm 也会出现在输出端的两端,如果使用单端输出 vicmv_{icm}vicm 就会出现在输出电压上。如果我们想获得较大的CMRR,我们推荐使用差分输出。之后我们会介绍如何保持CMRR无损的将差分信号转换为单端信号。

BJT的情况

同样对于BJT也存在共模抑制的情况,我们使用如下图的电路以及对应的半电路:

BJT
输出信号电压为:

vo1=vo2=−αRCre+2REEvicmv_{o1} = v_{o2} = -\frac{\alpha R_C}{r_e + 2R_{EE}}v_{icm} vo1=vo2=re+2REEαRCvicm

说明BJT的同样抑制共模信号。但是当出现电路不匹配的情况下,例如存在 ΔRC\Delta R_CΔRC

Acm=−αΔRC2REE+reA_{cm} = -\frac{\alpha \Delta R_C}{2R_{EE} + r_e} Acm=2REE+reαΔRC

因为 α≃1,re≪2REE\alpha \simeq 1,r_e \ll 2R_{EE}α1,re2REE 所以:

Acm≃−(RC2REE)(ΔRCRC)A_{cm} \simeq - (\frac{R_C}{2R_{EE}})(\frac{\Delta R_C}{R_C}) Acm(2REERC)(RCΔRC)

因此共模抑制比为:

CMRR=(2gmREE)/(ΔRCRC)CMRR = (2g_m R_{EE}) / (\frac{\Delta R_C}{R_C}) CMRR=(2gmREE)/(RCΔRC)

与MOS具有相同的形式。

BJT的输入阻抗是有限的,因此对于 vicmv_{icm}vicm 来说也存在输入阻抗,如图:

输入阻抗
我们定义 RicmR_{icm}Ricm 是共模信号的输入阻抗,对应的等效半电路输入阻抗为 2Ricm2R_{icm}2Ricm 我们有:

Ricm≃βREE1+RC/βro1+RC+2REEroR_{icm} \simeq \beta R_{EE} \frac{1 + R_C / \beta r_o}{1 + \frac{R_C + 2R_{EE}}{r_o}} RicmβREE1+roRC+2REE1+RC/βro

相关文章:

电子技术——共模抑制

电子技术——共模抑制 我们在之前学习过,无论是MOS还是BJT的差分输入对,共模信号并不会改变漏极电流的大小,因此我们说差分输入对共模信号无响应。但是实际上由于各种客观非理想因素,例如电流源有限阻抗等,此时共模是影…...

对KMP简单的理解

声明:下边的例子均表示下标从1开始的数组 ne数组的定义: next[i] 就是使子串 s[1…i] 有最长相等前后缀的前缀的最后一位的下标。ne[i]也可以表示相等子串的长度 准备执行jne[j]时, 表示当前s[i]!p[j1] , 如果ne[j]1 ,那么下…...

Hibernate不是过时了么?SpringDataJpa又是什么?和Mybatis有什么区别?

一、前言 ps: 大三下学期,拿到了一份实习。进入公司后发现用到的技术栈有Spring Data Jpa\Hibernate,但对于持久层框架我只接触了Mybatis\Mybatis-Plus,所以就来学习一下Spring Data Jpa。 1.回顾MyBatis 来自官方文档的介绍:MyBatis 是一款…...

数学建模拓展内容:卡方检验和Fisher精确性检验(附有SPSS使用步骤)

卡方检验和Fisher精确性检验卡方拟合度检验卡方独立性检验卡方检验的前提假设Fisher精确性检验卡方拟合度检验 卡方拟合度检验概要:卡方拟合度检验也被称为单因素卡方检验,用于检验一个分类变量的预期频率和观察到的频率之间是否存在显著差异。 卡方拟…...

【Python学习笔记之七大数据类型】

Python数据类型:Number数字、Boolean布尔值、String字符串、list列表、tuple元组、set集合、dictionary字典 int整数 a1 print(a,type(a))float浮点数 b1.1 print(b,type(b))complex复数 c100.5j print(c,type(c))bool布尔值:True、False,true和false并非Python…...

Android系统之onFirstRef自动调用原理

前言&#xff1a;抽丝剥茧探究onFirstRef究竟为何在初始化sp<xxx>第一个调用&#xff1f;1.onFirstRef调用位置<1>.system/core/libutils/RefBase.cpp#include <utils/RefBase.h>//1.初始化强指针 void RefBase::incStrong(const void* id) const {weakref_i…...

ipv6上网配置

一般现在的宽带都已经支持ipv6了&#xff0c;但是需要一些配置才能真正用上ipv6。记录一下配置过程。 当前测试环境为移动宽带&#xff0c;光猫下面接了一个路由器&#xff0c;家里所有的设备都挂到这个路由器下面的。 1. 光猫改桥接 光猫在使用路由模式下&#xff0c;ipv6无…...

python实现聚类技术—复杂网络社团检测 附完整代码

实验内容 某跆拳道俱乐部数据由 34 个节点组成,由于管理上的分歧,俱乐部要分解成两个社团。 该实验的任务即:要求我们在给定的复杂网络上检测出两个社团。 分析与设计 实验思路分析如下: 聚类算法通常可以描述为用相似度来衡量两个数据的远近,搜索可能的划分方案,使得目标…...

如何判断两架飞机在汇聚飞行?(如何计算两架飞机的航向夹角?)内含程序源码

ok&#xff0c;在开始一切之前&#xff0c;让我先猜一猜&#xff0c;你是不是想百度“二维平面下如何计算两个移动物体的航向夹角&#xff1f;”如果是&#xff0c;那就请继续往下看。 首先&#xff0c;我们要明确一个概念&#xff1a;航向角≠航向夹角&#xff01;&#xff0…...

Scipy稀疏矩阵bsr_array

文章目录基本原理初始化内置方法基本原理 bsr&#xff0c;即Block Sparse Row&#xff0c;bsr_array即块稀疏行矩阵&#xff0c;顾名思义就是将稀疏矩阵分割成一个个非0的子块&#xff0c;然后对这些子块进行存储。通过输入维度&#xff0c;可以创建一个空的bsr数组&#xff0…...

LeetCode笔记:Weekly Contest 332

LeetCode笔记&#xff1a;Weekly Contest 332 1. 题目一 1. 解题思路2. 代码实现 2. 题目二 1. 解题思路2. 代码实现 3. 题目三 1. 解题思路2. 代码实现 4. 题目四 1. 解题思路2. 代码实现 比赛链接&#xff1a;https://leetcode.com/contest/weekly-contest-332/ 1. 题目一…...

autox.js在vscode(win7)与雷神模拟器上的开发环境配置

目录 下载autox.js 安装autox.js&#xff1f; 在电脑上搭建autox.js开发环境 安装vscode 安装autox.js插件 雷神模拟器连接vscode 设置雷神模拟器IP 设置autox.js应用IP地址等 下载autox.js 大体来说&#xff0c;就是一个运行在Android平台上的JavaScript 运行环境 和…...

创建阿里云物联网平台

创建阿里云物联网平台 对云平台设备创建过程做记录&#xff0c;懒得再看视频 文章参考视频&#xff1a;https://www.bilibili.com/video/BV1jP4y1E7TJ?p26&vd_source50694678ae937a743c59db6b5ff46c31 阿里云&#xff1a;https://www.aliyun.com 1&#xff0e;物联网平…...

【链式二叉树】数据结构链式二叉树的(万字详解)

前言&#xff1a; 在上一篇博客中&#xff0c;我们已经详解学习了堆的基本知识&#xff0c;今天带大家进入的是二叉树的另外一种存储方式----“链式二叉树”的学习&#xff0c;主要用到的就是“递归思想”&#xff01;&#xff01; 本文目录1.链式二叉树的实现1.1前置说明1.2结…...

Koa2篇-简单介绍及使用

一.简介koa2是基于 Node.js 平台的下一代 web 开发框架, 致力于成为一个更小、更富有表现力、更健壮的 Web 框架。 可以避免异步嵌套. express中间件是异步回调,Koa2原生支持async/await二.async/awaitconst { rejects } require("assert"); const { resolve } req…...

Linux ALSA 之十一:ALSA ASOC Path 完整路径追踪

ALSA ASOC Path 完整路径追踪一、ASoc Path 简介二、ASoc Path 完整路径2.1 tinymix 设置2.2 完整路径 route一、ASoc Path 简介 如前面小节所描述&#xff0c;ASoc 中 Machine Driver 是 platform driver 和 codec driver 的粘合剂&#xff0c;audio path 离不开 FE/BE/DAI l…...

【Spring Cloud总结】1、服务提供者与服务消费者快速上手

目录 文件结构 代码 1、api 1.1实体类&#xff08;Dept &#xff09; 1.2数据库 2、provider 2.1 DeptController 2.2 DeptDao 2.3 DeptService 2.4 DeptServiceImpl 2.5 application.yml 3、consumer 3.1 ConfigBean 3.2 DeptConsumerController 测试 1.启动…...

若依项目学习之登录生成验证码

若依项目学习之登录生成验证码 使用DefaultKaptcha生成验证码 /*** 验证码配置* * author ruoyi*/ Configuration public class CaptchaConfig {/*** 生成字符类型的验证码**/Bean(name "captchaProducer")public DefaultKaptcha getKaptchaBean(){DefaultKaptcha…...

计算机网络5:数据在两台计算机之间是怎样传输的?

数据在两台计算机之间的传输总的来说包括了封装和解封两个过程 封装&#xff08;5层协议&#xff09; 以传送一张图片为例 **应用层&#xff1a;**将jpg格式的图片数据转化成计算机可以识别的0101的二进制的比特流 **传输层&#xff1a;**将应用层传输下来的数据进行分段&…...

就现在!为元宇宙和Web3对互联网的改造做准备!

欢迎来到Hubbleverse &#x1f30d; 关注我们 关注宇宙新鲜事 &#x1f4cc; 预计阅读时长&#xff1a;8分钟 本文仅代表作者个人观点&#xff0c;不代表平台意见&#xff0c;不构成投资建议。 如今&#xff0c;互联网是各种不同的网站、应用程序和平台的集合。由于彼此分离…...

树莓派超全系列教程文档--(61)树莓派摄像头高级使用方法

树莓派摄像头高级使用方法 配置通过调谐文件来调整相机行为 使用多个摄像头安装 libcam 和 rpicam-apps依赖关系开发包 文章来源&#xff1a; http://raspberry.dns8844.cn/documentation 原文网址 配置 大多数用例自动工作&#xff0c;无需更改相机配置。但是&#xff0c;一…...

系统设计 --- MongoDB亿级数据查询优化策略

系统设计 --- MongoDB亿级数据查询分表策略 背景Solution --- 分表 背景 使用audit log实现Audi Trail功能 Audit Trail范围: 六个月数据量: 每秒5-7条audi log&#xff0c;共计7千万 – 1亿条数据需要实现全文检索按照时间倒序因为license问题&#xff0c;不能使用ELK只能使用…...

Java多线程实现之Callable接口深度解析

Java多线程实现之Callable接口深度解析 一、Callable接口概述1.1 接口定义1.2 与Runnable接口的对比1.3 Future接口与FutureTask类 二、Callable接口的基本使用方法2.1 传统方式实现Callable接口2.2 使用Lambda表达式简化Callable实现2.3 使用FutureTask类执行Callable任务 三、…...

前端开发面试题总结-JavaScript篇(一)

文章目录 JavaScript高频问答一、作用域与闭包1.什么是闭包&#xff08;Closure&#xff09;&#xff1f;闭包有什么应用场景和潜在问题&#xff1f;2.解释 JavaScript 的作用域链&#xff08;Scope Chain&#xff09; 二、原型与继承3.原型链是什么&#xff1f;如何实现继承&a…...

自然语言处理——Transformer

自然语言处理——Transformer 自注意力机制多头注意力机制Transformer 虽然循环神经网络可以对具有序列特性的数据非常有效&#xff0c;它能挖掘数据中的时序信息以及语义信息&#xff0c;但是它有一个很大的缺陷——很难并行化。 我们可以考虑用CNN来替代RNN&#xff0c;但是…...

初学 pytest 记录

安装 pip install pytest用例可以是函数也可以是类中的方法 def test_func():print()class TestAdd: # def __init__(self): 在 pytest 中不可以使用__init__方法 # self.cc 12345 pytest.mark.api def test_str(self):res add(1, 2)assert res 12def test_int(self):r…...

MySQL JOIN 表过多的优化思路

当 MySQL 查询涉及大量表 JOIN 时&#xff0c;性能会显著下降。以下是优化思路和简易实现方法&#xff1a; 一、核心优化思路 减少 JOIN 数量 数据冗余&#xff1a;添加必要的冗余字段&#xff08;如订单表直接存储用户名&#xff09;合并表&#xff1a;将频繁关联的小表合并成…...

LLaMA-Factory 微调 Qwen2-VL 进行人脸情感识别(二)

在上一篇文章中,我们详细介绍了如何使用LLaMA-Factory框架对Qwen2-VL大模型进行微调,以实现人脸情感识别的功能。本篇文章将聚焦于微调完成后,如何调用这个模型进行人脸情感识别的具体代码实现,包括详细的步骤和注释。 模型调用步骤 环境准备:确保安装了必要的Python库。…...

【iOS】 Block再学习

iOS Block再学习 文章目录 iOS Block再学习前言Block的三种类型__ NSGlobalBlock____ NSMallocBlock____ NSStackBlock__小结 Block底层分析Block的结构捕获自由变量捕获全局(静态)变量捕获静态变量__block修饰符forwarding指针 Block的copy时机block作为函数返回值将block赋给…...

2.2.2 ASPICE的需求分析

ASPICE的需求分析是汽车软件开发过程中至关重要的一环&#xff0c;它涉及到对需求进行详细分析、验证和确认&#xff0c;以确保软件产品能够满足客户和用户的需求。在ASPICE中&#xff0c;需求分析的关键步骤包括&#xff1a; 需求细化&#xff1a;将从需求收集阶段获得的高层需…...