ImageVerifierCode 换一换
格式:DOCX , 页数:9 ,大小:112.16KB ,
资源ID:2330655      下载积分:12 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/2330655.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(用verilog编写16位加法器乘法器自动售货机.docx)为本站会员(b****2)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

用verilog编写16位加法器乘法器自动售货机.docx

1、用verilog编写16位加法器乘法器自动售货机Verilog课程实验报告实验1十六位超前进位加法器系统设计要求 用超前进位加法器实现一个有符号位的16位加法器,并且考虑溢出的情况详细设计 根据超前进位加法器的原理Co = G | ( P & Ci ) S = P Ci设计出4位加法器的子模块,然后通过4个4位加法器的相连来得到十六位的加法器。原理如下图所示。溢出用flag=0表示。 程序module sixteenaddertest; wire 15:0 s; reg 15:0a,b; wire flag; parameter times=5; a=-10743,b=11372没有溢出,st

2、o=0.通过这个实验验证了s=a+b,实现了带符号位的加法器。实验二 十六位加减法器系统设计要求 将加法器和减法器结合到一起,实现带符号位的16位加减法运算,并考虑溢出。详细设计 在16位加法器的基础上,加上一条判断语句,如果出现减的操作,被减数取反加一,这样就实现了减的运算,用add_sub来表示加减运算符,当add_sub=0时候实现的是减运算,add_sub=1的时候实现的是加运算。程序module adder_sub_test; wire 15:0 s; reg 15:0a,b; reg add_sub; wire flag; initial 当a=-4659 b=12817 add_

3、sub=0,减操作,输出s=-17476,无溢出,flag=0.当a=562 b=-24223 add_sub=1,加操作,输出s=-23661,无溢出,flag=0.通过以上的结果分析,此程序实现了带符号位的加减法的功能。实验三 十六位的乘法器11系统设计要求 实现16*16位的无符号位的乘法器详细设计乘法器的硬件电路原理如下定义16个寄存器,用来存储一行乘操作产生的数据,最后的结果为所有16行相加。程序;module mult_test;reg15:0 a,b_in;wire rdy;wire31:0 mux_out;reg clk,rst_n,en;initialbegin clk=0;

4、 forever #50 clk=clk;endinitialbegin rst_n=0; en=0; a=16h1231; b_in=16ha231; #100 begin rst_n=1; en=0; a=16h2137; b_in=16h0142;end #100 begin rst_n=1; en=1; a=16h0234; b_in=16h12a7;end #100 begin rst_n=1; en=1; a=16h0012; b_in=16ha261;end #100 begin rst_n=0; en=1; a=16h1112; b_in=16h0879;end #10000

5、$stop;endmux mux1(.clk(clk),.rst_n(rst_n),.en(en),.a(a),.b_in(b_in),.rdy(rdy),.mux_out(mux_out);endmodule仿真波形 通过仿真产生的波形如下所示: 当rst_n=0处于复位状态 输出mux_out=0,当rst=1并且使能端en=1时候,乘法器工作。当a=564,b=4775,mux_out=2693100,sto=1,实现了乘的操作,验证了电路实现乘法功能。 实验四 自动售货机设计系统设计要求自动售货机投入的金钱有50元,10元,5元,1元四种货币。可供选择的商品有7种类型。投入金钱后选择要

6、买的商品,当投入的钱足够时,显示money_enough。并显示出要买的商品,并且找零,当投入的钱不够的时候,通过复位成初始态。具体的要求如下图所示:详细设计 初始状态下,设投入的money,找零charge,money_enough都为0。投入的四种货币总共有12种情况,用price_all表示。设商品goods有7种,其价格为1,5,10,15,20,30,50,用price表示。Rest为低电平时候,一切初始。在rest为高电平的时候。选择商品,并且投币,当price-all小于price时候,也就是投入的金钱不够,显示money_enough为0,回初始状态。当pirce_all大于p

7、rice时候,输出选择的商品goods。并且找零。其状态转换图如下:Moneyn,selln对应的金钱和价格如下表所示:Moneyn123456789101112Price_all1510502201001151155560Selln1234567price151015203050程序module autosell_test;reg clk,rest;reg 3:0 money;reg 2:0 sell;wire 7:0 charge;wire2:0 goods;wire money_enough;initialbegin clk=0; forever #25 clk=clk;endiniti

8、albegin lk(clk),.sell(sell),.rest(rest),.money(money),.charge(charge),.goods(goods),.money_enough(money_enough);endmodule仿真结果 用进行仿真得到的仿真图形如下: 如图所示,在money类型为9,选择商品类型为6,对应的总投入的面值pirce-all=51 ,商品6的价格为price=30,显示money_enough为高电平,找零charge为21。在money为5,商品类型为7时候,Price_all=2,price=50.购买商品投入的钱不够,在经过一个clk的money_enough为低电平,在下一个clk上升沿输入商品goods 以及charge都是0。 经过功能验证,所设计的自动售货机实现了所需的要求。

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

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