数电第五周周结_by_yc

基本要点:

组合逻辑电路的行为特点、经典组合逻辑电路的设计、PPA优化

  • 组合逻辑电路设计要点:

      ①敏感变量列表应包含所有会影响输出的控制量;

      ②条件语句的完全描述,当电路中的条件语句未被完全描述,将会导致生成某一状态下对输出结果的锁存;

       - 在所有分支之前,添加赋值语句;

       - 在所有分支中对变量进行赋值。

      ③阻塞赋值:“=”,非阻塞赋值的“延时性”将会导致电路输出错误。若使用\({always@(*)}\)将会导致out_a和out_na的结果相同,这是由于将前述变量同样加入了敏感列表。\({\Rightarrow}\)鼓励多多使用\({always@(*)}\)

  • 组合电路中应避免产生latch!

      ①锁存器:电平触发的存储单元,当电平信号无效时,输出信号随输入信号变化,就像通过了缓冲器;当电平有效时,输出信号被锁存。

      ②latch危害:在实际电路中latch容易产生毛刺,导致下一级电路可能出现错误状态;生成latch需要更多的资源;锁存器的出现会使得静态时序分析变得更加复杂。

      ③避免产生latch的方法:

        A.if-else或case语句,结构保持完整;

        B.不要将赋值信号放在赋值源头或者条件判断中;

        C.敏感信号列表建议使用\({always@(*)}\)

  • 多路选择器:

//4选1多路选择器
module Multiplexer(
input a, b, c, d,
input s0, s1,
output reg y); always@(*) begin
if({s1,s0}==2'b00) y=a;
else if({s1,s0}==2'b01) y=b;
else if({s1,s0}==2'b10) y=c;
else if({s1,s0}==2'b11) y=d;
else y=1'bx;//省略将会带来latch
end endmodule

  • 比较器:
//2位比较器
module Comparator(
input in0, in1,
output reg gt, eq, lt); always@(*) begin
gt=0;
eq=0;
lt=0;
if(in0>in1) gt=1;
if(in0==in1) eq=1;
if(in0<in1) lt=1;
end endmodule
  • 编码器和译码器:
//8-3编码器
module encoder(
input [7:0] in,
output reg [2:0] encode_out,
output reg valid); always@(*) begin
valid=1;
case(in)
8'b00000001: encode_out = 3'b000;
8'b00000010: encode_out = 3'b001;
8'b00000100: encode_out = 3'b010;
8'b00001000: encode_out = 3'b011;
8'b00010000: encode_out = 3'b100;
8'b00100000: encode_out = 3'b101;
8'b01000000: encode_out = 3'b110;
8'b10000000: encode_out = 3'b111;
default : valid=0;
endcase
end endmodule
//3-8译码器
module decoder(
input [2:0] in,
output reg [7:0] out); always@(*) begin
case(in)
3'b000: out=8'b00000001;
3'b001: out=8'b00000010;
3'b010: out=8'b00000100;
3'b011: out=8'b00001000;
3'b100: out=8'b00010000;
3'b101: out=8'b00100000;
3'b110: out=8'b01000000;
3'b111: out=8'b10000000;
endcase
end endmodule
//8-3_priority_encoder
module priority_encoder(
input [7:0] din,
input EI,
output reg [2:0] dout,
output reg GS, EO); always@(*) begin
if(EI) begin dout=3'b111; GS=1; EO=1; end
else if(din[7]==0) begin dout=3'b000; GS=0; EO=1; end
else if(din[6]==0) begin dout=3'b001; GS=0; EO=1; end
else if(din[5]==0) begin dout=3'b010; GS=0; EO=1; end
else if(din[4]==0) begin dout=3'b011; GS=0; EO=1; end
else if(din[3]==0) begin dout=3'b100; GS=0; EO=1; end
else if(din[2]==0) begin dout=3'b101; GS=0; EO=1; end
else if(din[1]==0) begin dout=3'b110; GS=0; EO=1; end
else if(din[0]==0) begin dout=3'b111; GS=0; EO=1; end
else begin dout=3'b111; GS=1; EO=0; end
end
endmodule
  • 七段数码管:
//七段数码管
module hex_7seg_LED(
input [3:0] hex,
input dp,
output reg [7:0] sseg); always@(*) begin
case(hex)
4'h0: sseg=7'b0000001;
4'h1: sseg=7'b1001111;
4'h2: sseg=7'b0010010;
4'h3: sseg=7'b0000110;
4'h4: sseg=7'b1001100;
4'h5: sseg=7'b0100100;
4'h6: sseg=7'b0100000;
4'h7: sseg=7'b0001111;
4'h8: sseg=7'b0000000;
4'h9: sseg=7'b0000100;
4'ha: sseg=7'b0001000;
4'hb: sseg=7'b1100000;
4'hc: sseg=7'b0110001;
4'hd: sseg=7'b1000010;
4'he: sseg=7'b0110000;
4'hf: sseg=7'b0111000;
endcase
sseg[7]=dp;
end endmodule
  • PPA优化问题:PPA优化

  • 上机过程中出现的问题:

      ①定义寄存器时注意不要写成数组哈哈哈;

      ②for循环时️不要把起始和终止条件写反;

      ③使用for循环时最好将多语句块用begin...end包起来,因为for语句不会根据缩进来判断for循环是否结束。

数电第五周周结_by_yc的更多相关文章

  1. 模电&数电知识整理(不定期更新)

    模电总复习之爱课堂题目概念整理 Chapter 1 1) 设室温情况下某二极管的反偏电压绝对值为1V,则当其反偏电压值减少100mV时,反向电流的变化是基本不发生变化. 2) 二极管发生击穿后,在击穿 ...

  2. 数电课设——琐碎

    这几天没有更新过网站了,也没继续开发VellLock了,可是感觉还是没有闲着,一直在跟下面的一些元器件在打交道,当然下面的都是小儿科,英文文档都看得我快吐血了.数电基本属于棺材边上过的我,是各种头大, ...

  3. Android第五六周作业

    1.返回键实现对话框弹出是否退出应用程序 package com.example.zuoye1; import androidx.appcompat.app.AlertDialog; import a ...

  4. [问题2015S04] 复旦高等代数 II(14级)每周一题(第五教学周)

    [问题2015S04] 设 \(A\) 为 \(n\) 阶方阵, \(C\) 为 \(k\times n\) 矩阵, 且对任意的 \(\lambda\in\mathbb{C}\), \(\begin{ ...

  5. [问题2015S14] 复旦高等代数 II(14级)每周一题(第十五教学周)

    [问题2015S14]  设 \(J=\begin{pmatrix} 0 & I_n \\ -I_n & 0 \\ \end{pmatrix}\), \(A\) 为 \(2n\) 阶实 ...

  6. [问题2014A03] 复旦高等代数 I(14级)每周一题(第五教学周)

    [问题2014A03]  设 \(A=(a_{ij})\) 为 \(n\,(n\geq 3)\) 阶方阵,\(A_{ij}\) 为第 \((i,j)\) 元素 \(a_{ij}\) 在 \(|A|\) ...

  7. [问题2014A13] 复旦高等代数 I(14级)每周一题(第十五教学周)

    [问题2014A13]  设 \(V\) 是数域 \(K\) 上的 \(n\) 维线性空间, \(\varphi\) 是 \(V\) 上的幂零线性变换且满足 \(\mathrm{r}(\varphi) ...

  8. [问题2014S05] 复旦高等代数II(13级)每周一题(第五教学周)

    [问题2014S05]  设 \(A,B\) 分别是 \(4\times 3\) 和 \(3\times 4\) 实矩阵, \[ BA=\begin{pmatrix}-9 & -20 & ...

  9. [问题2014S15] 复旦高等代数II(13级)每周一题(第十五教学周)

    [问题2014S15]  设 \(O\) 为 \(n\) 阶正交阵,\(A=\mathrm{diag}\{a_1,a_2,\cdots,a_n\}\) 为实对角阵, 证明: 方阵 \(OA\) 的特征 ...

  10. [hihoCoder] 第五十周: 欧拉路·二

    题目1 : 欧拉路·二 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 在上一回中小Hi和小Ho控制着主角收集了分散在各个木桥上的道具,这些道具其实是一块一块骨牌. 主角 ...

随机推荐

  1. 第六章:Django 综合篇 - 10:消息框架 message

    在网页应用中,我们经常需要在处理完表单或其它类型的用户输入后,显示一个通知信息给用户. 对于这个需求,Django提供了基于Cookie或者会话的消息框架messages,无论是匿名用户还是认证的用户 ...

  2. ProxySQL(8):SQL语句的重写规则

    文章转载自: https://www.cnblogs.com/f-ck-need-u/p/9309760.html 为什么要重写SQL语句 ProxySQL在收到前端发送来的SQL语句后,可以根据已定 ...

  3. centos7使用yum方式安装node_exporter

    官网下载地址:https://prometheus.io/download/ 选择对应的系统版本 官网提供的是压缩包,点击旁边的github地址 github页面显示的有yum安装和docker安装, ...

  4. linux软链接的创建、修改和删除

    创建 ln -s [源文件或目录] [目标文件或目录] 修改 ln –snf [新的源文件或目录] [目标文件或目录] 删除 rm –rf 软链接名称 注意,上面这种形式可能会让人产生担忧,害怕删除的 ...

  5. krew插件安装

    概念 Krew是kubectl插件的包管理工具.借助Krew,可以轻松地使用kubectl plugin:发现插件.安装和管理插件.使用类似apt.dnf或者brew. 对于kubectl用户:kre ...

  6. Redis的web管理界面redis-manager

    下载 下载地址:https://github.com/ngbdf/redis-manager/releases 配置 tar -zxv -f redis-manager-2.3.2.2-RELEASE ...

  7. 使用port-forward访问集群中的应用程序,以Redis 为例

    为Redis创建Deployment和Service 创建 Redis Deployment,YAML文件如下: apiVersion: apps/v1 kind: Deployment metada ...

  8. 1. Fluentd安装方法

    Fluentd是一个跨平台的开源系统,支持在Linux(Redhat.Ubuntu.Debian).Windows平台上运行.MacOS呢?官方并没有明显指出,但是在安装说明中列出了通过Ruby Ge ...

  9. PAT (Basic Level) Practice 1031 查验身份证 分数 15

    一个合法的身份证号码由17位地区.日期编号和顺序编号加1位校验码组成.校验码的计算规则如下: 首先对前17位数字加权求和,权重分配为:{7,9,10,5,8,4,2,1,6,3,7,9,10,5,8, ...

  10. PHP实践项目【1】:注册登录页面

    在我们这个项目里面,一共用到了5个php文件,他们分别是: login.php 登录页面 logincheck.php 登录检测php文件 register.php 新用户注册页面 regcheck. ...