Verilog HDL语言组合逻辑电路设计实列

2024-02-08 00:08

本文主要是介绍Verilog HDL语言组合逻辑电路设计实列,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Verilog DHL语言组合逻辑举列

  • 内容
    • 8位带进位端的加法器的设计
    • 指令译码电路设计
    • 比较重组信号设计
    • 比较器设计
    • 3-8译码器设计

内容

8位带进位端的加法器的设计

实现模块:

module adder_8(cout,sum,a,b,cin);input cin;input[7:0] a,b;output cout;output[7:0] sum;assign {cout,sum}=a+b+cin;
endmodule

测试模块:

`timescale 1ns/1ns
`include "adder_8.v"
module adder_8_test;reg cin;reg[7:0] a,b;wire cout;wire[7:0] sum;initial begincin=1;a=8'b0110;b=8'b0011;#100 cin=0;a=8'b100;b=8'b0110;#100 $stop;endadder_8 m(.cout(cout),.sum(sum),.a(a),.b(b),.cin(cin));
endmodule

指令译码电路设计

实现模块:

`define plus 3'd0
`define minus 3'd1
`define band 3'd2
`define bor 3'd3
`define unegate 3'd4
module alu(out,opcode,a,b);output[7:0] out;input[2:0] opcode;input[7:0] a,b;reg [7:0] out;always @(opcode or a or b)begincase(opcode)`plus:out=a+b;`minus:out=a-b;`band:out=a&b;`bor:out=a|b;`unegate:out=~a;default:out=8'hx;endcaseend
endmodule

测试模块:

`timescale 1ns/1ns
`include "alu.v"
module alu_test;reg[7:0] a,b;reg[2:0] opcode;wire[7:0] out;initialbegina=4;b=6;opcode=3'd0;#100 opcode=3'd1;#100 opcode=3'd2;#100 opcode=3'd3;#100 opcode=3'd4;#100 $stop;endalu m(.out(out),.opcode(opcode),.a(a),.b(b));
endmodule;

比较重组信号设计

实现模块:

module sort4(ra,rb,rc,rd,a,b,c,d);parameter t=3;output[t:0] ra,rb,rc,rd;input[t:0] a,b,c,d;reg[t:0] ra,rb,rc,rd;always @(a or b or c or d)begin:localreg[t:0] va,vb,vc,vd;{va,vb,vc,vd}={a,b,c,d};sort2(va,vc);sort2(vb,vd);sort2(va,vb);sort2(vc,vd);sort2(vb,vc);{ra,rb,rc,rd}={va,vb,vc,vd};endtask sort2;inout[t:0]x,y;reg [t:0]tmp;if(x>y)begintmp=x;x=y;y=tmp;endendtask
endmodule

测试模块:

`timescale 1ns/1ns
`include "sort4.v"
module sort4_test;reg[3:0]a,b,c,d;wire[3:0] ra,rb,rc,rd;initialbegina=0;b=0;c=0;d=0;repeat(20)begin#100 a={$random}%15;b={$random}%15;c={$random}%15;d={$random}%15;end#100 $stop;endsort4 m(.ra(ra),.rb(rb),.rc(rc),.rd(rd),.a(a),.b(b),.c(c),.d(d));
endmodule

比较器设计

实现模块:

module compare(equal,a,b);parameter size=1;output equal;input[size-1:0] a,b;assign equal=(a==b)?1:0;
endmodule

测试模块:

`timescale 1ns/1ns
`include "compare.v"
module compare_test;reg a,b;wire equal;initial begina=0;b=0;repeat(10)begin#100 a={$random}%10;b={$random}%10;end#100 $stop;endcompare m(.equal(equal),.a(a),.b(b));
endmodule

3-8译码器设计

实现模块:

module decoder(out,in);output[7:0] out;input[2:0] in;assign out=1'b1<<in;
endmodule

测试模块:

`timescale 1ns/1ns
`include "decoder.v"
module decoder_test;reg[2:0] in;wire[7:0] out;initialbeginin=0;#100 in=3'b000;#100 in=3'b001;#100 in=3'b010;#100 in=3'b011;#100  in=3'b100;#100 in=3'b101;#100 in=3'b110;#100 in=3'b111;#100 $stop;enddecoder m(.out(out),.in(in));
endmodule

这篇关于Verilog HDL语言组合逻辑电路设计实列的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

hdu4869(逆元+求组合数)

//输入n,m,n表示翻牌的次数,m表示牌的数目,求经过n次操作后共有几种状态#include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<queue>#include<set>#include<map>#include<stdio.h>#include<stdlib.h>#includ

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

怎么让1台电脑共享给7人同时流畅设计

在当今的创意设计与数字内容生产领域,图形工作站以其强大的计算能力、专业的图形处理能力和稳定的系统性能,成为了众多设计师、动画师、视频编辑师等创意工作者的必备工具。 设计团队面临资源有限,比如只有一台高性能电脑时,如何高效地让七人同时流畅地进行设计工作,便成为了一个亟待解决的问题。 一、硬件升级与配置 1.高性能处理器(CPU):选择多核、高线程的处理器,例如Intel的至强系列或AMD的Ry

基于51单片机的自动转向修复系统的设计与实现

文章目录 前言资料获取设计介绍功能介绍设计清单具体实现截图参考文献设计获取 前言 💗博主介绍:✌全网粉丝10W+,CSDN特邀作者、博客专家、CSDN新星计划导师,一名热衷于单片机技术探索与分享的博主、专注于 精通51/STM32/MSP430/AVR等单片机设计 主要对象是咱们电子相关专业的大学生,希望您们都共创辉煌!✌💗 👇🏻 精彩专栏 推荐订阅👇🏻 单片机

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

如何确定 Go 语言中 HTTP 连接池的最佳参数?

确定 Go 语言中 HTTP 连接池的最佳参数可以通过以下几种方式: 一、分析应用场景和需求 并发请求量: 确定应用程序在特定时间段内可能同时发起的 HTTP 请求数量。如果并发请求量很高,需要设置较大的连接池参数以满足需求。例如,对于一个高并发的 Web 服务,可能同时有数百个请求在处理,此时需要较大的连接池大小。可以通过压力测试工具模拟高并发场景,观察系统在不同并发请求下的性能表现,从而

C语言:柔性数组

数组定义 柔性数组 err int arr[0] = {0}; // ERROR 柔性数组 // 常见struct Test{int len;char arr[1024];} // 柔性数组struct Test{int len;char arr[0];}struct Test *t;t = malloc(sizeof(Test) + 11);strcpy(t->arr,