手画1-bit cpu架构

1-bit全手动处理器

处理器架构

在这里插入图片描述
在这里插入图片描述

控制信号

机器人和人类握手的照片

处理器程序(与操作)

Python代码截图

关键组件

命令行截图

1-bit半自动处理器

在这里插入图片描述
在这里插入图片描述

1-bit全自动处理器

在这里插入图片描述

python语言模拟1-bit 处理器

class OneBitProcessor:
    def __init__(self):
        self.reg_a = 0
        self.reg_b = 0
        self.alu = None

    def load(self, reg, value):
        if reg == 'A':
            self.reg_a = value
        elif reg == 'B':
            self.reg_b = value

    def add(self):
        self.alu = self.reg_a + self.reg_b

    def sub(self):
        self.alu = self.reg_a - self.reg_b

    def and_(self):
        self.alu = self.reg_a & self.reg_b

    def or_(self):
        self.alu = self.reg_a | self.reg_b

    def xor(self):
        self.alu = self.reg_a ^ self.reg_b

    def execute(self, instr):
        op = instr[0]
        if op == 'LOAD':
            reg, value = instr[1:]
            self.load(reg, value)
        elif op == 'ADD':
            self.add()
        elif op == 'SUB':
            self.sub()
        elif op == 'AND':
            self.and_()
        elif op == 'OR':
            self.or_()
        elif op == 'XOR':
            self.xor()
        print(f"ALU: {self.alu}")

    def run(self, program):
        for instr in program:
            self.execute(instr)
# 运行上面的程序
program = [('LOAD', 'A', 0), ('LOAD', 'B', 1), ('XOR',)]
processor = OneBitProcessor()
processor.run(program)
输出结果:
ALU: 0
ALU: 1
ALU: 1

用Verilog编写1-bit处理器

module OneBitProcessor(
    input clk, // 时钟信号
    input rst, // 复位信号
    input [1:0] opcode, // 操作码
    input [1:0] dataA, // 操作数 A
    input [1:0] dataB, // 操作数 B
    output [1:0] result // 操作结果
);

reg [1:0] reg; // 1-bit 寄存器,存储一个位
reg [1:0] alu; // 1-bit ALU,存储运算结果

always @(posedge clk) begin
    if (rst) begin // 复位操作
        reg <= 2'b0; // 将寄存器清零
        alu <= 2'b0; // 将 ALU 清零
    end else begin
        case (opcode) // 根据操作码执行操作
            2'b00: alu <= dataA & dataB; // AND
            2'b01: alu <= dataA | dataB; // OR
            2'b10: alu <= dataA + dataB; // ADD
            2'b11: alu <= dataA - dataB; // SUB
        endcase
        reg <= alu; // 将 ALU 结果存储到寄存器中
    end
end

assign result = reg; // 输出寄存器的值作为操作结果

endmodule
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值