【FPGA】如何理解全加器

一丶什么是全加器

半加器比较容易理解,它的电路指对两个输入数据位(a、b)相加,输出一个结果位(sum)和进位(cout),但没有计算进位输入的加法器电路。
在这里插入图片描述

输出表达式
S = A ˉ B + A B ˉ = A ⊕ B {S=\bar{A}B+A\bar{B}=A\oplus B} S=AˉB+ABˉ=A⊕B
C = A B {C=AB} C=AB

相比半加器,全加器是将低位进位输入也代入计算的加法电路,同样输出一个结果位和进位。1位全加器就是计算带进位输入的 1位二进制数的加法电路,多个一位全加器进行级联可以得到多位全加器。

这里我们来理解一下低位进位和本位加法进位
对照真值表:
在这里插入图片描述

一开始的运算Ci-1=0,因为之前的运算没有产生进位,直至Ai=Bi=1时产生进位。 即: 0+0输出结果Si=0,没有进位,所以Ci=0.
1+0输出结果Si=1,没有进位,所以Ci=0. 1+1,根据二进制运算法则,进位,Ci=1,进位后输出结果清零,Si=0

在这里插入图片描述

二丶1位全加器的Verilog实现

module full_add2
(
	input a,
	input b,
	input cin,
	output sum,
	output cout
);
	assign sum = a^b^cin;
	assign cout = (a&b)|((a^b)&cin);
endmodule

三丶深层解析sum及cout表达式的逻辑

对于代码中sum和cout的算式我们来进行分析:

首先考虑输出cout的逻辑表达式,什么条件下进位输出cout为1???分两种情况:

1、a和b相加已经产生进位。说明a和b都为1,此时不管cin是1还是0,不影响cout输出,这种情况对应逻辑表达式(a&b)
  
2、a和b相加没有产生进位。说明a和b都为0(此时不管cin是何值,进位输出cout都不会为1),或a、b其中一个为1,另一个为0,此时a与b不相同,用异或逻辑表示便是(a^b),这种条件下只有cin为1时,进位输出才为1,对应逻辑表达为(a ^b)&cin

总结1(cout):将上述两种情况加起来就是cout的逻辑表示,或逻辑表示加和,所以最终cout逻辑表达式为:cout = (a&b) | ((a^b)&cin)。
另外对于sum思考下,什么条件下sum输出逻辑1???sum由输入cin,被加数a,加数b,三者加和得到,若想结果sum为1,则cin,a,b三个数中,必然要有奇数个1(若有偶数个1,则二进制数加和,必会产生进位使得最低位sum为0)。
可以首先判断a,b是否相同,使用异或逻辑(a^b),然后分两种情况谈论:
1、a^b=1。说明a和b不相同,则必然一个为0,一个为1,此时已经存在一个1,那cin必须要为0才能使得sum为1,此时 (a ^b) 与cin相异,所以使用异或逻辑来描述这种情况 (a ^b) ^cin

2、a^b=0。说明a和b相同,同时为0或同时为1;此时不管哪种情况,cin必须要为1才能使得sum为1,此时 (a ^b) 与cin仍然相异,所以还使用异或逻辑来描述这种情况 (a ^b) ^cin

总结2(sum):综合上述两种情况,a ^b ^cin为sum的逻辑表达通式,用以计算a,b,cin中1的个数(奇偶),以此赋值sum是否为1。

参考文章:https://blog.csdn.net/weixin_42294124/article/details/119853457

### FPGA全加器烧写结果 对于FPGA全加器的设计,在完成硬件描述语言(通常是Verilog或VHDL)编写并成功通过仿真验证后,下一步就是将设计下载到实际设备上。这一过程通常涉及使用厂商提供的开发工具链,如Xilinx Vivado、Lattice Diamond 或 Radiant等软件进行综合、映射、布局与布线操作,最终生成用于配置的目标文件(bit流)[^2]。 #### 成功烧写的预期行为 一旦bitstream被加载至FPGA器件内核中,理论上该器件应能按照所定义的功能逻辑运行——即作为一位或多比特位宽度的二进制数相加机器工作。具体来说,输入端口接收两个待求和的操作数以及可能存在的低位进位信号;而输出则提供相应的和值及其产生的高位进位标志。如果一切正常,则可以通过连接外部I/O接口观察到正确的算术运算结果[^1]。 ```verilog // Verilog code snippet for a simple full adder module module FullAdder( input A, input B, input Cin, // Carry-in output Sum, output Cout // Carry-out ); assign {Cout,Sum} = A + B + Cin; endmodule ``` #### 常见问题及解决方案 - **未能正确识别硬件资源** 设计者可能会发现某些特定类型的内部组件未按预期方式实例化。这可能是由于选择了不兼容的目标平台或是误用了IP核心造成的。解决办法是仔细检查项目设置中的目标板卡型号,并确保所有使用的库函数都适用于选定架构版本。 - **时序约束违规** 当合成后的电路无法达到指定的工作频率要求时会发生这种情况。优化路径可以包括调整寄存器之间的延迟分配策略、减少组合逻辑深度或者利用更高效的算法结构重写原始RTL源码。 - **电源管理不当** 不充分考虑供电条件可能导致不稳定现象甚至永久损坏敏感元件。建议遵循制造商给出的最佳实践指南来进行PCB布局规划,并采用适当去耦电容器来稳定电压水平。 - **调试困难** 缺乏有效的诊断手段使得定位错误变得棘手。集成在线监测单元可以帮助收集实时数据以便后续分析;另外也可以借助第三方测试框架辅助排查潜在缺陷所在位置。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值