VHDL:从浮点转换为定点解释?

时间:2011-02-03 03:48:42

标签: vhdl

在第6.2章的VHDL设计器指南中,有一个实体和体系结构体,用于从浮点到定点表示的转换器。我很困惑

library ieee; use ieee.std_logic_1164 all;
entity to_fp is
   port(vec: in std_u_logic_vector(15 downto 0);
        r: out real);
end entity to_fp;

architecture behavioral of to_fp is
begin 
    behavior : process (vec) is
       variable temp: bit_vector(vec'range);
       variable negative: boolean;
       variable int_result: integer;
    begin
       temp := to_bitvector(vec);
       negative := temp(temp'left) = '1';
       if negative then
          temp := not temp;
       end if;
       int_result := 0;
       for index in vec'range loop
           int_result := int_result*2 + bit'pos(temp(index));
       end loop;
       if negative then
          int_result := (-int_result) -1;
       end if;
       r <= real(int_result) / 2.0**15;
    end process behavior;
end architecture behavioral;

我理解其中的大部分内容。我只是不明白for循环。这如何为我们提供位向量的整数表示?请尽可能详细解释,谢谢:)。

1 个答案:

答案 0 :(得分:9)

for index in vec'range loop

这会在vec的范围内循环。在这种情况下(15 downto 0)。

bit'pos(temp(index));

位是 enumaration类型(std.standard中的type BIT is ('0', '1');)。 pos属性返回给定值的位置编号(作为整数类型)。所以bit'pos(...)将一位转换为整数。

循环的作用是将bit_vector转换为整数

我建议使用to_integer(unsigned(vec))来实现此目的。请记住use ieee.numeric_std.all;

最后一行将整数转换(强制转换)为real