找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1378|回复: 1
打印 上一主题 下一主题
收起左侧

VHDL四选一的结构描述

[复制链接]
跳转到指定楼层
楼主
ID:833673 发表于 2023-3-17 15:42 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
VHDL语句的四选一结构描述
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;

entity erxuanyi is
    Port ( A, B, Sel : in std_logic;
           Y : out std_logic);
end erxuanyi;
architecture Behavioral of erxuanyi is
begin
    Y <= A when Sel = '0' else B;
end Behavioral;

library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
entity sixuanyi is
    Port ( A, B, C, D, Sel : in std_logic_vector(1 downto 0);
           Y : out std_logic);
end sixuanyi;

-- 实现模块
architecture Behavioral of sixuanyi is

    -- 元件例化
    component erxuanyi
        Port ( A, B, Sel : in std_logic;
               Y : out std_logic);
    end component;

    -- 信号定义
    signal AB, CD : std_logic;
begin

    -- 实例化二选一模块
    U1: erxuanyi port map (A => A(0), B => B(0), Sel => Sel(0), Y => AB);
    U2: erxuanyi port map (A => C(0), B => D(0), Sel => Sel(0), Y => CD);

    -- 连接选择信号
    U3: erxuanyi port map (A => AB, B => CD, Sel => Sel(1), Y => Y);

end Behavioral;


verilog语句的四选一结构描述
module erxuanyi(
    input A, B, Sel,
    output Y
);

    assign Y = (Sel == 1'b0) ? A : B;

endmodule

module sixuanyi(
    input [1:0] A, B, C, D, Sel,
    output Y
);

    wire AB, CD;

    erxuanyi U1(
        .A(A[0]), .B(B[0]), .Sel(Sel[0]),
        .Y(AB)
    );

    erxuanyi U2(
        .A(C[0]), .B(D[0]), .Sel(Sel[0]),
        .Y(CD)
    );

    erxuanyi U3(
        .A(AB), .B(CD), .Sel(Sel[1]),
        .Y(Y)
    );

endmodule

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:1005954 发表于 2023-5-10 15:34 | 只看该作者
为什么有两个实体名啊erxuanyi和sixuanyi
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表