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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

基于springboot实现教学资源库系统项目【项目源码+论文说明】计算机毕业设计

基于springboot实现教学资源库系统演示 摘要 社会的进步&#xff0c;教育行业发展迅速&#xff0c;人们对教育越来越重视&#xff0c;在当今网络普及的情况下&#xff0c;教学模式也开始逐渐网络化&#xff0c;各大高校开始网络教学模式。 本文研究的教学资源库系统基于Sprin…

Linux的学习之路:8、Linux调试器-gdb使用

摘要 本章主要是说一下gdb的使用&#xff0c;以及把使用指令放入放个指令手册。 目录 摘要 一、背景 二、使用 1、产生debug文件 2、进入gdb 3、使用指令 三、思维导图 一、背景 Linux调试器gdb的背景主要涉及到Linux程序发布方式和调试需求。 在Linux中&#xff0c…

一款自研Python解释器

项目简介: PikaScript是一个完全重写的超轻量级python引擎,具有完整的解释器,字节码和虚拟机架构,可以在少于4KB的RAM下运行,用于小资源嵌入式系统。相比同类产品,如MicroPython,LuaOS等,资源占用减少85%以上。 入选2021年度 Gitee最有价值开源项目,加入RT-Thread嵌入…

动态规划(背包问题)

一:动态规划概述: 动态规划实际上是一种将原本的 大 方面的问题转化为许许多多的 小方面 的一种应用, 在一定程度上避免数据的重复, 并且能够将数据以自己希望的方式进行存储, 用来解决多阶段的数学问题, 从而提高算法的效率 在算法当中, 动态规划主要包括有: 递推, 线性DP 记忆…

不惑之年,反思我如何成为一个程序员

不惑之年&#xff0c;反思我如何成为一个程序员 文章目录 不惑之年&#xff0c;反思我如何成为一个程序员01/偶然掉入码河02/现实撕碎理想03/发展选择方向04/时代成就向往05/幸运装饰未来 在这个充满生机与希望的季节&#xff0c;博主有幸收到一家国企邀约面试&#xff0c;并顺…

【好消息】思维100活动历年真题模拟题700多道上线了,供反复吃透

今天是星期五&#xff0c;距离4月20日举办的上海小学生 2024年春季思维100活动线上比赛还有8天的时间&#xff0c;明天、后天的周末是可以用来备考的大块时间&#xff0c;报名了的同学要充分利用了。 为了帮助各位小朋友了解思维100活动的历年考试真题、官方发布的参考样题&…

ssm044基于java和mysql的多角色学生管理系统+jsp

学生管理系统设计与实现 摘 要 现代经济快节奏发展以及不断完善升级的信息化技术&#xff0c;让传统数据信息的管理升级为软件存储&#xff0c;归纳&#xff0c;集中处理数据信息的管理方式。本学生管理系统就是在这样的大环境下诞生&#xff0c;其可以帮助管理者在短时间内处…

力扣207.课程表

你这个学期必须选修 numCourses 门课程&#xff0c;记为 0 到 numCourses - 1 。 在选修某些课程之前需要一些先修课程。 先修课程按数组 prerequisites 给出&#xff0c;其中 prerequisites[i] [ai, bi] &#xff0c;表示如果要学习课程 ai 则 必须 先学习课程 bi 。 例如…

新版chrome 解决在http协议下无法调用摄像头和麦克风的问题(不安全)

解决办法&#xff1a;亲测可行 chrome浏览器地址栏中输入chrome://flags/#unsafely-treat-insecure-origin-as-secure&#xff0c;回车&#xff0c;如下图&#xff0c;将该选项置为Enabled&#xff0c; edge浏览器打开&#xff1a;edge://flags/#unsafely-treat-insecure-orig…

TDengine taosAdapter启用HTTPS

HTTPS &#xff08;Hypertext Transfer Protocol Secure &#xff09;&#xff0c;是以安全为目标的 HTTP 通道&#xff0c;在HTTP的基础上通过传输加密和身份认证保证了传输过程的安全性 。HTTPS 在HTTP 的基础下加入SSL&#xff0c;HTTPS 的安全基础是 SSL&#xff0c;因此加…

利用细粒度检索增强和自我检查提升对话式问题解答能力

&#x1f349; CSDN 叶庭云&#xff1a;https://yetingyun.blog.csdn.net/ 论文标题&#xff1a;Boosting Conversational Question Answering with Fine-Grained Retrieval-Augmentation and Self-Check 论文地址&#xff1a;https://arxiv.org/abs/2403.18243 检索增强生成…

使用easyexcel读取excel并生成sql语句

1、引入pom依赖 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apache.org/POM…

.NET Framework安装失败的原因及解决方法

.NET Framework安装失败的原因及解决方法 大家好我是艾西&#xff0c;一个做服务器租用的游戏爱好者兼网络架构系统环境问题网络工具人。在我们平时使用PC安装某些程序会出现.NET Framework缺失的提示&#xff0c;那么也会有很多的小伙伴搞不懂什么原因导致的&#xff0c;这个问…

MySQL 04-EMOJI 表情与 UTF8MB4 的故事

拓展阅读 MySQL View MySQL truncate table 与 delete 清空表的区别和坑 MySQL Ruler mysql 日常开发规范 MySQL datetime timestamp 以及如何自动更新&#xff0c;如何实现范围查询 MySQL 06 mysql 如何实现类似 oracle 的 merge into MySQL 05 MySQL入门教程&#xff0…

深水采样器小口径特氟龙材质FEP贝勒管

FEP贝勒管&#xff0c;深水采样器(bailers tube)&#xff0c;是一种经济型便携式水质采样器&#xff0c;操作简单&#xff0c;使用方便&#xff0c;性价比高&#xff0c;能大限度的保证样品的真实性。采样管直径很小&#xff0c;能够采取小口径的深水井水样。是一款简单实用&am…

L2-026 小字辈

一、题目要求 本题给定一个庞大家族的家谱&#xff0c;要请你给出最小一辈的名单。 输入格式&#xff1a; 输入在第一行给出家族人口总数 N&#xff08;不超过 100 000 的正整数&#xff09; —— 简单起见&#xff0c;我们把家族成员从 1 到 N 编号。随后第二行给出 N 个编…

Docker 学习笔记(五):梳理 Docker 镜像知识,附带 Commit 方式提交镜像副本,安装可视化面板 portainer

一、前言 记录时间 [2024-4-10] 前置文章&#xff1a; Docker学习笔记&#xff08;一&#xff09;&#xff1a;入门篇&#xff0c;Docker概述、基本组成等&#xff0c;对Docker有一个初步的认识 Docker学习笔记&#xff08;二&#xff09;&#xff1a;在Linux中部署Docker&…

QT系列教程(2) 创建项目和编译

新建Qt Widgets应用 我们启动qt creator 创建项目&#xff0c;选择Qt Widgets应用 接下来选择项目目录&#xff0c;项目名字就叫helloworld 构建系统选择qmake 我们创建一个名字为HelloDialog的类&#xff0c;继承于QDialog 构建套件选择你们安装的就行了&#xff0c;我这里选…

睿尔曼复合机器人之底盘操作流程

以操作流程为例&#xff0c;介绍底盘的操作流程。 开机&#xff1a;长按电源按钮&#xff0c;蜂鸣器短响两声&#xff0c;当第三声变长鸣后松开&#xff0c;等待机器开机。 使用&#xff1a; 建立通讯&#xff1a;主要采用无线WiFi与底盘进行通讯连接 无线连接方式&#xff…

android13 Camera加载流程

在 Android O 中,系统启动时,就会启动 CameraProvider 服务。它将 Camera HAL 从 cameraserver 进程中分离出来,作为一个独立进程 android.hardware.camera.provider@2.4-service 来控制 HAL。 这两个进程之间通过 HIDL 机制进行通信。 这样的改动源自于 Android O 版本加…