数字电路-基础逻辑门实验
基础逻辑门是数字电路设计的核心元件,它们执行的是基本的逻辑运算。通过这些基本运算,可以构建出更为复杂的逻辑功能。常见的基础逻辑门包括与门(AND)、或门(OR)、非门(NOT)、异或门(XOR)、与非门(NAND)和或非门(NOR)。这些逻辑门广泛应用于计算机、嵌入式系统以及各种数字电子设备中。
1、与门
1.1、符号
与门(AND gate),又称逻辑积电路。 只有当输入都为高电平(逻辑1)时,输出才为高电平(逻辑1),否则输出为低电平(逻辑0),与门逻辑符号(矩形国标符号与形状特征符号)如下所示。

1.2、与门真值表
| 输入 A | 输入 B | 输出 X(A & B) |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |
1.3、与门波形图
本质其实就是都是1就是1。

我们为什么在写 FPGA 时要先进行仿真,主要原因如下:
验证设计正确性:仿真可以在硬件实现之前验证逻辑设计的正确性。通过模拟输入信号并观察输出,设计者可以确保设计按照预期工作,及时发现并纠正逻辑错误。
减少硬件调试时间:在实际硬件上测试发现问题,调试往往非常耗时且复杂。通过在仿真环境中提前发现问题,可以大幅减少在FPGA硬件上的调试时间和成本。
功能验证:设计过程中,仿真可以用于验证各个功能模块的交互和整体系统的功能。确保模块之间的数据传输和控制信号的正确性。
提供的仿真例程文件都在对应工程的 sim 文件夹里面,如果想跟着一起写的话,先创建一个工程,工程里面包含 doc 、 rtl 、 sim 。
仿真文件 logical_and_mod.v 例程如下所示:
`timescale 1ns / 1ns // 定义时间单位为1纳秒,时间精度也为1纳秒module logical_and_mod(); // 模块定义,名称为logical_and_mod//reg define
reg A; // 定义A,作为输入信号
reg B; // 定义B,作为输入信号//wire define
wire X; // 定义逻辑与运算的输出// 初始化信号
initial beginA = 1'b0; // 将寄存器A初始化为0B = 1'b0; // 将寄存器B初始化为0#200; // 等待200纳秒A = 1'b0; // 设置A为0B = 1'b1; // 设置B为1#200; // 等待200纳秒A = 1'b1; // 设置A为1B = 1'b0; // 设置B为0#200; // 等待200纳秒A = 1'b1; // 设置A为1B = 1'b1; // 设置B为1#200; // 等待200纳秒
end// 例化
logical_and u_logical_and(.A(A), // 输入A.B(B), // 输入B.X(X) // 输出X,存储逻辑与运算结果
);endmodule // 模块结束
initial begin 表示 初始化过程,在仿真开始时执行。
在 initial 块内,给 A 和 B 分别赋值,并使用 #200 来表示等待 200 纳秒。
1'b0 表示 1 位的二进制值 0。
1'b1 表示 1 位的二进制值 1。
总共进行 4 次信号的变化,每次设置不同的值,然后等待 200 纳秒。
第一次: A = 0, B = 0
第二次: A = 0, B = 1
第三次: A = 1, B = 0
第四次: A = 1, B = 1
module logical_and(input A, //输入 Ainput B, //输入 Boutput X //输出 X);assign X = A & B; //将输入 A & B 的结果直接赋值给 输出 Xendmodule
module logical_and(...):这是一个名为 logical_and 的 Verilog 模块定义。这个模块实现了逻辑与(AND)运算。
input A:定义了输入端口 A,它是一个 1 位二进制输入信号。
input B:定义了输入端口 B,它也是一个 1 位二进制输入信号。
output X:定义了输出端口 X,它是一个 1 位二进制输出信号,用于存储逻辑与运算的结果。
assign X = A & B;:这是 Verilog 中的 连续赋值语句,表示将 A 和 B 进行 按位与(AND) 运算的结果直接赋值给输出端口 X。
A & B:对输入信号 A 和 B 进行 按位与(AND) 运算,运算规则如下:
0 AND 0 = 0
0 AND 1 = 0
1 AND 0 = 0
1 AND 1 = 1
结果 X 只会在 A 和 B 都为 1 时为 1,否则为 0。

相关文章:
数字电路-基础逻辑门实验
基础逻辑门是数字电路设计的核心元件,它们执行的是基本的逻辑运算。通过这些基本运算,可以构建出更为复杂的逻辑功能。常见的基础逻辑门包括与门(AND)、或门(OR)、非门(NOT)、异或门…...
新数据结构(9)——Java异常体系
异常的种类 程序本身通常无法主动捕获并处理错误(Error),因为这些错误通常表示系统级的严重问题,但程序可以捕获并处理异常(Excrption),而Error则被视为一种程序无法或不应尝试恢复的异常类型。…...
每日十题八股-补充材料-2025年2月15日
1.TCP是如何保证消息的顺序和可靠的? 写得超级好的文章 首先肯定是三次握手和四次挥手保证里通讯双方建立了正确有效的连接。 其次是校验和、序列号,ACK消息应答机制还有重传机制,保证了消息顺序和可靠。 同时配合拥塞机制和流量控制机制&am…...
使用 Python 爬虫获取微店快递费用 item_fee API 接口数据
在电商运营中,快递费用是影响商家利润和用户体验的重要因素之一。微店作为国内知名的电商平台,提供了丰富的 API 接口供开发者使用,其中也包括查询商品快递费用的接口。通过调用微店的 item_fee 接口,开发者可以获取指定商品的快递…...
通过用户名和密码登录服务器有哪些方法
通过用户名和密码登录到服务器的方式取决于你使用的工具和协议。以下是几种常见的方法: 1. 使用 SSH 登录到 Linux 服务器 你可以通过 SSH(Secure Shell)使用用户名和密码连接到远程服务器。通常,你会使用 ssh 命令来进行连接。…...
sort快排
当然可以!让我们通过类似的详细步骤来解释 快速排序(Quick Sort) 的原理和实现,就像之前解释 a &= (a - 1) 的原理一样。 快速排序(Quick Sort)原理 快速排序是一种高效的排序算法,其核心思想是分而治之。它通过选择一个“基准值”(pivot),将数组分为两部分: …...
用xml配置spring, bean标签有哪些属性?
用xml配置spring, bean标签有哪些属性? 在Spring框架中,使用XML配置文件时,<bean>标签用于定义一个Bean。以下是一些常用的<bean>标签属性: 1. class 描述:指定Bean的类名。示例:<bean id"myBe…...
纪念日倒数日项目的实现-【纪念时刻-时光集】
纪念日/倒数日项目的实现## 一个练手的小项目,uniappnodemysql七牛云。 在如今快节奏的生活里,大家都忙忙碌碌,那些具有特殊意义的日子一不小心就容易被遗忘。今天,想给各位分享一个“纪念日”项目。 【纪念时刻-时光集】 一…...
无人机不等同轴旋翼架构设计应用探究
“结果显示,对于不等组合,用户应将较小的螺旋桨置于上游以提高能效,但若追求最大推力,则两个相等的螺旋桨更为理想。” 在近期的研究《不等同轴旋翼性能特性探究》中,Max Miles和Stephen D. Prior博士深入探讨了不同螺…...
1-8 gitee码云的注册与使用
码云的网址:Gitee - 基于 Git 的代码托管和研发协作平台 这是一个国内的托管代码平台,速度要比国外的快 1.0 注册 如何注册码云? 查考文章:https://jingyan.baidu.com/article/425e69e6a8cad6ff14fc1615.html 2.0 使用 使用码云进…...
嵌入式硬件篇---OpenMV的硬件流和软件流
文章目录 前言一、硬件流控制(Hardware Flow Control)1. 基本原理RTSCTS 2. OpenMV中的实现• 硬件要求• 代码配置• 工作流程 二、软件流控制(Software Flow Control)1. 基本原理XONXOFF 2. OpenMV中的实现• 代码配置• 工作流…...
Word 里面嵌入DeepSeek
目录 一、问题描述 二、解决方法 三、代码 四、注意事项 五、总结 一、问题描述 如何在Word里面嵌入DeepSeek? 二、解决方法 1、新建文档,按 AltF11,进入VB界面。 2、选中文档,右键->插入->模块。 3、进入模块,粘入…...
聊聊 IP 地址和端口号的区别
在计算机网络中,两个基本概念对于理解设备如何通过网络进行通信至关重要。IP 地址和端口号是 TCP/IP 的典型特征,其定义如下:IP 地址是分配给连接到网络的每台机器的唯一地址,用于定位机器并与其通信。相反,端口号用于…...
rust学习一、入门之搭建简单开发环境
1、搭建开发环境(windows11) a.登录官网 一看就明白,此处略。 b.安装rustup 一看就明白,此处略。 c.安装 cargo script 或者 rust-script script cargo install cargo-script 完成后 注意:时间有一点点久。 测试 cargo s…...
浅聊MQ之Kafka与RabbitMQ简用
(前记:内容有点多,先看目录再挑着看。) Kafka与RabbitMQ的使用举例 Kafka的使用举例 安装与启动: 从Apache Kafka官网下载Kafka中间件的运行脚本。解压后,通过命令行启动Zookeeper(Kafka的运行…...
【原创】解决vue-element-plus-admin无法实现下拉框动态控制表单功能,动态显隐输入框
前言 目前使用vue-element-plus-admin想要做一个系统定时任务功能,可以选择不同的定时任务类型,比如使用cron表达式、周期执行、指定时间执行等。每种类型对应不同的输入框,需要动态显隐输入框才行,但是这个vue-element-plus-adm…...
SpringBoot开发——初步了解SpringBoot
文章目录 一、SpringBoot简介 1、什么是Spring Boot2、Spring Boot的优点3、Spring Boot功能 二、Spring与Spring Boot对比三、Spring Boot与Spring MVC四、Spring Boot体系结构五、Springboot Initializr 1、Spring Initializr2、Spring Initializr模块 一、SpringBoot简介…...
双轴伺服电机驱动控制器AGV、AMR专用双伺服电机驱动控制器解决方案
工业机器人数控机床XY机械手双轴机器人堆垛机专用双轴伺服电机驱动控制器48V 14ARMS带有STO功能,隔离高压CAN/RS485/USB通讯支持编码器和霍尔输入 双伺服电机驱动控制器TMCM2611功能介绍 集成2个伺服电机的控制和驱动于一体供电电压48V,驱动电流14A RM…...
【VB语言】EXCEL中VB宏的应用
【VB语言】EXCEL中VB宏的应用 文章目录 [TOC](文章目录) 前言一、EXCEL-VB1.实验过程2.代码 二、EXCEL-VB 生成.c.h文件1.实验过程2.代码 四、参考资料总结 前言 1.WPS-VB扩展包 提示:以下是本篇文章正文内容,下面案例可供参考 一、EXCEL-VB 1.实验过…...
Ubuntu添加桌面快捷方式
以idea为例 一. 背景 在ubuntu中,很多时候是自己解压的文件并没有桌面快捷方式,需要自己找到对应的目录的执行文件手动打开,很麻烦 而只需要在 /usr/share/applications 中创建自定义的desktop文件就能自动复制到桌面 二. 添加方法 创建desk…...
基于Xilinx Open-NIC-Shell的FPGA智能网卡开发实战指南
1. 项目概述:当FPGA遇见网卡,一场硬件加速的范式革命如果你是一名数据中心网络工程师、高性能计算(HPC)开发者,或者对低延迟、高吞吐网络处理有极致追求的硬件爱好者,那么“Xilinx/open-nic-shell”这个名字…...
AutoCoder:基于LLM的智能编程副驾,实现上下文感知的代码生成与重构
1. 项目概述:当AI成为你的编程副驾最近在GitHub上看到一个挺有意思的项目,叫bin123apple/AutoCoder。光看名字,你可能会觉得这又是一个“自动写代码”的玩具,或者一个简单的代码补全工具。但如果你像我一样,花点时间深…...
手把手教你用Python搞定KS Web端滑块注册(附完整代码与代理配置)
Python实战:KS Web端滑块验证破解与高效注册方案 每次遇到滑块验证码都让人头疼不已?特别是需要批量注册KS账号时,那些看似简单的滑块却成了数据采集路上的绊脚石。今天我们就来彻底解决这个问题——不是简单地绕过滑块,而是完整模…...
gh_mirrors/in/invoice部署实战:从开发到生产环境的完整迁移指南
gh_mirrors/in/invoice部署实战:从开发到生产环境的完整迁移指南 【免费下载链接】invoice Collaboration with wangxupeng(https://github.com/wangxupeng) 项目地址: https://gitcode.com/gh_mirrors/in/invoice gh_mirrors/in/invoice是一个基于YOLOv3CRN…...
StructBERT零样本分类-中文-base实时流式:Kafka接入+微批处理+低延迟分类流水线
StructBERT零样本分类-中文-base实时流式:Kafka接入微批处理低延迟分类流水线 1. 项目概述 StructBERT零样本分类-中文-base是一个强大的中文文本分类工具,它最大的特点是无需训练就能直接使用。想象一下,你拿到一堆中文文本,想…...
Prism:AI辅助开发的SwiftUI菜单栏工具,统一管理Claude API配置
1. 项目概述与核心价值如果你和我一样,日常开发、写作或者处理信息时,Claude 已经成了离不开的助手,那你肯定也遇到过这个痛点:手头有好几个不同的 AI 服务提供商,有的是官方的 Claude API,有的是国内大厂提…...
2025届必备的五大降AI率神器推荐榜单
Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 关乎维普检测系统之所涉 AI 降重计策要着重于文本之重新构建以及逻辑之 remodel。首先&#…...
命令行AI助手chatgpt-cli:集成LLM到终端工作流的完整指南
1. 项目概述:一个全能型命令行AI助手如果你和我一样,每天大部分时间都泡在终端里,那你肯定也想过:要是能把ChatGPT直接集成到命令行工作流里,该有多方便。不用再频繁切换浏览器标签,不用复制粘贴࿰…...
GIMP Resynthesizer:5分钟掌握图像修复与纹理合成的终极指南
GIMP Resynthesizer:5分钟掌握图像修复与纹理合成的终极指南 【免费下载链接】resynthesizer Suite of gimp plugins for texture synthesis 项目地址: https://gitcode.com/gh_mirrors/re/resynthesizer GIMP Resynthesizer是一套功能强大的GIMP插件套件&am…...
基于Framer Motion与Tailwind CSS的React动画组件库深度实践
1. 项目概述与核心价值如果你和我一样,是个对前端交互体验有“强迫症”的开发者,那你肯定也经历过这样的时刻:面对一个设计精美的UI稿,却苦于找不到现成的、动画效果足够丝滑且高度可定制的组件库。市面上的组件库要么动画生硬&am…...
