找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4800|回复: 1
收起左侧

TMS320C5502多波形发生器源程序 可产生正弦波,锯齿波等

[复制链接]
ID:240871 发表于 2017-10-19 14:27 | 显示全部楼层 |阅读模式
基于TMS320C5502的多波形发生器程序,可产生多种波形,例如正弦波,锯齿波程序.

0.png

dsp源程序如下:
  1. /***********************************************************************************/
  2. /*   文件名: Taylorsine.c (将sineCODEC和sinecompute合并,实现计算并实时输出)      */
  3. /*   创建时间:10/05/2012                                                          */
  4. /*   功能描述:利用Taylor展开式法计算正弦波,并将信号从J6端口发送出去,平台为BJTU-DSP5502板*/
  5. /*   作者: 钱满义myqian@bjtu.edu.cn 北京交通大学电信学院电工电子教学基地           */
  6. /*   修改者 hailingao , 06/25                                                                                                        */
  7. /************************************************************************************/


  8. #include <math.h>
  9. #include <stdio.h>

  10. #include <csl.h>
  11. #include <csl_chip.h>
  12. #include <csl_i2c.h>
  13. #include <csl_pll.h>
  14. #include <csl_mcbsp.h>
  15. #include <csl_emif.h>
  16. #include <csl_emifBhal.h>
  17. #include <stdio.h>
  18. //#include "E2PROM_Function.h"
  19. #include "CODEC.h"

  20. #define Nx 360             //每周期抽取点数
  21. #pragma DATA_SECTION(output1,"data_out1");    //存放sin数据,浮点型
  22. float output1[Nx];
  23. #pragma DATA_SECTION(output,"data_out");    //存放sin数据,定点型
  24. int output[Nx];

  25. #undef  CODEC_ADDR
  26. #define CODEC_ADDR 0x1A

  27. // 定义McBSP的句柄
  28. MCBSP_Handle hMcbsp;

  29. /*------------------------------------------------------------------------------------*/
  30. //
  31. // FUNCTION: MAIN
  32. //
  33. /*------------------------------------------------------------------------------------*/
  34.                   
  35. void main(void)
  36. {
  37.   
  38.     Uint16  i,k=0;
  39.    
  40. float input0=0,x1;
  41. float a,b,c,d,e,f,g,h,ii,step;//step为角度步长  
  42. step=360.0/Nx;                // Nx为360度内取样点数
  43. /*****************新增函数段*****************/
  44.   
  45. for(i=0;i<=Nx-1;i++)
  46.   {
  47.     float angle,xx;
  48.     angle=input0+step*i;
  49.     x1=3.1415926*angle/180;
  50.      xx=x1*x1;
  51.    a=1-xx/16/17;b=1-xx/14/15*a;c=1-xx/12/13*b;d=1-xx/10/11*c;e=1-xx/8/9*d;f=1-xx/6/7*e;g=1-xx/4/5*f;h=1-xx/2/3*g;ii=x1*h;
  52.   // g=x1*(1-xx/2/3*(1-xx/4/5*(1-xx/6/7*(1-xx/8/9*(1-xx/10/11*(1-xx/12/13*(1-xx/14/15*(1-xx/16/17))))))));//数学总公式
  53.   // fprintf(stdout,"COMPUTE%f",ii); fprintf(stdout,"\n  ");   //输出计算的正弦波的数值,x2=e
  54.    output1[i]= 32767*ii; //利用泰勒级数计算出正弦波的数值,存放到output1中
  55.    output[i]=output1[i];                                       
  56. }
  57. // Initialize CSL library - This is REQUIRED !!!
  58.     CSL_init();

  59. // The main frequency of system is 240MHz
  60. // 该频率是为了设置IIC模块的需要设置的,为了使用I2C_setup函数
  61.     PLL_setFreq(1, 0xC, 0, 1, 3, 3, 0);

  62.     //EMIF初始化
  63.      Emif_Config();
  64.   
  65. // Open McBSP port 1 and get a McBSP type handle
  66.         hMcbsp = MCBSP_open(MCBSP_PORT1,MCBSP_OPEN_RESET);

  67. // Config McBSP        port 1 by use previously defined structure
  68.         Mcbsp_Config(hMcbsp);
  69.        
  70. //I2C初始化
  71.         I2C_cofig();
  72.    
  73. //CODEC寄存器初始化
  74.         inti_AIC();
  75.                       
  76. /*------------------------------------------------------------------------------------*/                                      
  77. // Receive the ADC output data of CODEC  
  78. // Then output the received data to DAC of CODEC
  79. /*------------------------------------------------------------------------------------*/
  80.         while(1)
  81.         {
  82.                 while(!MCBSP_xrdy(hMcbsp)) {};
  83.                         MCBSP_write16(hMcbsp, output[k]);                //左声道输出

  84. while(!MCBSP_xrdy(hMcbsp)) {};
  85. MCBSP_write16(hMcbsp, output[k]);        //右声道输出

  86. //        k=k+1;    //正弦波每周期的样点为360个,输出信号的频率为Fs/N=32000/360=88.89Hz
  87.         k=k+10;    //正弦波每周期的样点为36个,输出信号的频率为Fs/N=32000/36=888.9Hz

  88.         if (k>=Nx) k=k%Nx;
  89. ……………………

  90. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
基于TMS320C5502的多波形发生器程序,可产生多种波形,例如正弦波,锯齿波.zip (680.89 KB, 下载次数: 44)
回复

使用道具 举报

ID:654099 发表于 2019-12-2 11:01 | 显示全部楼层
谢谢大佬
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表