使用DSP28335在CCS中生成正弦波

news2025/1/13 15:33:53

  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.0
    sin1 = sin(1.0 / 6.0 * PI);     //30度 0.5
    sin1 = sin(1.0 / 4.0 * PI);     //45度 0.707
    sin1 = sin(1.0 / 3.0 * PI);     //60度   0.866
    sin1 = sin(1.0 / 2.0 * PI);     //90度 1.0
    sin1 = sin(2.0 / 3.0 * PI);     //120度 0.866
    sin1 = sin(3.0 / 4.0 * PI);     //135度 0.707
    sin1 = sin(5.0 / 6.0 * PI);     //150度 0.5
    sin1 = sin(1 * PI);             //180度 0

    sin1 = sin(7.0 / 6.0 * PI);     //210度 -0.4999
    sin1 = sin(5.0 / 4.0 * PI);     //225度 -0.707
    sin1 = sin(4.0 / 3.0 * PI);     //240度 -0.866
    sin1 = sin(3.0 / 2.0 * PI);     //270度 -1.0
    sin1 = sin(5.0 / 3.0 * PI);     //300度 -0.866
    sin1 = sin(7.0 / 4.0 * PI);     //315度 -0.707
    sin1 = sin(11.0 / 6.0 * PI);    //330度 -0.5
    sin1 = 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 *F

void 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里面仿真的波形相位关系也是一样的。
在这里插入图片描述
通过直接调用库函数,通过参数的控制,就可以生成想要的各种波形了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1590543.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

VSCode中 task.json 和 launch.json 的作用和参数解释以及配置教程

前言 由于 VS Code 并不是一个传统意义上的 IDE&#xff0c;所以初学者可能在使用过程中会有很多的疑惑&#xff0c;其中比较常见的一个问题就是 tasks.json和 launch.json两个文件分别有什么作用以及如何配置 tasks.json VSCode 官网提供的 tasks.json 配置教程 使用不同的…

Linux 系统解压缩文件

Linux系统&#xff0c;可以使用unzip命令来解压zip文件 方法如下 1. 打开终端&#xff0c;在命令行中输入以下命令来安装unzip&#xff1a; sudo apt-get install unzip 1 2. 假设你想要将zip文件解压缩到名为"target_dir"的目录中&#xff0c;在终端中切换到目标路…

【线段树】【区间更新】2916. 子数组不同元素数目的平方和 II

算法可以发掘本质&#xff0c;如&#xff1a; 一&#xff0c;若干师傅和徒弟互有好感&#xff0c;有好感的师徒可以结对学习。师傅和徒弟都只能参加一个对子。如何让对子最多。 二&#xff0c;有无限多1X2和2X1的骨牌&#xff0c;某个棋盘若干格子坏了&#xff0c;如何在没有坏…

基于ssm微信小程序的医院挂号预约系统

采用技术 基于ssm微信小程序的医院挂号预约系统的设计与实现~ 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;SpringMVCMyBatis 工具&#xff1a;IDEA/Ecilpse、Navicat、Maven 页面展示效果 用户管理 医院管理 医生管理 公告资讯管理 科室信息管…

目前深圳嵌入式单片机就业环境如何?

深圳作为中国的科技创新中心之一&#xff0c;嵌入式行业的就业环境相对较好。我这里有一套嵌入式入门教程&#xff0c;不仅包含了详细的视频讲解&#xff0c;项目实战。如果你渴望学习嵌入式&#xff0c;不妨点个关注&#xff0c;给个评论222&#xff0c;私信22&#xff0c;我在…

DDoS攻击类型与应对措施详解

攻击与防御简介 SYN Flood攻击 原理&#xff1a; SYN Flood攻击利用的是TCP协议的三次握手机制。在正常的TCP连接建立过程中&#xff0c;客户端发送一个SYN&#xff08;同步序列编号&#xff09;报文给服务器&#xff0c;服务器回应一个SYN-ACK&#xff08;同步和确认&#xf…

创新科技:FlexLua助力LoRa无线一氧化碳传感器轻松开发

随着智能科技的不断进步&#xff0c;无线传感器技术在环境监测领域的应用越来越广泛。其中&#xff0c;LoRa无线一氧化碳传感器以其高效的通信原理和精准的传感器原理&#xff0c;在各种应用场景中大显身手。而借助FlexLua低代码技术&#xff0c;开发这类传感器变得更加轻松快捷…

蓝桥杯python速成

总写C&#xff0c;脑子一热&#xff0c;报了个Python&#xff08;有一点想锤死自己&#xff09;&#xff0c;临时抱佛脚了 1.list的插入删除 append extend insert&#xff08;在索引位插入99&#xff09;---忘记用法别慌&#xff0c;用help查询 remove&#xff08;去掉第一个3…

NGO-VMD+皮尔逊系数+小波阈值降噪+重构

NGO-VMD皮尔逊系数小波阈值降噪重构 NGO-VMD皮尔逊系数小波阈值降噪重构代码获取戳此处代码获取戳此处 以西储大学轴承数据为例&#xff0c;进行VMD&#xff0c;且采用NGO进行K a参数寻优 并对分解分量计算皮尔逊相关系数筛选含噪声分量&#xff0c;对其进行小波软硬阈值降噪&a…

查找问价夹或文件linux命令

查找目录&#xff1a;find /&#xff08;查找范围&#xff09; -name 查找关键字 -type d 查找文件&#xff1a;find /&#xff08;查找范围&#xff09; -name 查找关键字 -print find / -name arthas -type d

(N-148)基于微信小程序网上书城系统

开发工具&#xff1a;IDEA、微信小程序 服务器&#xff1a;Tomcat9.0&#xff0c; jdk1.8 项目构建&#xff1a;maven 数据库&#xff1a;mysql5.7 前端技术&#xff1a;vue、uniapp 服务端技术&#xff1a;springbootmybatisredis 本系统分微信小程序和管理后台两部分&a…

2024年mathorcup(妈妈杯)数学建模C题思路-物流网络分拣中心货量预测及人员排班

# 1 赛题 C 题 物流网络分拣中心货量预测及人员排班 电商物流网络在订单履约中由多个环节组成&#xff0c;图 ’ 是一个简化的物流 网络示意图。其中&#xff0c;分拣中心作为网络的中间环节&#xff0c;需要将包裹按照不同 流向进行分拣并发往下一个场地&#xff0c;最终使包裹…

2024妈妈杯数学建模A 题思路分析-移动通信网络中 PCI 规划问题

# 1 赛题 A 题 移动通信网络中 PCI 规划问题 物理小区识别码(PCI)规划是移动通信网络中下行链路层上&#xff0c;对各覆盖 小区编号进行合理配置&#xff0c;以避免 PCI 冲突、 PCI 混淆以及 PCI 模 3 干扰等 现象。 PCI 规划对于减少物理层的小区间互相干扰(ICI)&#xff0c;增…

中科数安 | 图纸加密、文件加密、设计院加密软件、防泄密软件、数据防泄漏系统….

#图纸加密# 中科数安是一家专注于数据安全领域的公司&#xff0c;提供的产品与服务设计图纸加密、文件加密、设计院专用加密软件以及防泄密软件、数据防泄漏系统等解决方案。 PC地址&#xff1a;www.weaem.com 以下是对中科数安相关产品和服务特点的概括&#xff1a; 图纸加密…

Html网页小游戏源代码

Html网页小游戏源代码 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>Jello Jumping Game</title><meta name"viewport" content"widthdevice-width, initial-scale1"&…

java数据结构与算法刷题-----LeetCode260. 只出现一次的数字 III

java数据结构与算法刷题目录&#xff08;剑指Offer、LeetCode、ACM&#xff09;-----主目录-----持续更新(进不去说明我没写完)&#xff1a;https://blog.csdn.net/grd_java/article/details/123063846 文章目录 与运算取末尾1分组 与运算取末尾1分组 解题思路&#xff1a;时间…

算法思想总结:分治思想

一、颜色划分 . - 力扣&#xff08;LeetCode&#xff09; class Solution { public:void sortColors(vector<int>& nums) {//三路划分的思想int nnums.size();int left-1, rightn,cur0;while(cur<right){if(nums[cur]0) swap(nums[left],nums[cur]);else if(nums…

Java常用数据结构与集合

数据结构 数组&#xff1a; 内存地址连续检索效率高(可以通过下标访问成员)增删操作效率低(保证数据越界的问题,需动态扩容)长度固定&#xff0c;扩容的需要新的数组复制或者Arrays类的copyOf方法 链表 内存地址不连续查询快删除慢&#xff0c;因为需要移动指针又分双向链表…

【LAMMPS学习】八、基础知识(2.6)Lammps中的Walls墙

8. 基础知识 此部分描述了如何使用 LAMMPS 为用户和开发人员执行各种任务。术语表页面还列出了 MD 术语&#xff0c;以及相应 LAMMPS 手册页的链接。 LAMMPS 源代码分发的 examples 目录中包含的示例输入脚本以及示例脚本页面上突出显示的示例输入脚本还展示了如何设置和运行各…

【opencv】示例-neural_network.cpp 使用机器学习模块创建并训练一个简单的多层感知机(神经网络)模型...

#include <opencv2/ml/ml.hpp> // 引入OpenCV的机器学习模块using namespace std; // 使用标准命名空间 using namespace cv; // 使用OpenCV命名空间 using namespace cv::ml; // 使用OpenCV机器学习命名空间int main() {//创建随机训练数据Mat_<float> data(100, …