- 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/
创建一个“海盗对话”,可以选择左手或右手。我希望它对“左”和“右”的不同拼写做出积极的回答(正如您将在代码中看到的那样),但是,当我为所有非“右”或“左”的输入添加最终的“else”代码时,它给了我一
With 语句 对一个对象执行一系列的语句。 With object statements End With 参数 object 必需的部分
While...Wend 语句 当指定的条件为 True 时,执行一系列的语句。 While condition  ; Version [stat
所以我正在处理的代码有一个小问题。 while True: r = input("Line: ") n = r.split() if r == " ":
我有一个对象数组: var contacts = [ { "firstName": "Akira", "lastName": "Laine", "number"
int main() { int f=fun(); ... } int fun() { return 1; return 2; } 在上面的程序中,当从main函数中调用一个
我的项目中有很多 if 语句、嵌套 if 语句和 if-else 语句,我正在考虑将它们更改为 switch 语句。其中一些将具有嵌套的 switch 语句。我知道就编译而言,switch 语句通常更
Rem 语句 包含程序中的解释性注释。 Rem comment 或 ' comment comment 参数是需要包含的注释文本。在 Rem 关键字和 comment 之间应有一个空格。
ReDim 语句 在过程级中声明动态数组变量并分配或重新分配存储空间。 ReDim [Preserve] varname(subscripts) [, varname(subscripts)]
Randomize 语句 初始化随机数生成器。 Randomize [number] number 参数可以是任何有效的数值表达式。 说明 Randomize 使用 number 参数初始
Public 语句 定义公有变量并分配存储空间。在 Class 块中定义私有变量。 Public varname[([subscripts])][, varname[([subscripts])
Sub 语句 声明 Sub 过程的名称、参数以及构成其主体的代码。 [Public [Default]| Private] Sub name [( arglist )]
Set 语句 将对象引用赋给一个variable或property,或者将对象引用与事件关联。 Set objectvar = {objectexpression | New classname
我有这个代码块,有时第一个 if 语句先运行,有时第二个 if 语句先运行。我不确定为什么会这样,因为我认为 javascript 是同步的。 for (let i = 0; i < dataObje
这是一个 javascript 代码,我想把它写成这样:如果此人回答是,则回复“那很酷”,如果此人回答否,则回复“我会让你开心”,如果此人回答的问题包含"is"或“否”,请说“仅键入”是或否,没有任何
这是我的任务,我尝试仅使用简短的 if 语句来完成此任务,我得到的唯一错误是使用“(0.5<=ratio<2 )”,除此之外,构造正确吗? Scanner scn = new Scanner(
有没有办法在 select 语句中使用 if 语句? 我不能在这个中使用 Case 语句。实际上我正在使用 iReport 并且我有一个参数。我想要做的是,如果用户没有输入某个参数,它将选择所有实例。
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: If vs. Switch Speed 我将以 C++ 为例,但我要问的问题不是针对特定语言的。我的意思是一
Property Set 语句 在 Class 块中,声明名称、参数和代码,这些构成了将引用设置到对象的 Property 过程的主体。 [Public | Private] Pro
Property Let 语句 在 Class 块中,声明名称、参数和代码等,它们构成了赋值(设置)的 Property 过程的主体。 [Public | Private] Prop
我是一名优秀的程序员,十分优秀!