基于dsp的正弦波发生器课程设计概诉Word文件下载.docx

上传人:b****5 文档编号:18725277 上传时间:2022-12-31 格式:DOCX 页数:23 大小:376.12KB
下载 相关 举报
基于dsp的正弦波发生器课程设计概诉Word文件下载.docx_第1页
第1页 / 共23页
基于dsp的正弦波发生器课程设计概诉Word文件下载.docx_第2页
第2页 / 共23页
基于dsp的正弦波发生器课程设计概诉Word文件下载.docx_第3页
第3页 / 共23页
基于dsp的正弦波发生器课程设计概诉Word文件下载.docx_第4页
第4页 / 共23页
基于dsp的正弦波发生器课程设计概诉Word文件下载.docx_第5页
第5页 / 共23页
点击查看更多>>
下载资源
资源描述

基于dsp的正弦波发生器课程设计概诉Word文件下载.docx

《基于dsp的正弦波发生器课程设计概诉Word文件下载.docx》由会员分享,可在线阅读,更多相关《基于dsp的正弦波发生器课程设计概诉Word文件下载.docx(23页珍藏版)》请在冰豆网上搜索。

基于dsp的正弦波发生器课程设计概诉Word文件下载.docx

1.3课题研究内容

用TMS320C54x的汇编语言程序设计正弦信号发生器大大方便了程序的编写、调试和加快了程序的运行速度。

第2章总体方案的分析和设计

2.1总体方案设计

1.基于DSP的特点,本设计采用TMS320C54X系列的DSP作为正弦信号发生器的核心控制芯片。

2.用泰勒级数展开法实现正弦波信号。

3.设置波形时域观察窗口,得到其滤波前后波形变化图;

4.设置频域观察窗口,得到其滤波前后频谱变化图。

2.2正弦波信号发生器

正弦波信号发生器已被广泛地应用于通信、仪器仪表和工业控制等领域的信号处理系统中。

通常有两种方法可以产生正弦波,分别为查表法和泰勒级数展开法。

查表法是通过查表的方式来实现正弦波,主要用于对精度要求不很高的场合。

泰勒级数展开法是根据泰勒展开式进行计算来实现正弦信号,它能精确地计算出一个角度的正弦和余弦值,且只需要较小的存储空间。

本次主要用泰勒级数展开法来实现正弦波信号。

产生正弦波的算法正弦函数和余弦函数可以展开成泰勒级数,其表达式:

取泰勒级数的前5项,得近似计算式:

递推公式:

sin(nx)=2cos(x)sin[(n-1)x]-sin[(n-2)x]

cos(nx)=2cos(x)sin[(n-1)x]-cos[(n-2)x]

由递推公式可以看出,在计算正弦和余弦值时,需要已知cos(x)、sin(n-1)x、sin(n-2)x和cos(n-2)x。

2.3总体方案设计

第3章硬件设计

3.1硬件组成

基于DSP的信号发生器的硬件结构图如图3.1所示,它主要由DSP主控制器,输出D/A通道和人机界面等几个主要部分组成。

图3.1基于DSP的信号发生器系统框图

3.2控制器部分

本系统采用TI公司的TMS320LF2407DSP处理器,该器件具有外设集成度高,程序存储器容量大,A/D转换精度高,运算速度高,I/O口资源丰富等特点,芯片内部集成有32KB的FLASH程序存储器、2KB的数据/程序RAM,两个事件管理器模块(EVE和EVB)、16通道A/D转换器、看门狗定时器模块、16位的串行外设接口(SPI)模块、40个可单独编程或复用的通用输入输出引脚(GPIO)以及5个外部中断和系统监视模块。

TMS320LF2407芯片中的事件管理模块(EV)是一个非常重要的组成部分。

SPWM波形的产生和输出就是由这一部分完成的,它由两个完全相同的模块(EVA和EVB)组成,每个模块都含有2个通用定时器、3个比较器、6至8个PWM发生器、3个捕获单元和2个正交脉冲编码电路(QEP)。

由于TMS320LF2407有544字的双口RAM(DARAM)和2K字的单口RAM(SARAM);

而本系统的程序仅有几KB,且所用RAM也不多,因此不用考虑存储器的扩展问题,而对于TMS320LF2407的I/O扩展问题,由于TMS320LF2407器件有多达40个通用、双向的数字I/O(GPIO)引脚,且其中大多数的基本功能和一般I/O复用的引脚,而实际上,本系统只需要17路I/O信号,这样,就可以为系统剩余50%多的I/O资源,因此可以说,该方案既不算浪费系统资源,也为系统今后的升级留有余地。

3.3微输出D/A通道部分

本系统的输出通道部分主要负责实现波形的输出,此通道的入口为TMS320LF2407的PWM8口,可输出SPWM等幅脉冲波形,出口为系统的输出端,这样,经过一系列的中间环节,便可将PWM脉冲波转化为交流正弦波形,从而实现正弦波的输出,其原理框图如图3.2所示。

图3.2输出通道的原理结构

图3.2中的缓冲电路的作用是对PWM口输出的数字量进行缓冲,并将电压拉高到5V左右,以供后级模拟电路滤波使用。

这一部分电路由两个芯片组成。

一片用三态缓冲器,由于PWM口的输出为3.3V的TTL电平,这样,在设计时就应当选用输入具有5V的TTL输入,CMOS输出电平的转换芯片(如TI公司的74HCT04);

另一片则可选用TOSHIBA公司出品的光电耦合器6N137;

输出端连接的5V精密稳压电源可选用BURR-BROWN公司生产的REF02型精密稳压电源,以输出标准的5V电压。

系统中的减法电路的主要作用是把0-10V直流脉动信号的转换成-5~+5V的正弦交流信号,并使其电压增益为1。

设计使可利用差分式电路来实现其功能,为了简化电路,可以选用较为常用的AD公司的AD524,并将AD524接成电压跟随器的形式,同时适当的选取电阻以满足要求,此外,为了使产生的正弦波信号具有2-5mA的驱动能力,可选用AD624来构成末级的信号放大电路。

AD624是高精度低噪声仪用放大器,若外接一只增益电阻,即可得到1-1000之间的任意增益值,其误差小于1%。

由于AD624的建立时间只有15μs,所以它非常适宜在高速数据采集系统中使用。

3.4人机接口部分

3.4.1驱动器设计

位驱动器电路由两片集成电路组成,即由位驱动的CMOS芯片和将TTL电平转换成CMOS电平的电平转换芯片组成,电平转换芯片可以和输出通道的电平转换芯片共用一片74HCT244(本部分使用4路,输出通道使用3路),其主要作用是对DSP输出的3.3VTTL电平与5VCMOS电平进行匹配,从而带动具有CMOS电平的位驱动器,根据动态扫描显示的要求,位驱动器需要选用每路输出吸收电流都要大于200mA的芯片,因此,本设计选用了TI公司的74LS06来做LED的大电流驱动器件。

3.4.2键盘设计

本系统选用四个独立式按键,分别接入PF3-PF6口,并使用四个220Ω上拉电阻接VCC。

所谓独立式,就是将每一个独立键按一对一地直接接到I/O输入线上,而在读键值时,直接读I/O口,每一个键的状态通过读入键值的一位(二进制位)来反应,所以这种方式也称为一维直读方式,这种方式的查键软件比较简单,但占用I/O线较多,一般在键的数量较少时采用,不过,由于DSP芯片有足够的I/O接口可供使用,因而可大大方便设计,设计时可以充分利用这一特点来连接硬件,至于按键的削抖动措施,则可在软件中完成。

第4章软件设计

4.1流程图

本系统软件可以按照模块化设计思想来编写,包括主程序、常数计算程序、占空比计算程序和相应的一些功能子程序,主程序用于调用各功能子程序、初始化变量、查询键盘、判断显示数据是否需要刷新、同时判断一个脉冲是否完成发送等工作,具体方案见图4.1所示的流程图。

图4.1主程序流程图

在程序中,应在第N-1个脉冲周期里计算占空比,并在第N个脉冲周期里输出波形,这就要求在设计时要在一个脉冲周期内完成计算,如果选用20MHz的晶振,那么,在一倍频下,执行一条执行只需50ns,若输出400Hz的正弦波,即每一个周期(即2.5ms)要输出200个脉冲,这样,也就是说,一个脉冲需要12.5μs(相当于12500/50=250条指令)。

而执行一个占空比的计算程序只需要几十条指令,这种算法从软件开销上考虑是可以实现的。

4.2正弦信号发生器程序清单

;

ThisfunctiongeneratesthesinewaveofangleusingtheTaylorseriesexpansion

sin(theta)=x(1-x^2/2*3(1-x^2/4*5(1-x^2/6*7(1-x^2/8*9))))

cos(theta)=1-x^2/2*3(1-x^2/4*5(1-x^2/6*7(1-x^2/8*9)))

sin(2*theta)=2*sin(theta)*cos(theta)

.title"

sin.asm"

.mmregs

.def_c_int00

.refsinx,d_xs,d_sinx,cosx,d_xc,d_cosx

sin_x:

.usect"

sin_x"

360

STACK:

STACK"

10

k_theta.set286

PA0.set0

_c_int00

.text

STM#STACK+10,SP

STMk_theta,AR0

STM0,AR1

STM#sin_x,AR6

STM#90,BRC

RPTBloop1-1

LDMAR1,A

LD#d_xs,DP

STLA,@d_xs

STLA,@d_xc

CALLsinx

CALLcosx

LD#d_sinx,DP

LD@d_sinx,16,A

MPYA@d_cosx

STHB,1,*AR6+

MAR*AR1+0

loop1:

STM#sin_x+89,AR7

STM#88,BRC

RPTBloop2-1

LD*AR7-,A

STLA,*AR6+

loop2:

STM#179,BRC

STM#sin_x,AR7

RPTBloop3-1

LD*AR7+,A

NEGA

loop3:

STM#1,AR0

STM#360,bk

loop4:

PORTW*AR6+0%,PA0

Bloop4

sinx:

.defd_xs,d_sinx

.data

table_s.word01c7h

.word030bh

.word0666h

.word1556h

d_coef_s.usect"

coef_s"

4

d_xs.usect"

sin_vars"

1

d_squr_xs.usect"

d_temp_s.usect"

d_sinx.usect"

c_l_s.usect"

SSBXFRCT

STM#d_coef_s,AR5

RPT#3

MVPD#table_s,*AR5+

STM#d_coef_s,AR3

STM#d_xs,AR2

STM#c_l_s,AR4

ST#7FFFh,c_l_s

SQUR*AR2+,A

STA,*AR2

||LD*AR4,B

MASR*AR2+,*AR3+,B,A

MPYAA

STHA,*AR2

MASR*AR2-,*AR3+,B,A

MPYA*AR2+

STB,*AR2

MPYAd_xs

STHB,d_sinx

RET

cosx:

.defd_xc,d_cosx

d_coef_c.usect"

coef_c"

table_c.word0249h

.word0444h

.word0aabh

.word4000h

d_xc.usect"

cos_vars"

d_squr_xc.usect"

d_temp_c.usect"

d_cosx.usect"

c_l_c.usect"

STM#d_coef_c,AR5

MVPD#table_c,*AR5+

STM#d_coef_c,AR3

STM#d_xc,AR2

STM#c_l_c,AR4

ST#7FFFh,c_l_c

SFTAA,-1,A

MAR*AR2+

RETD

ADD*AR4,16,B

STHB,*AR2

.end

MEMORY

{

PAGE0:

EPROM:

org=0E000h,len=1000h

VECS:

org=0FF80h,len=0080h

PAGE1:

SPRAM:

org=0060h,len=0020h

DARAM1:

org=0080h,len=0010h

DARAM2:

org=0090h,len=0010h

DARAM3:

org=0200h,len=0200h

}

SECTIONS

{

.text:

>

EPROMPAGE0

.data:

STACK:

SPRAMPAGE1

sin_vars:

DARAM1PAGE1

coef_s:

cos_vars:

DARAM2PAGE1

coef_c:

sin_x:

align(512){}>

DARAM3PAGE1

.vectors:

VECSPAGE0

sin_v.asm"

.ref_c_int00

.sect"

.vectors"

B_c_int00

第5章系统仿真

5.1CCS工程项目的调试

程序的运行控制

在调试程序的过程中,经常需要复位、执行、单步执行等操作。

这些操作称为程序运行控制。

CCS开发环境提供了多种调试程序的运行操作。

用户可以使用调试工具条或调试菜单“Debug”中的相应命令控制程序的运行。

创建工程项目

1.进入CCS集成开发环境

2.创建一个新的工程项目

3.将源程序文件、链接命令文件、库文件和头文件添加到工程项目中

4.单击所有“+”项观看工程项目所包含的文件双击各图标,打开各文件

工程项目的编译

1.工程项目的编译链接

设置探测点

1.将volume.out文件装入目标板

2.设置探测点

3.为探测点选择链接的数据文件

4.设置数据文件的属性

5.将数据文件链接到探测点

6.关闭“FileI/O”对话框

工程项目的调试和结果的图形显示

1.设置断点

2.设置输入变量的图形属性

3.设置输出变量的图形属性

4.运行程序,显示图形

5.调整输出增益

观察寄存器的运行数据

5.2仿真波形图

图5.2仿真波形图

仿真结果表明系统产生的波形稳定,抗干扰能力强,频率和幅度调节方便,精确度高。

该设计方案简单可行,新颖实用,有推广价值。

第6章总结

本次课程设计中遇到一些课堂中从未有过的问题,通过网络查找和同学交流,大大促进了设计进程。

并在过程中进一步提高自身的创作、创新水平,扎实基础,扩展所学。

并且此次课程设计,基于课程理论知识和网上资料,使我对数字信号处理课程有了更深一步的了解和掌握,对利用CCS软件编程的数字信号处理方法有了进一步的了解。

在理论课的基础上进行实验实习,是对本门课程的深入学习和掌握,在以后的工作学习中,数字信号的处理都是采用计算机仿真的方法进行测试,因此,掌握基于计算机的数字信号处理方法对以后的工作和学习有很大的帮助。

这样一个课程设计对我们的发展有着极大的帮助!

最后,这个设计之所以能按时完成离不开老师的指导和同学的帮助,在这我对他们表示衷心的感谢。

参考文献

[1]顾卫钢.手把手教你学DSP-基于TMS320x281x北京航空航天大学出版社,2011.

[2]苏奎峰等.TMS320X281xDSP原理及C程序开发.北京航空航天大学出版社,2008.

[3]苏奎峰等.TMS320F2812原理与开发.电子工业出版社,2005.

[4]万山明.TMS320F2812/2810原理及应用实例.北京航空航天大学出版社,2007.

[5]TI公司著,胡广书等编译.TMS320C28X系列DSP的CPU与外设.清华大学出版社,2005.

[6]TI公司著,胡广书等编译.TMS320C28X系列DSP指令和编程指南.清华大学出版社,2005.

附录

DSP程序代码

.wo

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 医药卫生 > 基础医学

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1