当前位置:文档之家› 计算机辅助设计综合实习报告(全面)

计算机辅助设计综合实习报告(全面)

计算机辅助设计综合实习报告学院:信息科学与工程学院班级:电子信息科学与技术08-2学号:3080448201姓名:邝辉宁指导老师:陈小琴日期:2010.9.18计算机辅助设计综合实习报告一.实习的性质与目的1、课程性质:计算机辅助设计是电子信息类各专业本科生的必修课。

计算机辅助设计技术范畴包含电子系统设计和开发的全过程,可分为系统级、电路级和物理级。

2、实习目的:借助现代EDA技术进行系统电路设计,侧重于综合应用所学知识,设计较为复杂的功能电路或小型电子系统,培养学生的现代电路设计与综合应用的能力,提高电路设计水平,培养现代电子系统设计能力和创新研究能力。

二.实习教学的基本要求给出实习课题任务要求,学生通过阅读资料、选择方案、设计电路、编程仿真、性能指标测试、撰写报告等过程,培养学生综合运用所学知识解决实际问题的能力和创新研究能力。

需要熟练掌握常用电子系统设计工具Protel DXP。

三.实习主题:LED数字式温度计的设计。

要求:1.用2个8段数码管显示所测温度计;2.测量范围为30~99℃四.实习内容及过程:1.方案选择和电路设计根据题目要求,选用单片机设计电路系统能较轻松和准确地实现,这里采用的单片机是常用的AT89C52。

2.利用keilc51编写单片机程序已经有了电路图,接下来就要编写程序并进行仿真,从而确定各元件的参数。

Keilc51是常用的单片机编程软件,现用于编写一个应用于AT89C52的温控程序。

程序如下:编译结果如图1所示:图13.利用proteus进行电路图仿真Proteus是适合于单片机电路仿真的软件,现用于对LED数字式温度计电路仿真。

通过仿真可以确定各元件的参数,并对程序进行修正。

经过多次测试,终于确定了元件的参数。

电路图及仿真过程如图2所示:图24.利用Protel DXP画出PCB图(1).电路原理图设计新建工程,然后新建原理图文件,打开原理图就可以设计原理图了。

画原理图之前,先添加所需要的元件库。

利用设计管理器可以方便地添加元件库,一般常用的是“Miscellaneous Devices.ddb”库和“Protel Dos”库。

在画原理图时,放置元件的方法是,选择目标元件所在的元件库,然后从它下面的具体元件列表框中选择目标元件,点击place按钮,将目标元件拖到图纸中,并放置在所需要的位置。

点击“place”之后,放置元件之前,按下“tab”键,就会弹出元件属性对话框,可以编辑元件的属性,其中元件封装和元件标号是必须编辑的。

放置好元件之后,就可以连线了,Protel DXP提供了多种连线方式,可以通过空格键进行切换。

连好线,原理图就设计好了。

(2).编辑新元件尽管Protel DXP内置的元件库已经相当丰富,但有时还是无法从这些元件库中找到想要的元件,这时就需要自行建立新的元件及元件库了。

现在需要建立单片机AT89C52这个元件,方法如下:在当前设计管理器环境下,执行“File/new”,选择“Schematic Library Document”,就创建了一个新元件库文档,把文档名改为“89c52”。

双击打开进入元件库编辑界面,执行“Place/Rectangle”,拖动鼠标绘制一个直角矩形,大小为25*13格,执行“Place/Pins”,在矩形周围画40个引脚,用空格键可以旋转方向。

双击引脚,逐一编辑各引脚属性。

执行“Tools/Rename Component”,在对话框中把元件名称改为“89c52”,然后保存。

在原理图设计界面把此元件装载到元件库中,就可以取用“89c52”元件了。

(3)ERC检查在原理图设计界面下,执行“Tools/ERC”可以生成ERC表,用于检查电路图是否有问题,可以根据ERC表修正原理图中的错误。

原理图的最终设计如图3:图3(4).生成网络表ERC检查无误后,执行“Design/Create Netlist”,选择网络表类型,生成网络表。

(5).建立PCB文件,装载网络表执行“File/New”,选择“PCB Document”,则建立了一个PCB文件,双击打开PCB 编辑器,添加所需要的封装库。

执行“Design/Load Nets”,在对话框中选择所用到的网络表,点击“ok”按钮,这时如果有错误提示,则要返回原理图修正,重新生成和装载网络表,直到没有错误提示为止,点击“Execute”按钮,就装入了网络表和元件。

(6).布局和布线在PCB编辑界面下,点击下方的“keepoutlayer”,执“Place/Keepout/Track”,画出电路板边框。

执行“右键/Rules”,在弹出对话框中定义布局和布线规则。

然后进行手工布局,把已装入的元件一一拖入边框内的合适位置,并调整好元件放置方向。

布局完后,执行“AutoRoute/All”,单击对话框中的“Route All”按钮即可完成自动布线,手工进行一些调整即可完成PCB图的设计。

如图4:图4(7).电气规则检查当一块线路板已经设计好,我们要检查布线是否有错误,Protel DXP提供了很好的检查工具“DRC”自动规则检查。

执行“Tools/Design Rlue Check”,计算机会自动将检查结果列出来。

电气规则检查无误,就可以保存设计,并交付PCB文件给制版厂家生产电路板了。

实习心得:经过为时三周的计算机辅助设计综合实习,我查阅了不少的资料,使用了Protel DXP画PCB图和keilc51编程,用了proteus仿真:利用EDA技术完成了一个LED数字式温度计的设计。

这个实习使我的电子设计水平和解决实际问题的能力有了很大的提高。

附录:/* 18B20单线温度检测的应用样例程序,请将18b20插紧,然后在数码管可以显示XX,如显示28表示当前温度28度*/#include<reg52.h> //包含头文件,一般情况不需要改动,头文件包含特殊功能寄存器的定义#include<math.h>#include<INTRINS.H>#define uchar unsigned char#define uint unsigned int;/* 定义端口*/sbit seg1=P2^0;sbit seg2=P2^1;sbit seg3=P2^2;sbit DQ=P1^3;//ds18b20 端口sfr dataled=0x80;//显示数据端口/* 全局变量*/uint temp;uchar flag_get,count,num,minute,second;uchar code tab[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};//7段数码管段码表共阳uchar str[6];/* 函数声明*/ void delay1(uchar MS);unsigned int ReadTemperature(void);void Init_DS18B20(void);unsigned char ReadOneChar(void);void WriteOneChar(unsigned char dat);void delay(unsigned int i);/* 主函数*/ main(){unsigned char TempH,TempL;TMOD|=0x01;//定时器设置TH0=0xef;TL0=0xf0;IE=0x82;TR0=1;P2=0x00;count=0;while(1){str[2]=tab[(TempH%100)/10]; //十位温度str[3]=tab[(TempH%100)%10]+0x80; //个位温度,带小数点if(flag_get==1) //定时读取当前温度{temp=ReadTemperature();if(temp&0x8000){str[0]=0x40;//负号标志temp=~temp; // 取反加1temp +=1;}elsestr[0]=0;TempH=temp>>4;TempL=temp&0x0F;TempL=TempL*6/10;//小数近似处理flag_get=0;}}}/* 定时器中断*/ void tim(void) interrupt 1 using 1//中断,用于数码管扫描和温度检测间隔{TH0=0xef;//定时器重装值TL0=0xf0;num++;if (num==50){num=0;flag_get=1;//标志位有效second++;if(second>=60){second=0;minute++;}}count++;if(count==1){P2=0;dataled=str[0];}//数码管扫描if(count==2){P2=1;dataled=str[1];}if(count==3){ P2=2;dataled=str[2];}if(count==4){ P2=3;dataled=str[3];}if(count==5){ P2=4;dataled=str[4];}if(count==6){ P2=5;dataled=str[5];count=0;}}/* 延时函数*/ void delay(unsigned int i)//延时函数{while(i--);}/* 初始化*/ void Init_DS18B20(void){DQ = 1; //DQ复位delay(8); //稍做延时DQ = 0; //单片机将DQ拉低delay(80); //精确延时大于480usDQ = 1; //拉高总线delay(10);x=DQ; //稍做延时后如果x=0则初始化成功x=1则初始化失败delay(5);}/* 读一个字节*/ unsigned char ReadOneChar(void){unsigned char i=0;unsigned char dat = 0;for (i=8;i>0;i--){DQ = 0; // 给脉冲信号dat>>=1;DQ = 1; // 给脉冲信号if(DQ)dat|=0x80;delay(5);}return(dat);}/* 写一个字节*/ void WriteOneChar(unsigned char dat){unsigned char i=0;for (i=8; i>0; i--){DQ = 0;DQ = dat&0x01;delay(5);DQ = 1;dat>>=1;}delay(5);}/* 读取温度*/ unsigned int ReadTemperature(void){unsigned char a=0;unsigned int b=0;Init_DS18B20();WriteOneChar(0xCC); // 跳过读序号列号的操作WriteOneChar(0x44); // 启动温度转换delay(200);Init_DS18B20();WriteOneChar(0xCC); //跳过读序号列号的操作WriteOneChar(0xBE); //读取温度寄存器等(共可读9个寄存器)前两个就是温度a=ReadOneChar(); //低位b=ReadOneChar(); //高位b<<=8;t=a+b;return(t);}。

相关主题