





# جلسه دوم

• نحوه پیادهسازی testbench

• پیادهسازی مالتی پلکسره، دیکودر، انکودر و مقایسه کننده در سطح انتزاع گیت



## پیادهسازی ۴ Decoder ۲ to







#### ساختار VHDL



#### ساختار process





یک Process به خودی خود ساختاری همروند است. پروسس را میتوان یک BlackBox در نظر گرفت که رفتارش توسط ساختار ترتیبی بیادهسازی میشود.



ساختار Process را در زیر مشاهده میکنید:

```
Process (sensitivity-list)
begin
sequential stater
```

sequential statement; sequential statement;

...

end process;



#### ساختار case

Case یک عملیات ترتیبی است که درون ساختارهای ترتیبی مانند process قرار میگیرد.



case A is

when "00" => 
$$X(0) <= '0';$$
 when "01" => 
$$X(1) <= '0';$$
 when "10" => 
$$X(2) <= '0';$$
 when "11" => 
$$X(3) <= '0';$$
 when others => 
$$X <= "1111";$$



end case;



### پیادهسازی ۴ Decoder ۲ to پیادهسازی

```
library IEEE;
use IEEE.STD_LOGIC_1164.all;
entity decoder2 is
         port(a:in STD_LOGIC_VECTOR(1 downto 0);
               b: out STD_LOGIC_VECTOR(3 downto 0);
               end decoder2;
architecture Structural of decoder2 is
begin
b(0) \le not a(0) and not a(1);
b(1) \le not a(0) and a(1);
b(2) \le a(0) and not a(1);
b(3) \le a(0) and a(1);
end Structural;
```

### پیادهسازی ۴ Decoder و بیادهسازی

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
entity decode_2to4_top is

Port (A: in STD_LOGIC_VECTOR (1 downto 0); -- 2-bit input

X: out STD_LOGIC_VECTOR (3 downto 0); -- 4-bit output

EN: in STD_LOGIC); -- enable input

end decode_2to4_top;
architecture Behavioral of decode_2to4_top is

Begin

process (A, EN)

Begin

X <= "1111"; -- default output value
```



### ییادهسازی ۴ Decoder ۲ to پیادهسازی