## Lab Task 1:

# **LED blinking with Variable Frequency**

#### VHDL Code:

```
library ieee;
use ieee.std_logic_1164.all;
use ieee.std logic unsigned.all;
entity ledBlinking is
    port (
        fpga clk : in std logic;
        switch : in std logic vector(2 downto 0);
             : out std logic vector(3 downto 0)
    );
end ledBlinking;
architecture bhv of ledBlinking is
    --signals
    signal count
                   : std logic vector(31 downto 0) := X"00000000";
    signal top clk : std logic;
    signal ledout : std logic vector(3 downto 0);
begin
    process (fpga clk)
        if (fpga clk 'event' and fpga clk = '1') then
        count <= count + 1;</pre>
        end if;
    end process;
    process (fpga clk , count)
    begin
        if (fpga clk 'event' and fpga clk = '1') then
            case switch is
                when "000" => top clk <= count(20);
                when "100" => top clk <= count(31);
                when "010" => top_clk <= count(15);</pre>
                when "001" => top_clk <= count(2);</pre>
                when others => top clk <= count(2);
            end case;
        end if;
    end process;
    process(top_clk)
    begin
        if (top clk 'event' and top clk = '1') then
            ledout <= not ledout;</pre>
        end if;
    end process;
    ___
```

```
led <= ledout;
end bhv;</pre>
```

### **Simulation:**



Simulation 1: LED blinking at variable frequencies based on switch-controlled clock division.

## **Control Switch:**

| SELECTION | OPERATION (Clock Division Factor) |
|-----------|-----------------------------------|
| 000       | Slow Blinking(Count(20))          |
| 100       | Very Slow Blinking (Count(31))    |
| 010       | Medium Blinking (Count(15))       |
| 001       | Fast Blinking (Count(2))          |

Table 1: LED Blinking Frequency Selection Based on Switch Input