单片机产生SPWM课程设计报告

上传人:cn****1 文档编号:490192194 上传时间:2022-08-16 格式:DOC 页数:15 大小:14.46MB
返回 下载 相关 举报
单片机产生SPWM课程设计报告_第1页
第1页 / 共15页
单片机产生SPWM课程设计报告_第2页
第2页 / 共15页
单片机产生SPWM课程设计报告_第3页
第3页 / 共15页
单片机产生SPWM课程设计报告_第4页
第4页 / 共15页
单片机产生SPWM课程设计报告_第5页
第5页 / 共15页
点击查看更多>>
资源描述

《单片机产生SPWM课程设计报告》由会员分享,可在线阅读,更多相关《单片机产生SPWM课程设计报告(15页珍藏版)》请在金锄头文库上搜索。

1、课程设计基于89C52单片机SPWM波形发生器摘 要本系统由89C52单片机控制模块、滤波和稳压模块组成。利用Matlab计算SPWM脉冲序列占空比,采用查表方式,控制双极性SPWM控制脉冲序列的输出。关键字:单片机 Matlab 查表 SPWM1设计目的和要求1.1设计目的设计并制作一套单相SPWM触发脉冲电路,掌握SPWM算法和硬件实现方法,理解驱动电路功能。1.2任务要求采用双极调制算法,产生一个7脉冲SPWM触发脉冲,并用单片机数字化近似实现;完成拓展硬件电路,软件编程和调试;具有2ms死区设计;低次谐波较少;2设计方案本系统以89C52单片机为控制核心,由查表法通过定时器产生SPWM

2、波,系统设计框图如下:电源模块输出+5V双极性pwm转换电路spwm波单片机主控电路模块图1 设计框图3 理论分析和计算3.1查表产生SPWM波理论分析SPWM采用频率数倍于正弦波的三角波调制正弦波,可得到近似于正弦波的输出。三角波的频率越高,即载波比越高,谐波的频率就越高,输出端滤波器就更容易去除谐波。查表就是通过计算得到脉冲序列中每一个矩形脉冲周期内高低电平持续时间,c语言编程时用数组来表示,通过编写对应程序来查表进而控制输出端口高低电平时间及转换,从而产生SPWM波。图2 SPWM原理图3.2利用Matlab计算SPWM脉冲序列占空比MATLAB是一个高级的数学分析与运算软件,具有强大的

3、计算功能。SPWM控制通过MATLAB进行分析和设计,可取得事半功倍的效果。采用MATLAB可方便地得到正弦波与三角波的交点。在判断交点时,可通过交点的数学定义来判断。所谓交点,就是在交点附近时刻两函数之差值的绝对值趋于0或许某一精度,而在交点附近的极小区域,离交点越远,差值的绝对值逐渐增大。3.2.1Matlab计算程序以下子程序为计算交点的MATLAB程序。基波数据L2 =4*sin(2*pi*f*x)/5,载波数据L1=sawtooth(2*pi*9*f*(x+1/1800),0.5),t(j)为交点时刻数据。 % 设置clc;prec = 0.00001; %精度f=50;step =

4、 0.00000001;start = 0;stop = 0.02;% plotx=start:step:stop;L1=sawtooth(2*pi*9*f*(x+1/1800),0.5);L2 =4*sin(2*pi*f*x)/5;plot(x,L1,red,x,L2,blue);legend(L1,L2,location,NorthWest);title(曲线交点图, L1=sawtooth(2*pi*9*f*(x+1/1800),0.5),L2=4*sin(2*pi*f*x)/5);xlabel(x);ylabel(y); %找交点jCount = 0;t=0;j=0;for i=1:l

5、ength(x) if(abs(L1(i)-L2(i) 第1交点是:(0,0)第2交点是:(0.00097685,0.24167),第2与1点电平持续时间0.00097685ms,定时器初值:FC2F第3交点是:(0.0025405,0.57283),第3与2点电平持续时间0.0015636ms,定时器初值:F9E4第4交点是:(0.0029758,0.64361),第4与3点电平持续时间0.00043531ms,定时器初值:FE4D第5交点是:(0.0048886,0.79952),第5与4点电平持续时间0.0019128ms,定时器初值:F887第6交点是:(0.0051114,0.799

6、52),第6与5点电平持续时间0.00022276ms,定时器初值:FF21第7交点是:(0.0070242,0.64361),第7与6点电平持续时间0.0019128ms,定时器初值:F887第8交点是:(0.0074595,0.57283),第8与7点电平持续时间0.00043531ms,定时器初值:FE4D第9交点是:(0.0090232,0.24167),第9与8点电平持续时间0.0015636ms,定时器初值:F9E4第10交点是:(0.01,0),第10与9点电平持续时间0.00097685ms,定时器初值:FC2F第11交点是:(0.010977,-0.24167),第11与10

7、点电平持续时间0.00097685ms,定时器初值:FC2F第12交点是:(0.01254,-0.57283),第12与11点电平持续时间0.0015636ms,定时器初值:F9E4第13交点是:(0.012976,-0.64361),第13与12点电平持续时间0.00043531ms,定时器初值:FE4D第14交点是:(0.014889,-0.79952),第14与13点电平持续时间0.0019128ms,定时器初值:F887第15交点是:(0.015111,-0.79952),第15与14点电平持续时间0.00022276ms,定时器初值:FF21第16交点是:(0.017024,-0.6

8、4361),第16与15点电平持续时间0.0019129ms,定时器初值:F887第17交点是:(0.01746,-0.57283),第17与16点电平持续时间0.00043531ms,定时器初值:FE4D第18交点是:(0.019023,-0.24167),第18与17点电平持续时间0.0015636ms,定时器初值:F9E4第19交点是:(0.02,0),第19与18点电平持续时间0.00097685ms,定时器初值:FC2F图3 Matlab运行结果图3.3单片机电平时间间隔表由MATLAB计算结果可以得出下表:十进制电平时间间隔表:976 1563 435 1912 222 1912

9、435 1563 976976 1563 435 1912 222 1912 435 1563 976十六进制定时器初值表:FC2F F9E4 FE4D F887 FF21 F887 FE4D F9E4 FC2F FC2F F9E4 FE4D F887 FF21 F887 FE4D F9E4 FC2F4单片机程序设计4.1程序设计流程图查表切换计数值,翻转I/O口开始I/O端口初始化定时器A初始化定时器A赋初始值,开总中断启动定时器定时器计数,I/O端口保持电平图4 程序流程图4.2C语言实现程序4.2.1主程序#include#include#define uint unsigned int

10、int i=0;char flag=0;sbit P10=P10;sbit P17=P17;sbit P20=P20;/近似int a=1000,1000,1900,200,1900,500,1500,1000,1000,1500,500,1900,200,1900,500,1500,2000;/精确int a1=976 1563 435 1912 222 1912 435 1563 976 976 1563 435 1912 222 1912 435 1563 976;void main()P10=0;P17=0;IE=0x82;TMOD=0x01;TH0=(65536-ai)/256;TL

11、0=(65536-ai)%256;TR0=1;while(1)if(flag=1)flag=0;P17=P17;P20=P20; 4.2.2中断程序void timer0() interrupt 1i+;if(i=18)i=0;TH0=(65536-ai)/256;TL0=(65536-ai)%256;flag=1;5电路设计图5 单片机主控电路图6 电源模块图7 双极性pwm转换电路6测试和结果6.1测试过程6.1.1使用直流稳压电源,示波器,万用表以及低通滤波器进行测试图8 测试环境6.1.2使用低通滤波器对输出电压进行处理图9 滤波过程6.1.3正负12V直流电源供电图10 供电电源6.2测试波形6.2.1低通滤波的截止频率较低时的输出波形图11 实验波形6.2.2含有少量杂波的输出波形图12 实验波形6.2.3截止频率较大时的输出波形图13 实验波形6.2.4含有少量杂波的输出波形图14 实验波形6.2.5黄色为使用较低截止频率的滤波器后的输出波形图15 实验波形6.2.6使用较高截止频率的滤波器测试结果蓝色为SPWM波形,黄色为使用较高截止频率的滤波器后的输出波形图16 实验波形6.2.7使用非常高的截止频率的滤波器测试结果蓝色为SPWM波形,黄色为使用非常高的截止频率的滤波器后的输出波形

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 高等教育 > 其它相关文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号