LIBRARY IEEE;
USE IEEE.STD_LOGIC_1164.ALL;
USE IEEE.STD_LOGIC_UNSIGNED.ALL;
ENTITY PSGtraffic is
port(clk:in std_logic;
people:in std_logic;
cnttime: out std_logic_vector(7 downto 0);
carled: out std_logic_vector(3 downto 0);
peopleled: out std_logic(3 downto 0));
end PSGtraffic;
ARCHITECTURE behave OF PSGtraffic IS
type statetype is (CGPR,CYPR,CRPG);
SIGNAL STATE: statetype := CGPR;
SIGNAL cnt :std_logic_vector(7 downto 0);
begin
process(clk,people,cnt)
begin
if (clk'event and clk='1')then
if clk/=0 then
if cnt(3 downto 0)=x"0"then
cnt(7 downto 4)<=cnt(7 downto 4)-1;
cnt(3 downto 0)<=x"9";
else
cnt(3 downto 0)<=cnt(3 downto 0)-1;
end if;
end if;
case state is
when CGPR =>
carled<="0010";
peopleled<="0100";
if people ="1"and cnt=0 then
state <= CYPR;
cnt <=x"3"AFTER 30s;
end if;
when CYPR =>
carled<="0001";
peopleled<="0100";
if cnt = 0 then
state <= CRPG;
cnt <=x"15";
end if;
when CRPG =>
carled<="0100";
peopleled<="0010";
if cnt = 0 then
if people ="0" and cnt=0 then
state <= CGPR;
cnt <=x"30";
end if;
when others => NULL;
end case;
end if;
cnttime<=cnt;
end process;
end behave;
我要赚赏金打赏帖 |
|
|---|---|
| 【S32K3XX】LPSPI参数配置说明被打赏¥21元 | |
| 在WT9932C61-TINY上实现超声波测距被打赏¥22元 | |
| 基于WT9932C61-TINY的环境构建及OLED屏驱动测试被打赏¥20元 | |
| 【S32K3XX】Core-to-Core 中断使用被打赏¥21元 | |
| 「AI编程记录--含源码」用一晚上的时间写一个esp32的示波器被打赏¥19元 | |
| STM32C0116DK开发探索记(3)被打赏¥30元 | |
| STM32C0116DK开发探索记(2)被打赏¥24元 | |
| STM32C0116DK开发探索记(1)被打赏¥29元 | |
| 谨防极海G32M3101电机评估板易跌落的陷阱被打赏¥24元 | |
| 【全网首拆】M5STACK ATOM系列开发板拆解 / AtomS3R-CAM摄像头更换方法(提高10倍像素)被打赏¥26元 | |
我要赚赏金
