Получение правильных значений для нескольких входов. Не для всех комбинаций в множителе 4 * 4 - PullRequest
0 голосов
/ 30 октября 2018

Я пишу код для множителя 4 * 4. Хотя я получаю правильные значения для нескольких входов, это дает мне неправильные значения для нескольких других. Пожалуйста, предложите мне, какие логические ошибки присутствуют здесь, так как я не могу их обнаружить


library IEEE;
use IEEE.STD_LOGIC_1164.ALL;

    entity multiplier is
        Port ( a : in  std_logic_vector (3 downto 0);
               b : in std_logic_vector (3 downto 0);
               result : out std_logic_vector (7 downto 0));
    end multiplier;

    architecture Behavioral of multiplier is

    signal P0: std_logic_vector(7 downto 0);
    signal P1: std_logic_vector(7 downto 0);
    signal SP1: std_logic_vector(7 downto 0);
    signal P2: std_logic_vector(7 downto 0);
    signal SP2: std_logic_vector(7 downto 0);
    signal P3: std_logic_vector(7 downto 0);

    component genericadder

            Port ( a : in std_logic_vector(3 downto 0);
                   b : in std_logic_vector(3 downto 0);
                   sum : out std_logic_vector (4 downto 0));
            end component;  

    begin 

    result(0) <= a(0) and b(0);
    P0(0) <= a(0) and b(1);
    P0(1) <= a(0) and b(2);
    P0(2) <= a(0) and b(3);
    P0(3) <='0';

    P0(4) <= a(1) and b(0);
    P0(5) <= a(1) and b(1);
    P0(6) <= a(1) and b(2);
    P0(7) <= a(1) and b(3);

    ga_for : genericadder
    port map(
     a =>P0( 3 downto 0),
     b =>P0( 7 downto 4),   
     sum =>P1(4 downto 0));    


    result(1)<= P1(0);
    SP1<= std_logic_vector(shift_right(unsigned(P1),1));
    P1(4) <= a(2) and b(0);
    P1(5) <= a(2) and b(1);
    P1(6) <= a(2) and b(2);
    P1(7) <= a(2) and b(3);

    ga_for1 : genericadder
    port map(
     a =>SP1( 3 downto 0),
     b =>P1( 7 downto 4),
     sum =>P2(4 downto 0));

    result(2) <= P2(0);
    SP2<= std_logic_vector(shift_right(unsigned(P2),1));
    P2(4) <= a(3) and b(0);
    P2(5) <= a(3) and b(1);
    P2(6) <= a(3) and b(2);
    P2(7) <= a(3) and b(3);

    ga_for2 : genericadder
    port map(
     a =>SP2( 3 downto 0),
     b =>P2( 7 downto 4),
     sum =>P3(4 downto 0));

    result(3)<=P3(0);


    result(4)<=P3(1);
    result(5)<=P3(2);
    result(6)<=P3(3);
    result(7)<=P3(4);


    end Behavioral;


entity genericadder is
 generic (
    n : Integer:=4       
     );
    Port ( a : in STD_LOGIC_VECTOR (n-1 downto 0);
           b : in STD_LOGIC_VECTOR (n-1 downto 0);
           sum : out STD_LOGIC_VECTOR (n downto 0));
end genericadder;

-

Универсальная гадюка состоит из полных сумматоров. Пожалуйста, дайте мне знать об ошибке. Я действительно не могу двигаться вперед

...