## Assignment-1. HDL Basics

Due: 11:59pm 11/1/2023

- 1. EDA tools for HDL are evolving at a very fast pace. Find the difference between iverilog, Verilator and Pyrtl? Why researchers develop Verilator and PyRTL as there already exist open-source simulators like lcarus Verilog and commercial simulators (e.g. vcs)?
- 2. 你是否曾想改变交通灯的转换策略?机会来了!你现在要帮忙设计一个路口的交通灯,示意图如下。 CLK 周期 5s, RST 为 high active reset,  $S_A$  和  $S_B$  为安装的传感器,比如  $S_A$  (东西向)探测到有人的话,会输出一个 1,然后东西向就需要变绿灯通行。如果 SA 和 SB 都有人,那就需要你对红黄绿灯转换时间的设计(需以 SB 为最低时间单位)啦。

Q1: 画出 state-transfer diagram

Q2: 完成基于 FSM 的 TrafficLightController module。

Q3: 写一个 testbench 测试证明 Q2 中的 code 是对的、结果时序图请截图提交。



## 3. 有符号数乘法:

- (3.1) 推导基于补数 (2's complement) 的乘法,假设有两个 8bit 整数 A (8'ba<sub>7</sub>a<sub>6</sub>a<sub>5</sub>a<sub>4</sub>\_a<sub>3</sub>a<sub>2</sub>a<sub>1</sub>a<sub>0</sub>) ,与 B (8'bb<sub>7</sub>b<sub>6</sub>b<sub>5</sub>b<sub>4</sub>\_b<sub>3</sub>b<sub>2</sub>b<sub>1</sub>b<sub>0</sub>) , a<sub>7</sub> 与 b<sub>7</sub> 为符号位;
- (3.2) 基于上面的推导,用一些基本电路模块(逻辑门、全加器、半加器等)实现上述 8bit 有符号整数的乘法器。