[资料分享] c和c++教程!我也做点贡献

xuzongjin   2007-2-1 12:05 楼主

[]

    4965.zip (2007-2-1 12:05 上传)

    252.88 KB, 下载次数: 417

回复评论 (49)

Re: c和c++教程!我也做点贡献

谢谢!互相学习,共同进步!
点赞  2007-2-1 14:02

Re: c和c++教程!我也做点贡献

谢谢老兄!!
点赞  2007-4-6 22:25

Re: c和c++教程!我也做点贡献

呵呵,,分享下。。
点赞  2007-4-7 13:44

Re: c和c++教程!我也做点贡献

正在学习中
点赞  2007-4-8 14:43

Re: c和c++教程!我也做点贡献

好东西!
点赞  2007-4-8 16:52

Re: c和c++教程!我也做点贡献

支持你咯
呼呼...在校应届大四学生,代做电子类毕业设计(测量类、仪器类、控制类、无线通信类、电子产品类、界面设计类、纯论文类等等,一一俱全)。涉及各种单片机软硬件设计、电路模拟分析、FPGA、CPLD、ARM7/ARM9、LINUX、VB/VC++/QT界面等等。包过。。。欢迎咨询。Tel:13957160506。QQ:273437087
点赞  2007-4-8 17:10

Re: c和c++教程!我也做点贡献

顶用!
点赞  2007-4-18 18:46

Re: c和c++教程!我也做点贡献

谢谢,我下载了。
点赞  2007-4-18 19:21

Re: c和c++教程!我也做点贡献

哈哈,这里好东西忒多了!!!
点赞  2007-5-10 12:44

Re: c和c++教程!我也做点贡献

不错 谢谢
点赞  2007-5-30 16:56

回复:c和c++教程!我也做点贡献

顶顶
点赞  2007-7-24 19:55

交通灯控制系统设计

交通灯控制系统设计
摘要:本系统由单片机系统、键盘、LED 显示、交通灯演示系统组成。系统包括人行道、左转、右转、以及基本的交通灯的功能。系统除基本交通灯功能外,还具有倒计时、时间设置、紧急情况处理、分时段调整信号灯的点亮时间以及根据具体情况手动控制等功能。
关键词:AT89S51,交通规则
一、 方案比较、设计与论证
1 电源提供方案
为使模块稳定工作,须有可靠电源。我们考虑了两种电源方案

方案一:采用独立的稳压电源。此方案的优点是稳定可靠,且有各种成熟电路可供选用;缺点是各模块都采用独立电源,会使系统复杂,且可能影响电路电平。
方案二:采用单片机控制模块提供电源。改方案的优点是系统简明扼要,节约成本;缺点是输出功率不高。
综上所述,我们选择第二种方案。
2 显示界面方案
该系统要求完成倒计时、状态灯等功能。基于上述原因,我们考虑了三种方案:
方案一:完全采用数码管显示。这种方案只显示有限的符号和数码字苻,无法胜任题目要求。
方案二:完全采用点阵式LED 显示。这种方案实现复杂,且须完成大量的软件工作;但功能强大,可方便的显示各种英文字符,汉字,图形等。
方案三:采用数码管与点阵LED 相结合的方法因为设计既要求倒计时数字输出,又要求有状态灯输出等,为方便观看并考虑到现实情况,用数码管与LED灯分别显示时间与提示信息。这种方案既满足系统功能要求,又减少了系统实现的复杂度。权衡利弊,第三种方案可互补一二方案的优缺,我们决定采用方案三以实现系统的显示功能。
3 输入方案:
题目要求系统能手动设灯亮时间、紧急情况处理,我们讨论了两种方案:
方案一:采用8155扩展I/O 口及键盘,显示等。该方案的优点是:
使用灵活可编程,并且有RAM,及计数器。若用该方案,可提供较多I/O 口,但操作起来稍显复杂。
方案二: 直接在IO口线上接上按键开关。因为设计时精简和优化了电路,所以剩余的口资源还比较多,我们使用四个按键,分别是K1、K2、K3、K4。
由于该系统对于交通灯及数码管的控制,只用单片机本身的I/O 口就可实现,且本身的计数器及RAM已经够用,故选择方案二。
二、理论分析与计算
1.交通灯显示时序的理论分析与计算
对于一个交通路口来说,能在最短的时间内达到最大的车流量,就算是达到了最佳的性能,我们称在单位时间内多能达到的最大车流为车流量,用公式:车流量= 车流 / 时间 来表示。

先设定一些标号如图2-1 所示。



说明:此图为直方图,上边为北路口灯,右边为东路口灯,下边为南路口灯,左边为西
路口灯。
图2-2 所示为一种红绿灯规则的状态图,分别设定为S1、S2、S3、S4,交通灯以这四
的状态为一个周期,循环执行(见图2-3)。



请注意图2-1b和图2-1d,它们在一个时间段中四个方向都可以通车,这种状态能在
一定的时间内达到较大的车流量,效率特别高。
依据上述的车辆行驶的状态图,可以列出各个路口灯的逻辑表,由于相向的灯的状态图
是一样的,所以只需写出相邻路口的灯的逻辑表;根据图2-3 可以看出,相邻路口的灯它
们的状态在相位上相差180°。因此最终只需写出一组S1、S2、S3、S4的逻辑状态表。

如表2-1 所示。





表中的“×”代表是红灯亮(也代表逻辑上的0),“√”是代表绿灯亮(也代表逻辑上
的1),依上表,就可以向相应的端口送逻辑值。

2.交通灯显示时间的理论分析与计算


东西和南北方向的放行时间的长短是依据路口的各个方向平时的车流量来设定,并且
S1、S2、S3、S4各个状态保持的时间之有严格的对应关系,其公式如下所示。
T-S1+T-S2=T-S3
T-S2=T-S4
T-S1=T-S3
我们可以依据上述的标准来改变车辆的放行时间。按照一般的规则,一个十字路口可分

为主干道和次干道,主干道的放行时间大于次干道的放行时间,我们设定值时也应以此为参
考。
三、电路图及设计文件
1.灯控制电路设计
由于32个LED 来实现红绿灯状态,若直接接在单片机的口线,路口倒计时的显示就不
能实现,所以本次设计中采用一种新型的电路如图3-1 所示。



图中74LS04的作用是倒相和驱动,它输出的电流大约48mA,实际测试发现足以满足要
求,而且发光管也能达到足够的亮度。
观察图可以看出:两组发光管(一组红、一组绿)由于反相器的作用,其逻辑状态恰恰
相反。
图中和电阻串联的二极管的作用是为了分压,防止因上下两组发光管分压不同导致逻辑
的错误。
共四组和上述相同的电路分别代表东西南北四个方向的红绿灯,使用两片74LS04 作为
驱动。
2.倒计时显示电路设计
前面已经分析过相向的灯的状态和倒计时都是相同的,所以为了节省,采用两组四个数码管
作为倒计时的显示;同时为了节省口资源,采用串口显示的方式驱动数码管。见图3-2 所
示。



四、程序设计思路与流程图
1.主程序流程图
主程序中主要是一个死循环,不停的循环四个状态,如图4-1 所示。



2.按键子程序流程图
它包含倒计时调整和紧急状态两个状态。
主程序中放了一个按键的判断指令,当有按键按下的时候,程序就自动的跳转到按键子
程序处理。当检测到K2键按下的时候就自动返回到主程序。
当出现紧急的情况的时候,按下K3或者K4 就切换到紧急状态,当紧急事件处理完毕
的时候,按下K2,就可以返回正常状态。

五、测试、数据及结果分析
1.状态灯显示测试
当电路连接完毕后,将写好的测试程序刷写到芯片内,K1 和K2分别给端口送高电平和
低电平,通电即可检测。
2.数码管的测试
将串口的和电路板上的接口连接,将写好的测试程序刷写到芯片内,开电源即可测试。
3.整体电路测试
系统上电,刷写好程序即可开始测试,观测一个周期(共计S1~S4四个状态,默认140
秒)灯的显示状态是否正常,同时观察倒计的计数是否正常。
六、总结
由于使用的是单片机作为核心的控制元件,使得电路的可靠性比较高,功能也比较强大,
而且可以随时的更新系统,进行不同状态的组合。
但是在我们设计和调试的过程中,也发现了一些问题,譬如红灯和绿灯的切换还不够迅
速,红绿灯规则不效率还不是很高等等,这需要在实践中进一步完善。
参考文献
[1] 李朝青.单片机原理及接口技术(修订版).北京:北京航空航天大学出版社,1998
[2] 李广弟.单片机基础.北京:北京航空航天大学出版社,1992
[3] 何立民.单片机应用技术大全.北京:北京航空航天大学出版社, 1994
[4] 张毅刚. 单片机原理及接口技术.哈尔滨:哈尔滨工业大学出版社,1990
[5] 谭浩强.单片机课程设计. 北京:清华大学出版社,1989
Abstract
This system is made up of single-chip microcomputer ,keyboard,lcd displaying module
and Traffic lights system.The system includes pavement,left truning,right truning,and the basic
traffic lights function.Excepting the basic traffic lights function,italso includes couting,time
installing,emergency disposaling,speech cluing,lcd information displaying,adjusting the lighting
time of lights based on different time and controlling with hand in accordance with circumstances
and so on.

附录 系统总体电路图



1.满足南北向红绿灯亮,东西向红灯亮,占25秒——南北向黄灯亮,东西向红灯亮,占5秒——南北向红灯亮,东西向绿灯亮,占25秒——南北向红灯亮,东西向黄灯亮,占5秒。如此循环,周而复始。 2.十字路口要有数字显示,提示行人把握时间:当某方向绿灯亮时,置显示器为24,然后以每秒减1计数方式工作,直到减为0,绿灯灭,黄灯亮。黄灯灭,红灯亮时,再次置显示器为29,并开始减计数,直到为0,十字路口红绿灯交换,完成一次工作循环。
3.可手动调整和自动调整,夜间为黄灯闪耀。

下面是一个单片机交通灯程序

/*
******************************************************************************************
* *
* Keil C 89S51 交通信号控制程序 *
* (C) 版权所有 Dai_Weis@hotmail.com *
* *
******************************************************************************************

*/
#include "reg51.h"

#define UINT unsigned int
#define ULONG unsigned long
#define UCHAR unsigned char

/*
信号灯变量
南北方向绿灯
sbit n_bike_g = P1^0; //自行车
sbit n_right_g = P1^1; //右转
sbit n_up_g = P1^2; //直行
sbit n_left_g = P1^3; //左转 调头

南北方向红灯
sbit n_bike_r = P1^4; //自行车
sbit n_right_r = P1^5; //右转
sbit n_up_r = P1^6; //直行
sbit n_left_r = P1^7; //左转 调头

南北方向黄灯
sbit n_bike_y = P3^0; //自行车
sbit n_right_y = P3^1; //右转
sbit n_up_y = P3^2; //直行
sbit n_left_y = P3^3; //左转 调头


东西方向绿灯
sbit e_bike_g = P2^0; //自行车
sbit e_right_g = P2^1; //右转
sbit e_up_g = P2^2; //直行

东西方向红灯
sbit e_bike_r = P2^4; //自行车
sbit e_right_r = P2^5; //右转
sbit e_up_r = P2^6; //直行

东西方向黄灯
sbit e_bike_y = P3^4; //自行车
sbit e_right_y = P3^5; //右转
sbit e_up_y = P3^6; //直行
*/

//延时
void delay(UINT t, UINT s)
{
while (t)
{
UINT i;
for (i = 0; i < s; i++)
{
}
t --;
}
}

//信号灯状态
void time_x(UCHAR P_P1, UCHAR P_P2, UCHAR P_P3)
{
P1 = P_P1;
P2 = P_P2;
P3 = P_P3;
delay(150, 65535);
}

void time_s(UCHAR P_P1, UCHAR P_P2, UCHAR P_P3, UCHAR P_P11, UCHAR P_P22)
{
UINT i;
for (i = 0; i < 3; i ++)
{
P1 = P_P1;
P2 = P_P2;
delay(5, 65535);
P1 = P_P11;
P2 = P_P22;
delay(5, 65535);
}
P1 = P_P1;
P2 = P_P2;
P3 = P_P3;
delay(10, 65535);
}

//主程序
void main()
{
P1 = P2 = P3 = 0x0;
while (1)
{
time_x(0xA5, 0x38, 0x0);

time_s(0xA4, 0x38, 0x1, 0xA5, 0x38);

time_x(0x96, 0x52, 0x0);

time_s(0x92, 0x52, 0x4, 0x96, 0x52);

time_x(0x5A, 0x52, 0x0);

time_s(0x50, 0x50, 0x2A, 0x5A, 0x52);

time_x(0xF0, 0x25, 0x0);

time_s(0xF0, 0x24, 0x20, 0xF0, 0x25);

time_x(0xD2, 0x16, 0x0);

time_s(0xD0, 0x10, 0x62, 0xD2, 0x16);

}
}
给你一个定时控制的信号系统,我只做的简单的测试,至于延时我用的软件,你自己想办法。^_^


Dai_Weis 于 2005-5-4 13:43:23

重新给你说明
/*
***********************************************************************************
* *
* Keil C AT89S51 交通信号控制程序 *
* (C) 版权所有 Dai_Weis@hotmail.com *
* *
***********************************************************************************
开发说明:
固定时间信号变换,南北设置调头、左传、直行、右转、自行车。
东西设置左传、直行、右转、自行车。
时序状态:
红 绿 红 绿
序号 左 前 右 自 左 前 右 自 前 右 自 前 右 自
1 1 0 1 0 0 1 0 1 1 1 1 0 0 0
2 1 0 0 1 0 1 1 0 1 0 1 0 1 0
3 0 1 0 1 1 0 1 0 1 0 1 0 1 0
4 1 1 1 1 0 0 0 0 0 1 0 1 0 1
5 1 1 0 1 0 0 1 0 0 0 1 1 1 0
*/
另外修正个错误
while (1)
{
time_x(0xA5, 0x70, 0x0);

time_s(0xA4, 0x70, 0x1, 0xA5, 0x70);
点赞  2008-11-18 17:25

两个交通灯控制的c程序

//程序一
include
#include
#define uint unsigned int
#define uchar unsigned char
#define PA XBYTE[0xFFD8]
#define PB XBYTE[0xFFD9]
#define PC XBYTE[0xFFDA]
#define PS XBYTE[0xFFDB]

void delayus(uint us)
{
while(us--);
}
delayms(uint ms)
{
uint i,j;
for(i=0;i for(j=0;j<15;j++)
delayus(1);
}
main()
{

//set 8255 mode
PS=0x88;


// initial

PB=0x02;
PA=0x49;
delayms(2000);

while(1)
{//status 1:
PB=0x03;
PA=0x0c;
delayms(5000);

//status 2:
PB=0x02;
PA=0x8a;
delayms(2000);


//status 3:
PB=0x08;
PA=0x61;
delayms(5000);

//status 4:
PB=0x04;
PA=0x51;
delayms(2000);
}

}

而后觉得,每次都要给DPTR赋值,似乎效率来得不如直接改变DPL的值好,于是改写为:

//程序二
#include
#include
#define uint unsigned int
#define uchar unsigned char
void delayus(uint us)
{
while(us--);
}
delayms(uint ms)
{
uint i,j;
for(i=0;i for(j=0;j<15;j++)
delayus(1);
}
main()
{
uchar volatile xdata *X8255;
//set 8255 mode
X8255=0xFFDB;
*X8255=0x88;
//PS=0x80;


// initial
DPL--;
DPL--;
*X8255=0x0f;
DPL--;
*X8255=0xff;
delayms(2000);

while(1)
{//status 1:
DPL++;
*X8255=0x03;
DPL--;
*X8255=0x0c;
delayms(5000);

//status 2:
DPL++;
*X8255=0x02;
DPL--;
*X8255=0x8a;
delayms(2000);


//status 3:
DPL++;
*X8255=0x08;
DPL--;
*X8255=0x61;
delayms(5000);

//status 4:
DPL++;
*X8255=0x04;
DPL--;
*X8255=0x51;
delayms(2000);
}

}

结果改后,程序运行不是想象中的效果。于是将程序中的DPL全部替换为X8255
这下程序没问题了,可是,按想象, dec/inc DPL 应该比 mov DPTR #****H效率来得高,没想到生成的目标文件居然大了100多字节。


include
#include
#define uint unsigned int
#define uchar unsigned char
#define PA XBYTE[0xFFD8]
#define PB XBYTE[0xFFD9]
#define PC XBYTE[0xFFDA]
#define PS XBYTE[0xFFDB]

void delayus(uint us)
{
while(us--);
}
delayms(uint ms)
{
uint i,j;
for(i=0;i for(j=0;j<15;j++)
delayus(1);
}
main()
{

//set 8255 mode
PS=0x88;


// initial

PB=0x02;
PA=0x49;
delayms(2000);

while(1)
{//status 1:
PB=0x03;
PA=0x0c;
delayms(5000);

//status 2:
PB=0x02;
PA=0x8a;
delayms(2000);


//status 3:
PB=0x08;
PA=0x61;
delayms(5000);

//status 4:
PB=0x04;
PA=0x51;
delayms(2000);
}

}

而后觉得,每次都要给DPTR赋值,似乎效率来得不如直接改变DPL的值好,于是改写为:

//程序二
#include
#include
#define uint unsigned int
#define uchar unsigned char
void delayus(uint us)
{
while(us--);
}
delayms(uint ms)
{
uint i,j;
for(i=0;i for(j=0;j<15;j++)
delayus(1);
}
main()
{
uchar volatile xdata *X8255;
//set 8255 mode
X8255=0xFFDB;
*X8255=0x88;
//PS=0x80;


// initial
DPL--;
DPL--;
*X8255=0x0f;
DPL--;
*X8255=0xff;
delayms(2000);

while(1)
{//status 1:
DPL++;
*X8255=0x03;
DPL--;
*X8255=0x0c;
delayms(5000);

//status 2:
DPL++;
*X8255=0x02;
DPL--;
*X8255=0x8a;
delayms(2000);


//status 3:
DPL++;
*X8255=0x08;
DPL--;
*X8255=0x61;
delayms(5000);

//status 4:
DPL++;
*X8255=0x04;
DPL--;
*X8255=0x51;
delayms(2000);
}

}

结果改后,程序运行不是想象中的效果。于是将程序中的DPL全部替换为X8255
这下程序没问题了,可是,按想象, dec/inc DPL 应该比 mov DPTR #****H效率来得高,没想到生成的目标文件居然大了100多字节。
点赞  2008-11-18 17:28
谢谢!互相学习,共同进步!
点赞  2008-11-18 18:47

Re: c和c++教程!我也做点贡献

很好谢谢拉楼主!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
点赞  2009-1-19 22:05

Re: c和c++教程!我也做点贡献

谢谢,楼主分享
点赞  2009-2-19 21:02

Re: c和c++教程!我也做点贡献

谢谢!互相学习,共同进步!
点赞  2009-2-19 21:31

Re: c和c++教程!我也做点贡献

谢谢!互相学习,不知这个就爱哦才
点赞  2009-3-25 23:25
很好的的资料  谢谢楼主了  
点赞  2009-4-9 15:28
123下一页
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 京公网安备 11010802033920号
    写回复