77范文网 - 专业文章范例文档资料分享平台

基于FPGA乒乓球游戏机Verilog设计(2)

来源:网络收集 时间:2020-06-03 下载这篇文档 手机版
说明:文章内容仅供预览,部分内容可能不全,需要完整文档或者需要复制内容,请下载word后使用。下载word有问题请添加微信号:或QQ: 处理(尽可能给您提供完整文档),感谢您的支持与谅解。点击这里给我发消息

乒乓球游戏机核心控制模块:

module led_con(clk_1s,reset,start,key_a,key_b,led_pose,sum,score_a,score_b,speaker,led);

input clk_1s; input reset; input start; input key_a; input key_b; input led_pose; output[4:0] sum; output[3:0] score_a; output[3:0] score_b; output[5:0] led; output speaker; reg speaker;

//-------------------------------------------------------------- reg[5:0] led_move; reg[3:0] score_a_r; reg[3:0] score_b_r; reg[6:0] state;

parameter[6:0] s0 = 7'b0000001, s1 = 7'b0000010, s2 = 7'b0000100, s3 = 7'b0001000, s4 = 7'b0010000, s5 = 7'b0100000, s6 = 7'b1000000;

always @(posedge clk_1s or negedge reset) begin

if(!reset) state <= s0; else

if(!start)

begin case(state) s0: begin speaker <= 1; if(score_a_r == 4'd11 || score_b_r == 4'd11) begin score_a_r <= 4'b0; score_b_r <= 4'b0; end else if(!led_pose) begin led_move <= 6'b011111; state <= s1; end else if(led_pose) begin led_move <= 6'b111110; state <= s4; end end s1: begin if(!key_a) begin led_move <= {led_move[0],led_move[5:1]}; state <= s2; end else if(!key_b) begin speaker <= 0; state <= s0; end else state <= s1; end s2: begin if((led_move[2] == 0 || led_move[1] == 0 || led_move[0] == 0) && !key_b) state <= s6; else if(((led_move[2] == 0 || led_move[1] == 0) && key_b) ||(led_move[5] == 0 || led_move[4] == 0 || led_move[3] == 0)) state <= s3; else begin score_a_r <= score_a_r+1;

s3: s4:

state <= s0; end end

begin

led_move <= {led_move[0],led_move[5:1]}; state <= s2; end

begin

if(!key_b) begin led_move <= {led_move[4:0],led_move[5]}; state <= s5; end

else if(!key_a) begin speaker <= 0; state <= s0; end else state <= s4; end

s5: begin if((led_move[3] == 0 || led_move[4] == 0 || led_move[5] == 0) && !key_a) state <= s3; else if(((led_move[3] == 0 || led_move[4] == 0) && key_a) ||(led_move[0] == 0 || led_move[1] == 0 || led_move[2] == 0)) state <= s6; else begin score_b_r <= score_b_r+1; state <= s0; end end s6: begin led_move <= {led_move[4:0],led_move[5]}; state <= s5; end default:state <= s0; endcase end else begin

led_move <= 6'b110011; speaker <= 1; end end

assign score_a = score_a_r; assign score_b = score_b_r; assign led = led_move;

assign sum = score_a_r+score_b_r; endmodule

基于 FPGA乒乓球比赛游戏机顶层原理图

后记:因为时间关系,资料没有整理的很理顺,请大家谅解,整个工程会给出,在板子上已调试成功,因为乒乓球位置控制模块所用的时钟为clk_1000ms,所以按键停留最好

超过1s就能更稳的接住球。程序有点乱,没有优化,仅供参考!!

百度搜索“77cn”或“免费范文网”即可找到本站免费阅读全部范文。收藏本站方便下次阅读,免费范文网,提供经典小说教育文库基于FPGA乒乓球游戏机Verilog设计(2)在线全文阅读。

基于FPGA乒乓球游戏机Verilog设计(2).doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印 下载失败或者文档不完整,请联系客服人员解决!
本文链接:https://www.77cn.com.cn/wenku/jiaoyu/1086087.html(转载请注明文章来源)
Copyright © 2008-2022 免费范文网 版权所有
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ: 邮箱:tiandhx2@hotmail.com
苏ICP备16052595号-18
× 注册会员免费下载(下载后可以自由复制和排版)
注册会员下载
全站内容免费自由复制
注册会员下载
全站内容免费自由复制
注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: