一.   流水灯

1.1流水灯原理

流水灯是每个学电子的入门“游戏” ,示意图如图1,其原理极其简单,但是可玩性却极强,可以就8个LED写出不同花样的程序。在1.2中我们列出两个不同思路的代码作为VHDL的入门例程。

图1 流水灯电路图

1.2 流水灯例程

这里提供两个不同的代码。

第一个代码的思路是先对系统时钟分频,产生1s信号(即变量count取值到25000000,这样分频时间=20ns*25000000*2=1s),然后使用移位操作符指令进行操作。该指令是在VHDL93中引入的,包括sll,srl,sla,sra,rol,ror6个指令,指令操作如图2一目了然。值得注意的是,使用该指令,左操作数必须是BIT_VECTOR类型,右操作数必须是INTEGER类型(前面可以有负号)。

图2 移位操作符示意图

例如:令x <= “10110”,则

y <= x sll 2 ;--逻辑左移两位,y <= “ 11000”,空余位填充0

y <= x srl 2 ;--逻辑右移两位,y <= “00101”,空余位填充0

y <= x sla 2 ;--算术左移两位,y <= “11000”,空余位复制最右边上的数值

y <= x sra 2 ;--算术右移两位,y <= “11101”,空余位复制最左边上的数值

y <= x rol 2 ;--循环逻辑左移两位,y <= “11010”,左侧移出位填补到右侧

y <= x ror 2 ;--循环逻辑右移两位,y <= “10101”,右侧移出位填补到左侧

例程一:

 --------------------------------------------------------------------------------------------------

 library IEEE;

 use IEEE.std_logic_1164.all;

 --------------------------------------------------------------------------------------------------

 entity VHDL_LEDWATER1 is

        port (

                      Clk    : in  STD_LOGIC;             --创建时钟端口,连接开发板PIN23

                      Rst     : in  STD_LOGIC;            --创建复位端口,连接开发板PIN116

                      Output : out BIT_VECTOR( downto ) --创建输出端口,对应8个LED。分别

             --为PIN142-PIN133,要使用移位操作符

               );                                         --其左侧必须为BIT_VECTOR类型

 end VHDL_LEDWATER1;

 --------------------------------------------------------------------------------------------------

 architecture behave of VHDL_LEDWATER1 is

        signal Clk1 : STD_LOGIC;             --建立中间时钟信号

 begin

 P1:process(Clk)

 variable count : INTEGER range  to  := ; --变量初始值不可综合,在仿真中使用,并

 variable count1: STD_LOGIC := '';           --且为便于仿真,这里取到25,当烧写到开

        --发板时候,改写为25000000即可           

        begin

               if(Rst = '') then

                      count := ;

               elsif(Clk'event and Clk = '') then

                      count := count + ;

                      if(count = ) then --这里使用=,而不是>=,可以防止产生比较器,节省硬件资源

                             count := ;

                             count1 := not count1;

                      end if;

               end if;

               Clk1 <= count1;

    end process P1;

 P2:process(Clk1)

        variable temp : BIT_VECTOR( downto ) := "";--注意左操作数类型

        begin

               if(Clk1'event and Clk1 = '') then

                      temp := (temp rol );                  

               end if;

               Output <= temp;

        end process P2;

 end architecture;

--------------------------------------------------------------------------------------------------

仿真波形:


从仿真波形中,可以验证例程的正确性。

第二个代码的思路是先对系统时钟分频,产生1s信号,然后对该1s信号进行模8计数,再利用case-when语句进行判断,进而控制LED。

例程二:

 --------------------------------------------------------------------------------------------------

 library IEEE;

 use IEEE.std_logic_1164.all;--该库定义了std_logic(8值)和std_ulogic(9值)多值逻辑结构

 --------------------------------------------------------------------------------------------------

 entity LEDWATER is

 port (

        Clk    : in  STD_LOGIC;                  --创建时钟端口,连接开发板PIN23

        Rst    : in  STD_LOGIC;                  --创建复位端口,连接开发板PIN116

      Output : out  STD_LOGIC_VECTOR( downto ) --创建输出端口,连接开发板PIN142-PIN133

 );

 end LEDWATER;

 --------------------------------------------------------------------------------------------------

 architecture BEHAVIOR_LEDWATER of LEDWATER is

        signal Clk1 : STD_LOGIC;                           --建立中间时钟信号

 begin

 P1: process(Clk)                                          --进程1,对时钟信号进行N分频

 variable count : INTEGER range  to  := ;--变量初始值不可综合,在仿真中使用

        variable count1: STD_LOGIC := '';

        begin

               if(Rst = '') then

                      count := ;                   

               elsif(Clk'event and Clk = '') then

                      count := count + ;

                      if(count = ) then

                             count := ;

                             count1:= not count1;

                      end if;

                      Clk1 <= count1;

               end if;

        end process;

 P2: process(Clk1)                                  --进程2,对分频信号进行计数,进而控制LED亮灭

        variable count2 : INTEGER range  to  := ;--变量初始值不可综合,在仿真中使用

        begin

               if(Clk1'event and Clk1 = '') then

                      count2 := count2 + ;

                      if(count2 = ) then

                             count2 := ;

                      end if;

               end if;

               case count2 is

                      when  => Output <= "";

                      when  => Output <= "";

                      when  => Output <= "";

                      when  => Output <= "";

                      when  => Output <= "";

                      when  => Output <= "";

                      when  => Output <= "";

                      when  => Output <= "";

                      when others => Output <= (others => 'Z');

               end case;

        end process;  

 end BEHAVIOR_LEDWATER;

仿真波形:


从仿真波形中,可以验证例程的正确性。

1.3 总结

其实,肯定还有其他精妙的想法,这里只列举了两种代码作为学习的开头。不过通过两个代码的学习,也熟悉了移位操作符和case-when语句的使用。下一节将开始数码管的学习。

参考文献:

[1] Volnei A.Pedroni.VHDL 数字电路设计教程[M].北京:电子工业出版社,2009:39-40;

[2] http://leonmoon.blog.hexun.com/4609284_d.html

3. 戏说VHDL之入门游戏一:流水灯的更多相关文章

  1. Unity3D 入门 游戏开发 Unity3D portal game development

    Unity3D 入门 游戏开发 Unity3D portal game development 作者:韩梦飞沙 Author:han_meng_fei_sha 邮箱:313134555@qq.com ...

  2. 神经网络入门游戏推荐BugBrain

    今天看到一款神经网络入门游戏.BugBrain.在游戏中,你能够通过连接神经元.设置神经元阈值等建造虫子的大脑,让瓢虫.蠕虫.蚂蚁等完毕各种任务.下载下来玩了玩,难度真不是入门级的= =! 真心佩服作 ...

  3. NIOS ii 流水灯

    为了做项目的前期验证工作,实验室购买了某开发板,下面是基于该板子的实现过程.作为笔记记录,供入门者参考. 1:创建一个Quartus II的工程 next选择器件,然后finish.我的器件是cycl ...

  4. STM32学习笔记(二) 基于STM32-GPIO的流水灯实现

    学会了如何新建一个工程模板,下面就要开始动手实践了.像c/c++中经典的入门代码"hello world"一样,流水灯作为最简单的硬件设备在单片机领域也是入门首推.如果你已经有了一 ...

  5. 第一个FPGA工程—LED流水灯

    这一章我们来实现第一个FPGA工程-LED流水灯.我们将通过流水灯例程向大家介绍一次完整的FPGA开发流程,从新建工程,代码设计,综合实现,管脚约束,下载FPGA程序.掌握本章内容,大家就算正式的开始 ...

  6. S5PV210_流水灯

    1.整体思路:把相应的配置数据写入相应的寄存器,控制GPIO电平(Led.s)——运用工程管理Makefile编译.链接文件(由Led.s编译得到led.bin,该文件用于USB启动方式点亮LED,若 ...

  7. 嵌入式Linux学习入门:控制LED灯

    记录自己linux学习过程,让自己能够一直坚持下去 1.原理图分析: nLED_1, nLED_2, nLED_4, 给低电平则对应LED灯亮,高电平则对应LED灯灭, S3C2440芯片GPF4-G ...

  8. (一)GPIO 编程实验 LED 流水灯控制

    7个寄存器 是R1-R16.(当然,里面有很多是分几个模式的,所以总共有37个)类似于单片机的R0-R7. GPXCON,GPXDAT等等是另外的寄存器,应该叫,特殊功能寄存器,类似于单片机的P0,P ...

  9. [51单片机] EEPROM 24c02 [I2C代码封装-保存实现流水灯]

    这里把EEPROM 24c02封装起来,今后可以直接调用,其连线方式为:SDA-P2.1;SCL-P2.0;WP-VCC >_<:i2c.c /*--------------------- ...

随机推荐

  1. Ossim应用体验视频

    Ossim体验视频 近期,我写的有关Ossim应用的系列文章网友们非常关注,这里对大家提出有一些问题我制作了高清的视频和截图发布到网站,以让更多的人了解这款开源安全平台.在年后出版的教程中会详细讲解o ...

  2. 轻松找回Win7桌面“消失”的IE9图标

    打开注册表编辑器(Win+R打开运行窗口,运行regedit命令),依次展开到 [HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion ...

  3. Elsevier期刊网上投稿指南

    一.ELSEVIER期刊介绍:ELSEVIER出版集团创建于1580年,是世界上著名学术期刊出版公司,也是全球最大的科学文献出版发行商.它由Academic Press.Bailliere Tinda ...

  4. 几款超实用的 CSS 开发工具

      当你开发一个网站或 web 应用程序的时候,有合适的工具,绝对可以帮助您节省大量的时间.在这篇文章中,我为大家收集了超有用的 CSS 开发工具. 对于 Web 开发人员来说,找到有用的 css 开 ...

  5. C++ 学习基础一

    1.预处理器指示符如果文件名用尖括号“<”和”>”括起来的,则表示该文件是工程或标准头文件,查找过程会检查预定义的目录.如果文件名用双引号括起来,则表示该文件是用户自定义的头文件,查找该文 ...

  6. ajax 的简单应用

    ajax作为前端技术,采用异步方式,根据其采用的方式来讲,不用刷新界面,只是进行数据的传递. 后台还是用servlet的.servlet接收到ajax的get或post请求后.将数据组装成xml或者j ...

  7. Save a bricked Samsung Note 3 and do extraction

    The case scenario was about bank robery and the suspect threw his Samsung Note 3 into the river. For ...

  8. Jquery设置select控件指定text的值为选中项

    <select name="streetid" id="streetid"> <option value="4">北 ...

  9. mysql实体关系(mysql学习五)

    实体关系  表设计 1:1 两个实体表内,存在相同的主键字段 如果记录的主键值等于另一个关系表内记录的主键值,则两条记录的对应为一一对应 优化上称为垂直分割 1:n 一个实体对应多个其他实体(一个班级 ...

  10. php获取客户端浏览器以及操作系统信息的方法

    发布:sunday01   来源:net   阅读: 2   [大 中 小] 在较为智能的程序中,php可以获取客户端浏览器及操作系统信息,然后根据浏览器及系统类型,加载不同的页面,以提供更加个性化的 ...