1、孙鹏DSP正余弦波形发生器 DSP正余弦波形发生器 班级:232122组员:孙鹏 吴斌 李文柏指导老师:杨越实习教室:信息楼 一实习题目正余弦波形发生器实现:产生一个2kHz 的正弦信号和同频的余弦信号(泰勒级数展开法)。从相应的观察窗口查看波形,并可通过DAC输出,通过示波器观察结果。二实习步骤1熟悉DSP的软件编程技巧及硬件连接方式。2按照题目要求分析正余弦波产生机理,查表法及泰勒级数法。3上机将历程操作,并修改参数使其达到其题目要求,根据查表法原理和泰勒级数展开式原理分别产生2khz正余弦波,比较有何差异。4整理数据资料,分析波形产生原因及机理。三实习过程TMS320F5416是ti公司
2、c5000系列16位定点系列产品,最高最平主频120MHZ。RAM128K,ROM16K,能适用一般的运用场合,本实习过程采用该开发板做简单的正余弦波发生器,绰绰有余。因为系统主要修改在主函数那里所以我只写主函数这部分程序。这里主要讲查表法和泰勒展开式法。1查表法:利用单片机自带的数学库函数,生成一个104个数的正余弦表,由DA输出就可以形成一个正弦波形。/-头文件-#include DspRegDefine.h /VC5402 寄存器定义#include math.h/-/* * 宏定义 */#define UCHAR unsigned char#define UINT16 unsigned
3、 int#define UINT32 unsigned long#define TRUE 1#define FALSE 0#define pi 3.1415926#define LEN 104 /定义由256点改104点,恰好可以实现2KHZ波形/-/* 端口定义 */-ioport UINT16 port8001; /定义输出io端口为0x8001;/-/-/* 全局变量定义 */-int data_buffLEN; /数据缓冲UINT16 show = 0x00aa; /LED显示的数值 /* * 所使用的函数原型 */void cpu_init(void); /初始化CPUvoid De
4、lay(UINT16 numbers); /延迟extern void delay_3us(void); /3us延迟void mcbsp0_write_rdy(UINT16 out_data);/MCBSP0发送一个数据void mcbsp0_init_SPI(void);/MCBSP0设置为SPI模式void mcbsp0_close(void);/MCBSP0关闭/-/* * 函数定义 */-/ 函数名称 : void cpu_init(void)/ 函数说明 : 初始化CPU/ 输入参数 : 无/ 输出参数 : 无/-void cpu_init(void) asm( nop ); as
5、m( nop ); asm( nop ); *(unsigned int*)CLKMD=0x0; /switch to DIV mode clkout= 1/2 clkin while(*(unsigned int*)CLKMD)&01)!=0); *(unsigned int*)CLKMD=0x37ff; /switch to PLL X 4 mode *(unsigned int*)IMR=0x0; *(unsigned int*)IFR=0xffff;/- asm( nop ); asm( nop ); asm( nop ); /*- 函数名称 : void Delay(int numb
6、ers)- 函数说明 : 延时- 输入参数 : numbers- 输出参数 : 无*/void Delay(UINT16 numbers) UINT16 i,j; for(i=0;i4000;i+) for(j=0;jnumbers;j+); /*- 函数名称 : void mcbsp0_write_rdy(UINT16 out_data);- 函数说明 : MCBSP0发送一个数据- 输入参数 : data- 输出参数 : 无- 补充说明 : 内部带是否发送完成的判断*/void mcbsp0_write_rdy(UINT16 out_data) UINT16 j; *(unsigned i
7、nt*)McBSP0_SPSA=0x0001; /McBSP0_SPSA 指向 SPCR2 while (*(unsigned int *)McBSP0_SPSD&0x0002)=0); / for(j=0;j20;j+); /delay不需要延时,这样可以节约时间,较少每点之间的DA输出时间 *(unsigned int *)McBSP0_DXR1= out_data; /输出da的数据/*- 函数名称 : void mcbsp0_init_SPI(void);- 函数说明 : MCBSP0设置为SPI模式- 输入参数 : 无- 输出参数 : 无- 补充说明 : */void mcbsp0_
8、init_SPI(void) /复位 McBSP0 *(unsigned int*)McBSP0_SPSA=0x0000;/SPCR1 *(unsigned int*)McBSP0_SPSD=0x0000;/设置SPCR1.0(RRST=0) *(unsigned int*)McBSP0_SPSA=0x0001;/SPCR2 *(unsigned int*)McBSP0_SPSD=0x0000;/设置SPCR1.0(XRST=0) /- /延迟 Delay(0); /延迟 4000*CPU 时钟周期 /等待复位稳定 /- /配置 McBSP0为 SPI 模式 *(unsigned int*)M
9、cBSP0_SPSA=0x0000;/SPCR1 *(unsigned int*)McBSP0_SPSD=0x1800; *(unsigned int*)McBSP0_SPSA=0x0001;/SPCR2 *(unsigned int*)McBSP0_SPSD=0x0000; *(unsigned int*)McBSP0_SPSA=0x000E;/PCR *(unsigned int*)McBSP0_SPSD=0x0A0C; *(unsigned int*)McBSP0_SPSA=0x0002;/RCR1 *(unsigned int*)McBSP0_SPSD=0x0040;/ *(unsigned int*)McBSP0_SPSA=0x0003;/RCR2 *(unsigned int*)McBSP0_SPSD=0x0041;/ *(unsigned int*)McBSP0_SPSA=0x0004;/XCR1 *(unsigned int*)McBSP0_SPSD=0x0040; *(unsigned int*)McBSP0_SPSA=0x0005;/XCR2 *(un
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1