### ☐ xbarto0c / Digital-electronics-1

<> Code (!) Issues 11 Pull requests Actions Projects Security ✓ Insi Digital-electronics-1 / Labs / 08-traffic\_lights / ሦ main ▾ xbarto0c 8.cv ... **Images** 1 hour ago  $traffic\_lights$ 18 seconds ago readme.md 18 seconds ago

18 seconds ago

readme.md

readme.pdf

# Part 1: Preparation tasks:

### Complete state table:

| Input<br>P  | 0        | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 1        | 1 | 0 |
|-------------|----------|---|---|---|---|---|---|---|---|----------|---|---|
| Clock       | <b>↑</b> | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | <b>↑</b> | 1 | 1 |
| State       | Α        | Α | В | С | С | D | Α | В | С | D        | В | В |
| Output<br>R | 0        | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1        | 0 | 0 |

### Color settings table:

| RGB LED | Artix-7 pin names | Red   | Yellow | Green |
|---------|-------------------|-------|--------|-------|
| LD16    | N15, M16, R12     | 1,0,0 | 1,1,0  | 0,1,0 |
| LD17    | N16, G14, R11     | 1,0,0 | 1,1,0  | 0,1,0 |

### Color settings table:



Image taken from Nexys A7 datasheet

# Part 2: Traffic light controller:

State diagram:



## Listing of VHDL code of sequential process p\_traffic\_fsm:

```
p_traffic_fsm : process(clk) -- ovládání stavů
begin
    if rising_edge(clk) then
        if (reset = '1') then
                                    -- Synchronous reset
            s_state <= STOP1 ;
                                    -- Set initial state
                  <= c_ZERO; -- Clear all bits</pre>
            s cnt
        elsif (s_en = '1') then
            -- Every 250 ms, CASE checks the value of the s_state
            -- variable and changes to the next state according
            -- to the delay value.
            case s state is
                -- If the current state is STOP1, then wait 1 sec
                -- and move to the next GO_WAIT state.
                when STOP1 =>
                    -- Count up to c_DELAY_1SEC
                    if (s_cnt < c_DELAY_1SEC) then</pre>
                         s_cnt <= s_cnt + 1;</pre>
                    else
                         -- Move to the next state
                         s_state <= WEST_GO;</pre>
                        -- Reset local counter value
                        s cnt
                                <= c_ZERO;
                    end if;
```

```
when WEST_GO =>
    if (s_cnt < c_DELAY_4SEC) then</pre>
         s_cnt <= s_cnt + 1;
    else
         -- Move to the next state
         s_state <= WEST_WAIT;</pre>
        -- Reset local counter value
         s_cnt <= c_ZERO;</pre>
    end if;
when WEST_WAIT =>
    if (s_cnt < c_DELAY_2SEC) then</pre>
         s_cnt <= s_cnt + 1;
    else
         -- Move to the next state
         s_state <= STOP2;</pre>
        -- Reset local counter value
         s_cnt <= c_ZERO;</pre>
    end if;
when STOP2 =>
    if (s_cnt < c_DELAY_1SEC) then</pre>
         s_cnt <= s_cnt + 1;</pre>
    else
         -- Move to the next state
         s_state <= SOUTH_GO;</pre>
         -- Reset local counter value
         s_cnt <= c_ZERO;</pre>
    end if;
when SOUTH_GO =>
    if (s_cnt < c_DELAY_4SEC) then</pre>
         s_cnt <= s_cnt + 1;
    else
         -- Move to the next state
         s_state <= SOUTH_WAIT;</pre>
         -- Reset local counter value
         s_cnt <= c_ZERO;</pre>
    end if;
when SOUTH_WAIT =>
    if (s_cnt < c_DELAY_2SEC) then</pre>
         s_cnt <= s_cnt + 1;
    else
         -- Move to the next state
         s_state <= STOP1;</pre>
         -- Reset local counter value
         s_cnt <= c_ZERO;</pre>
```

#### Listing of VHDL code of combinatorial process p\_output\_fsm:

```
p_output_fsm : process(s_state) -- ovládání výstupů
begin
   case s_state is
       when STOP1 =>
           south_o <= "100"; -- Red (RGB = 100)
           west_o <= "100"; -- Red (RGB = 100)
       when WEST_GO =>
           south_o <= "100"; -- Red (RGB = 100)
           west o <= "010"; -- Green (RGB = 010)
       when WEST_WAIT =>
           south_o <= "100"; -- Red (RGB = 100)
           west_o <= "110"; -- Yellow (RGB = 110)
       when STOP2 =>
           south_o <= "100"; -- Red (RGB = 100)
           west_o <= "100"; -- Red (RGB = 100)
       when SOUTH_GO =>
           south o <= "010"; -- Green (RGB = 010)
           west_o <= "100"; -- Red (RGB = 100)
       when SOUTH_WAIT =>
           south_o <= "110"; -- Yellow (RGB = 110)
           west_o <= "100"; -- Red (RGB = 100)
       when others =>
           south_o <= "100"; -- Red (RGB = 100)
           west_o <= "100"; -- Red (RGB = 100)
   end case;
end process p_output_fsm;
```

#### Simulation screenshot:



# Part 3: Smart controller:

### State table, part 1:

| Input<br>Sensor<br>[South-<br>West]   | 00            | 01         | 10            | 11        | 00             |
|---------------------------------------|---------------|------------|---------------|-----------|----------------|
| Clock                                 | $\uparrow$    | $\uparrow$ | $\uparrow$    | <b>↑</b>  | <b>†</b>       |
| Actual<br>State                       | South_go      | South_go   | South_go      | South_go  | Sout_wait      |
| Output<br>Colours<br>[West-<br>South] | red-<br>green | red-green  | red-<br>green | red-green | red-<br>yellow |
| Next<br>State                         | South_go      | Sout_wait  | Sout_go       | Sout_wait | West_go        |

### State table, part 2:

| Input<br>Sensor<br>[South-<br>West] | 00       | 01       | 10       | 11       | 00        |
|-------------------------------------|----------|----------|----------|----------|-----------|
| Clock                               | <b>↑</b> | <b>↑</b> | <b>↑</b> | <b>↑</b> | 1         |
| Actual<br>State                     | South_go | South_go | South_go | South_go | Sout_wait |

| Input<br>Sensor<br>[South-<br>West]   | 00            | 01        | 10            | 11        | 00             |
|---------------------------------------|---------------|-----------|---------------|-----------|----------------|
| Output<br>Colours<br>[West-<br>South] | green-<br>red | green-red | green-<br>red | green-red | yellow-<br>red |
| Next<br>State                         | South_go      | Sout_wait | Sout_go       | Sout_wait | West_go        |

### State diagram:



### Listing of VHDL code of sequential process p\_smart\_traffic\_fsm:

```
case s_smart_state is
    -- If the current state is SOUTH_GO, then wait 3 seconds
    -- and move to the next GO_WAIT state.
    when SOUTH_GO =>
         -- Count up to c_DELAY_1SEC
        if (s_cnt < c_DELAY_3SEC) then</pre>
             s_cnt <= s_cnt + 1;
        else
             if (s_sensors_i = "01" or s_sensors_i = "11") then
                  -- Move to the next state
                 s_smart_state <= SOUTH_WAIT;</pre>
                 -- Reset local counter value
                 s_cnt <= c_ZERO;</pre>
             else
                 s_cnt <= c_ZERO;</pre>
             end if;
        end if;
    when SOUTH WAIT =>
        if (s_cnt < c_DELAY_500mSEC) then</pre>
             s_cnt <= s_cnt + 1;</pre>
        else
             -- Move to the next state
             s_smart_state <= WEST_GO;</pre>
             -- Reset local counter value
                    <= c_ZERO;
             s_cnt
        end if;
    when WEST GO =>
        if (s_cnt < c_DELAY_3SEC) then</pre>
             s_cnt <= s_cnt + 1;</pre>
        else
             if (s_sensors_i = "10" or s_sensors_i = "11") then
                 -- Move to the next state
                 s_smart_state <= WEST_WAIT;</pre>
                  -- Reset local counter value
                 s_cnt <= c_ZERO;</pre>
             else
                 s_cnt <= c_ZERO;</pre>
             end if;
        end if;
    when WEST_WAIT =>
        if (s_cnt < c_DELAY_500mSEC) then</pre>
             s_cnt <= s_cnt + 1;</pre>
        else
             -- Move to the next state
             s_smart_state <= SOUTH_GO;</pre>
             -- Reset local counter value
```