单片机 利用C语言产生正弦波DA数据

       通过改变单片机的DA输出电压,可以得到各种各样的电压波形输出,下面介绍产生正弦波形需送DA的数据是如何计算的。

       首先既然是正弦波,那么就要确定要输出一个周期正弦波的采样点数point,即由多少点组成了一周期的正弦波,还要知道单片机输出DA的数字值maxnum是多少,比如

8位DA,maxnum=256。10位DA,maxnum=1024。

       知道以上两个值后,就开始计算需要得到的正弦波DA数据了,我设置一个正弦波由61个点组成,所选DA最大数字输入值为1024,那么我的正弦波数据数组就有61个数据,即sin_tab[61],也就是把一个正弦波360度,分成了61份,那么每份就是360÷61=5.901度,这样就可以计算出61点中每个点对应的角度值jiaodu,有了角度值就可以算出来角度对应的正弦值,利用正弦值和输出DA的数字值maxnum,就可以计算出对应DA输入的数值了。

公式为:

 sin_tab[i]=(maxnum/2)*sin(x)+(maxnum/2); //  i代表某点      x为某角度对应的弧度      弧度=角度*(π/180);  //(maxnum/2)为正弦波零点处对应DA输入值;即DA满量程的一半;

在51单片机运行了以下函数,DA输出波形完美,验证产生的DA数据无误。

 #include<math.h> //注意需添加此头文件,包含了求正弦值函数sin(弧度值);

//获取不同点数的正弦波数据
//point: 一周期内的取样点数
//maxnum: 一周期内对应DA输出最大值
void getSinTab(uchar point,uint maxnum)
{
uchar i=0; 
float x;   //弧度
float jiao;//角度 分度角
jiao=360.000/point; 

  for(i=0;i<point;i++)
{
x=jiao*i;    //得到角度值
   x=x*0.01744; //角度转弧度  弧度=角度*(π/180)
      sin_tab[i]=(maxnum/2)*sin(x)+(maxnum/2);
}

}

// sin_tab[i] 为得到的正弦波数据,用于送给DA输出。

以下开发板均用到以上算法设计,可供参考学习。

STC12单片机单极性spwm单相逆变电源开发板:

https://item.taobao.com/item.htm?spm=a1z10.1-c-s.w4004-22434898952.8.2826230a8lz9DJ&id=611852790285

STC15W4K单片机双极性spwm单相逆变电源开发板:

https://item.taobao.com/item.htm?spm=a1z10.1-c-s.w4004-22434898952.4.2826230a8lz9DJ&id=611607961856

stm32F103单片机双极性spwm单相全桥逆变电源开发板

https://item.taobao.com/item.htm?spm=a1z10.1-c-s.w4004-22434898952.2.2826230a8lz9DJ&id=613067659199

STM32F030单片机单极性spwm单相逆变电源开发板

https://item.taobao.com/item.htm?spm=a1z10.1-c-s.w4004-22434898952.6.2826230a8lz9DJ&id=611610069092

  • 26
    点赞
  • 133
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 13
    评论
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

>行者<

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值