超大规模集成电路设计----学习框架(一)

2023-12-04 01:12

本文主要是介绍超大规模集成电路设计----学习框架(一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文仅供学习,不作任何商业用途,严禁转载。绝大部分资料来自----数字集成电路——电路、系统与设计(第二版)及中国科学院段成华教授PPT

超大规模集成电路设计----学习框架(一)

  • 这门课在学什么?
  • 这门课该怎么学?
  • 这门课需要哪些基础
  • 可同时修或后续修读的课程
  • 超大规模集成电路设计各章节课程传送门
  • 同时修读课程传送门

本人才疏学浅,以下纯属个人见解,如有错误,欢迎指正。
另外上完此课感打通任督二脉,深感段老师功力雄厚,在此对段老师表示感谢!
如有在UCAS上学的且对数字IC门级、电路级设计感兴趣的同学,强推这门课!

在这里插入图片描述

这门课在学什么?

  1. 这门课首先讲了器件,简单地讲述了MOS器件的工作原理,各种工作区,电压电流方程等等。
  2. 然后就是最基础的CMOS反相器,详细地说明了CMOS反相器的结构,如何设计CMOS反相器中的PMOS和NMOS的宽长比,及一丢丢的版图结构,着重讲了CMOS反相器在不同扇入扇出情况下该如何设计。(注:这里的设计指的是设计CMOS反相器的宽长比,以及CMOS反相器的级联个数甚至是部分组合电路的宽长比设计)。同时这一章节还对CMOS反相器的功耗,性能进行了探讨。
  3. 接着叙述的是各种组合电路,这一章节重点讲述各种组合电路拓扑结构及其功能,它们所带来的优缺点。这些组合电路不一定都是互补CMOS逻辑构成的,有些是有比逻辑,有些是无比逻辑,还有一些由它们衍生而来的逻辑,比如多米诺逻辑。
  4. 时序逻辑部分重点讲述的是时序电路,首先介绍了时序电路中非常重要的时间参数,如何确定最小时钟周期及如何确定数据的保持时间,后面讲述了各种时序逻辑,比如锁存器,触发器,及各种触发器下建立时间和传播延时,保持时间该如何考虑。
  5. 段老师还根据自己查找的资料详细介绍了CPLD和FPGA,虽然CPLD这种器件已经使用的很少了,但是里面的一些功能模块还是有研究及参考价值的。FPGA部分拿了xilinx的几款芯片来讲。这一章节属于补充内容,对超大规模集成电路设计框架搭建相对前面几章没那么重要。
  6. 段老师还讲述了VHDL语言的使用,由于这部分快到了期末考试,本人有太多考试需要复习,这部分听的不是很仔细,但是仍然会出一期关于VHDL语言的博文来解释一些常见用法和设计一个异步FIFO。
  7. 最后一部分段老师讲述的是FSM的设计。

这门课该怎么学?

  1. 如果有机会,当然还是推荐大家来中国科学院大学上段成华老师的课,真的是如沐春风!
  2. 当然,如果实在是没法来上课,大家不嫌弃也可以根据我后面写博文来进行学习,我一定尽可能详细地解释各种概念。
  3. 同时,我希望大家在学习的过程中也能够进行输出,无论是讲述给身边的同学,还是自己写作,这种费曼学习法将会对你大有裨益,受益终生。

这门课需要哪些基础

  1. 《电路原理》:其实掌握KCL、KVL、戴维南等效等基础知识就足以应付超大规模集成电路设计这门课了。
  2. 《数字电子技术基础》:数电哪里都要掌握,么得偷懒!
  3. 《模拟电子技术基础》:掌握MOS管原理部分及基本单管电路就已经对这门课够用了。

可同时修或后续修读的课程

  1. 《高级数字集成电路设计》:主要是补充RTL级设计的知识,这门课主要是学习Verilog语言及各种典型电路如快速乘法器、快速加法器、FFT等经典电路的RTL Level设计。
  2. 《计算机体系结构》:主要是补充系统级的设计,特别是CPU、流水线、内存、缓存、指令集架构的设计。
  3. 《VLSI可测试性设计》:主要是补充超大规模集成电路测试性方面的知识,特别是DFT、ATPG等等和测试性相关的内容。
  4. 《高级模拟集成电路设计》:这个虽然和数字设计关系相对没那么大,但是还是要好好学的,假如哪天数字电路不行了,方便转模拟(dog)。

超大规模集成电路设计各章节课程传送门

超大规模集成电路设计----基本概念(二)

同时修读课程传送门

这篇关于超大规模集成电路设计----学习框架(一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/451560

相关文章

Mysql中设计数据表的过程解析

《Mysql中设计数据表的过程解析》数据库约束通过NOTNULL、UNIQUE、DEFAULT、主键和外键等规则保障数据完整性,自动校验数据,减少人工错误,提升数据一致性和业务逻辑严谨性,本文介绍My... 目录1.引言2.NOT NULL——制定某列不可以存储NULL值2.UNIQUE——保证某一列的每一

Python Web框架Flask、Streamlit、FastAPI示例详解

《PythonWeb框架Flask、Streamlit、FastAPI示例详解》本文对比分析了Flask、Streamlit和FastAPI三大PythonWeb框架:Flask轻量灵活适合传统应用... 目录概述Flask详解Flask简介安装和基础配置核心概念路由和视图模板系统数据库集成实际示例Stre

Olingo分析和实践之OData框架核心组件初始化(关键步骤)

《Olingo分析和实践之OData框架核心组件初始化(关键步骤)》ODataSpringBootService通过初始化OData实例和服务元数据,构建框架核心能力与数据模型结构,实现序列化、URI... 目录概述第一步:OData实例创建1.1 OData.newInstance() 详细分析1.1.1

Spring 框架之Springfox使用详解

《Spring框架之Springfox使用详解》Springfox是Spring框架的API文档工具,集成Swagger规范,自动生成文档并支持多语言/版本,模块化设计便于扩展,但存在版本兼容性、性... 目录核心功能工作原理模块化设计使用示例注意事项优缺点优点缺点总结适用场景建议总结Springfox 是

Python的端到端测试框架SeleniumBase使用解读

《Python的端到端测试框架SeleniumBase使用解读》:本文主要介绍Python的端到端测试框架SeleniumBase使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全... 目录SeleniumBase详细介绍及用法指南什么是 SeleniumBase?SeleniumBase

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

MyBatis设计SQL返回布尔值(Boolean)的常见方法

《MyBatis设计SQL返回布尔值(Boolean)的常见方法》这篇文章主要为大家详细介绍了MyBatis设计SQL返回布尔值(Boolean)的几种常见方法,文中的示例代码讲解详细,感兴趣的小伙伴... 目录方案一:使用COUNT查询存在性(推荐)方案二:条件表达式直接返回布尔方案三:存在性检查(EXI

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

C++ HTTP框架推荐(特点及优势)

《C++HTTP框架推荐(特点及优势)》:本文主要介绍C++HTTP框架推荐的相关资料,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Crow2. Drogon3. Pistache4. cpp-httplib5. Beast (Boos

SpringBoot基础框架详解

《SpringBoot基础框架详解》SpringBoot开发目的是为了简化Spring应用的创建、运行、调试和部署等,使用SpringBoot可以不用或者只需要很少的Spring配置就可以让企业项目快... 目录SpringBoot基础 – 框架介绍1.SpringBoot介绍1.1 概述1.2 核心功能2