Header Ads

Header ADS

Program for Water Level Detector

Introduction

Hello friends, In this post, we will learn how to write a simple program in VHDL for Water Level Detector.
VHDL has been at the heart of electronic design productivity since initial ratification by the IEEE in 1987. For almost 15 years the electronic design automation industry has expanded the use of VHDL from initial concept of design documentation, to design implementation and functional verification. It can be said that VHDL fueled modern synthesis technology and enabled the development of ASIC semiconductor companies.The editions of Doug Perry’s books have served as the authoritative source of practical information on the use of VHDL for users of the language around the world.

The fact that VHDL is adaptable is a tribute to its architecture. The industry has seen the use of VHDL’s package structure to allow designers, electronic design automation companies and the semiconductor industry to experiment with new language concepts to ensure good design tool and data interoperability. When the associated data types found in the IEEE 1164 standard were ratified, it meant that design data interoperability was possible.

This new generation of electronic designers, along with the current designers of complex systems and ASICs, will find this book as invaluable as the first generation of VHDL users did with the first addition. Updated with current use of the standard, all will benefit from the years of use that have made the VHDL language the underpinning of successful electronic design.

VHDL usage has risen rapidly since its inception and is used by literally tens of thousands of engineers around the globe to create sophisticated electronic products. This chapter will start the process of easing the reader into the complexities of VHDL. VHDL is a powerful language with numerous language constructs that are capable of describing very complex behavior. Learning all the features of VHDL is not a simple task.

Program

library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;

---- Uncomment the following library declaration if instantiating
---- any Xilinx primitives in this code.
--library UNISIM;
--use UNISIM.VComponents.all;

entity pro_level is
    Port ( A : in  STD_LOGIC;
           B : in  STD_LOGIC;
           clk : in  STD_LOGIC;
           rst : in  STD_LOGIC;
           m : out  STD_LOGIC);
end pro_level;

architecture Behavioral of pro_level is
signal pstate : integer range 0 to 4;
begin
process(clk,rst)
begin
if rst='1' then
m<='0'; pstate<=0;
elsif clk='1' and clk'event then
case pstate is
when 0=>
m<='1';
if A='1' then
pstate<=1;
else pstate<=0;
end if;
when 1=>
m<='0';
if B='1' then
pstate<=0;
else pstate<=1;
end if;
when others=> null;
end case;
end if;
end process;

end Behavioral;



No comments

Powered by Blogger.