EDA技术及应用实验报告完整版纯手打.docx

上传人:b****5 文档编号:7540590 上传时间:2023-01-24 格式:DOCX 页数:37 大小:31.16KB
下载 相关 举报
EDA技术及应用实验报告完整版纯手打.docx_第1页
第1页 / 共37页
EDA技术及应用实验报告完整版纯手打.docx_第2页
第2页 / 共37页
EDA技术及应用实验报告完整版纯手打.docx_第3页
第3页 / 共37页
EDA技术及应用实验报告完整版纯手打.docx_第4页
第4页 / 共37页
EDA技术及应用实验报告完整版纯手打.docx_第5页
第5页 / 共37页
点击查看更多>>
下载资源
资源描述

EDA技术及应用实验报告完整版纯手打.docx

《EDA技术及应用实验报告完整版纯手打.docx》由会员分享,可在线阅读,更多相关《EDA技术及应用实验报告完整版纯手打.docx(37页珍藏版)》请在冰豆网上搜索。

EDA技术及应用实验报告完整版纯手打.docx

EDA技术及应用实验报告完整版纯手打

 

《EDA技术及应用》实验报告

 

系部:

 

指导教师:

 

学号:

 

姓名:

 

实验一点亮LED设计

一、实验目的

通过此实验让用户逐步了解、熟悉和掌握FPGA开发软件QuartusII的使用方法及VerilogHDL的编程方法。

本实验力求以详细的步骤和讲解让读者以最快的方式了解EDA技术开发以

及软件的使用,从而快速入门并激起读者对EDA技术的兴趣。

二、实验内容

SmartSOPC实验箱上有8个发光二极管LED1~8,并分别与FPGA的50、53~55、176和47~49引脚相连。

本实验的内容是建立可用于控制LED亮/灭的简单硬件电路,要求点亮SmartSOPC实验箱上的4个发光二极管(LED1、LED3、

LED5和LED7)。

三、实验原理

FPGA器件同单片机一样,为用户提供了许多灵活独立的输入/输出I/O口(单元)。

FPGA每个I/O口可以配置为输入、输出、双向I/O、集电极开路和三态门等各种组态。

作为输出口时,FPGA的I/O口可以吸收最大为24mA的电流,可以直

接驱动发光二极管LED等器件。

所以只要正确分配并锁定引脚后,在相应的引脚上输出低电平“0,”就可以实现点亮该发光二级管的功能。

四、实验步骤

1、启动QuartersII建立一个空白工程,命名为led_test.qpf。

然后分别建立图形设计文件,命名为led_test.bdf,以及文本编辑文件led1.v,将他们都添加进工程中。

2、对工程进行设计。

在led1.v中输入程序代码,并保存,进行综合编译,若在编译中发现错误,则找出并更正错误,直至编译成功为止。

从设计文件中创建模块,由led1.v生成名为led1.bsf的模块符号文件。

在led_test.bdf中任意空白处双击鼠标左键,将symbol对话框中libraries:

project下的led1模块添加到图形文件

led_test.bdf中,加入输入、输出引脚,双击各管脚符号,进行管脚命名。

完整的

顶层模块原理图如下图所示。

选择目标器件并进行引脚锁定。

将未使用的管脚设置为三态输入。

led1

led[7..0]OUTPUTled[7..0]

 

inst

3、设置编译选项并编译硬件系统。

将led_test.bdf设置为顶层实体。

对该工程文件进行全程编译处理。

若在编译过程中发现错误,则找出并更正错误,直到编译成功为止。

 

4、下载硬件设计到目标FPGA。

将产生的led_test.sof输出对FPGA进行配置。

5、观察LED的状态。

五、实验程序

//利用连续赋值

assign语句实现

moduleled1(led);

//模块名

led1

output[7:

0]led;

assignled=8'b10101010;

//定义输出端口、

//输出0xAA

endmodule

//利用过程赋值语句实现(暂时已屏蔽)

/*

moduleled1(led);

//模块名

led1

output[7:

0]led;

reg[7:

0]led;

always

//定义输出端口

//定义寄存器

//过程1,无敏感变量

begin

led=8'b10101010;

//输出

0xAA

end

endmudule*/

六、思考题

写出使用QuartusII软件开发工程的完整的流程。

 

实验二流水灯实验

 

一、实验目的

通过此实验让用户进一步了解、熟悉和掌握CPLD/FPGA开发软件的使用方

法及VerilogHDL的编程方法。

学习简单时序电路的设计和硬件测试。

 

二、实验内容

本实验的内容是建立可用于控制LED流水灯的简单硬件电路,要求在

SmartSOPC实验箱上实现LED1~LED8发光二极管流水灯显示。

三、实验原理

1、在LED1~LED8引脚上周期性的输出流水数据,如原来输出的数据是11111100则表示点亮LED1、LED2,流水一次后,输出的数据应该为11111000,而此时则应点亮LED1~LED3三个LED发光二极管,就可以实现LED流水灯。

为了观察方便,流水速率最好在2Hz左右。

在QuickSOPC核心板上有一个48MHz的标准时钟源,该时钟脉冲Clock与芯片的28管脚相连。

为了产生2Hz的时钟脉冲,在此调用了一个分频模块(int_div模块,位于光盘中EDA_Component目录下),通过

修改分频系数来改变输出频,当分频系数为

24x10^6时,输出即为

2Hz的频率信

号。

2、Int_div分频模块说明:

int_div模块是一个占空比为50%的任意整数分频器。

输入时钟为clock,输出时钟为clk_out。

其中F_DIV为分频系数,分频系数范围

为1~2^n(n=F_DIV_WIDTH),若要改变分频系数,改变参数F_DIV和

F_DIV_WIDTH到相应范围即可。

在本例中输入时钟为48MHz,要得到2Hz的信号,所以分频系数为48x10^6/2=24x10^6;对于分频系数为24x10^6的数需要一个

25位宽的计数器即可。

四、实验步骤

1、启动QuartersII建立一个空白工程,命名为led_water.qpf。

2、新建VerilogHDL源程序文件ledwater.v,输入程序代码并保存,进行综合编译,

若在编译中发现错误,则找出并更正错误,直至编译成功为止。

3、从设计文件中创建模块,由ledwater.v生成名为ledwater.bsf的模块符号文件。

4、将光盘中EDA_Component目录下的int_div.bsf和int_div.v拷贝到工程目录。

5、新建图形设计文件命名为led_water.bdf并保存。

在空白处双击鼠标左键,分别

将symbol对话框中libraries:

project下的ledwater和int_div模块放在图形文件

led_water.bdf中,加入输入、输出引脚,双击各管脚符号,进行管脚命名。

双击int_div

的参数框,并修改参数,将F_DIV的值改为24000000,F_DIV_WIDTH的值改为

 

25.完整的顶层模块原理图如下图所示。

 

Parameter

Value

F_DIV

24000000

F_DIV_WIDTH25

int_div

ledwater

clock

INPUT

clock

clk_out

clkled[7..0]

OUTPUT

led[7..0]

VCC

 

instinst1

6、选择目标器件并进行引脚锁定。

将未使用的管脚设置为三态输入。

7、将led_water.bdf设置为顶层实体。

对该工程文件进行全程编译处理。

若在编译

过程中发现错误,则找出并更正错误,直到编译成功为止。

8、将产生的led_water.sof输出对FPGA进行配置。

9、更改分频模块(int_div)的分频系数,并重新编译下载,观察流水灯的变化。

五、实验程序

moduleledwater(led,clk);output[7:

0]led;inputclk;

//模块名ledwater

//定义LED输出口

//定义时钟输入口

reg[8:

0]led_r;

//定义输出寄存器

assignled=led_r[7:

0];

always@(posedgeclk)

//寄存器输出

//在时钟上升沿触发进程

begin

led_r<=led_r<<1;

if(led_r==9'd0)

led_r<=9'b111111111;

//是,则输出左移一位

//循环完毕吗?

//是,则重新赋初值

end

endmodule

六、思考题

本实验顶层采用了图形输入的方式,若采用文本输入方式,如何编写顶层文件?

写出相应程序。

 

实验三键盘、LED发光实验

一、实验目的

通过此实验让用户进一步了解、熟悉和掌握CPLD/FPGA开发软件的使用方法及VerilogHDL的编程方法,熟悉以VerilogHDL文件为顶层模块的设计。

学习和体会分支条件语句case的使用方法及FPGAI/O口的输出控制。

二、实验内容

SmartSOPC实验箱上有8个发光二极管LED1~8和8个按键KEY1~KEY8。

本实验的内容要求在SmartSOPC实验箱上完成对8个按键KEY1~KEY8

控,一旦有按键输入判断其键值,并点亮相应的发光二极管,如若KEY3

进行监

按下,

则点亮

LED1~LED3

发光二极管。

三、实验原理

FPGA的所有I/O控制块允许每个I/O口引脚单独配置为输出口,不过这种配置是系统自动完成的,一旦该I/O口被设置为输入口使用时(如定义key0为输入引脚:

inputkey0;)该I/O控制模块将直接使三态缓冲区的控制端接地,使得该I/O口引脚对外呈高阻态,这样该I/O口引脚即可用作专用输入引脚。

只要正确分配并锁定引脚后,一旦在KEY1~KEY8中有按键输入,在检测到键盘输入的情况下,继续判断其键值并做出相应的处理。

四、实验步骤

1、启动QuartersII建立一个空白工程,命名为keyled.qpf。

2、新建VerilogHDL源程序文件keyled.v,输入程序代码并保存,进行综合编译,

若在编译中发现错误,则找出并更正错误,直至编译成功为止。

3、选择目标器件并进行引脚锁定。

将未使用的管脚设置为三态输入。

4、对该工程文件进行全程编译处理。

若在编译过程中发现错误,则找出并更正错

误,直到编译成功为止。

 

5、将产生的keyled.sof输出对FPGA进行配置。

按下不同按键观察LED发光管的状态。

五、实验程序

modulekeyled(key,led);

//模块名keyled

input[7:

0]

key;

//定义键盘输入口

output[7:

0]led;

//定义发光管输出口

reg[7:

0]

led_r;

//定义寄存器

reg[7:

0]

buffer_r;

assignled=led_r;

//输出键值

always@(key)

//过程1

begin

buffer_r=key;

//读取键值

case(buffer_r)

8'b11111110:

led_r=8'b11111110;//是键KEY1,则给寄存器赋值

0xfe

8'b11111101:

led_r=8'b11111100;//是键KEY2,则给寄存器赋值

0xfc

8'b11111011:

led_r=8'b11111000;//是键KEY3,则给寄存器赋值

0xf8

8'b11110111:

led_r=8'b11110000;//是键KEY4,则给寄存器赋值

0xf0

8'b11101111:

led_r=8'b11100000;//是键KEY5,则给寄存器赋值

0xe0

8'b11011111:

led_r=8'b11000000;//是键KEY6,则给寄存器赋值

0xc0

8'b10111111:

led_r=8'b10000000;//是键KEY7,则给寄存器赋值

0x80

8'b01111111:

led_r=8'b00000000;//是键KEY8,则给寄存器赋值

0x00

default:

led_r=8'b11111111;//否则给寄存器赋值0xffendcase

end

endmodule

六、思考题

能否用if语句改写本实验程序?

如果能,写出相应程序。

 

实验四静态数码管显示实验

一、实验目的

学习7段数码管显示译码器的设计,进一步了解、熟悉和掌握FPGA开发软

件QuartusII的使用方法及VerilogHDL的编程方法,学习LPM兆功能模块的调

用。

二、实验内容

SmartSOPC实验箱上有2个4位动态共阳极数码管LED12和LED13。

其中8个位码DIG0~DIG7和8位段码SEG0~SEG7分别与FPGA相应的引脚相连。

这样,只要DIG0~DIG7上一直输出低电平“0,”则8个数码管将显示相同的数码(因为8

个LED数码管的段码线分别接到了同一引脚上),这样8位动态的LED数码管就变成了静态的LED。

本实验的内容是建立7段译码显示模块,用于控制LED数码管的静态显示。

要求在SmartSOPC实验箱上的数码管依次显示0~9和A~F16个字符。

三、实验原理

数码管LED显示是工程项目中使用较广的一种输出显示器件。

常见的数码管有共阴和共阳2种。

共阴数码管是将8个发光二极管的阴极连接在一起作为公共端,而共阳数码管是将8个发光二极管的阳极连接在一起作为公共端。

公共端常

被称作位码,而将其他的8位称作段码。

数码管有8个段分别为:

h、g、f、e、d、c、b和a(h为小数点),只要公共端为高电平“1,”某个段输出低电平“0则”相应

 

的段就亮。

本实验通过分频模块int_div分频得到1Hz的频率信号,加载于4位计数器的

时钟输入端,计数循环输出0~9、A~F16个数。

最后通过七段译码模块译码后在

数码管上显示出来。

四、实验步骤

1、启动QuartersII建立一个空白工程,命名为sled.qpf。

2、新建VerilogHDL源程序文件decl7s.v,输入程序代码并保存,进行综合编译,

若在编译中发现错误,则找出并更正错误,直至编译成功为止。

3、从设计文件中创建模块,由decl7s.v生成名为decl7s.bsf的模块符号文件。

4、将光盘中EDA_Component目录下的int_div.bsf和int_div.v拷贝到工程目录。

5、添加4位计数器兆功能模块。

6、新建图形设计文件命名为sled.bdf并保存。

在空白处双击鼠标左键,分别将symbol对话框中libraries:

project下的counter、decl7s和int_div模块放在图形文

件sled.bdf中,在symbol对话框中Name:

输入gnd,添加gnd符号。

加入输入、输出引脚,双击各管脚符号,进行管脚命名。

双击int_div的参数框,并修改参数,将F_DIV的值改为48000000,F_DIV_WIDTH的值改为26。

完整的顶层模块原理图如下图所示。

ParameterValue

F_DIV48000000

OUTPUTdig[7..0]

F_DIV_WIDTH26

GND

数码管位码输出

int_div

counter

decl7s

clock

INPUT

upcounter

clockclk_out

clock

OUTPUT

seg[7..0]

VCC

d[3..0]seg[7..0]

q[3..0]

inst

数码管段码输出

inst2

inst1

 

7、选择目标器件并进行引脚锁定。

将未使用的管脚设置为三态输入。

8、将sled.bdf设置为顶层实体。

对该工程文件进行全程编译处理。

若在编译过程

中发现错误,则找出并更正错误,直到编译成功为止。

9、将产生的sled.sof输出对FPGA进行配置。

观察LED显示状态。

五、实验程序

moduledecl7s(d,seg);//模块名decl7s

input[3:

0]d;//输入4位二进制码

output[7:

0]seg;//七段译码输出

reg[7:

0]seg_r;//定义数码管输出寄存器

 

assignseg=seg_r;//输出数码管译码结果

 

always@(d)

begin

case(d)//七段译码

 

4'h0:

seg_r=8'hc0;

4'h1:

seg_r=8'hf9;

4'h2:

seg_r=8'ha4;

4'h3:

seg_r=8'hb0;

4'h4:

seg_r=8'h99;

4'h5:

seg_r=8'h92;

4'h6:

seg_r=8'h82;

4'h7:

seg_r=8'hf8;

4'h8:

seg_r=8'h80;

4'h9:

seg_r=8'h90;

4'ha:

seg_r=8'h88;

4'hb:

seg_r=8'h83;

4'hc:

seg_r=8'hc6;

4'hd:

seg_r=8'ha1;

4'he:

seg_r=8'h86;

4'hf:

seg_r=8'h8e;

 

//显示

//显示

//显示

//显示

//显示

//显示

//显示

//显示

//显示

//显示

//显示

//显示

//显示

//显示

//显示

//显示

 

0

1

2

3

4

5

6

7

8

9

a

b

c

d

e

f

endcase

end

endmodule

六、思考题

1.本实验采用的是共阳极数码管,若采用共阴极数码管,有什么不同?

 

2.如何显示HHHHHHHH和PPPPPPPP?

 

实验五动态数码管显示实验

一、实验目的

学习动态扫描显示的原理及电路的设计。

二、实验内容

本实验的内容是建立数码管动态扫描显示模块,具体内容如下:

1、在SmartSOPC实验箱上完成LED数码管的动态显示“1~8”8个数字;

2、放慢扫描速度演示动态显示的原理过程。

三、实验原理

一个FPGA的片子如果带动多个(比如说8个)数码管,选用静态显示的话,

管脚很容易不够用,于是大多采用动态显示的方式。

本次采用共阳极的数码管,

其中每个数码管的8个段:

h、g、f、e、d、c、b和a(h为小数点)都分别连接

 

到SEG0~SEG7,8个数码管分别由8个选通信号DIG0~DIG7来选择。

被选通的

数码管显示数据,其余关闭。

如果在某一时刻

DIG2

为低电平“

0”,其余选通信

号为高电平“

1”,这时仅

DIG2

对应的数码管显示来自段码信号端的数据,其余

7

个数码管呈现关闭状态。

根据这种电路状态,如果希望

8个数码管显示希望的数

据,就必须使得8个选通信号DIG0~DIG7分别被单独选通,并在此同时,在段信

号输入口加上希望在该对应数码管上显示的数据,于是随着选通信号的扫描就能

实现扫描显示的目的。

虽然每次只有一个LED显示,但只要扫描显示速率足够快,

由于人的视觉余辉效应,使我们仍会感觉所有的数码管都在同时显示。

四、实验步骤

1、启动QuartersII建立一个空白工程,命名为dled.qpf。

2、新建VerilogHDL源程序文件scan_led.v,输入程序代码并保存,进行综合编译,

若在编译中发现错误,则找出并更正错误,直至编译成功为止。

3、从设计文件中创建模块,由scan_led.v生成名为scan_led.bsf的模块符号文件。

4、将光盘中EDA_Component目录下的int_div.bsf和int_div.v拷贝到工程目录。

5、添加常量兆功能模块。

6、新建图形设计文件命名为dled.bdf并保存。

在空白处双击鼠标左键,分别将

symbol对话框中libraries:

project下的constant、scan_led和int_div模块放在图形

文件dled.bdf中,加入输入、输出引脚,双击各管脚符号,进行管脚命名。

双击

int_div的参数框,并修改参数,将F_DIV的值改为48000,F_DIV_WIDTH的值

改为16。

完整的顶层模块原理图如下图所示。

 

int_div

Parameter

Value

clock

INPUT

F_DIV

48000

clock

clk_out

F_DIV_WIDTH

16

VCC

 

inst

scan_led

clk_1k

dig[7..0]

OUTPUT

dig[7..0]

constant

d[31..0]

seg[7..0]

OUTPUT

seg[7..0]

305419896

32

inst1

inst2

 

7、选择目标器件并进行引脚锁定。

将未使用的管脚设置为三态输入。

8、将dled.bdf设置为顶层实体。

对该工程文件进行全程编译处理。

若在编译过程

中发现错误,则找出并更正错误,直到编译成功为止。

9、将产生的sled.sof输出对FPGA进行配置。

观察LED数码管上的数字是否为

“12345678”,然后把分频模块的参数改为F_DIV:

24000000,F_DIV_WIDTH:

25,

再重新编译下载,观察这次LED数码管上的显示数据,可以看到数据“12345678”

 

动起来了,这正是动态扫描的方法和过程。

五、实验程序

modulescan_led(clk_1k,d,dig,seg);inputclk_1k;

input[31:

0]d;

output[7:

0]dig;

output[7:

0]seg;

 

reg[7:

0]seg_r;

reg[7:

0]dig_r;

reg[3:

0]disp_dat;

reg[2:

0]count;

 

assigndig

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 医药卫生 > 预防医学

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1