PLD的PROTEUS电路仿真

时间:2013-09-04来源:网络

图4 16V8元件属性由前面PLD的设计可得3-8译码器的真值表:输入信号输出信号I3 I2 I1 IO7 IO6 IO5 IO4 IO3 IO2 IO1 IO0 0 0 0 1 1 1 1 1 1 1 0 0 0 1 1 1 1 1 1 1 0 1 0 1 0 1 1 1 1 1 0 1 1 0 1 1 1 1 1 1 0 1 1 1 1 0 0 1 1 1 0 1 1 1 1 0 1 1 1 0 1 1 1 1 1 1 1 0 1 0 1 1 1 1 1 1 1 1 1 0 1 1 1 1 1 1 1表1 3-8译码器真值表为了观察16V8的输入与输出的对应关系,我们在AT89C52的程序(程序见附录)中将与I3、I2、I1相连的P2_2、P2_1、P2_0三个端口按真值表中的顺序依次改变,观察LED灯是否由IO0至IO7依附点亮。

将单片机的程序加入AT89C52后,在Proteus中点击Play键观看电路仿真结果:当输入端的I1、I2、I3值按程序设定按真值表中的000—111依附改变时,输出端对应LED灯按真值表中的对应关系由IO0至IO7依次点亮,如下图。说明PLD器件16V8设计的三八译码器译码正确。

图5译码电路对应输入/输出截图

图5译码电路对应输入/输出截图

4.结语

单片机与PLD的结合是当前嵌入式设计经常采用一的种方式。但如果要进行硬件电路测试和系统调试则比较麻烦,因为要进行这两个过程必须在电路板制作完成、元器件焊接完毕之后进行。而电路板的制作、元器件的安装、焊接是费时费力的,如果采用作为单片机系统的仿真工具PROTEUS进行单片机和PLD的仿真,则不用制作具体的电路板也能够完成以上工作。在使用PROTEUS运行系统虚拟开发成功之后再进行实际制作,可以直观得观察电路的运行情况,提前发现设计的错误,可以极大的提高开发效率、降低开发成本、提高开发速度。

程序附录:

#include sbit P2_0=P2^0;sbit P2_1=P2^1;sbit P2_2=P2^2;

void delaytime(int count);void main(void)

{ while(1)

{ P2_2=0;P2_1=0;P2_0=0;delaytime(500);P2_2=0;P2_1=0;P2_0=1;delaytime(500);P2_2=0;P2_1=1;P2_0=0;delaytime(500);P2_2=0;P2_1=1;P2_0=1;delaytime(500);P2_2=1;P2_1=0;P2_0=0;delaytime(500);P2_2=1;P2_1=0;P2_0=1;delaytime(500);P2_2=1;P2_1=1;P2_0=0;delaytime(500);P2_2=1;P2_1=1;P2_0=1;delaytime(500);

}

void delaytime(int count)
{
int j,k;
while(count-- !=0)
{
for(j=0;j10;j++)
for(k=0;k72;k++)
;
}
}

1 2

关键词: PROTEUS PLD 电路仿真

加入微信
获取电子行业最新资讯
搜索微信公众号:EEPW

或用微信扫描左侧二维码

相关文章

查看电脑版