# "一生一芯"太理工作室一组寒假研学第三次学 习路线

学习情况:经过年前两周的学习,大家完成了数字设计理论学习,数据结构,LCTHW实践内容,部分 同学已经学完了计组的绝大部分内容。

学习目标: Verilog实践练习和LCTHW数据结构实践,有能力的同学彻底完结计组知识。

# 学习任务

# 1. 数字设计

记住verilog的本质是硬件描述语言而不是硬件设计语言,因此你需要去了解行为级建模,数据流建 模,结构化建模的区别,以及为什么我们不推荐使用行为级建模。

相关推荐学习资料:

html文档学习: Verilog实践部分文档学习(可以在这上面直接学习相关的语法——重实践)

推荐的自学课程:中科大的Verilog OJ平台(需要注册并登录),推荐边看书边练手。实际部分掌握不错 的可以跳过该课程

🌝 **推荐学习方法:看书作为理论学习,Verilog实践**文档作为实践学习,然后就可以上手**中科大** 的verilog实践OJ平台了,全部知识学完之后,就可以开始拔高部分的数字设计HDLbits OJ 做题网站学习了。(这两个平台有一些题目是重复的,做过一遍可以跳过)

# 学习作业

- 1. 随时记录自己的学习记录,一定要如实记录,我们会不定期查看各位的学习情况。
- 2. Learn C The Hard Way中第17, 18节完成, 20-25需要学习, 但是附加题不强制要求学习。最后将 章节练习任务放在命名为 "C"的文件夹中。
  - 只需交回17,18的附加题练习任务,其他部分学习实操练习即可。
    - ——不需交回并不是不重要,而是这部分附加题出的并没有那么好。。。但是此部分学习内容 还是很不错的, 所以大家学懂这部分的学习内容即可。

- 3. Verilog实践: Verilog在线学习网站——veilog学习实践,全英文(在这里推荐一个浏览器插件: 沉 浸式翻译,如果看不懂的话,就用这个插件配合学习吧! ),完成到3.2sequential logic时序逻辑 计数器结束,中间3.1.4的卡诺图部分可跳过,最后完成部分上传截图即可
  - 进度快的同学继续向后做即可,做腻了可以选择拔高或选做的其他部分内容 这里如果有卡住的题可以跳过

# **More Verilog Features**

- Conditional ternary operator ○
- Reduction operators ○
- Reduction: Even wider gates ○
- Combinational for-loop: Vector reversal 2
- Combinational for-loop: 255-bit population count ○
- Generate for-loop: 100-bit binary adder 2 O
- Generate for-loop: 100-digit BCD adder ○

# **Circuits**

# **Combinational Logic**

# **Basic Gates**

- Wire O
- GND O
- NOR O
- Another gate ○
- Two gates O
- More logic gates O
- 7420 chip O
- Truth tables ○
- Two-bit equality ○
- Simple circuit A O
- Simple circuit B O
- Combine circuits A and B O
- Ring or vibrate? ○
- Thermostat O
- 3-bit population count ○

- Gates and vectors ()
- Even longer vectors O

# Multiplexers

- 2-to-1 multiplexer O
- 2-to-1 bus multiplexer O
- 9-to-1 multiplexer ○
- 256-to-1 multiplexer ○
- 256-to-1 4-bit multiplexer O

# **Arithmetic Circuits**

- Half adder O
- Full adder O
- 3-bit binary adder O
- Adder O
- $\bullet \ \ \text{Signed addition overflow} \ \bigcirc$
- 100-bit binary adder O
- 4-digit BCD adder 4位 BCD 加法器 ○

# **Sequential Logic**

| Latcn    | es and Fiip-F           | iops                     |          |           |
|----------|-------------------------|--------------------------|----------|-----------|
| • D flip | o-flop 🔘                |                          |          |           |
| • D flip | o-flops 🔾               |                          |          |           |
| • DFF    | with reset O            |                          |          |           |
| • DFF    | with reset value O      |                          |          |           |
| • DFF    | with asynchronous r     | eset O                   |          |           |
| • DFF    | with byte enable 🔾      |                          |          |           |
| • D La   | tch O                   |                          |          |           |
| • DFF    | $\circ$                 |                          |          |           |
| • DFF    | $\circ$                 |                          |          |           |
| • DFF-   | +gate ○                 |                          |          |           |
| • Mux    | and DFF ()              |                          |          |           |
| • Mux    | and DFF ()              |                          |          |           |
| • DFFs   | s and gates 🔾           |                          |          |           |
| • Crea   | te circuit from truth 1 | table O                  |          |           |
| • Dete   | ct an edge 🔾            |                          |          |           |
| • Dete   | ct both edges O         |                          |          |           |
| • Edge   | e capture register 🔘    |                          |          |           |
| • Dual   | -edge triggered flip-fl | ор 🔾                     |          |           |
| Count    | ters                    |                          |          |           |
| • Four   | -bit binary counter C   |                          |          |           |
| • Deca   | ade counter 🔾           |                          |          |           |
| • Deca   | ade counter again 🔾     |                          |          |           |
| • Slow   | decade counter 🔾        |                          |          |           |
| • Cour   | nter 1-12 🔘             |                          |          |           |
| • Cour   | nter 1000 🔾             |                          |          |           |
| • 4-dig  | git decimal counter 🤇   |                          |          |           |
| • 12-h   | our clock O             |                          |          |           |
|          |                         |                          |          |           |
| 上内容放入    | 一个文件夹里,文件夹作             | 命名为 <mark>你的姓名-专业</mark> | L班级,然后压约 | 宿为一个压缩文件即 |

最后将以」 可。

请严格按照上述要求发送到邮箱: YunDing\_YSYX@163.com

我相信这个寒假不少同学会充分利用这个黄金时间学习技术,那么以上的学习内容肯定是不够你学的,因此我准备了这个部分内容。

# 选做

# 计算机组成原理

#### 地位

考研408数据结构 操作系统 **计算机组成原理** 计算机网络,计算机知识硬件部分精华科目,理工科学生必修课之一,无论考研还是工作都占据极其重要的地位,同时更是我们后续实践的基础科目。

# ? 为什么有这么重要的地位呢?

完第五章处理器即可。

那就要知道机组具体学的内容了,以下是机组完整学习的思维导图,大家自取了解: *链接:https://pan.baidu.com/s/1YDMg\_OsAa2Kn5wpj7k99JA?pwd=9999 提取码:9999* 看完之后,你应该就明白为何如此重要了——这不就是我们设计芯片的基础蓝图吗? 第六七章的IO和总线部分难度大,内容多,大家在后续才会接触,因此我们寒假只需要学习

# 内容

以下视频的CH5最后一章内容学习,记得随手typora记录笔记和继续自己的学习记录哦!

https://www.bilibili.com/video/BV1Ba4y1V7GD/?vd source=4ec31615294fd2510d5fd40f0183648f

机组部分学习会大量涉及你学过的数电知识,如果当时没有好好学,那就要比较吃力了。

註意!该课程是使用教材为MIPS指令集版本,我们之后设计芯片,使用的是RISCV指令集版本,但是考虑到该课程体系完善,效果好,指令集思想是相通的,因此我们仍然选择了该视频课程,配套书籍为黑皮书:计算机组成与设计:硬件软件接口,图示如下(群内有电子版资料),想搭配书籍的同学可以参考──不推荐纯看书,黑皮书阅读难度大,知识点深而且广,很难理清知识点。

因此, **也可以选择你觉得好的计组课程或者硬啃黑皮书**, 学到知识就好!



### 🍟 学完机组我能干什么?

- 1.为之后的数字设计,硬件设计,芯片设计等等相关方面打基础,缺少机组知识你将寸步难 行
- 2.对考研有很大的帮助
- 3.硬件相关学校课程你的修读难度会很低

# 任务

交回相关markdown笔记(我们**推荐**大家进行**总结归纳和心得记录**,这真的很有帮助),以此说明你完成了此部分的学习。

# 拔高

# 1. 数字设计

数字设计重要性不言而喻,因此拔高部分你可以选择继续学习数字设计,学的越多越好,并搭配实践学习; Verilog在线学习网站中一二三四章都非常推荐学习,所以加油吧!

# ? 那我机组部分的实践内容嘞?

机组的学习内容就决定,它**学到的很多是思想**,是**整体的架构,**这就意味**机组实践内容需要你技术栈更全更深**,因此机组实践内容还要向后放,简单部分实践在之后会有一部分, 处理器设计方面内容则需要寒假开学之后,视个人进度逐步进行实践。

# 2. Learn C the hard way

LCTHW: https://wizardforcel.gitbooks.io/lcthw/content/preface.html 其中的**26、37-41、43、45-47不需要学习**,性价比比较低,不推荐学习,**其他内容我们都很推荐学习**,想要技术很强的话,都可以试着去学习,并在其中锻炼自己gdb等debug工具使用和相关能力思维。

其中有关"一生一芯"的必须完成部分如下:

#### I'C语言入门必做题

Learn C the hard way☑ 练习0到练习18, 练习32, 练习33, 练习42, 练习44 需要完成编程算法以及附加题.

- 这是入学答辩的一部分,如果你在某些地方被卡住,可以通过RTFW或咨询助教
- 参考资料使用上文提到的学习资料

# 3. 一生一芯课程PA

PA是我们后续学习中非常重要的一部分内容,目前我们已经把PA0相关的基础知识进行了补全,大家可以去尝试PA0的相关内容学习,不过想开PA1还需要一些时间,PA1的内容需要数据结构,Lchtw都学到不错的地步并具备一定的编程思想,然后就需要你的时间和精力花费了。

说这么多,其实就是告诉大家**PA1部分的学习内容难度很高**,可能会花费不少时间,同时这也是后续预学习答辩的重要内容之一,所以如果**你想挑战自己的能力极限**,那现在去做PA1也是可以的,加油!

以上就是拔高作业的全部内容,说实话如果你能在这个寒假把以上内容全做完,意味着——》寒假结束后一个月内即可参加预学习答辩并顺利通过,正式进入"一生一芯"项目,后续继续保持学习,那么你的技术将比我更强!暑假你完全可以凭借自己的实力进入线下基地。**但是也请大家劳逸结合,考虑自己的能力和精力,合理学习,不要为了求快,去燃烧自己的热情与生命,这样是非常得不偿失的**,

# ? 难度这么高几乎无法完成,那拔高作业布置这么多是为什么?

- 1. 想让大家明白自己要学的内容还有很多。
- 2. 让大家可以自由选择拔高的学习内容,以上三项,皆可自由选择学习,不存在非常强烈的 关联先后关系。

#### 3. 并没有要求大家拔高作业全部完成,而是根据自己情况,可以完成多少就完成多少。

本作品《"太理工一生一芯工作室前置讲义寒假研学篇"》由 许鹏远 创作,并采用 CC BY-SA 4.0 协议进行授权。

遵循CC BY-SA 4.0开源协议: https://creativecommons.org/licenses/by-sa/4.0/deed.en

转载或使用请标注所有者:许鹏远,太理"一生一芯"工作室