[Digital IC]C语言实现硬件加法器

// ConsoleApplication1.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//

#include "pch.h"
#include <iostream>
#include <stdlib.h>

typedef unsigned char uchar;

typedef struct
{
	unsigned char sum;
	unsigned char carry;
}ADD_Result;

uchar AND(uchar a, uchar b);						//2-1 与门
uchar OR(uchar a, uchar b);							//2-1 或门
uchar NOT(uchar a);									//1-1 非门		
uchar XOR(uchar a, uchar b);						//2-1 异或门

ADD_Result* ADD_Cell_1(uchar a, uchar b, uchar c);
ADD_Result* ADD_Cell_8(uchar a, uchar b, uchar c);

int main()
{
	uchar a, b, c;
	ADD_Result* add_1_bit;
	ADD_Result* add_8_bit;
	
	//测试单个加法器
	for (a = 0; a <= 1; a++)
	{
		for (b = 0; b <= 1; b++)
		{
			for (c = 0; c <= 1; c++)
			{
				add_1_bit = ADD_Cell_1(a, b, c);
				printf("%d,%d,%d:s:%d c:%d\n", a, b, c, add_1_bit->sum, add_1_bit->carry);
				free(add_1_bit);
			}
		}
	}
	printf("\n\n");

	
	//测试8位加法器
	//测试单个加法器
	for (a = 55; a <= 80; a++)
	{
		for (b = 160; b <= 190; b++)
		{	
			add_8_bit = ADD_Cell_8(a, b, 0);
			printf("%d,%d,%d:s:%d c:%d\n", a, b, 0, add_8_bit->sum, add_8_bit->carry);
			free(add_8_bit);
		}
	}
	 
	 
}

ADD_Result* ADD_Cell_8(uchar a, uchar b, uchar c)
{
	int bit_location;//0 最低位

	ADD_Result* result = (ADD_Result*)malloc(sizeof(ADD_Result));
	result->sum = 0;
	result->carry = 0;

	uchar c_bit = c & 0x1;

	for (bit_location = 0; bit_location < 8; bit_location++)
	{
		uchar a_bit = (a >> bit_location) & 0x1;
		uchar b_bit = (b >> bit_location) & 0x1;
		
		//计算一位加法
		ADD_Result* result_1_bit;
		result_1_bit = ADD_Cell_1(a_bit, b_bit, c_bit);
		
		//累加到8位加法中
		result->sum	|= result_1_bit->sum << bit_location;
		c_bit		 = result_1_bit->carry;

		//释放一位加法结果
		free(result_1_bit);
		
	}
	result->carry = c_bit;

	return result;
}

//一位加法器
ADD_Result* ADD_Cell_1(uchar a, uchar b, uchar c)
{
	ADD_Result* result = (ADD_Result*)malloc(sizeof(ADD_Result));

	//输出
	result->sum		= XOR(XOR(a,b),c);
	result->carry	= OR(AND(b,c),AND(a,XOR(b,c)));

	return result;
}

//与门
uchar AND(uchar a, uchar b)
{
	a = a & 0x1;
	b = b & 0x1;

	return (a & b);
}

//或门
uchar OR(uchar a, uchar b)
{
	a = a & 0x1;
	b = b & 0x1;

	return (a | b);
}

//非门
uchar NOT(uchar a)
{	
	a = ~a & 0x1;

	return a;
}

//异或门
uchar XOR(uchar a, uchar b)
{	
	a = a & 0x1;
	b = b & 0x1;

	uchar c = OR(AND(NOT(a),b),AND(NOT(b),a));

	return c;
}


// 运行程序: Ctrl + F5 或调试 >“开始执行(不调试)”菜单
// 调试程序: F5 或调试 >“开始调试”菜单

// 入门提示: 
//   1. 使用解决方案资源管理器窗口添加/管理文件
//   2. 使用团队资源管理器窗口连接到源代码管理
//   3. 使用输出窗口查看生成输出和其他消息
//   4. 使用错误列表窗口查看错误
//   5. 转到“项目”>“添加新项”以创建新的代码文件,或转到“项目”>“添加现有项”以将现有代码文件添加到项目
//   6. 将来,若要再次打开此项目,请转到“文件”>“打开”>“项目”并选择 .sln 文件

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在MATLAB中,您可以使用量子计算工具箱(Quantum Computing Toolbox)来创建全加法器的量子电路。下面是一个示例代码,展示了如何在MATLAB中创建一个简单的全加法器量子电路: ```matlab % 导入量子计算工具箱 import qctoolkit.* % 创建量子寄存器和经典寄存器 qreg = quantreg(3); % 3位输入寄存器 creg = classreg(2); % 2位输出寄存器 % 创建量子电路 qcircuit = circuit(qreg, creg); % 添加量子门操作 qcircuit.h(qreg(1)); % 应用Hadamard门到第一个输入位 qcircuit.cx(qreg(1), qreg(2)); % 应用CNOT门,控制位为第一个输入位,目标位为第二个输入位 qcircuit.cx(qreg(1), qreg(3)); % 应用CNOT门,控制位为第一个输入位,目标位为第三个输入位 qcircuit.ccx(qreg(2), qreg(3), qreg(1)); % 应用Toffoli门,控制位为第二个和第三个输入位,目标位为第一个输入位 % 测量输出寄存器 qcircuit.measure(qreg(2), creg(1)); % 测量第二个输入位并将结果存储在第一个输出位 qcircuit.measure(qreg(3), creg(2)); % 测量第三个输入位并将结果存储在第二个输出位 % 显示量子电路 disp(qcircuit); ``` 这段代码使用量子计算工具箱创建了一个3位输入和2位输出的全加法器量子电路。首先,我们导入了qctoolkit库。然后,我们创建了一个3位输入寄存器和一个2位输出寄存器。接下来,我们使用`circuit`函数创建了一个量子电路对象。在量子电路中,我们添加了一系列的量子门操作,包括Hadamard门、CNOT门和Toffoli门,以模拟全加法器的功能。最后,我们使用`measure`函数将输出位进行测量,并将结果存储在相应的经典寄存器中。最后,我们使用`disp`函数显示了生成的量子电路。请注意,这只是一个简单的示例,您可以根据自己的需求和具体的全加法器电路设计进行更复杂的量子电路构建。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值