# CPLD 設計作業

## 銘傳大學電腦與通訊工程系

| 班 級     | 電通二乙               |
|---------|--------------------|
| 組 別     | 第 27 組             |
| 組員姓名/學號 | 05050032 陳韋澔       |
| 組員姓名/學號 | 05050536 陳奕璁       |
| 作業撰寫人   | 陳韋澔                |
| 授課教師    | 陳慶逸                |
| 實習成果    | 本次應繳作業共 2 題,完成 2 題 |
| 時 間     | 2017/12/1          |

#### 第一題

問題描述: 實現一個 1Hz 頻率計數的 3 bits 計數器

#### 程式碼:計數器

```
LIBRARY ieee;
USE ieee.std_logic_1164.ALL;
use ieee.std_logic_unsigned.all;
ENTITY aa IS
PORT( x,CLK:IN STD_LOGIC;
                :OUT std_logic_vector(2 downto 0));
         OP
END aa;
ARCHITECTURE a OF aa IS
BEGIN
PROCESS(clk)
variable present_state: std_logic_vector (2 downto 0);
     BEGIN
IF clk'event and clk='1' then
           CASE present state IS
            WHEN "000" =>
                 if x='1' then present_state:="001";
                 else present_state:="111";
                 end if;
            WHEN "001" =>
                 if x='1' then present_state:="010";
                 else present_state:="000";
                 end if:
            WHEN "010" =>
                 if x='1' then present_state:="011";
                 else present_state:="001";
                 end if:
            WHEN "011" =>
                 if x='1' then present_state:="100";
                 else present_state:="010";
                 end if;
           WHEN "100" =>
```

```
if x='1' then present_state:="101";
                  else present_state:="011";
                  end if;
             WHEN "101" =>
                  if x='1' then present_state:="110";
                  else present_state:="100";
                  end if;
             WHEN "110" =>
                  if x='1' then present_state:="111";
                  else present_state:="101";
                  end if:
             WHEN "111" =>
                  if x='1' then present_state:="000";
                  else present_state:="110";
                  end if;
             WHEN others=>
                  if x='1' then present_state:="000";
                  else present_state:="000";
                  end if;
             END CASE;
     end if;
     op<= present_state;</pre>
END PROCESS:
END a:
```

#### 1HZ 除頻

```
signal PULSE : std_logic;
begin
process(clockIN)
variable counter, divisor2: integer range 0 to divisor;
begin
  divisor2:=divisor/2;
     if (clockIN 'event and clockIN ='1') then
       if counter = divisor then
          counter := 1;
       else
          counter := counter + 1;
       end if;
     end if;
if (clockIN 'event and clockIN ='1') then
       if (( counter= divisor2) or (counter = divisor))then
          PULSE <= not PULSE ;</pre>
       end if;
     end if;
     clockOUT <= PULSE;</pre>
  end process;
end arch;
```

#### 模擬結果:

逆時針:https://www.youtube.com/watch?v=8PIzlaCHh4s

順時針: https://www.youtube.com/watch?v=H\_QdpNDrE-U

#### 第二題

### 題目: 試實現下面之 Mealy 狀態機



#### 程式碼:

LIBRARY ieee;

USE ieee.std\_logic\_1164.ALL;

use ieee.std\_logic\_unsigned.all;

ENTITY dd IS

PORT(CLK :IN STD\_LOGIC;

X :IN STD\_LOGIC;

op :OUT STD\_LOGIC);

END dd;

ARCHITECTURE a OF dd IS

TYPE State IS (s0,s1,s2,s3,s4);

SIGNAL present\_state : State;

SIGNAL next\_state: State;

**BEGIN** 

state\_comp: PROCESS(present\_state)

```
BEGIN
CASE present_state IS
WHEN s0 \Rightarrow
    IF X = '0' THEN
        next_state <= s0;</pre>
    ELSE
        next_state <= s1;</pre>
    END IF;
    IF X = '0' THEN
        op <= '0';
    ELSE
        op <= '0';
    END IF;
WHEN s1 =>
    IF X = '0' THEN
        next_state <= s2;</pre>
    ELSE
        next_state <= s3;</pre>
    END IF;
    IF X = '0' THEN
        op <= '0';
    ELSE
        op <= '0';
    END IF;
WHEN s2 \Rightarrow
    IF X = '0' THEN
```

```
next_state <= s4;</pre>
    ELSE
        next_state <= s0;</pre>
    END IF;
    IF X = '0' THEN
        op <= '0';
    ELSE
        op <= '1';
    END IF;
WHEN s3 =>
    IF X = '0' THEN
        next_state <= s1;</pre>
    ELSE
        next_state <= s2;</pre>
    END IF;
    IF X = '0' THEN
        op <= '1';
    ELSE
        op <= '1';
    END IF;
WHEN s4 =>
    IF X = '0' THEN
        next_state <= s3;</pre>
    ELSE
        next_state <= s4;</pre>
    END IF;
```

```
IF X = '0' THEN
           op <= '1';
       ELSE
           op <= '1';
       END IF;
   END CASE;
   END PROCESS state_comp;
       state_clocking: PROCESS (CLK)
   BEGIN
       IF CLK'EVENT AND CLK = '1' THEN
           present_state <= next_state;</pre>
       END IF;
   END PROCESS state_clocking;
END a;
```

