抢答器是一种智力竞赛常用的器件,抢答器的设计方法千差万别,文章利用常用的数字电子器件,设计了八路抢答器电路的设计、仿真及实现的全过程,提出两种可行的设计方案:方案1采用74ls373实现电路锁存,74ls148实现电路编码,74ls74及数码管实现电路显示;方案二采用CD4511BCN和LMC555CM集成电路及数码管实现抢答器的控制和显示。本文设计用的器件简单,容易理解,适用于初学电子技术的人员。Answer scrambler is a common device in intelligence competition, and its design methods vary greatly. This paper designs the whole process of design, simulation and Realization of the circuit of eight-way answer scrambler by using common digital electronic devices, and puts forward two feasible design schemes: scheme 1 uses 74 ls373 to realize circuit latching, 74 ls148 to realize circuit coding,74 ls74 and digital tube to realize circuit. The second scheme uses CD4511 BCN, LMC555 CM integrated circuit and digital tube to control and display the answerer. The device designed in this paper is simple and easy to understand, and it is suitable for the beginners of electronic technology.
标签: 抢答器
上传时间: 2022-04-05
上传用户:
eeworm.com VIP专区 单片机源码系列 8资源包含以下内容:1. 单片机最小系统与基本输入输出电路设计.ppt2. 基于8051仿真 STC12C5A60S2-PDIP40+DS18B20+LCD1602.zip3. ATmega_128常用程序例子.doc4. 利用时钟芯片DS1302实现万年历.rar5. 单片机驱动继电器 (非常有用).ppt6. iccavr_atmega128程序大全.wps7. 16&16LED点阵显示器设计.rar8. DAC0832工作原理及其在单片机中的应用(基于Proteus仿真).docx9. 单片机设计 16*16点阵屏电路图.pdf10. 基于单片机的直流电机调速系统设计.doc11. 学校电子日历的研发.zip12. dy-mini 80 v3单片机开发板图.rar13. 51单片机综合学习系统-SPI总线.pdf14. 基于STC12C5A60S2单片机的静态应变采集器设计.zip15. AT89C51开发例程 protues仿真 keil编程.rar16. 十天学会单片机和C51_视频教程的种子文件.rar17. 基于单片机的双轴太阳能跟踪系统的设计.zip18. DM430-L单片机系统板.pdf19. S51下载线制作原理文件包V2.0.rar20. 基于MSP430的低成本及超低功耗数字测温器设计.zip21. STM32_在KEIL_MDK环境下使用V3.4库.pdf22. 动态显示中断定时计数.ppt23. 基于stc89c51的数电课设—“开灯游戏设计”.doc24. 步进电机实验电路.doc25. stc15单片机开发板使用说明书.pdf26. 温度报警加按键调节上下限.doc27. 好书共享-《实例解读51单片机完全学习与应用》.pdf28. 利用宏晶科技的IAP单片机开发自己的ISP程序实例.zip29. 稀里糊涂玩STM32第四讲:白驹过隙.pdf30. 利用宏晶科技的IAP单片机开发自己的ISP程序.doc31. STM32讲义+第三讲:事出有因+5D.pdf32. STM32的恒温消毒柜设计.zip33. 稀里糊涂玩STM32第二讲:源源不绝+5D.pdf34. AT89c52控制数码管带温度显示的万年历.rar35. 稀里糊涂玩STM32 第一讲:泾渭分明+5D.pdf36. 基于I2C总线的AD存储DA的proteus仿真.rar37. MSP430x1xx Family user guide.pdf38. 自动通风系统程序及proteus仿真.rar39. USB下载器(STC89C5x系列).pdf40. 稀里糊涂玩STM32第六讲:川流不息.pdf41. 最简单易学的C语言教程资料包.zip42. 稀里糊涂玩STM32第五讲:争分夺秒.pdf43. c语言编程实例训练.zip44. 用lcd1602和adc0808设计的数字电压表.doc45. bin转hex的小程序.rar46. 51单片机设计的心形流水灯.zip47. 131-双色点阵交替图形显示.rar48. 74LS138译码器应用.zip49. 自动往返电动小汽车设计报告.pdf50. 多路智力竞赛抢答器装调实训.doc51. 天漠科技SBC8100单板机概述.pdf52. 单片机相应芯片资料.rar53. 单线CAN总线隔离中继器的设计.zip54. keil C51完全破解版.zip55. IAR使用教程.pdf56. 基于HT46F49E的低成本智能电表设计.zip57. LCD12864串口显示程序(实际检验通过).doc58. keil c51完全版.zip59. MSP430单片机在水声应答释放器中的应用.zip60. nokia5110智能电子钟的设计ds1302+ds18b20+stc12c5a60s2.rar61. msp430G2553程序实例.ppt62. 基于AT89S51单片机的低频信号设计及仿真研究.zip63. ATMEGA16L熔丝配置详解.pdf64. TX-1C实验板分块原理图.rar65. 12864显示DS18B20温度曲线.rar66. Keil_uvision_4基本使用教程.pdf67. 飞思卡尔智能车设计资料.pdf68. DIY四轴花样流水灯(附原程序和仿真).rar69. CT107D单片机综合实训平台使用说明书.pdf70. 52单片机开发板的实例程序.rar71. STM32F103中文教程及参考手册.pdf72. 读懂芯片时序.zip73. STM8中文资料.pdf74. 一种声音引导倒车系统设计研究.pdf75. arm菜鸟 快速入门.rar76. 用8051单片机实现智能浇花.pdf77. 21天学通51单片机开发(第2版).rar78. 红外线发射接收对管的简单应用基础.doc79. 定时器中断 (加强理解).rar80. STC12C5A60S2增强型51单片机手册.pdf81. 新概念51单片机C语言教程书中例程.rar82. 电子竞赛,智能小车资料大全,郭天祥单片机编程高清视频教程入门与提高.zip83. 一种基于MSP430单片机的蓄电池充电系统.pdf84. CC2530中文数据手册完全版.pdf85. 315M无线收发系统编码,解码程序.zip86. 一种基于MSP430单片机技术的新型电压监测仪.pdf87. 单片机频率计C代码.zip88. 智能小车C语言模块化编程(我见过最好的).pdf89. AVR单片机系统开发经典实例部分源程序.rar90. 基于LM35的温度测量系统.doc91. 飞思卡尔智能车资料.rar92. MK60DN512ZVLQ10资料.pdf93. 字符特征提取和单片机显示.zip94. Microcontrollers Projects in C for The 8051.pdf95. 基于AT89S52的无线传感网节点前端设计.zip96. 基于MSP430F149的人员登记与录入系统设计.zip97. nRF905微功率模块资料汇总(2012-08-20).rar98. STC12C5A60S2数据手册.pdf99. 具有实时时钟器的测温系统的设计.zip100. 单片机C语言课程设计_程序--花样流水灯.doc
上传时间: 2013-05-15
上传用户:eeworm
eeworm.com VIP专区 单片机源码系列 65资源包含以下内容:1. C8051F35X单片机内部Flash存储器的擦写方法.pdf2. 学51单片机之数码管部分.pdf3. 单片机在汽车驾驶模拟器中的应用.pdf4. 学51单片机之C51基础知识.pdf5. 学51单片机之单片机基础知识.pdf6. PIC单片机的C语言编程教材.pdf7. 学51单片机之LED部分.pdf8. NiosII培训教程与实验材料.rar9. Keil C51语言使用技巧及实战(周立功).pdf10. STM32F10xxx USB开发工具包.pdf11. 教你写Makefile.pdf12. 怎样写testbench-xilinx.pdf13. 学单片机之中断部分部分.pdf14. 代码优化的文档.pdf15. 学单片机之定时器部分.pdf16. Nios 的用户定义接口逻辑实例.rar17. 学单片机之串口通信.pdf18. Avlon总线规范参考手册.pdf19. AVR单片机与GCC编程.rar20. 数字信号处理.doc21. 为何选用SAMSUNG S3C44B0进行开发.doc22. 各类开发实用电路图.rar23. linux 中断和设备驱动.rar24. 基于C语言的MCS-51系列单片机软件开发系统.rar25. 基于单片机技术的光电检测研究.pdf26. 基于单片机的智能流量控制系统.pdf27. 基于AT89C51的腰椎牵引仪的设计.pdf28. 基于单片机的数字温度测控系统设计.pdf29. 基于MSP430单片机的二氧化碳测量系统.pdf30. usb调试助手.rar31. 基于PIC单片机的螺杆空压机控制器.pdf32. 基于PIC单片机的蓄电池检测及均衡系统.pdf33. AVR Terminal.EXE34. 闪速8 AD转换器TLC5510与单片微机的接口技术.pdf35. 基域C8051F020芯片的多功能计数器设计.pdf36. MCU51的串口调试工具.rar37. 基于单片机的楼宇供暖节能系统的设计.pdf38. 基于MSP430单片机的近红外水分分析仪设计.pdf39. 可编程计数器陈列PCA原理及应用设计.pdf40. 基于单片机控制多路PZT的驱动电路设计.pdf41. 基于MSP430单片机的深水监测装置.pdf42. 74系列选型参考资料.pdf43. 基于DS1820的无线温度采集系统的设计.pdf44. 基于单片机的热电偶测温系统的设计.pdf45. 基于单片机的车速控制技术的研究.pdf46. 基于C8051F410的精确信号模拟电路设计.pdf47. 简述单片机测控通用系统.doc48. 基于ATmega128的泥浆压力脉冲信号仿真器.pdf49. 基于芯片ADE7755单相电能计量电路的设计.pdf50. 32位嵌入式CPU中系统控制协处理器的设计与实现.pdf51. 基于ADS1253的色谱仪数据采集系统设计.pdf52. 用单片机实现流水灯的控制设计.pdf53. 基于SMBus的双单片机多通道ADC.pdf54. 基于单片机的人体腰椎复位研究.pdf55. 用stm32设计的rtc万年历程序.rar56. 基于PIC单片机的太阳能路灯控制器.pdf57. 基于SPCE061A的智能语音处理系统设计.pdf58. 串口利用定时器中断接受不同的帧.rar59. 基于SMS的单片机无线监控系统设计.pdf60. STM32的SD卡驱动及液晶驱动源代码资料.rar61. 基于单片机的资料库温和湿度监控系统.pdf62. I2C的模拟驱动资料下载.rar63. 基于单片机的多点温度烟雾测控系统设计.pdf64. FREERTOS的官方移植文档.rar65. 基于单片机的粮库多点测温系统的设计.pdf66. 强人写的UCOS_II,V2.52.rar67. SPCE061A在智能家居系统中的应用.pdf68. 飞思卡尔S12系列单片机系统硬件设计.rar69. 基于单片机的温度远程控制系统设计.pdf70. MC9S08FL16 DEMO资料.pdf71. WORKBENCH学习指导资料.pdf72. M52235EVB-K2e 开发板资料.rar73. AVR应用经验解析.pdf74. M52221 DEMO板资料.rar75. DSP系列56F800 DEMO开发板资料.rar76. DSP 56f800 DBUM开发板资料.rar77. SD协议介绍.doc78. CML-5282开发板资料.rar79. 单片机C51编程规范教程.doc80. IIC总线协议中文版.pdf81. Freescale MC9S12C64介绍及编程练习.rar82. freescaler开发板资料及原理图.rar83. PIC16F877的外围功能模块资料.pdf84. HCS12中断原理分析 ppt.rar85. PIC16f877快速入门教程.pdf86. DEMO9RS08KB12开发板资料及原理图.rar87. Freescale HCS12微控制器资料 ppt.rar88. 单片机语言C51程序设计.pdf89. 基于SPCE061A的步进电机控制系统设计.pdf90. HCS12微控制器MC9S12DP256使用指南 ppt.rar91. 单片机常用的程序30例.rar92. MCS-51单片机实用子程序库实验(七).doc93. DEMOLL16_Lab_code使用资料.rar94. FSL08系列单片机开发及C语言编程简介.pdf95. MCS-51单片机实用子程序库实验(六).doc96. HCS12X系列存储器配置操作指南.pdf97. MC9S08QG8英文资料 pdf.pdf98. MCS-51单片机实用子程序库实验(五).doc99. 基于XGATE进行Manchester译码的方法.pdf100. FREESCALE单片机的C编程教程.pdf
标签: 滚动码
上传时间: 2013-05-21
上传用户:eeworm
双向DC/DC变换器(Bi-directionalDC/DCconverters)是能够根据需要调节能量双向传输的直流/直流变换器。随着科技的发展,双向DC/DC变换器的应用需求越来越多,正逐步应用到无轨电车、地铁、列车、电动车等直流电机驱动系统,直流不间断电源系统,航天电源等场合。一方面,双向DC/DC变换器为这些系统提供能量,另一方面,又使可回收能量反向给供电端充电,从而节约能量。 大多数双向DC/DC变换器采用复杂的辅助网络来实现软开关技术,本文所研究的Buck/Boost双向的DC/DC变换器从拓扑上解决器件软开关的问题;由于Buck/Boost双向DC/DC变换器的电流纹波较大,这会带来严重的电磁干扰,本文结合Buck/Boost双向DC/DC变换器拓扑与磁耦合技术使电感电流纹波减小;由于在同一频率下不同负载时电流纹波不同,本文在控制时根据负载改变PWM频率,从而使轻载时的电流纹波均较小。 本文所研究的双向DC/DC变换器采用DSP处理器进行控制,其原因在于:目前没有专门用于控制该Buck/Boost双向DC/DC变换器的控制芯片,而DSP具有多路的高分辨率PWM,通过对DSP寄存器的配置可以实现Buck/Boost双向DC/DC变换器的控制PWM;DSP具有多路高速的A/D转换接口,并可以通过配合PWM完成对反馈采样,具备一定的滤波功能。 本文所研究的数字双向DC/DC变换器实现了在Buck模式下功率MOSFET的零电压开通及零电压关断,电感电流的交迭使其电感输出端电流纹波明显变小,轻载时PWM频率的提升也使得电流纹波变小。
上传时间: 2013-06-08
上传用户:cy_ewhat
随着数字电视全国范围丌播时间表的临近,数字电视技术得到很大发展,数字电视信号在信源基带数据和信道传输等方面已经进一步标准化,数字电视传播途径也越来越广,在卫星、地面及有线电视网中传输数字电视信号得到迅速发展。借着2008年奥运的东风,数字电视领域的应用研究方兴未艾。 本课题目的是完成有线数字电视广播系统的重要设备--调制器的设计和实现,核心器件选用FPGA芯片。系统硬件实现以国家标准GY/T 170-2001(有线数字电视广播信道编码与调制规范)为主要依据,以Xilinx公司的Virtex系列(Virtex 4,Virtex 5)芯片及相关开发板(ML402、ML506)为平台,主要任务是基于相关标准对其实用技术进行研究和开发。完成了信道编码和调制的模块划分、Verilog HLD程序的编写(或IP核的调用)和仿真以及在板调试和联调等工作,设计目的是在提高整个系统集成度的前提下实现多频点调制。 本文在研究现有数字电视网络技术和相关产品的基础上,以国标GY/T170-2001为主要依据并参阅了其他的相关标准,提出了多频点QAM调制器的实现方案。整个工作包括:模块划分,完成了基带物理接口(输入)、包头反转与随机化、RS编码、卷积交织、码流变换、差分编码、星座映射、基带成型(包括Nyquist滤波器、半带滤波器、CIC滤波器的设计或模块调用)、高端DAC的配置(输出)等模块的Verilog HLD程序的编写(或者IP核调用)和仿真等工作;成功进行了开发板板级调试,调试的过程中充分利用Xilinx公司的开发板和调试软件ChipScope,成功设计了验证方案并进行了模块验证;最后进行了各模块联调工作,设计了系统验证方案并成功完成对整个系统的验证工作。 经测试表明,该系统主要性能达到国家相关标准GY/T 198-2003(有线数字电视广播QAM调制器技术要求和测量方法)规定的技术指标,可以进入样机试生产环节。
上传时间: 2013-04-24
上传用户:jiangfire
特点: 精确度0.1%满刻度 可作各式數學演算式功能如:A+B/A-B/AxB/A/B/A&B(Hi or Lo)/|A|/ 16 BIT类比输出功能 输入与输出绝缘耐压2仟伏特/1分钟(input/output/power) 宽范围交直流兩用電源設計 尺寸小,穩定性高
上传时间: 2014-12-23
上传用户:ydd3625
特点(FEATURES) 精确度0.1%满刻度 (Accuracy 0.1%F.S.) 可作各式数学演算式功能如:A+B/A-B/AxB/A/B/A&B(Hi or Lo)/|A| (Math functioA+B/A-B/AxB/A/B/A&B(Hi&Lo)/|A|/etc.....) 16 BIT 类比输出功能(16 bit DAC isolating analog output function) 输入/输出1/输出2绝缘耐压2仟伏特/1分钟(Dielectric strength 2KVac/1min. (input/output1/output2/power)) 宽范围交直流两用电源设计(Wide input range for auxiliary power) 尺寸小,稳定性高(Dimension small and High stability)
上传时间: 2013-11-24
上传用户:541657925
TLC2543是TI公司的12位串行模数转换器,使用开关电容逐次逼近技术完成A/D转换过程。由于是串行输入结构,能够节省51系列单片机I/O资源;且价格适中,分辨率较高,因此在仪器仪表中有较为广泛的应用。 TLC2543的特点 (1)12位分辩率A/D转换器; (2)在工作温度范围内10μs转换时间; (3)11个模拟输入通道; (4)3路内置自测试方式; (5)采样率为66kbps; (6)线性误差±1LSBmax; (7)有转换结束输出EOC; (8)具有单、双极性输出; (9)可编程的MSB或LSB前导; (10)可编程输出数据长度。 TLC2543的引脚排列及说明 TLC2543有两种封装形式:DB、DW或N封装以及FN封装,这两种封装的引脚排列如图1,引脚说明见表1 TLC2543电路图和程序欣赏 #include<reg52.h> #include<intrins.h> #define uchar unsigned char #define uint unsigned int sbit clock=P1^0; sbit d_in=P1^1; sbit d_out=P1^2; sbit _cs=P1^3; uchar a1,b1,c1,d1; float sum,sum1; double sum_final1; double sum_final; uchar duan[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f}; uchar wei[]={0xf7,0xfb,0xfd,0xfe}; void delay(unsigned char b) //50us { unsigned char a; for(;b>0;b--) for(a=22;a>0;a--); } void display(uchar a,uchar b,uchar c,uchar d) { P0=duan[a]|0x80; P2=wei[0]; delay(5); P2=0xff; P0=duan[b]; P2=wei[1]; delay(5); P2=0xff; P0=duan[c]; P2=wei[2]; delay(5); P2=0xff; P0=duan[d]; P2=wei[3]; delay(5); P2=0xff; } uint read(uchar port) { uchar i,al=0,ah=0; unsigned long ad; clock=0; _cs=0; port<<=4; for(i=0;i<4;i++) { d_in=port&0x80; clock=1; clock=0; port<<=1; } d_in=0; for(i=0;i<8;i++) { clock=1; clock=0; } _cs=1; delay(5); _cs=0; for(i=0;i<4;i++) { clock=1; ah<<=1; if(d_out)ah|=0x01; clock=0; } for(i=0;i<8;i++) { clock=1; al<<=1; if(d_out) al|=0x01; clock=0; } _cs=1; ad=(uint)ah; ad<<=8; ad|=al; return(ad); } void main() { uchar j; sum=0;sum1=0; sum_final=0; sum_final1=0; while(1) { for(j=0;j<128;j++) { sum1+=read(1); display(a1,b1,c1,d1); } sum=sum1/128; sum1=0; sum_final1=(sum/4095)*5; sum_final=sum_final1*1000; a1=(int)sum_final/1000; b1=(int)sum_final%1000/100; c1=(int)sum_final%1000%100/10; d1=(int)sum_final%10; display(a1,b1,c1,d1); } }
上传时间: 2013-11-19
上传用户:shen1230
单片机指令系统原理 51单片机的寻址方式 学习汇编程序设计,要先了解CPU的各种寻址法,才能有效的掌握各个命令的用途,寻址法是命令运算码找操作数的方法。在我们学习的8051单片机中,有6种寻址方法,下面我们将逐一进行分析。 立即寻址 在这种寻址方式中,指令多是双字节的,一般第一个字节是操作码,第二个字节是操作数。该操作数直接参与操作,所以又称立即数,有“#”号表示。立即数就是存放在程序存储器中的常数,换句话说就是操作数(立即数)是包含在指令字节中的。 例如:MOV A,#3AH这条指令的指令代码为74H、3AH,是双字节指令,这条指令的功能是把立即数3AH送入累加器A中。MOV DPTR,#8200H在前面学单片机的专用寄存器时,我们已学过,DPTR是一个16位的寄存器,它由DPH及DPL两个8位的寄存器组成。这条指令的意思就是把立即数的高8位(即82H)送入DPH寄存器,把立即数的低8位(即00H)送入DPL寄存器。这里也特别说明一下:在80C51单片机的指令系统中,仅有一条指令的操作数是16位的立即数,其功能是向地址指针DPTR传送16位的地址,即把立即数的高8位送入DPH,低8位送入DPL。 直接寻址 直接寻址方式是指在指令中操作数直接以单元地址的形式给出,也就是在这种寻址方式中,操作数项给出的是参加运算的操作数的地址,而不是操作数。例如:MOV A,30H 这条指令中操作数就在30H单元中,也就是30H是操作数的地址,并非操作数。 在80C51单片机中,直接地址只能用来表示特殊功能寄存器、内部数据存储器以及位地址空间,具体的说就是:1、内部数据存储器RAM低128单元。在指令中是以直接单元地址形式给出。我们知道低128单元的地址是00H-7FH。在指令中直接以单元地址形式给出这句话的意思就是这0-127共128位的任何一位,例如0位是以00H这个单元地址形式给出、1位就是以01H单元地址给出、127位就是以7FH形式给出。2、位寻址区。20H-2FH地址单元。3、特殊功能寄存器。专用寄存器除以单元地址形式给出外,还可以以寄存器符号形式给出。例如下面我们分析的一条指令 MOV IE,#85H 前面的学习我们已知道,中断允许寄存器IE的地址是80H,那么也就是这条指令可以以MOV IE,#85H 的形式表述,也可以MOV 80H,#85H的形式表述。 关于数据存储器RAM的内部情况,请查看我们课程的第十二课。 直接寻址是唯一能访问特殊功能寄存器的寻址方式! 大家来分析下面几条指令:MOV 65H,A ;将A的内容送入内部RAM的65H单元地址中MOV A,direct ;将直接地址单元的内容送入A中MOV direct,direct;将直接地址单元的内容送直接地址单元MOV IE,#85H ;将立即数85H送入中断允许寄存器IE 前面我们已学过,数据前面加了“#”的,表示后面的数是立即数(如#85H,就表示85H就是一个立即数),数据前面没有加“#”号的,就表示后面的是一个地址地址(如,MOV 65H,A这条指令的65H就是一个单元地址)。 寄存器寻址 寄存器寻址的寻址范围是:1、4个工作寄存器组共有32个通用寄存器,但在指令中只能使用当前寄存器组(工作寄存器组的选择在前面专用寄存器的学习中,我们已知道,是由程序状态字PSW中的RS1和RS0来确定的),因此在使用前常需要通过对PSW中的RS1、RS0位的状态设置,来进行对当前工作寄存器组的选择。2、部份专用寄存器。例如,累加器A、通用寄存器B、地址寄存器DPTR和进位位CY。 寄存器寻址方式是指操作数在寄存器中,因此指定了寄存器名称就能得到操作数。例如:MOV A,R0这条指令的意思是把寄存器R0的内容传送到累加器A中,操作数就在R0中。INC R3这条指令的意思是把寄存器R3中的内容加1 从前面的学习中我产应可以理解到,其实寄存器寻址方式就是对由PSW程序状态字确定的工作寄存器组的R0-R7进行读/写操作。 寄存器间接寻址 寄存间接寻址方式是指寄存器中存放的是操作数的地址,即操作数是通过寄存器间接得到的,因此称为寄存器间接寻址。 MCS-51单片机规定工作寄存器的R0、R1做为间接寻址寄存器。用于寻址内部或外部数据存储器的256个单元。为什么会是256个单元呢?我们知道,R0或者R1都是一个8位的寄存器,所以它的寻址空间就是2的八次方=256。例:MOV R0,#30H ;将值30H加载到R0中 MOV A,@R0 ;把内部RAM地址30H内的值放到累加器A中 MOVX A,@R0 ;把外部RAM地址30H内的值放到累加器A中 大家想想,如果用DPTR做为间址寄存器,那么它的寻址范围是多少呢?DPTR是一个16位的寄存器,所以它的寻址范围就是2的十六次方=65536=64K。因用DPTR做为间址寄存器的寻址空间是64K,所以访问片外数据存储器时,我们通常就用DPTR做为间址寄存器。例:MOV DPTR,#1234H ;将DPTR值设为1234H(16位) MOVX A,@DPTR ;将外部RAM或I/O地址1234H内的值放到累加器A中 在执行PUSH(压栈)和POP(出栈)指令时,采用堆栈指针SP作寄存器间接寻址。例:PUSH 30H ;把内部RAM地址30H内的值放到堆栈区中堆栈区是由SP寄存器指定的,如果执行上面这条命令前,SP为60H,命令执行后会把内部RAM地址30H内的值放到RAM的61H内。 那么做为寄存器间接寻址用的寄存器主要有哪些呢?我们前面提到的有四个,R0、R1、DPTR、SP 寄存器间接寻址范围总结:1、内部RAM低128单元。对内部RAM低128单元的间接寻址,应使用R0或R1作间址寄存器,其通用形式为@Ri(i=0或1)。 2、外部RAM 64KB。对外部RAM64KB的间接寻址,应使用@DPTR作间址寻址寄存器,其形式为:@DPTR。例如MOVX A,@DPTR;其功能是把DPTR指定的外部RAM的单元的内容送入累加器A中。外部RAM的低256单元是一个特殊的寻址区,除可以用DPTR作间址寄存器寻址外,还可以用R0或R1作间址寄存器寻址。例如MOVX A,@R0;这条指令的意思是,把R0指定的外部RAM单元的内容送入累加器A。 堆栈操作指令(PUSH和POP)也应算作是寄存器间接寻址,即以堆栈指针SP作间址寄存器的间接寻址方式。 寄存器间接寻址方式不可以访问特殊功能寄存器!! 寄存器间接寻址也须以寄存器符号的形式表示,为了区别寄存器寻址我寄存器间接寻址的区别,在寄存器间接寻址方式式中,寄存器的名称前面加前缀标志“@”。 基址寄存器加变址寄存器的变址寻址 这种寻址方式以程序计数器PC或DPTR为基址寄存器,累加器A为变址寄存器,变址寻址时,把两者的内容相加,所得到的结果作为操作数的地址。这种方式常用于访问程序存储器ROM中的数据表格,即查表操作。变址寻址只能读出程序内存入的值,而不能写入,也就是说变址寻址这种方式只能对程序存储器进行寻址,或者说它是专门针对程序存储器的寻址方式。例:MOVC A,@A+DPTR这条指令的功能是把DPTR和A的内容相加,再把所得到的程序存储器地址单元的内容送A假若指令执行前A=54H,DPTR=3F21H,则这条指令变址寻址形成的操作数地址就是54H+3F21H=3F75H。如果3F75H单元中的内容是7FH,则执行这条指令后,累加器A中的内容就是7FH。 变址寻址的指令只有三条,分别如下:JMP @A+DPTRMOVC A,@A+DPTRMOVC A,@A+PC 第一条指令JMP @A+DPTR这是一条无条件转移指令,这条指令的意思就是DPTR加上累加器A的内容做为一个16位的地址,执行JMP这条指令是,程序就转移到A+DPTR指定的地址去执行。 第二、三条指令MOVC A,@A+DPTR和MOVC A,@A+PC指令这两条指令的通常用于查表操作,功能完全一样,但使用起来却有一定的差别,现详细说明如下。我们知道,PC是程序指针,是十六位的。DPTR是一个16位的数据指针寄存器,按理,它们的寻址范围都应是64K。我们在学习特殊功能寄存器时已知道,程序计数器PC是始终跟踪着程序的执行的。也就是说,PC的值是随程序的执行情况自动改变的,我们不可以随便的给PC赋值。而DPTR是一个数据指针,我们就可以给空上数据指针DPTR进行赋值。我们再看指令MOVC A,@A+PC这条指令的意思是将PC的值与累加器A的值相加作为一个地址,而PC是固定的,累加器A是一个8位的寄存器,它的寻址范围是256个地址单元。讲到这里,大家应可明白,MOVC A,@A+PC这条指令的寻址范围其实就是只能在当前指令下256个地址单元。所在,这在我们实际应用中,可能就会有一个问题,如果我们需要查询的数据表在256个地址单元之内,则可以用MOVC A,@A+PC这条指令进行查表操作,如果超过了256个单元,则不能用这条指令进行查表操作。刚才我们已说到,DPTR是一个数据指针,这个数据指针我们可以给它赋值操作的。通过赋值操作。我们可以使MOVC A,@A+DPTR这条指令的寻址范围达到64K。这就是这两条指令在实际应用当中要注意的问题。 变址寻址方式是MCS-51单片机所独有的一种寻址方式。 位寻址 80C51单片机有位处理功能,可以对数据位进行操作,因此就有相应的位寻址方式。所谓位寻址,就是对内部RAM或可位寻址的特殊功能寄存器SFR内的某个位,直接加以置位为1或复位为0。 位寻址的范围,也就是哪些部份可以进行位寻址: 1、我们在第十二课学习51单片机的存储器结构时,我们已知道在单片机的内部数据存储器RAM的低128单元中有一个区域叫位寻址区。它的单元地址是20H-2FH。共有16个单元,一个单元是8位,所以位寻址区共有128位。这128位都单独有一个位地址,其位地址的名字就是00H-7FH。这里就有一个比较麻烦的问题需要大家理解清楚了。我们在前面的学习中00H、01H。。。。7FH等等,所表示的都是一个字节(或者叫单元地址),而在这里,这些数据都变成了位地址。我们在指令中,或者在程序中如何来区分它是一个单元地址还是一个位地址呢?这个问题,也就是我们现在正在研究的位寻址的一个重要问题。其实,区分这些数据是位地址还是单元地址,我们都有相应的指令形式的。这个问题我们在后面的指令系统学习中再加以论述。 2、对专用寄存器位寻址。这里要说明一下,不是所有的专用寄存器都可以位寻址的。具体哪些专用寄存器可以哪些专用寄存器不可以,请大家回头去看看我们前面关于专用寄存器的相关文章。一般来说,地址单元可以被8整除的专用寄存器,通常都可以进行位寻址,当然并不是全部,大家在应用当中应引起注意。 专用寄存器的位寻址表示方法: 下面我们以程序状态字PSW来进行说明 D7 D6 D5 D4 D3 D2 D1 D0 CY AC F0 RS1 RS0 OV P 1、直接使用位地址表示:看上表,PSW的第五位地址是D5,所以可以表示为D5H MOV C,D5H 2、位名称表示:表示该位的名称,例如PSW的位5是F0,所以可以用F0表示 MOV C,F0 3、单元(字节)地址加位表示:D0H单元位5,表示为DOH.5 MOV C,D0H.5 4、专用寄存器符号加位表示:例如PSW.5 MOV C,PSW.5 这四种方法实现的功能都是相同的,只是表述的方式不同而已。 例题: 1. 说明下列指令中源操作数采用的寻址方式。 MOV R5,R7 答案:寄存器寻址方式 MOV A,55H 直接寻址方式 MOV A,#55H 立即寻址方式 JMP @A+DPTR 变址寻址方式 MOV 30H,C 位寻址方式 MOV A,@R0 间接寻址方式 MOVX A,@R0 间接寻址方式 改错题 请判断下列的MCS-51单片机指令的书写格式是否有错,若有,请说明错误原因。 MOV R0,@R3 答案:间址寄存器不能使用R2~R7。 MOVC A,@R0+DPTR 变址寻址方式中的间址寄存器不可使用R0,只可使用A。 ADD R0,R1 运算指令中目的操作数必须为累加器A,不可为R0。 MUL AR0 乘法指令中的乘数应在B寄存器中,即乘法指令只可使用AB寄存器组合。
上传时间: 2013-11-11
上传用户:caozhizhi
pic单片机实用教程(提高篇)以介绍PIC16F87X型号单片机为主,并适当兼顾PIC全系列,共分9章,内容包括:存储器;I/O端口的复位功能;定时器/计数器TMR1;定时器TMR2;输入捕捉/输出比较/脉宽调制CCP;模/数转换器ADC;通用同步/异步收发器USART;主控同步串行端口MSSP:SPI模式和I2C模式。突出特点:通俗易懂、可读性强、系统全面、学练结合、学用并重、实例丰富、习题齐全。<br>本书作为Microchip公司大学计划选择用书,可广泛适用于初步具备电子技术基础和计算机知识基础的学生、教师、单片机爱好者、电子制作爱好者、电器维修人员、电子产品开发设计者、工程技术人员阅读。本教程全书共分2篇,即基础篇和提高篇,分2册出版,以适应不同课时和不同专业的需要,也为教师和读者增加了一种可选方案。 第1章 EEPROM数据存储器和FIASH程序存储器1.1 背景知识1.1.1 通用型半导体存储器的种类和特点1.1.2 PIC单片机内部的程序存储器1.1.3 PIC单片机内部的EEPROM数据存储器1.1.4 PIC16F87X内部EEPROM和FIASH操作方法1.2 与EEPROM相关的寄存器1.3 片内EEPROM数据存储器结构和操作原理1.3.1 从EEPROM中读取数据1.3.2 向EEPROM中烧写数据1.4 与FLASH相关的寄存器1.5 片内FLASH程序存储器结构和操作原理1.5.1 读取FLASH程序存储器1.5.2 烧写FLASH程序存储器1.6 写操作的安全保障措施1.6.1 写入校验方法1.6.2 预防意外写操作的保障措施1.7 EEPROM和FLASH应用举例1.7.1 EEPROM的应用1.7.2 FIASH的应用思考题与练习题第2章 输入/输出端口的复合功能2.1 RA端口2.1.1 与RA端口相关的寄存器2.1.2 电路结构和工作原理2.1.3 编程方法2.2 RB端口2.2.1 与RB端口相关的寄存器2.2.2 电路结构和工作原理2.2.3 编程方法2.3 RC端口2.3.1 与RC端口相关的寄存器2.3.2 电路结构和工作原理2.3.3 编程方法2.4 RD端口2.4.1 与RD端口相关的寄存器2.4.2 电路结构和工作原理2.4.3 编程方法2.5 RE端口2.5.1 与RE端口相关的寄存器2.5.2 电路结构和工作原理2.5.3 编程方法2.6 PSP并行从动端口2.6.1 与PSP端口相关的寄存器2.6.2 电路结构和工作原理2.7 应用举例思考题与练习题第3章 定时器/计数器TMR13.1 定时器/计数器TMR1模块的特性3.2 定时器/计数器TMR1模块相关的寄存器3.3 定时器/计数器TMR1模块的电路结构3.4 定时器/计数器TMR1模块的工作原理3.4.1 禁止TMR1工作3.4.2 定时器工作方式3.4.3 计数器工作方式3.4.4 TMR1寄存器的赋值与复位3.5 定时器/计数器TMR1模块的应用举例思考题与练习题第4章 定时器TMR24.1 定时器TMR2模块的特性4.2 定时器TMR2模块相关的寄存器4.3 定时器TMR2模块的电路结构4.4 定时器TMR2模块的工作原理4.4.1 禁止TMR2工作4.4.2 定时器工作方式4.4.3 寄存器TMR2和PR2以及分频器的复位4.4.4 TMR2模块的初始化编程4.5 定时器TMR2模块的应用举例思考题与练习题第5章 输入捕捉/输出比较/脉宽调制CCP5.1 输入捕捉工作模式5.1.1 输入捕捉摸式相关的寄存器5.1.2 输入捕捉模式的电路结构5.1.3 输入捕捉摸式的工作原理5.1.4 输入捕捉摸式的应用举例5.2 输出比较工作模式5.2.1 输出比较模式相关的寄存器5.2.2 输出比较模式的电路结构5.2.3 输出比较模式的工作原理5.2.4 输出比较模式的应用举例5.3 脉宽调制输出工作模式5.3.1 脉宽调制模式相关的寄存器5.3.2 脉宽调制模式的电路结构5.3.3 脉宽调制模式的工作原理5.3.4 脉定调制模式的应用举例5.4 两个CCP模块之间相互关系思考题与练习题第6章 模/数转换器ADC6.1 背景知识6.1.1 ADC种类与特点6.1.2 ADC器件的工作原理6.2 PIC16F87X片内ADC模块6.2.1 ADC模块相关的寄存器6.2.2 ADC模块结构和操作原理6.2.3 ADC模块操作时间要求6.2.4 特殊情况下的A/D转换6.2.5 ADC模块的转换精度和分辨率6.2.6 ADC模块的内部动作流程和传递函数6.2.7 ADC模块的操作编程6.3 PIC16F87X片内ADC模块的应用举例思考题与练习题第7章 通用同步/异步收发器USART7.1 串行通信的基本概念7.1.1 串行通信的两种基本方式7.1.2 串行通信中数据传送方向7.1.3 串行通信中的控制方式7.1.4 串行通信中的码型、编码方式和帧结构7.1.5 串行通信中的检错和纠错方式7.1.6 串行通信组网方式7.1.7 串行通信接口电路和参数7.1.8 串行通信的传输速率7.2 PIC16F87X片内通用同步/异步收发器USART模块7.2.1 与USART模块相关的寄存器7.2.2 USART波特率发生器BRG7.2.3 USART模块的异步工作方式7.2.4 USART模块的同步主控工作方式7.2.5 USART模块的同步从动工作方式7.3 通用同步/异步收发器USART的应用举例思考题与练习题第8章 主控同步串行端口MSSP——SPI模式8.1 SPI接口的背景知识8.1.1 SPI接口信号描述8.1.2 基于SPI的系统构成方式8.1.3 SPI接口工作原理8.1.4 兼容的MicroWire接口8.2 PIC16F87X的SPI接口8.2.1 SPI接口相关的寄存器8.2.2 SPI接口的结构和操作原理8.2.3 SPI接口的主控方式8.2.4 SPI接口的从动方式8.3 SPI接口的应用举例思考题与练习题第9章 主控同步串行端口MSSP——I(平方)C模式9.1 I(平方)C总线的背景知识9.1.1 名词术语9.1.2 I(平方)C总线的技术特点9.1.3 I(平方)C总线的基本工作原理9.1.4 I(平方)C总线信号时序分析9.1.5 信号传送格式9.1.6 寻址约定9.1.7 技术参数9.1.8 I(平方)C器件与I(平方)C总线的接线方式9.1.9 相兼容的SMBus总线9.2 与I(平方)C总线相关的寄存器9.3 典型信号时序的产生方法9.3.1 波特率发生器9.3.2 启动信号9.3.3 重启动信号9.3.4 应答信号9.3.5 停止信号9.4 被控器通信方式9.4.1 硬件结构9.4.2 被主控器寻址9.4.3 被控器接收——被控接收器9.4.4 被控器发送——被控发送器9.4.5 广播式寻址9.5 主控器通信方式9.5.1 硬件结构9.5.2 主控器发送——主控发送器9.5.3 主控器接收——主控接收器9.6 多主通信方式下的总线冲突和总线仲裁9.6.1 发送和应答过程中的总线冲突9.6.2 启动过程中的总线冲突9.6.3 重启动过程中的总线冲突9.6.4 停止过程中的总线冲突9.7 I(平方)C总线的应用举例思考题与练习题附录A 包含文件P16F877.INC附录B 新版宏汇编器MPASM伪指令总表参考文献
上传时间: 2013-12-14
上传用户:xiaoyuer