模C第五章——电流镜

[[CMOS_ch05_2021(1).pdf]]

一、基本的电流镜

  1. How to obtain stable current source
  • 电阻分压
  • 复制标准电流:将 I r e f I_{ref} Iref转化为 V G V_G VG,作用在M1,使M1产生电流 i o u t = I r e f i_{out}=I_{ref} iout=Iref. 栅电压必须由 I r e f I_{ref} Iref产生,因此使用二极管链接,让 V G S V_{GS} VGS自适应 I r e f I_{ref} Iref
  1. 基本电流镜
  • 电流镜的应用:我们需要尽量避免长的电流链
  • 尺寸问题—— 电流只能通过W的改变:由于沟道长度受 L D L_D LD影响太大;而且W也不是完全可以精确加倍的:
  • 同样说明一点,电流镜能够处理信号,可以放大小信号电路,但其代价是成比例的增加偏置电流

二、Cascode current mirrors

基本电流镜存在的问题

  1. Drawback of the basic current mirror
    如果做到精准匹配,忽略了沟道长度调制响应,如果考虑该效应
  • 共源共栅结构的屏蔽作用,使得X点的电压变化在P点没什么影响,电流差别很小!

  • 为了避免,采用共源共栅极电路

改进方法一:共源共栅

  1. 共源共栅极电流镜
    抵抗电压波动的影响:左侧低阻抗,右侧高阻抗
  • 最低电压:电路有高的输出阻抗和精确的值,但是它却消耗了很大 的
    电压余度 。
  • 为解决上述问题,分析共源共栅的大信号特性

改进方法二:低压共源共栅极

  1. 尝试:串联电阻造压降
  • 这个组合也可以看作一个二极管连接型器件
  1. 另一种实现方法
  • 能够让 V b V_b Vb自由设计
  • V b V_b Vb的产生电路
    • 靠谱方法
    • 三种不靠谱的方法

三、Active current mirrors

3.0 概述

电流镜也可以处理信号,像有源器件一样工作而不产生反向,这一节我们研究这种特性

  • 五管“运算跨导放大器”OTA注意他的输出是单端的,因此,此电路有时候用于把差动信号转换为单端输出信号。在研究OTA之前,先研究更简单的无源负载拓扑结构
  1. 无源差动对

首先,两种方式计算小信号增益(由于电路不对称,不能使用单边电路)

  1. 有源负载差动对
    在5.23(a)中,M1的小信号漏电流被浪费了,如下图所示,我们希望在输出端用合适的极性来使用这个电流
  • M3是如何提高增益的?

3.1 大信号分析

  • 状态分析
    • 如果左侧输入远小于右侧,M1、3、4均为关断状态,输出为0
    • 随着左侧输入增大,M1导通,M5的一部分电流流到M3,并且M4导通。输出电压开始依赖于右侧两个晶体管的差值
    • 当左侧和右侧的输入差的很小,M2、4都处于饱和,产生一个很高的增益
    • 当左侧输入比右侧输入大的多的时候,I2电流会减小,导致输出电压增大,最终驱使M4进入线性区
    • 如果左侧输入远大于右侧,M2关断,M4的电流为0,工作在深线性区,输出为VDD
  • 缺点:共模电平对输出摆幅的限制
  • 说明将差动输入转换成大摆幅的单端是输出时候,OTA是有用的

3.2 小信号分析

  1. 近似分析

  2. 精确分析(小信号模型)

  3. 余度问题

3.3 共模特性

  1. A C M A_{CM} ACM

  2. A C M A_{CM} ACM的计算

  3. CMRR共模抑制比

  4. 失配的影响(有时间的话研究一下)

3.4 五管OTA的其他特性

四、Bias techniques

### C语言第五章 指针与数组 #### 数组名作为指针 在C语言中,数组名可以被解释为指向该数组首元素的常量指针。这意味着当提到数组名称而不带下标时,实际上是在引用数组的第一个元素地址。 ```c #include <stdio.h> int main() { int arr[5] = {1, 2, 3, 4, 5}; int *ptr = arr; for (int i = 0; i < 5; i++) { printf("Element %d: %d\n", i, *(ptr + i)); } } ``` 上述代码展示了如何通过将`arr`赋给一个整型指针变量来遍历整个数组[^1]。 #### 指针数组 不同于简单的指针,指针数组是一个特殊类型的数组,其中每个元素本身就是一个指针。这允许创建更复杂的数据结构,比如动态分配内存中的多维数组表示形式。 ```c int *a[4]; // 定义了一个含有四个元素的指针数组,这些元素都将是整数指针 ``` 这段声明语句定义了一种新的数据类型——即由四个成员组成的数组,而每一个成员都可以存储任意数量连续整数值的位置信息(地址)。因此,在实际编程过程中可以根据需求灵活调整各个子集大小[^2]。 #### 使用指针数组拟二维数组 利用指针数组还可以实现类似于传统意义上的二维或多维矩阵操作方式: ```c #include <stdio.h> int main(){ int arr1[4] = { 1,2,3,4 }; int arr2[4] = { 2,3,4,5 }; int arr3[4] = { 3,4,5,6 }; int* arr[3] = {arr1,arr2,arr3}; for(int i=0;i<3;i++){ for(int j=0;j<4;j++) printf("%d ", arr[i][j]); printf("\n"); } return 0;} ``` 此程序片段说明了怎样借助一维指针数组构建并访问具有行列布局特征的对象集合。这里的关键在于理解每一行代表的是独立的一级索引位置,并且它们共同构成了更高维度上的逻辑视图[^3]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值