PID控制PWM调节直流电机速度(12v)
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
PID算法介绍:
本次设计主要研究的是PID控制技术在运动控制领域中的应用,纵所周知运动控制系统最主要的控制对象是电机,在不同的生产过程中,电机的运行状态要满足生产要求,其中电机速度的控制在占有至关重要的作用,因此本次设计主要是利用PID 控制技术对直流电机转速的控制。
其设计思路为:以AT89S51单片机为控制核心,产生占空比受PID算法控制的PWM脉冲实现对直流电机转速的控制。
同时利用光电传感器将电机速度转换成脉冲频率反馈到单片机中,构成转速闭环控制系统,达到转速无静差调节的目的。
在系统中采128×64LCD显示器作为显示部件,通过4×4键盘设置P、I、D、V四个参数和正反转控制,启动后通过显示部件了解电机当前的转速和运行时间。
因此该系统在硬件方面包括:电源模块、电机驱动模块、控制模块、速度检测模块、人机交互模块。
软件部分采用C语言进行程序设计,其优点为:可移植性强、算法容易实现、修改及调试方便、易读等。
本次设计系统的主要特点:
(1)优化的软件算法,智能化的自动控制,误差补偿;
(2)使用光电传感器将电机转速转换为脉冲频率,比较精确的反映出电机的转速,从而与设定值进行比较产生偏差,实现比例、积分、微分的控制,达到转速无静差调节的目的;
(3)使用光电耦合器将主电路和控制电路利用光隔开,使系统更加安全可靠;(4)128×64LCD显示模块提供一个人机对话界面,并实时显示电机运行速度和运行时间;
(5)利用Proteus软件进行系统整体仿真,从而进一步验证电路和程序的正确性,避免不必要的损失;
(6)采用数字PID算法,利用软件实现控制,具有更改灵活,节约硬件等优点;(7)系统性能指标:超调量≤8%;
调节时间≤4s;
转速误差≤±1r/min。
1PID算法及PWM控制技术简介
1.1PID算法
控制算法是微机化控制系统的一个重要组成部分,整个系统的控制功能主要由控制算法来实现。
目前提出的控制算法有很多。
根据偏差的比例(P)、积分(I)、微分(D)进行的控制,称为PID控制。
实际经验和理论分析都表明,PID控制能够
满足相当多工业对象的控制要求,至今仍是一种应用最为广泛的控制算法之一。
下面分别介绍模拟PID 、数字PID 及其参数整定方法。
1.1.1 模拟PID
在模拟控制系统中,调节器最常用的控制规律是PID 控制,常规PID 控制系统原理框图如图1.1所示,系统由模拟PID 调节器、执行机构及控制对象组成。
图1.1 模拟PID 控制系统原理框图
PID 调节器是一种线性调节器,它根据给定值)(t r 与实际输出值)(t c 构成的控制偏差: )(t e =)(t r -)(t c (1.1) 将偏差的比例、积分、微分通过线性组合构成控制量,对控制对象进行控制,故称为PID 调节器。
在实际应用中,常根据对象的特征和控制要求,将P 、I 、D 基本控制规律进行适当组合,以达到对被控对象进行有效控制的目的。
例如,P 调节器,PI 调节器,PID 调节器等。
模拟PID 调节器的控制规律为
])()(1)([)(0dt
t de T dt t e T t e K t u D t I p ++=⎰ (1.2) 式中,P K 为比例系数,I T 为积分时间常数,D T 为微分时间常数。
简单的说,PID 调节器各校正环节的作用是:
(1)比例环节:即时成比例地反应控制系统的偏差信号)(t e ,偏差一旦产生,调节器立即产生控制作用以减少偏差;
(2)积分环节:主要用于消除静差,提高系统的无差度。
积分作用的强弱取决于积分时间常数I T ,I T 越大,积分作用越弱,反之则越强;
(3)微分环节:能反映偏差信号的变化趋势(变化速率),并能在偏差信号的值变得太大之前,在系统中引入一个有效的早期修正信号,从而加快系统的动作速度,减少调节时间。
由式1.2可得,模拟PID 调节器的传递函数为
)11()()()(S T S
T K S E S U S D D I P ++== (1.3) 由于本设计主要采用数字PID 算法,所以对于模拟PID 只做此简要介绍。
1.1.2 数字PID
在DDC 系统中,用计算机取代了模拟器件,控制规律的实现是由计算机软件来完成的。
因此,系统中数字控制的设计,实际上是计算机算法的设计。
由于计算机只能识别数字量,不能对连续的控制算式直接进行运算,故在计算机控制系统中,首先必须对控制规律进行离散化的算法设计。
为将模拟PID 控制规律按式(1.2)离散化,我们把图1.1中)(t r 、)(t e 、)(t u 、)(t c 在第n 次采样的数据分别用)(n r 、)(n e 、)(n u 、)(n c 表示,于是式(1.1)变为 :
)(n e =)(n r -)(n c (1.4)
当采样周期T 很小时dt 可以用T 近似代替,)(t de 可用)1()(--n e n e 近似代替,“积分”用“求和”近似代替,即可作如下近似
T n e n e dt t de )1()()(--≈ (1.5) ⎰∑=≈t
n
i T i e dt t e 01)()( (1.6)
这样,式(1.2)便可离散化以下差分方程
01})]1()([)()({)(u n e n e T
T n e T T n e K n u n i D I P +--++=∑= (1.7) 上式中0u 是偏差为零时的初值,上式中的第一项起比例控制作用,称为比例(P )项)(n u P ,即
)()(n e K n u P p = (1.8)
第二项起积分控制作用,称为积分(I )项)(n u I 即 ∑==n i I
P I i e T T K n u 1)()( (1.9)
第三项起微分控制作用,称为微分(D )项)(n u D 即 )]1()([)(--=n e n e T
T K n u D P D (1.10) 这三种作用可单独使用(微分作用一般不单独使用)或合并使用,常用的组合有:
P 控制: 0)()(u n u n u P += (1.11)
PI 控制: 0)()()(u n u n u n u I P ++= (1.12) PD 控制: 0)()()(u n u n u n u D P ++= (1.13)
PID 控制: 0)()()()(u n u n u n u n u D I P +++= (1.14) 式(1.7)的输出量)(n u 为全量输出,它对于被控对象的执行机构每次采样时刻应达到的位置。
因此,式(1.7)又称为位置型PID 算式。
由(1.7)可看出,位置型控制算式不够方便,这是因为要累加偏差)(i e ,不仅要占用较多的存储单元,而且不便于编写程序,为此对式(1.7)进行改进。
根据式(1.7)不难看出u (n -1)的表达式,即
011})]2()1([)()1({)1(u n e n e T
T n e T T n e K n u n i D I P +---++-=-∑-= (1.15) 将式(1.7)和式(1.15)相减,即得数字PID 增量型控制算式为
)1()()(--=∆n u n u n u
)]2()1(2)([)()]1()([-+--++--=n e n e n e K n e K n e n e K D I P (1.16)
从上式可得数字PID 位置型控制算式为
)(n u 0)]2()1(2)([)()]1()([u n e n e n e K n e K n e n e K D I P +-+--++--= (1.17) 式中: P K 称为比例增益;
I
P
I T T K K =称为积分系数; T T K K D P D =称为微分系数[1]。
数字PID 位置型示意图和数字PID 增量型示意图分别如图1.2和1.3所示:
图1.2 数字PID 位置型控制示意图
图1.3 数字PID 增量型控制示意图
1.1.3 数字PID 参数整定方法
如何选择控制算法的参数,要根据具体过程的要求来考虑。
一般来说,要求被控过程是稳定的,能迅速和准确地跟踪给定值的变化,超调量小,在不同干扰下系统输出应能保持在给定值,操作变量不宜过大,在系统和环境参数发生变化时控制应保持稳定。
显然,要同时满足上述各项要求是很困难的,必须根据具体过程的要求,满足主要方面,并兼顾其它方面。
PID 调节器的参数整定方法有很多,但可归结为理论计算法和工程整定法两种。
用理论计算法设计调节器的前提是能获得被控对象准确的数学模型,这在工业过程中一般较难做到。
因此,实际用得较多的还是工程整定法。
这种方法最大优点就是整定参数时不依赖对象的数学模型,简单易行。
当然,这是一种近似的方法,有时可能略嫌粗糙,但相当适用,可解决一般实际问题。
下面介绍两种常用的简易工程整定法。
(1)扩充临界比例度法
这种方法适用于有自平衡特性的被控对象。
使用这种方法整定数字调节器参数的步骤是:
①选择一个足够小的采样周期,具体地说就是选择采样周期为被控对象纯滞后时间的十分之一以下。
②用选定的采样周期使系统工作:工作时,去掉积分作用和微分作用,使调节器成为纯比例调节器,逐渐减小比例度δ(P K /1=δ)直至系统对阶跃输入的响应达到临界振荡状态,记下此时的临界比例度K δ及系统的临界振荡周期k T 。
③选择控制度:所谓控制度就是以模拟调节器为基准,将DDC 的控制效果与模拟调节器的控制效果相比较。
控制效果的评价函数通常用误差平方面积⎰∞02)(t e 表示。
控制度=模拟])([])([0202⎰⎰∞∞dt t e dt t e DDC
(1.18)
实际应用中并不需要计算出两个误差平方面积,控制度仅表示控制效果的物理 概念。
通常,当控制度为1.05时,就可以认为DDC 与模拟控制效果相当;当控制度为2.0时,DDC 比模拟控制效果差。
④根据选定的控制度,查表1.1求得T 、P K 、I T 、D T 的值[1]。
表1.1 扩充临界比例度法整定参数
(2)经验法
经验法是靠工作人员的经验及对工艺的熟悉程度,参考测量值跟踪与设定值曲 线,来调整P 、I 、D 三者参数的大小的,具体操作可按以下口诀进行:
参数整定找最佳,从小到大顺序查;
先是比例后积分,最后再把微分加;
曲线振荡很频繁,比例度盘要放大;
曲线漂浮绕大湾,比例度盘往小扳;
曲线偏离回复慢,积分时间往下降;
曲线波动周期长,积分时间再加长;
曲线振荡频率快,先把微分降下来;
动差大来波动慢,微分时间应加长。
下面以PID 调节器为例,具体说明经验法的整定步骤:
①让调节器参数积分系数I K =0,实际微分系数D K =0,控制系统投入闭环运行,由小到大改变比例系数P K ,让扰动信号作阶跃变化,观察控制过程,直到获得满意的控制过程为止。
②取比例系数P K 为当前的值乘以0.83,由小到大增加积分系数I K ,同样让扰动信号作阶跃变化,直至求得满意的控制过程。
③积分系数I K 保持不变,改变比例系数P K ,观察控制过程有无改善,如有改善则继续调整,直到满意为止。
否则,将原比例系数P K 增大一些,再调整积分系数I K ,力求改善控制过程。
如此反复试凑,直到找到满意的比例系数P K 和积分系数I K 为止。
④引入适当的实际微分系数D K 和实际微分时间D T ,此时可适当增大比例系数P K 和积分系数I K 。
和前述步骤相同,微分时间的整定也需反复调整,直到控制过程满意为止。
PID 参数是根据控制对象的惯量来确定的。
大惯量如:大烘房的温度控制,一般P 可在10以上,I 在(3、10)之间,D 在1左右。
小惯量如:一个小电机闭环控制,一般P 在(1、10)之间,I 在(0、5)之间,D 在(0.1、1)之间,具体参数要在现场调试时进行修正。
1.2 PWM 脉冲控制技术
PWM (Pulse Width Modulation )控制就是对脉冲的宽度进行调制的技术。
即通过对一系列脉冲的宽度进行调制,来等效地获得所需要波形(含形状和幅值)。
1.2.1 PWM 控制的基本原理
在采样控制理论中有一个重要的结论:冲量相等而形状不同的窄脉冲加在具有惯性的环节上时,其效果基本相同。
冲量即指窄脉冲的面积。
这里所说的效果基本相同,是指环节的输出响应波形基本相同。
如果把各输出波形用傅立叶变换分析,则其低频段非常接近,仅在高频段略有差异。
例如图1.4中a 、b 、c 所示的三个窄脉冲形状不同,其中图1.4的a 为矩形脉冲,图1.4的b 为三角脉冲,图1.4的c 为正弦半波脉冲,但它们的面积(即冲量)都等于1,那么,当它们分别加在具有惯性的同一环节上时,其输出响应基本相同。
当窄脉冲变为如图1.4的d 所示的单位脉冲函数)(t 时,环节的响应即为该环节的脉冲过渡函数。
图1.4 形状不同而冲量相同的各种窄脉冲
图1.5a 的电路是一个具体的例子。
图中)(t e 为窄脉冲,其形状和面积分别如图1.4的a 、b 、c 、d 所示,为电路的输入。
该输入加在可以看成惯性环节的R-L 电路上,设其电流)(t i 为电路的输出。
图1.5b 给出了不同窄波时)(t i 的响应波形。
从波形可以看出,在)(t i 的上升段,脉冲形状不同时)(t i 的形状也略有不同,但其
a b c d
a b L 下降段几乎完全相同。
脉冲越窄,各)(t i 波形的差异也越小。
如果周期性的施加上述脉冲,则响应)(t i 也是周期性的。
用傅立叶级数分解后将可看出,各)(t i 在低频段的特性非常接近,仅在高频段有所不同[2]。
图1.5 冲量相同的各种窄脉冲的响应波形
1.2.2 直流电机的PWM 控制技术
直流电动机具有优良的调速特性,调速平滑、方便,调速范围广,过载能力大,能承受频繁的冲击负载,可实现频繁的无级快速起动、制动和反转;能满足生产过程自动化系统各种不同的特殊运行要求,在许多需要调速或快速正反向的电力拖动系统领域中得到了广泛的应用。
直流电动机的转速调节主要有三种方法:调节电枢供电的电压、减弱励磁磁通和改变电枢回路电阻。
针对三种调速方法,都有各自的特点,也存在一定的缺陷。
例如改变电枢回路电阻调速只能实现有级调速,减弱磁通虽然能够平滑调速,但这种方法的调速范围不大,一般都是配合变压调速使用。
所以在直流调速系统中,都是以变压调速为主。
其中,在变压调速系统中,大体上又可分为可控整流式调速系统和直流PWM 调速系统两种。
直流PWM 调速系统与可控整流式调速系统相比有下列优点:由于PWM 调速系统的开关频率较高,仅靠电枢电感的滤波作用就可获得平稳的直流电流,低速特性好、稳速精度高、调速范围宽。
同样,由于开关频率高,快速响应特性好,动态抗干扰能力强,可以获得很宽的频带;开关器件只工作在开关状态,因此主电路损耗小、装置效率高;直流电源采用不可控整流时,电网功率因数比相控整流器高。
正因为直流PWM 调速系统有以上优点,并且随着电力电子器件开关性能的不断提高,直流脉宽调制( PWM ) 技术得到了飞速的发展。
随着科学技术的迅猛发展传统的模拟和数字电路已被大规模集成电路所取代,这就使得数字调制技术成为可能。
目前,在该领域中大部分应用的是数字脉宽调制技术。
电动机调速系统采用微机实现数字化控制,是电气传动发展的主要方向之一。
采用微
0U
00000机控制后,整个调速系统实现全数字化,并且结构简单、可靠性高、操作维护方便,电动机稳态运转时转速精度可达到较高水平,静动态各项指标均能较好地满足工业生产中高性能电气传动的要求。
下面主要介绍直流电机PWM 调速系统的算法实现。
根据PWM 控制的基本原理可知,一段时间内加在惯性负载两端的PWM 脉冲与相等时间内冲量相等的直流电加在负载上的电压等效,那么如果在短时间T 内脉冲宽度为0t ,幅值为U ,由图1.6可求得此时间内脉冲的等效直流电压为:
图1.6 PWM 脉冲
T
U t U ⨯=00,若令T t 0=α,α即为占空比,则上式可化为: U U ⨯=α0 (U 为脉冲幅值) (1.19)
若PWM 脉冲为如图1.7所示周期性矩形脉冲,那么与此脉冲等效的直流电压的计算方法与上述相同,即
U T U t nT U nt U ⨯=⨯=⨯=
α000 (α为矩形脉冲占空比) (1.20)
图1.7 周期性PWM 矩形脉冲
由式1.20可知,要改变等效直流电压的大小,可以通过改变脉冲幅值U 和占空比α来实现,因为在实际系统设计中脉冲幅值一般是恒定的,所以通常通过控制占空比α的大小实现等效直流电压在0~U 之间任意调节,从而达到利用PWM 控制技术实现对直流电机转速进行调节的目的。
2设计方案与论证
2.1系统设计方案
根据系统设计的任务和要求,设计系统方框图如图2.1所示。
图中控制器模块为系统的核心部件,键盘和显示器用来实现人机交互功能,其中通过键盘将需要设置的参数和状态输入到单片机中,并且通过控制器显示到显示器上。
在运行过程中控制器产生PWM脉冲送到电机驱动电路中,经过放大后控制直流电机转速,同时利用速度检测模块将当前转速反馈到控制器中,控制器经过数字PID运算后改变PWM脉冲的占空比,实现电机转速实时控制的目的。
图2.1系统方案框图
系统各模块采用的方案如下:
(1)控制模块:采用AT89S51单片机;
(2)电机驱动模块:采用直流电机驱动芯片L298N实现;
(3)速度采集模块:采用光电传感器;
(4)显示模块:采用128×64LCD液晶显示模块;
(5)键盘模块:采用标准的4×4矩阵式键盘;
(6)电源模块:采用7805、7812芯片实现。
3单元电路设计
3.1硬件资源分配
本系统电路连接及硬件资源分配见图3.1所示。
采用AT89S51单片机作为核心器件,转速检测模块作为电机转速测量装置,通过AT89S51的P3.3口将电脉冲信
号送入单片机处理,L298作为直流电机的驱动模块,利用128×64LCD显示器和4×4键盘作为人机接口。
图
3.1系统电路连接及硬件资源分配图
3.2电源电路设计
电源是整个系统的能量来源,它直接关系到系统能否运行。
在本系统中直流电机需要12V电源,而单片机、显示模块等其它电路需要5V的电源,因此电路中选用7805和7812两种稳压芯片,其最大输出电流为1.5A,能够满足系统的要求,其电路如图3.2所示。
图3.2电源电路
3.3电机驱动电路设计
驱动模块是控制器与执行器之间的桥梁,在本系统中单片机的I/O口不能直接驱动电机,只有引入电机驱动模块才能保证电机按照控制要求运行,在这里选用
L298N电机驱动芯片驱动电机,该芯片是由四个大功率晶体管组成的H桥电路构成,四个晶体管分为两组,交替导通和截止,用单片机控制达林顿管使之工作在开关状态,通过调整输入脉冲的占空比,调整电动机转速。
其中输出脚(SENSEA和SENSEB)用来连接电流检测电阻,Vss接逻辑控制的电源。
Vs为电机驱动电源。
IN1-IN4输入引脚为标准TTL逻辑电平信号,用来控制H桥的开与关即实现电机的正反转,ENA、ENB引脚则为使能控制端,用来输入PWM信号实现电机调速。
其电路如图3.3所示,利用两个光电耦合器将单片机的I/O与驱动电路进行隔离,保证电路安全可靠。
这样单片机产生的PWM脉冲控制L298N的选通端[7],使电机在PWM脉冲的控制下正常运行,其中四个二极管对芯片起保护作用。
图3.3 电机驱动电路
3.4电机速度采集电路设计
在本系统中由于要将电机本次采样的速度与上次采样的速度进行比较,通过偏差进行PID运算,因此速度采集电路是整个系统不可缺少的部分。
本次设计中应用了比较常见的光电测速方法来实现,其具体做法是将电机轴上固定一圆盘,且其边缘上有N个等分凹槽如图3.5(a)所示,在圆盘的一侧固定一个发光二极管,其位置对准凹槽处,在另一侧和发光二极光平行的位置上固定一光敏三极管,如果电动机转到凹槽处时,发光二极管通过缝隙将光照射到光敏三极管上,三极管导通,反之三极管截止,电路如图3.4(b)所示,从图中可以得出电机每转一圈在P3.3的输出端就
会产生N 个低电平。
这样就可根据低电平的数量来计算电机此时转速了。
例如当电机以一定的转速运行时,P3.3将输出如图3.5所示的脉冲,若知道一段时间t 内传感器输出的低脉冲数为n ,则电机转速v=r/s 。
(a) (b)
图3.4 电机速度采集方案
图3.5 传感器输出脉冲波形
3.5 显示电路设计
根据设计要求要对系统各项参数和电机运行状态进行显示,因此在电路中加入显示模块是非常必要的。
在系统运行过程中需要显示的数据比较都,而且需要汉字显示,在这里选用128×64液晶显示器比较适合,它是一种图形点阵液晶显示器,主要由行驱动器/列驱动器及128×64全点阵液晶显示器组成,可完成汉字(16×16)显示和 图形显示共有20个引脚[8],其引脚名称及引脚编号的对应关系如图3.6,引脚功能如表3.1所示。
图3.6 128×64LCD 引脚分布 表3.1 12864液晶显示模块引脚功能
圆盘光敏三极管
128×64液晶显示器与单片机的连接电路如图3.7所示:
图3.7显示模块电路图
3.6键盘电路设计
根据设计需求,本系统中使用了4×4键盘用以实现对P、I、D三个参数和电机正反转的设定,以及对电机启动、停止、暂停、继续的控制,其电路原理图如图4.8所示。
图中L0~L3为4×4键盘的列信号,H0~H3为4×4键盘的行信号。
在本系统中,用P1.0~P1.3连接键盘的列信号L0~L3;用P0.4~P0.7连接键盘的行信号H0~H3[9]。
按照要求设计操作面板如图3.8所示:
图3.8键盘模块
键盘操作说明:在系统开始运行时,128×64LCD将显示开机界面,若按下设置键显示屏进入参数设置界面,此时按1、2、3、4进入相应参数的设置的状态,输入相应的数字即可完成该参数的设置,待所有量设置完成后按正/反控制键设置正反转,最后按启动键启动系统,在运行过程中可按下相应键对电机进行暂停、继续、停止运行的控制。
)]2()1(2)
([)()]1()([u n e n e n e K n e K n e n e K D I P +-+--++--
4 软件设计
4.1 算法实现
4.1.1 PID 算法
本系统设计的核心算法为PID 算法,它根据本次采样的数据与设定值进行比较得出偏差)(n e ,对偏差进行P 、I 、D 运算最终利用运算结果控制PWM 脉冲的占空比来实现对加在电机两端电压的调节[10],进而控制电机转速。
其运算公式为:
=)(n u 因此要想实现PID 控制在单片机就必须存在上述算法, 其程序流程如图4.1所示。
4.1.2 电机速度采集算法
本系统中电机速度采集是一个非常重要的部分,它的精度直接影响到整个控制的精度。
在设计中采用了光电传感器做为测速装置,其计算公式为:
v =
60⨯⨯t
N n
r/min 从这里可以看出速度
v
的误差主要是由圆盘边缘上的凹槽数的多少决定的,为了减
少系统误差应尽量提高凹槽的数量,在本次设计中取凹槽数N 为120,采样时间t 为0.5s ,则速度计算具体程序流程如图4.2所示。
图4.2 测速程序流程
图4.1
PID 程序流程
4.2程序流程
4.2.1主流程图
在一个完整的系统中,只有硬件部分是不能完成相应设计任务的,所以在该系统中软件部分是非常重要的,按照要求和系统运行过程设计出主程序流程如图4.3所示。
图4.3主程序流程
4.2.2键盘程序程序流程
键盘中断程序是用来设在系统相应参数和控制系统进入相应的运行状态,其程序流程图如图4.4所示。
图4.4键盘程序流程
4.2.3定时程序流程
在本系统中定时器T0中断子程序是用来控制电机运行时间和进行速度计算和PID运算,其程序流程如图4.5所示。
图4.5定时程序流程
4.2.4显示程序流程
显示模块是实现人机对话的重要部分,在这里选用128×64LCD显示器可实现对汉字和字符的显示,该显示器的引脚功能在上面已经做了说明,下面介绍128×64LCD的相关指令。
(1)读取状态字
当R/W=1,D/I=0时,在E信号为高的作用下,状态分别输出到数据总线上。
状态字是了解模块当前工作状态的唯一的信息渠道,在每次对模块操作之前,都要读出状态字判断BUSY是否为“0”。
若不为“0”,则计算机需要等待,直至BUSY =0为止。
(2)显示开关设置
D=1:开显示;D=0关显示。
显示起始行设置
指令表中DB5~DB0为显示起始行的地址,取值在0~3FH(1~64行)范围内,它规定了显示屏上最顶一行所对应的显示存储器的行地址。
(4)页面地址设置
页面地址是DDRAM的行地址。
8行为一页,DDRAM共64行即8页,DB2-DB0表示0-7页。
(5)列地址设置
列地址是DDRAM的列地址。
共64列,DB5-DB0取不同值得到0-3FH (1-64),代表某一页面上的某一单元地址,列地址计数器在每一次读/写数据后它将自动加一。
(6)写显示数据
该操作将8位数据写入先前已确定的显示存储器的单元内。
操作完成后列地址计数器自动加一。
(7)读显示数据
该操作将12864模块中的DDRAM 存储器对应单位中的内容读出,然后列地址计数器自动加一。
根据上面指令结合系统要实行的功能,其显示子程序流程如图4.6所示。
图4.6 显示程序流程
4.3 系统Proteus 仿真
4.3.1 Proteus 软件简介
Proteus 是英国Labcenter electronics 公司研发的EDA 设计软件, 是一个
基于ProSPICE 混合模型仿真器的,完整的嵌入式系统软、硬件设计仿真平台。
Proteus 不仅可以做数字电路、模拟电路、数模混合电路的仿真,还可进行多种CPU
的仿真,涵盖了51、PIC 、A VR 、HC11、ARM 等处理器,真正实现了在计算机从原理设计、电路分析、系统仿真、测试到PCB 板完整的电子设计,实现了从
概念到产品的全过程。
以下为本系统在Protues 中的仿真流程:
(1)新建文件:打开Protues 点File ,在弹出的下拉菜单中选择New Design ,
在弹出的图幅选择对话框中选Default 。
(2)设置编辑环境:按上述的方法对Protues 的设计环境进行设置。
(3)元器件选取:按设计要求,在对象选择窗口中点P ,弹出Pickdevices 对
a) 写入16*16汉字程序流程
b)写入8*16数字。