- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 VHDL 的新手,我正在尝试实现一个在 ABEL 中看起来像的真值表:
Truth-table
([C2.FB, C1.FB, C0.FB, DISABLE] -> [A, B])
[ X , X , X , 1 ] -> [0, 0];
[ 0 , 0 , 0 , 0 ] -> [0, 3];
[ 0 , 0 , 1 , 0 ] -> [3, 5];
[ 0 , 1 , 0 , 0 ] -> [5, 6];
[ 0 , 1 , 1 , 0 ] -> [6, 7];
[ 1 , 0 , 0 , 0 ] -> [7, 6];
[ 1 , 0 , 1 , 0 ] -> [6, 5];
[ 1 , 1 , 0 , 0 ] -> [5, 3];
[ 1 , 1 , 1 , 0 ] -> [3, 0];
据我所知,VHDL 中没有对真值表的真正支持,但也许“with select 语句”已经很接近了?
with C select
A <= std_logic_vector(to_unsigned(0, A'length)) when "000",
std_logic_vector(to_unsigned(3, A'length)) when "001",
std_logic_vector(to_unsigned(5, A'length)) when "010",
std_logic_vector(to_unsigned(6, A'length)) when "011",
...
是否可以在同一条语句中同时对 A 和 B 进行赋值?例如:
A,B <= 0,3 when "000",
3,5 when "001",
...
还是我必须做几条陈述(对于长表来说很烦人)?我该如何处理 DISABLE 信号?有没有更好更聪明的方法来做到这一点?
感谢您的帮助!
最佳答案
如果有预定义的 VHDL 机制,为什么要使用真值表...?
B <= "000" when (disable = '1') else A;
C <= "000" when (disable = '1') else not A;
或者如果需要作为整数结果
B <= 0 when (disable = '1') else to_integer(unsigned(A));
C <= 0 when (disable = '1') else to_integer(unsigned(not A));
你可以这样写一个函数 mux(...) 或称它为 ite(...)(if-then-else 的缩写):
function ite(condition : boolean; a : std_logic_vector; b : std_logic_vector) return std_logic_vector is
begin
if (cond = true) then
return a;
else
return b;
end if;
end function;
现在你可以把上面的语句写得更短一些:
B <= ite((disable = '1'), "000", A);
C <= ite((disable = '1'), "000", not A);
用基本的 bool 运算计算结果。您可以将禁用信号放大到与 A 宽度一样多的位,然后使用合取运算符。 (这也称为“A is gated by disable”或门电路)。
B <= (A'range => disable) and A;
C <= (A'range => disable) and not A;
我的示例现在使用类型转换(您的示例将 std_logic_vector 作为输入和输出)。如果需要,请随意添加转换函数,如 unsigned(..) 或 to_integer(..)。
如果你真的想实现真值表,我建议使用 ROM。所以定义一个常量,其内容由 es 函数(预)计算。然后将您的输入用作 ROM 地址,并将选定的输出用作结果。
这里是一个使用整数作为结果的例子
subtype t_uint3 : integer range 0 to 7;
type t_uint3_vector is array (natural range <>) of t_uint3;
constant B_TRUTH_TABLE : t_uint3_vector(7 downto 0) := (0, 1, 2, 3, 4, 5, 6, 7);
constant C_TRUTH_TABLE : t_uint3_vector(7 downto 0) := (7, 6, 5, 4, 3, 2, 1, 0);
B <= B_TRUTH_TABLE(to_integer(unsigned(A)));
C <= C_TRUTH_TABLE(to_integer(unsigned(A)));
此示例现在具有禁用功能。要添加它,请将 ROM 与上述语句之一结合使用。
使用函数进行预计算:将元素列表 (0, 1, ..., 7) 替换为如下函数:
function precalc_B_ROM return t_uint3_vector is
variable result : t_uint3_vector(7 downto 0);
begin
for i in result'range loop
result(i) := i;
end loop;
return result;
end function;
function precalc_C_ROM return t_uint3_vector is
variable result : t_uint3_vector(7 downto 0);
begin
for i in result'range loop
result(i) := result'high - i; -- reverse numbers
end loop;
return result;
end function;
constant B_TRUTH_TABLE : t_uint3_vector(7 downto 0) := precalc_B_ROM;
constant C_TRUTH_TABLE : t_uint3_vector(7 downto 0) := precalc_C_ROM;
计算多个结果的组合过程。
process(inA, inB, ...)
begin
-- default assignments
outX <= '0';
outY <= '0';
outZ <= '0';
case (inA & inB) is
when "00" =>
outY <= '1';
outZ <= '1';
when "01" =>
outX <= '1';
outY <= '1';
[...]
when others =>
outZ <= '1';
end case;
end process;
(默认赋值减少了 when 语句和时钟进程中的代码行,阻碍了生成锁存器的综合。)
因此,如果您返回一条记录并将结果拆分为子结果,或者如果您使用具有多个分配的案例,那么这是一个编码问题。
附录提供的 ROM 也可以返回一条记录。 => 1) 定义您的结果记录; 2)将这条记录打包成一个新的数组/向量类型; 3)定义一个新类型的ROM; 4) 通过地址访问ROMs条目->结果就是你请求的记录。
关于vhdl - 从同一语句分配两个信号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24207176/
同时使用 VHDL-2019 IEEE 规范部分。 5.2.3.1.一般 "However, an implementation shall allow the declaration of any
我正在设计通用移位算术运算符。除了以下面介绍的方式使用 32 位多路复用器(解码器)之外,还有更好的方法来实现它吗? ENTITY isra IS PORT ( clk: in std_lo
描述:我正在尝试编写一个具有 4 个输入和 3 个输出的 LUT(查找表)的 vhdl 模块。我希望我的 3 位输出是一个二进制数,等于输入中 1 的个数。 我的真值表: ABCD|XYZ 0000|
我想使用 vhdl 制作幂函数,其中幂是浮点数,数字是整数(将始终为“2”)。 2^ 一些浮点数。 我使用 ieee 库和(fixed_float_types.all、fixed_pkg.all 和
是否有可能有一个通用的包? 这意味着当我实例化实体时,我提供了一些泛型,包将依赖于它。 我有一个块,我想多次使用,每次使用不同的包(即不同的参数) 我必须使用包,因为我想使用数组数组,而我只能使用包来
使用 VHDL,我希望有一些寄存器在每个寄存器中存储 16 位。 所以我发现 VHDL 有一个内置数组,我想用它在 iy 中的每个元素中存储 16 位,所以我想知道 VHDL 是否将此数组映射到实际寄
在 vhdl 中我可以定义我自己的枚举类型并创建这种类型的信号: type tp is (red,green,blue,yellow); signal sg: tp := red; 但现在我想要一个
我是 VHDL 的新手。 有一行,如下所示: constant TIME_DELTA : time := 100 ns; 这是什么字time在行吗?是不是和integer一样的数据类型?当我在互联网上
A <= 3 * B; 上面语句中的3是一个整数或自然数。如果它是自然数,如果我在那里使用负数怎么办? VHDL 是否将其识别为整数? 最佳答案 整数文字属于匿名预定义类型universal_inte
我为以下 vhdl 代码编写了测试平台: library ieee; USE ieee.std_logic_1164.all; ---USE ieee.std_logic_unsigned.all;
我有使用 Verilog/SystemVerilog 的经验,但我是 VHDL 新手,我试图弄清楚何时应该使用组件实例化或实体实例化。我所说的组件实例化是指在实例化实体组件之前声明实体组件的传统方式。
我一直无法理解如何在 VHDL 中取消引用指针。 我想到的是一个 C 代码,如: int a; int* ptr_a; a = 42; ptr_a=&a; *ptr_a=451;/
我为以下 vhdl 代码编写了测试平台: library ieee; USE ieee.std_logic_1164.all; ---USE ieee.std_logic_unsigned.all;
我想知道VHDL中是否定义了整数溢出。我在 2002 年规范中找不到任何内容。 作为示例(注意,这可能无法编译,它只是一个通用示例...): entity foo is port ( clk
如何组合/捆绑语句以供进一步使用和更好地处理?例如,像这样的一些赋值会在以后的例程调用中多次使用。 ADDR_PC '0'); constant OP_NOP: std
我正在编写一个 IP 核,根据用户选择的通用参数,并非所有 OUT/IN 端口都是必需的。是否可以有可选端口?我知道类似的事情应该是可能的,因为当我使用 Xilinx IP-Cores 时,根据参数,
我有一个数组: type offsets_type is array (4 downto 0) of std_logic_vector (4 downto 0); signal av : of
type有什么区别和 subtype在 VHDL 中,我应该在哪里使用它们? 我的理解是subtype只是主要类型之一的缩小版本,例如 integer :subtype small_integer i
我试图更好地使用 VHDL protected 类型,所以我将以下测试放在一起(当然只是为了说明 - 我的实际用例要复杂得多): type prot_type1 is protected proc
首先,我想声明这是我参加的模拟考试。我知道答案是:cout = 4ns,S = 7ns。只是在寻找一点解释。提前致谢。 对于下面所示的全加器的 VHDL 实现,输出 cout 和 S 何时稳定在它们的
我是一名优秀的程序员,十分优秀!