Circuits-Combinational Logic-Karnaugh Map to circuit

1、3-variable

在这里插入图片描述

module top_module(
    input a,
    input b,
    input c,
    output out  ); 
    assign out = ~((~a)&(~b)&(~c));
endmodule

2、4-variable

在这里插入图片描述

module top_module(
    input a,
    input b,
    input c,
    input d,
    output out  ); 
    assign out = (~a)&(~d) | (~a)&(~b)&(~c) | (~a)&b&c | (~b)&(~c) | a&c&d;
endmodule

3、4-variable

在这里插入图片描述

module top_module(
    input a,
    input b,
    input c,
    input d,
    output out  ); 
    assign out = a | ((~a)&(~b)&c);
endmodule

4、4-variable

在这里插入图片描述

module top_module(
    input a,
    input b,
    input c,
    input d,
    output out  ); 
    assign out = (~a&b&~c&~d) | (a&~b&~c&~d) | 
        		 (~a&~b&~c&d) | (a&b&~c&d)   | 
       			 (~a&b&c&d)   | (a&~b&c&d)   | 
        		 (~a&~b&c&~d) | (a&b&c&~d);
endmodule

5、Minimum SOP and POS

A single-output digital system with four inputs (a,b,c,d) generates a logic-1 when 2, 7, or 15 appears on the inputs, and a logic-0 when 0, 1, 4, 5, 6, 9, 10, 13, or 14 appears. The input conditions for the numbers 3, 8, 11, and 12 never occur in this system. For example, 7 corresponds to a,b,c,d being set to 0,1,1,1, respectively.

SOP(Sum of Product):(c&d) | (~ a&~b&c)
POS(Product of Sum): ~ ((~ c|~d) & (a|b|~c))

module top_module (
    input a,
    input b,
    input c,
    input d,
    output out_sop,
    output out_pos
); 
    assign out_sop = (c&d) | (~a&~b&c);
    assign out_pos = ~((~c|~d) & (a|b|~c));
endmodule

6、Karnaugh map

在这里插入图片描述

module top_module (
    input [4:1] x, 
    output f );
    assign f = (~x[1] & x[3]) | (x[2] & x[4]);
endmodule

7、Karnaugh map

在这里插入图片描述

module top_module (
    input [4:1] x,
    output f
); 

    assign f = ~x[2]&~x[4] | ~x[1]&x[3] | x[2]&x[3]&x[4];
    
endmodule

8、K-map implemented with a multiplexer

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

module top_module (
    input c,
    input d,
    output [3:0] mux_in
); 
    always@(*) begin
        case({c,d})
            2'b00:mux_in = 4'b0100;
            2'b01:mux_in = 4'b0001;
            2'b11:mux_in = 4'b1001;
            default:mux_in = 4'b0101;
        endcase
    end
        
endmodule

参考资料:https://hdlbits.01xz.net/

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值