Proteus实验报告

Proteus实验报告
Proteus实验报告

Proteus实验报告

姓名: xxxxx

专业: xxxxxx

系别:电气信息工程学院

学号:xxxxxxxx

班级:xxxxxxxxxxxxxxxx

老师: xxxxxxx

2012年11月

实验一

花样灯一

一、实验目的

使用P2端口控制LED0~LED7进行花样显示。显示顺序规律为:○18个LED 依次左移点亮;○28个LED依次右移点亮;○3LED0、LED2、LED4、LED6亮1s熄灭,LED1、LED3、LED5、LED7亮1s熄灭,再LED0、LED2、LED4、LED6亮1s熄灭……循环3次;○4LED0~LED3亮1s熄灭,LED4~LED7亮1s熄灭,循环2次;○5LED2、LED3、LED6、LED7亮1s熄灭,LED0、LED1、LED4、LED5亮1s熄灭,循环3次,然后再从○1循环。

二、实验仪器

单片机AT89C51、瓷片电容CAP22Pf、晶振CRYSTAL 11.0592MHz、电解电容CAP-ELEC、电阻RES、发光二级管LED-GREEN、发光二级管LED-YELLOW、发光二级管LED-RED、发光二级管LED-BULE、按钮BUTTON。

三、实验流程图

四、实验原理

电路图:

程序: #include"reg51.h"

#define uint unsigned int

#define uchar unsigned char

const tab[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f,

0xbf,0xdf,0xef,0xf7,0xfb,0xfd,0xfe,0xff,

0xaa,0x55,0xaa,0x55,0xaa,0x55,0xff,

0xf0,0x0f,0xf0,0x0f,0xff,

0x33,0xcc,0x33,0xcc,0x33,0xcc,0xff

}

void delay(void)

{uint i,j,k;

for(i=0;i>0;i--)

{for(j=200;j>0;j--)

{for(k=230;k>0;k--);}}

}

void main(void)

{uchar i;

while(1)

{for(i=0;i<35;i++)

{P2=tab[i];

delay();}}}

五、实验结果

实验二

定时计数器一

一、实验目的

使用定时计数器作为延时,要求在P0.0和P0.1间两灯按1s间隔互相闪烁。

二、实验仪器

单片机AT89C51、瓷片电容CAP22Pf、晶振CRYSTAL 11.0592MHz、电解电容CAP-ELEC、电阻RES、发光二级管LED-GREEN、排阻RESPACLK-8、发光二级管LED-RED、发光二级管LED-YELLOW、按钮BUTTON。

三、实验流程图

四、实验原理

电路图:

程序:#include"reg51.h"

#define uint unsigned int

#define uchar unsigned char

sbit P0_0=P0^0;

sbit P0_1=P0^1;

uint t=0;

void time0_server_(void)interrupt 1 {

TH0=0x4C;

TL0=0x00;

t++;}

void Init_t0(void)

{TMOD=0x01;

TH0=0x4C;

TL0=0x00;

EA=1;

ET0=1;

TR0=1;}

void main(void)

{P0_0=1;

P0_1=0;

Init_t0();

while(1)

{if(t==20){

t=0;

P0_0=~P0_0;

P0_1=~P0_1;

}

}

}

五、实验结果

实验三

中断系统应用一

一、实验目的

主程序将P0端口进行花样显示,显示顺序规律为:○18个LED 依次左移点亮;○28个LED依次右移点亮;○3LED0、LED2、LED4、LED6

亮1s熄灭,LED1、LED3、LED5、LED7亮1s熄灭,再LED0、LED2、LED4、LED6亮1s熄灭……循环3次。中断时(INT0与按钮K1连接)使8个LED 闪烁5次。

二、实验器件

单片机AT89C51、瓷片电容CAP22Pf、晶振CRYSTAL 11.0592MHz、电解电容CAP-ELEC、电阻RES、发光二级管LED-GREEN、排阻RESPACLK-8、发光二级管LED-RED、按钮BUTTON、发光二级管LED-BULE、发光二级管LED-YELLOW。

三、实验流程图

四、实验原理

原理图:

程序:#include "reg51.h"

#define uint unsigned int

#define uchar unsigned char

const tab[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f,

0xbf,0xdf,0xef,0xf7,0xfb,0xfd,0xfe,0xff,

0xaa,0x55,0xaa,0x55,0xaa,0x55,0xff,};

const tab2[]={0xff,0x00,0xff,0x00,0xff,0x00,0xff,0x00,0xff,0x00,}; void delay(void)

{

uint i,j,k;

for(i=10;i>0;i--)

{for(j=200;j>0;j--) {for(k=230;k>0;k--);}} }

void int0() interrupt 0 {

uchar i;

for(i=0;i<10;i++)

{

P0=tab2[i];

delay();

}

} void INT0_init(void) {

EX0=1;

IT0=1;

EA=1;

}

void main(void)

{

uchar x;

INT0_init();

while(1)

{

for(x=0;x<23;x++) {

P0=tab[x]; delay(); }

}

}

五、实验结果

实验四

两个单片机之间的串行通信

一、实验目的

再摸控制系统中有U1、U2这两个单片机,U1单片机首先将P1端口指拨开关数据载入SUBF,然后由TXD将数据传送给U2单片机,U2单片机将接收数据存入SBUF,再由SUBF载入累加器,并输出至P1端口,点亮相应端口的LED。

二、实验器件

发光二级管LED-RED、按钮BUTTON、单片机AT89C51、瓷片电容CAP22Pf、晶振CRYSTAL 11.0592MHz、电解电容CAP-ELEC、电阻RES、发光二级管LED-GREEN、拨码开关DIPSW-8、开关SWITCH。

三、实验流程图

四、实验原理

原理图:

程序:

U1:

#include "reg51.h"

#define uchar unsigned char

#define uint unsigned int

void send(uchar state)

{

SBUF=state;

while(TI=0);

TI=0;

}

void SCON_init(void)

{

SCON=0x50;

TMOD=0x20;

PCON=0x00;

TH1=0xFD;

TL1=0xFD;

TI=0;

TR1=1;

ES=1;

}

void main(void)

{

P1=0xFF;

SCON_init();

while(1)

{

send(P1);

}

}

U2:

#include "reg51.h"

#define uchar unsigned char

#define uint unsigned int

uchar state;

void receive()

{

while(RI=0);

state=SBUF;

RI=0;

}

Void SCON_init(void)

{

SCON=0x50; TMOD=0x20; PCON=0x00;

TH1=0xFD;

TL1=0xFD;

RI=0;

TR1=1;

}

void main(void) {

SCON_init();

while(1)

{

receive();

P1=state;

}

}

五、实验结果

U1

U2:

实验五

矩阵式键盘识别一

一、实验目的

设计一个4x4的矩阵键盘,以P3.0~P3.3作为行线,以P3.4~P3.7作为列线,在数码管上显示每个按键的0~F序号。

二、实验器件

单片机AT89C51、瓷片电容CAP22Pf、晶振CRYSTAL 11.0592MHz、电解电容CAP-ELEC、电阻RES、排阻RESPACLK-7、按钮BUTTON、共阳数码管7SEG-COM-AM-GRN。

三、实验流程图

四、实验原理

程序:

#include"reg51.h"

#define uchar unsigned char #define uint unsigned int

uchar buff,times,j;

uchar code dispcode[]={0xC0,0xF9,0xA4,0 xB0,0x99,0x92,0x82,0xF8,0x8 0,0x90,0x88,0x83,0xC6,0xA1, 0x86,0x8E};

uchar idata value[8];

void delay1ms(void)

{

uchar i;

for(i=200;i>0;i--);

}

void delay5ms(void)

{

unsigned char i,j;

for(i=5;i>0;i--)

for(j=230;j>0;j--);

}

void key_scan(void)

{

uchar hang,lie,key;

P3=0xf0;

if((P3&0xf0)!=0xf0)

{

delay1ms();

if((P3&0xf0)!=0xf0)

{hang=0xfe;

times++;

if(times=9)

times=1;

while((hang&0x10)!=0)

{P3=hang;

if((P3&0xf0)!=0xf0) {lie=(P3&0xf0)|0x0f;

buff=((~hang)+(~lie));

switch(buff)

{

case 0x11:key=0;break; case 0x21:key=1;break; case 0x41:key=2;break; case 0x81:key=3;break;

case 0x12:key=4;break;

case 0x22:key=5;break;

case 0x42:key=6;break;

case 0x82:key=7;break;

case 0x14:key=8;break;

case 0x24:key=9;break;

case 0x44:key=10;break;

case 0x84:key=11;break;

case 0x18:key=12;break;

case 0x28:key=13;break;

case 0x48:key=14;break;

case 0x88:key=15;break;

}

value[times-1]=key;

}

else

hang=(hang<<1)|0x01;

}

}

}

}

void main(void)

{

while(1)

{

key_scan();

P0=dispcode[value[times-1]];

}

}

原理图:

五、实验结果

相关主题
相关文档
最新文档