使用DSP28335在CCS中生成正弦波

2024-04-12 23:36

本文主要是介绍使用DSP28335在CCS中生成正弦波,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  DSP芯片支持数学库,那如何通过DSP芯片生成一个正弦波呢?通过几天研究,现在将我的方法分享一下,如有错误,希望大家及时指出,共同进步。

sin函数的调用

  首先看下一sin函数 的使用。

//头文件的定义
#include"math.h"
#define PI    3.1415926           //定义圆周率float sin1;
float signal1[1000];
void sinetest(void)
{sin1 = sin(0 * PI);             //0度  0.0sin1 = sin(1.0 / 6.0 * PI);     //30度 0.5sin1 = sin(1.0 / 4.0 * PI);     //45度 0.707sin1 = sin(1.0 / 3.0 * PI);     //60度   0.866sin1 = sin(1.0 / 2.0 * PI);     //90度 1.0sin1 = sin(2.0 / 3.0 * PI);     //120度 0.866sin1 = sin(3.0 / 4.0 * PI);     //135度 0.707sin1 = sin(5.0 / 6.0 * PI);     //150度 0.5sin1 = sin(1 * PI);             //180度 0sin1 = sin(7.0 / 6.0 * PI);     //210度 -0.4999sin1 = sin(5.0 / 4.0 * PI);     //225度 -0.707sin1 = sin(4.0 / 3.0 * PI);     //240度 -0.866sin1 = sin(3.0 / 2.0 * PI);     //270度 -1.0sin1 = sin(5.0 / 3.0 * PI);     //300度 -0.866sin1 = sin(7.0 / 4.0 * PI);     //315度 -0.707sin1 = sin(11.0 / 6.0 * PI);    //330度 -0.5sin1 = sin(2 * PI);             //360度 0
}

  这里用一个函数简单的测试一下,添加 math.h 头文件之后就可以直接使用sin函数了。通过这几个测试可以看出来,这里的sin函数里面使用的是弧度。也就是说一个周期的值是0到2π。生成的曲线是1到-1的正弦波。

生成单周期sin波

  如果想要直接使用sin函数生成一个正弦波数组的话,就需要控制里面的参数在0到2π之间。根据公式Φ=ωt=2πft可以看出如果要生成一个50Hz的正弦波的话,只有t是变化的,那么就需要在程序中控制这个t的值。频率50Hz,对于t的值就为0.02s。
当t的值从0增加到0.02时。f*t的值为1,刚好一个周期。
  这里使用一段代码测试一下,假如要生成50Hz的波,一个周期用50个点来组成,那么程序就修改为下面的样子。

void sin_test(void)
{int i;float t;float f = 50;for (i = 0; i < 50; i++){t =i * ( 1.0 / f / 50);sin1 = sin(2 * PI * f * t);signal1[i] = sin1;}
}

  由于数组的下标只能是整数,所以这里要进行一些处理。f=50,那么周期就是1/50=0.02s,如果要在0.02s内生成50个数据,那么一个数据需要的时间就是0.02/50=0.0004s。然后用for循环来控制生成数据的个数。用数组的下标乘每个数据需要的时间0.0004s,这样生成50个数据之后,时间值t刚好就是0.02s,然后再乘频率f,这样
ft 相乘结果刚好就是1。

  运行这段代码,查看数组中的数据。
在这里插入图片描述

在数组名上单击鼠标右键,将数组添加到观察窗口。
在这里插入图片描述
在观察窗口就可以查看数组中的值,此时数组中的值全是0,这是由于程序打了断点,还没运行到sin计算的函数。
在这里插入图片描述

点击单步运行,执行sin_test()函数。
在这里插入图片描述
这时就可以看到已经成功生成了一组数据,总共50个数据,从零开始增加到1,然后减小到-1,在增加到0,刚好是一组正弦变换的数据。

显示sin波形

  也可以使用ccs中波形显示工具,将生成的数据打印成波形查看。工具栏中选择
Tools—Graph—Single Time
在这里插入图片描述
设置要显示的波形参数
在这里插入图片描述
按照上面的参数进行设置,设置完成之后点OK按钮。
在这里插入图片描述
此时就会将数组中的数据用图形绘制出来,可以看到这是一个标准的正弦波。

生成2个周期sin波

  上面生成了一组正弦波,将for循环的次数改为100次,那么就会在数组中生成两组正弦波的数据。

void sin_test(void)
{int i;float t;float f = 50;for (i = 0; i < 100; i++){t =i * ( 1.0 / f / 50);sin1 = sin(2 * PI * f * t);signal1[i] = sin1;}
}

在这里插入图片描述
在数组中可以看到总共100个数据。
然后修改波形显示参数,这个参数可以直接在工具栏中选择,也可以在波形显示界面直接点属性设置的图标。
在这里插入图片描述
点击两个红叉后面的那个图标就会打开属性设置框。
在这里插入图片描述
将显示数据的大小改为100,这时候就会看到显示的波形从一个周期变为了2个周期。

  这时可以将一个周期采样50个点修改为100个点。
在这里插入图片描述
波形显示从两个周期又变回了一个周期。

宏定义参数

  为了方便修改参数,将每个周期采样的点数,和总共采样的点数设置为宏定义。修改代码如下。

#define PI    3.1415926           //定义圆周率
#define F     50                  //正弦波频率
#define TN    100                 //每个周期需要采样的点数
#define N     500                //总共采样的点数,数组大小float sin1;
float signal1[1000];void sin_test1(void)
{int i;float t;for (i = 0; i < N; i++){t =i * ( 1.0 / F / TN);sin1 = sin(2 * PI * F * t);signal1[i] = sin1;}
}

  将宏定义设置为每个周期采样100个点,总共采样500个点,也就是5个周期。

在这里插入图片描述
将波形采样点设置为500
在这里插入图片描述
此时可以看出输出了5个周期的波形。

  在上面代码中计算时间时1.0 / F / TN需要进行两次除法,可以将N和TN这两个参数直接合并为一个。

#define PI    3.1415926           //定义圆周率
#define F     50                  //正弦波频率
#define TN    100                 //每个周期需要采样的点数
#define N     500                //总共采样的点数,数组大小
#define FS    5000               //采样频率  FS = TN *Fvoid sin_test2(void)
{int i;float t;for (i = 0; i < N; i++){t = i * (1.0 / FS);sin1 = sin(2 * PI * F * t);signal1[i] = sin1;}
}

这里增加一个宏定义采样频率 FS,替换掉原来连续两次除法。当然为了让计算步骤更少,也可以将
2 * PI * F这三个数相乘的结果也用一个宏定义来表示,这里为了代码阅读起来比较容易,就不合并了。

测试波形周期

再次运行代码,同时将波形显示里面的采样频率修改为FS的值5000,其他设置参数不变。
在这里插入图片描述
此时在波形显示窗口就可看到,一个波形的周期刚好是20ms。总共显示5个周期。
在这里插入图片描述

生成sin、cos波形

  生成波形的代码框架已经好了,接下来就直接生成一组sin波形,一组cos波形。在原来的代码上增加一个cos波形的生成,使用第2个数组存储cos的波形。

//头文件的定义
#include"stdio.h"
#include"math.h"
#include"string.h"#define PI    3.1415926           //定义圆周率
#define F     50                  //正弦波频率
#define TN    100                 //每个周期需要采样的点数
#define N     500                 //总共采样的点数,数组大小
#define FS    5000                //采样频率  FS = TN * F#define Sample_points    1000     //采样点数
float signal1[Sample_points];
float signal2[Sample_points];float sin1;
float sin2;void sin_test3(void)
{int i;float t;for (i = 0; i < N; i++){t = i * (1.0 / FS);sin1 = sin(2 * PI * F * t);signal1[i] = sin1;sin2 = cos(2 * PI * F * t);signal2[i] = sin2;}
}

按照上面的方法将第二个数组的波形也显示出来。
在这里插入图片描述

生成三相sin波形

  接下来就可以生成三相波形了。要生成三相波首先得知道三相波形的样子,这里使用PSIM仿真软件直接查看三相波形。

放置一个三相波,然后用示波器查看每一相的波形。
在这里插入图片描述
在这里插入图片描述
点开这个模型,查看帮助文档,可以看到波形生成的具体方式。
在这里插入图片描述
在这里插入图片描述
通过帮助文档可以看出,a相相位为0度,b相相位为-120度,c相相位为120度。

按照这种相位关系自己用三个独立的正弦波通过相位的调整组合出一个三相波。
在这里插入图片描述
通过波形可以看出,通过对相位的控制,就可以生成三相正弦波了。

按照这种方法直接在程序里面生成三相正弦波,修改代码如下:

#include "DSP2833x_Device.h"     // DSP2833x Headerfile Include File
#include "DSP2833x_Examples.h"   // DSP2833x Examples Include File
//头文件的定义
#include"math.h"#define PI    3.1415926           //定义圆周率
#define F     50                  //正弦波频率
#define TN    100                 //每个周期需要采样的点数
#define N     500                 //总共采样的点数,数组大小
#define FS    5000                //采样频率  FS = TN * F
#define Sample_points    1000     //采样点数float signal1[Sample_points];
float signal2[Sample_points];
float signal3[Sample_points];float sin1;
float sin2;
float sin3;void clear_buf(void)
{int i;for (i = 0; i < Sample_points; i++){signal1[i] = 0;signal2[i] = 0;signal3[i] = 0;}
}void sin_3ph(void)
{int i;float t;for (i = 0; i < N; i++){t = i * (1.0 / FS);sin1 = sin(2 * PI * F * t);                 //生成a相波 相位0度signal1[i] = sin1;sin2 = sin(2 * PI * F * t - 2.0 / 3.0 * PI); //生成b相波 相位-120度signal2[i] = sin2;sin3 = sin(2 * PI * F * t + 2.0 / 3.0 * PI); //生成C相波 相位 120度signal3[i] = sin3;}
}
void main()
{InitSysCtrl();InitPieCtrl();IER = 0x0000;IFR = 0x0000;InitPieVectTable();clear_buf();sin_3ph();while (1);
}

将三相波形都显示出来

在这里插入图片描述
通过代码生成的三相正弦波波形和PSIM仿真的波形是一样的。

生成三相cos波形

接下来在生成余弦的三相波形,首先在PSIM中看一下余弦的三相波形,由于PSIM中没有余弦的模型,这里将三相正弦信号的初始相位修改为90度,这样发出的波形就是余弦波形了。
在这里插入图片描述
通过示波器观察三相波形的相位关系。
在这里插入图片描述
将上面代码中的sin直接修改为cos。

#include "DSP2833x_Device.h"     // DSP2833x Headerfile Include File
#include "DSP2833x_Examples.h"   // DSP2833x Examples Include File
//头文件的定义
#include"math.h"#define PI    3.1415926           //定义圆周率
#define F     50                  //正弦波频率
#define TN    100                 //每个周期需要采样的点数
#define N     500                 //总共采样的点数,数组大小
#define FS    5000                //采样频率  FS = TN * F
#define Sample_points    1000     //采样点数float signal1[Sample_points];
float signal2[Sample_points];
float signal3[Sample_points];float sin1;
float sin2;
float sin3;void clear_buf(void)
{int i;for (i = 0; i < Sample_points; i++){signal1[i] = 0;signal2[i] = 0;signal3[i] = 0;}
}void cos_3ph(void)
{int i;float t;for (i = 0; i < N; i++){t = i * (1.0 / FS);sin1 = cos(2 * PI * F * t); //生成a相波signal1[i] = sin1;sin2 = cos(2 * PI * F * t - 2.0 / 3.0 * PI); //生成b相波signal2[i] = sin2;sin3 = cos(2 * PI * F * t + 2.0 / 3.0 * PI); //生成C相波signal3[i] = sin3;}
}
void main()
{InitSysCtrl();InitPieCtrl();IER = 0x0000;IFR = 0x0000;InitPieVectTable();clear_buf();cos_3ph();while (1);
}

通过波形可以看出代码生成的余弦三相波形和PSIM里面仿真的波形相位关系也是一样的。
在这里插入图片描述
通过直接调用库函数,通过参数的控制,就可以生成想要的各种波形了。

这篇关于使用DSP28335在CCS中生成正弦波的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/898544

相关文章

C#中checked关键字的使用小结

《C#中checked关键字的使用小结》本文主要介绍了C#中checked关键字的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录✅ 为什么需要checked? 问题:整数溢出是“静默China编程”的(默认)checked的三种用

C#中预处理器指令的使用小结

《C#中预处理器指令的使用小结》本文主要介绍了C#中预处理器指令的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录 第 1 名:#if/#else/#elif/#endif✅用途:条件编译(绝对最常用!) 典型场景: 示例

Mysql中RelayLog中继日志的使用

《Mysql中RelayLog中继日志的使用》MySQLRelayLog中继日志是主从复制架构中的核心组件,负责将从主库获取的Binlog事件暂存并应用到从库,本文就来详细的介绍一下RelayLog中... 目录一、什么是 Relay Log(中继日志)二、Relay Log 的工作流程三、Relay Lo

使用Redis实现会话管理的示例代码

《使用Redis实现会话管理的示例代码》文章介绍了如何使用Redis实现会话管理,包括会话的创建、读取、更新和删除操作,通过设置会话超时时间并重置,可以确保会话在用户持续活动期间不会过期,此外,展示了... 目录1. 会话管理的基本概念2. 使用Redis实现会话管理2.1 引入依赖2.2 会话管理基本操作

Springboot请求和响应相关注解及使用场景分析

《Springboot请求和响应相关注解及使用场景分析》本文介绍了SpringBoot中用于处理HTTP请求和构建HTTP响应的常用注解,包括@RequestMapping、@RequestParam... 目录1. 请求处理注解@RequestMapping@GetMapping, @PostMappin

springboot3.x使用@NacosValue无法获取配置信息的解决过程

《springboot3.x使用@NacosValue无法获取配置信息的解决过程》在SpringBoot3.x中升级Nacos依赖后,使用@NacosValue无法动态获取配置,通过引入SpringC... 目录一、python问题描述二、解决方案总结一、问题描述springboot从2android.x

SpringBoot整合AOP及使用案例实战

《SpringBoot整合AOP及使用案例实战》本文详细介绍了SpringAOP中的切入点表达式,重点讲解了execution表达式的语法和用法,通过案例实战,展示了AOP的基本使用、结合自定义注解以... 目录一、 引入依赖二、切入点表达式详解三、案例实战1. AOP基本使用2. AOP结合自定义注解3.

Python中Request的安装以及简单的使用方法图文教程

《Python中Request的安装以及简单的使用方法图文教程》python里的request库经常被用于进行网络爬虫,想要学习网络爬虫的同学必须得安装request这个第三方库,:本文主要介绍P... 目录1.Requests 安装cmd 窗口安装为pycharm安装在pycharm设置中为项目安装req

使用Python将PDF表格自动提取并写入Word文档表格

《使用Python将PDF表格自动提取并写入Word文档表格》在实际办公与数据处理场景中,PDF文件里的表格往往无法直接复制到Word中,本文将介绍如何使用Python从PDF文件中提取表格数据,并将... 目录引言1. 加载 PDF 文件并准备 Word 文档2. 提取 PDF 表格并创建 Word 表格

使用Python实现局域网远程监控电脑屏幕的方法

《使用Python实现局域网远程监控电脑屏幕的方法》文章介绍了两种使用Python在局域网内实现远程监控电脑屏幕的方法,方法一使用mss和socket,方法二使用PyAutoGUI和Flask,每种方... 目录方法一:使用mss和socket实现屏幕共享服务端(被监控端)客户端(监控端)方法二:使用PyA