标题: 单片机SPWM波 产生正弦波的源程序及工具 [打印本页]

作者: 51黑ff    时间: 2016-9-11 23:28
标题: 单片机SPWM波 产生正弦波的源程序及工具
程序能用,如果不是你想要的频率,那就 自己改一下数据 记得同时要替换数组里面的值

如果数组里面的值不知道怎么弄 点击这个链接下载软件就行   如果下载软件 记得 看一下我的问题
spwm_calc_v1.3.2.rar (167.66 KB, 下载次数: 879)

SPWM信号经低通滤波后可变换为直流电压,窄带范围内的方波经低通滤波后可变换为相应频率的正弦波


那么spwm波出来以后  后面的滤波电路怎么搭建,截止频率与pwm频率或者所在载正弦波的频率有什么必然的关系,然后才能滤出正弦波????求解答这儿顺便上传一个SPWM波表,希望下载的网友回复一下,让牛逼人士看到我的困惑




源程序: 程序.zip (20.54 KB, 下载次数: 446)
  1. #include<reg52.h>
  2. #define uInt unsigned int
  3. #define uchar unsigned char
  4. uchar t_max = 10;                       //一个周期
  5. static uchar t = 0,i = 0;        //PWM计数
  6. /*
  7. uchar code SinParam[40]={  
  8. 0,3,6,9,13,16,19,22,25,28,31,34,37,40,43,45,
  9. 48,51,54,56,59,61,64,66,68,71,73,75,77,79,81,83,
  10. 84,86,88,89,90,92,93,94,95,96,97,98,98,99,99,100,
  11. 100,100,100,100,100,100,99,99,98,98,97,96,95,94,93,92,
  12. 90,89,88,86,84,83,81,79,77,75,73,71,68,66,64,61,
  13. 59,56,54,51,48,45,43,40,37,34,31,28,25,22,19,16,
  14. 13,9,6,3
  15. };
  16. */
  17. uchar code SinParam[20]={  
  18.   5,5,6,7,7,8,9,9,9,9,10,9,9,9,9,8,
  19. 7,7,6,5
  20. };


  21. // 200点正弦波样本值

  22. void main(void)
  23. {
  24.         TMOD = 0x02;                                //定时器0,工作模式2,8位定时模式
  25.         TH0 = 146;                                //写入预置初值(取值1-255,数越大PWM频率越高)
  26.         TL0 = 146;                                //写入预置值(取值1-255,数越大PWM频率越高)
  27.         TR0 = 1;                                        //启动定时器
  28.         ET0 = 1;                                        //允许定时器0中断
  29.         EA = 1;                                        //允许总中断

  30.         P2 = 0xff;                                //初始化P1

  31.         while(1)
  32.         {
  33.                 ;
  34.         }
  35. }


  36. timer0()interrupt 1 using 2
  37. {
  38.         t++;                                //每次定时器溢出加1

  39.         if(t < t_max && t >= SinParam[i])        //PWM周期                                          5
  40.                 {                                
  41.                         P2 = 0x00;                        //使LED灯亮
  42.                 }
  43.                 else if( t >= t_max)
  44.                 {
  45.                         t = 0;        //使t=0,开始新的PWM周期
  46.                         i++;                        
  47.                         P2 = 0xff;        
  48.                 }               
  49.    if(i >= 20) i = 0;
  50. }
复制代码




作者: sunboyzzl    时间: 2016-11-26 10:47
自己验证一下
作者: somlye    时间: 2017-3-2 19:58
,我是一个一个试出来的。楼主有电路图吗?

软件1.JPG (55.73 KB, 下载次数: 375)

软件1.JPG

软件2.JPG (66.97 KB, 下载次数: 244)

软件2.JPG

作者: 拉稀拉稀    时间: 2017-5-6 15:06
谁有spwm生成工具文件,给一份
作者: LENGED1314    时间: 2017-5-21 17:47
拉稀拉稀 发表于 2017-5-6 15:06
谁有spwm生成工具文件,给一份

我有一个

spwm_calc.rar

124.64 KB, 下载次数: 274, 下载积分: 黑币 -5

SPWM表格生成


作者: DDL123~    时间: 2017-7-25 21:42
最近在学习逆变器spwm编程的问题,过来看看
作者: 风子.    时间: 2017-7-31 11:07
SPWM不是根据需要的正弦波转换成的方波吗?为什么软件看出来的波形是正弦波
作者: icecremdd    时间: 2017-8-2 14:13
这不是正弦吗
作者: 386115360    时间: 2017-8-2 15:13
非常的软件,正好要学习SPWM方面的知识。
作者: 胡代松    时间: 2017-8-8 15:47
楼主确定这能输出spwm波吗

作者: 895855647    时间: 2017-8-10 17:25
请问楼主用得多大晶振
作者: picq    时间: 2017-9-5 14:56
下载看看,学习学习!
作者: niushaoyan    时间: 2017-11-18 15:48
不知道能不能用,反正很需要
作者: 斜月为谁明    时间: 2018-5-12 20:01
调制度是什么意思?
作者: jjwangxu2008    时间: 2018-5-13 01:56
楼主确定这能输出spwm波吗
作者: STM32MSP430    时间: 2018-6-21 11:50
请问下调制度是什么意思
作者: wzd145    时间: 2018-7-21 13:57
看起来不错,下下来看看

作者: liht1634    时间: 2018-9-6 10:55
看上这个软件了。
作者: 羽毛的飞舞    时间: 2018-11-3 09:39
先谢过楼主,学习一下
作者: 羽毛的飞舞    时间: 2018-11-3 10:13
新人学习一下,
作者: 羽毛的飞舞    时间: 2018-11-3 10:43
大神,上面程序要在那个软件里能运行显示
作者: 小男孩0    时间: 2019-2-2 14:47
求电路图
作者: suuy79    时间: 2019-2-2 15:51
好贴,MARK!
作者: G-8652    时间: 2019-4-8 17:14
下载看看
作者: LXMT    时间: 2019-4-13 01:40
很棒   !!!!!!!!!!!!!
作者: chenxiaoya    时间: 2019-4-19 00:15
非常感谢分享谢谢
作者: ptlantu    时间: 2019-4-19 11:34
感谢楼主分享
作者: xiongliya    时间: 2019-5-5 23:23
软件那几个参数什么意思?
作者: 筑梦者1993    时间: 2019-5-8 15:33
可以的好像很好玩
作者: 筑梦者1993    时间: 2019-5-8 15:59
哪个引脚是输出口
作者: carolineee    时间: 2019-5-16 16:12
谢谢分享
作者: liuy5134    时间: 2019-6-1 14:33
这工具不错,程序这么简单能用吗
作者: 小笨鸟O    时间: 2019-6-1 19:05
请问:频率可调么?
作者: Jaser    时间: 2019-6-16 14:19
spwm怎么在电脑上看?
作者: 66249259    时间: 2019-7-9 18:18
下载参考
作者: 鹏博士PBs    时间: 2019-7-9 23:08
不错 不错 感谢分享
作者: 流淌的歌声    时间: 2019-7-11 11:16
谢谢分享,正在学习正弦波
作者: 薛定谔了    时间: 2019-7-18 09:09
帮了大忙了
作者: winkle    时间: 2019-7-26 10:23
很实用的spwm工具
作者: 1513184435    时间: 2019-7-29 19:39
感谢楼主分享
作者: TaySwift    时间: 2019-8-2 13:12
CMSIS-DAP Mini仿真器-用户手册.pdf (619.72 KB, 下载次数: 25)

作者: TaySwift    时间: 2019-8-2 13:23
私发一份行吗
作者: jimmyduan    时间: 2019-8-8 20:38
学习一哈
作者: jean2019    时间: 2019-9-2 23:58
正需要,谢谢分享
作者: guoyin    时间: 2019-9-17 17:21
谢谢了
作者: cjjdemon    时间: 2019-11-8 09:15
学习一下,正好对这个挺感兴趣的。
作者: 今天天气不错    时间: 2019-12-9 16:00
还不知道怎么用,谢谢楼主
作者: luchenzhijia    时间: 2020-4-22 23:59
先谢过楼主,学习一下
作者: luchenzhijia    时间: 2020-4-23 10:19
不错,挺好用的
作者: luchenzhijia    时间: 2020-4-23 17:52
不错的学习资料
作者: MONKEY529S    时间: 2020-6-14 18:42
单片机怎么产生spwm波呀
作者: foxpro2005    时间: 2020-9-23 21:55
我来更新一下吧,再传一些使用说明:
spwm_tool_v1.3.5.rar (611.71 KB, 下载次数: 247)
SPWM波形生成工具使用说明.pdf (597.07 KB, 下载次数: 211)

作者: 18208717694    时间: 2020-10-1 21:28
foxpro2005 发表于 2020-9-23 21:55
我来更新一下吧,再传一些使用说明:

谢谢分享
作者: cgsvdf    时间: 2020-10-10 16:03
正弦波样本值怎么有点问题啊
作者: univers    时间: 2020-10-31 15:29
感谢,下载下学习一下。
作者: djdjhdhdh    时间: 2020-12-4 15:57
有protues仿真图吗?
作者: djdjhdhdh    时间: 2020-12-4 15:58
有仿真图吗?
作者: hfei    时间: 2021-12-10 17:00
非常感谢,正研究spwm
作者: 阿瓦塞翻译    时间: 2022-1-29 23:00
试一下这个软件
作者: cn_zhx    时间: 2022-2-8 09:07
这里计算的是占空比吧?
作者: chenglcd123    时间: 2022-2-9 11:20
这个SPWM如果在程序里做成频率可调,不用MCU外围的电路修正就完美了
作者: slaoliu    时间: 2023-3-29 21:39
做个课件下载研究下。多谢
作者: 大漠孤烟001    时间: 2023-3-30 10:23
STC8H/STC8G/STC32系列可以方便的产生SPWM

可以方便的产生SPWM.png (286.59 KB, 下载次数: 510)

可以方便的产生SPWM.png

作者: woyaodwn    时间: 2023-4-3 10:29
楼主的问题也是我的问题,楼主有解决了吗
作者: saxhongan    时间: 2023-7-28 10:41
准备研究一下,谢谢分享
作者: 抹茶旦旦    时间: 2024-5-7 10:04
foxpro2005 发表于 2020-9-23 21:55
我来更新一下吧,再传一些使用说明:

牛逼啊老哥
作者: STC庄伟    时间: 2024-5-7 15:50
/*---------------------------------------------------------------------*/
/* --- STC MCU Limited ------------------------------------------------*/
/* --- STC 1T Series MCU Demo Programme -------------------------------*/

/* 如果要在程序中使用此代码,请在程序中注明使用了STC的资料及程序        */
/*---------------------------------------------------------------------*/


/*************  功能说明    **************

本例程基于STC8H8K64U为主控芯片的实验箱9进行编写测试,STC8H系列芯片可通用参考.

高级PWM定时器 PWM1P/PWM1N,PWM2P/PWM2N,PWM3P/PWM3N,PWM4P/PWM4N 每个通道都可独立实现PWM输出,或者两两互补对称输出.

演示使用PWM1P,PWM1N产生互补的SPWM.

主时钟选择24MHZ, PWM时钟选择1T, PWM周期2400, 死区12个时钟(0.5us).正弦波表用200点.

输出正弦波频率 = 24000000 / 2400 / 200 = 50 HZ.

本程序仅仅是一个SPWM的演示程序, 用户可以通过上面的计算方法修改PWM周期和正弦波的点数和幅度.

本程序输出频率固定, 如果需要变频, 请用户自己设计变频方案.

本程序从P6.0(PWM1P)输出正相脉冲, 从P6.1(PWM1N)输出反相脉冲(互补).

******************************************/

#include    "reg51.h"       //包含此头文件后,里面声明的寄存器不需要再手动输入,避免重复定义
#include    "intrins.h"
#include    "T_SineTable.h"

#define     MAIN_Fosc       24000000L   //定义主时钟

typedef     unsigned char   u8;
typedef     unsigned int    u16;
typedef     unsigned long   u32;

//手动输入声明"reg51.h"头文件里面没有定义的寄存器
sfr TH2  = 0xD6;
sfr TL2  = 0xD7;
sfr IE2  = 0xAF;
sfr INT_CLKO = 0x8F;
sfr AUXR = 0x8E;
sfr P_SW1 = 0xA2;
sfr P_SW2 = 0xBA;

sfr P4   = 0xC0;
sfr P5   = 0xC8;
sfr P6   = 0xE8;
sfr P7   = 0xF8;
sfr P1M1 = 0x91;    //PxM1.n,PxM0.n     =00--->Standard,    01--->push-pull
sfr P1M0 = 0x92;    //                  =10--->pure input,  11--->open drain
sfr P0M1 = 0x93;
sfr P0M0 = 0x94;
sfr P2M1 = 0x95;
sfr P2M0 = 0x96;
sfr P3M1 = 0xB1;
sfr P3M0 = 0xB2;
sfr P4M1 = 0xB3;
sfr P4M0 = 0xB4;
sfr P5M1 = 0xC9;
sfr P5M0 = 0xCA;
sfr P6M1 = 0xCB;
sfr P6M0 = 0xCC;
sfr P7M1 = 0xE1;
sfr P7M0 = 0xE2;

sbit P00 = P0^0;
sbit P01 = P0^1;
sbit P02 = P0^2;
sbit P03 = P0^3;
sbit P04 = P0^4;
sbit P05 = P0^5;
sbit P06 = P0^6;
sbit P07 = P0^7;
sbit P10 = P1^0;
sbit P11 = P1^1;
sbit P12 = P1^2;
sbit P13 = P1^3;
sbit P14 = P1^4;
sbit P15 = P1^5;
sbit P16 = P1^6;
sbit P17 = P1^7;
sbit P20 = P2^0;
sbit P21 = P2^1;
sbit P22 = P2^2;
sbit P23 = P2^3;
sbit P24 = P2^4;
sbit P25 = P2^5;
sbit P26 = P2^6;
sbit P27 = P2^7;
sbit P30 = P3^0;
sbit P31 = P3^1;
sbit P32 = P3^2;
sbit P33 = P3^3;
sbit P34 = P3^4;
sbit P35 = P3^5;
sbit P36 = P3^6;
sbit P37 = P3^7;
sbit P40 = P4^0;
sbit P41 = P4^1;
sbit P42 = P4^2;
sbit P43 = P4^3;
sbit P44 = P4^4;
sbit P45 = P4^5;
sbit P46 = P4^6;
sbit P47 = P4^7;
sbit P50 = P5^0;
sbit P51 = P5^1;
sbit P52 = P5^2;
sbit P53 = P5^3;
sbit P54 = P5^4;
sbit P55 = P5^5;
sbit P56 = P5^6;
sbit P57 = P5^7;

/****************************** 用户定义宏 ***********************************/

#define PWMA_ENO     (*(unsigned char  volatile xdata *)  0xFEB1)
#define PWMA_PS      (*(unsigned char  volatile xdata *)  0xFEB2)

#define PWMA_CR1     (*(unsigned char  volatile xdata *)  0xFEC0)
#define PWMA_CR2     (*(unsigned char  volatile xdata *)  0xFEC1)
#define PWMA_SMCR    (*(unsigned char  volatile xdata *)  0xFEC2)
#define PWMA_ETR     (*(unsigned char  volatile xdata *)  0xFEC3)
#define PWMA_IER     (*(unsigned char  volatile xdata *)  0xFEC4)
#define PWMA_SR1     (*(unsigned char  volatile xdata *)  0xFEC5)
#define PWMA_SR2     (*(unsigned char  volatile xdata *)  0xFEC6)
#define PWMA_EGR     (*(unsigned char  volatile xdata *)  0xFEC7)
#define PWMA_CCMR1   (*(unsigned char  volatile xdata *)  0xFEC8)
#define PWMA_CCMR2   (*(unsigned char  volatile xdata *)  0xFEC9)
#define PWMA_CCMR3   (*(unsigned char  volatile xdata *)  0xFECA)
#define PWMA_CCMR4   (*(unsigned char  volatile xdata *)  0xFECB)
#define PWMA_CCER1   (*(unsigned char  volatile xdata *)  0xFECC)
#define PWMA_CCER2   (*(unsigned char  volatile xdata *)  0xFECD)
#define PWMA_CNTRH   (*(unsigned char  volatile xdata *)  0xFECE)
#define PWMA_CNTRL   (*(unsigned char  volatile xdata *)  0xFECF)
#define PWMA_PSCRH   (*(unsigned char  volatile xdata *)  0xFED0)
#define PWMA_PSCRL   (*(unsigned char  volatile xdata *)  0xFED1)
#define PWMA_ARRH    (*(unsigned char  volatile xdata *)  0xFED2)
#define PWMA_ARRL    (*(unsigned char  volatile xdata *)  0xFED3)
#define PWMA_RCR     (*(unsigned char  volatile xdata *)  0xFED4)
#define PWMA_CCR1H   (*(unsigned char  volatile xdata *)  0xFED5)
#define PWMA_CCR1L   (*(unsigned char  volatile xdata *)  0xFED6)
#define PWMA_CCR2H   (*(unsigned char  volatile xdata *)  0xFED7)
#define PWMA_CCR2L   (*(unsigned char  volatile xdata *)  0xFED8)
#define PWMA_CCR3H   (*(unsigned char  volatile xdata *)  0xFED9)
#define PWMA_CCR3L   (*(unsigned char  volatile xdata *)  0xFEDA)
#define PWMA_CCR4H   (*(unsigned char  volatile xdata *)  0xFEDB)
#define PWMA_CCR4L   (*(unsigned char  volatile xdata *)  0xFEDC)
#define PWMA_BKR     (*(unsigned char  volatile xdata *)  0xFEDD)
#define PWMA_DTR     (*(unsigned char  volatile xdata *)  0xFEDE)
#define PWMA_OISR    (*(unsigned char  volatile xdata *)  0xFEDF)

/*****************************************************************************/

#define PWM1_1      0x00        //P:P1.0  N:P1.1
#define PWM1_2      0x01        //P:P2.0  N:P2.1
#define PWM1_3      0x02        //P:P6.0  N:P6.1

#define PWM2_1      0x00        //P:P1.2/P5.4  N:P1.3
#define PWM2_2      0x04        //P:P2.2  N:P2.3
#define PWM2_3      0x08        //P:P6.2  N:P6.3

#define PWM3_1      0x00        //P:P1.4  N:P1.5
#define PWM3_2      0x10        //P:P2.4  N:P2.5
#define PWM3_3      0x20        //P:P6.4  N:P6.5

#define PWM4_1      0x00        //P:P1.6  N:P1.7
#define PWM4_2      0x40        //P:P2.6  N:P2.7
#define PWM4_3      0x80        //P:P6.6  N:P6.7
#define PWM4_4      0xC0        //P:P3.4  N:P3.3

#define ENO1P       0x01
#define ENO1N       0x02
#define ENO2P       0x04
#define ENO2N       0x08
#define ENO3P       0x10
#define ENO3N       0x20
#define ENO4P       0x40
#define ENO4N       0x80

/*************  本地变量声明    **************/

u16 PWM1_Duty;
u8        PWM_Index;        //SPWM查表索引

/******************** 主函数 **************************/
void main(void)
{
    P_SW2 |= 0x80; //扩展寄存器(XFR)访问使能

    P0M1 = 0x00;   P0M0 = 0x00;   //设置为准双向口
    P1M1 = 0x00;   P1M0 = 0x00;   //设置为准双向口
    P2M1 = 0x00;   P2M0 = 0x00;   //设置为准双向口
    P3M1 = 0x00;   P3M0 = 0x00;   //设置为准双向口
    P4M1 = 0x00;   P4M0 = 0x00;   //设置为准双向口
    P5M1 = 0x00;   P5M0 = 0x00;   //设置为准双向口
    P6M1 = 0x00;   P6M0 = 0x00;   //设置为准双向口
    P7M1 = 0x00;   P7M0 = 0x00;   //设置为准双向口

    PWM1_Duty = 1220;

    PWMA_CCER1 = 0x00; //写 CCMRx 前必须先清零 CCxE 关闭通道
    PWMA_CCER2 = 0x00;
    PWMA_CCMR1 = 0x68; //通道模式配置
//    PWMA_CCMR2 = 0x68;
//    PWMA_CCMR3 = 0x68;
//    PWMA_CCMR4 = 0x68;
    PWMA_CCER1 = 0x05; //配置通道输出使能和极性
//    PWMA_CCER2 = 0x55;

    PWMA_ARRH = 0x09; //设置周期时间
    PWMA_ARRL = 0x60;

    PWMA_CCR1H = (u8)(PWM1_Duty >> 8); //设置占空比时间
    PWMA_CCR1L = (u8)(PWM1_Duty);

    PWMA_DTR = 0x0C;   //设置死区时间

    PWMA_ENO = 0x00;
    PWMA_ENO |= ENO1P; //使能输出
    PWMA_ENO |= ENO1N; //使能输出
//    PWMA_ENO |= ENO2P; //使能输出
//    PWMA_ENO |= ENO2N; //使能输出
//    PWMA_ENO |= ENO3P; //使能输出
//    PWMA_ENO |= ENO3N; //使能输出
//    PWMA_ENO |= ENO4P; //使能输出
//    PWMA_ENO |= ENO4N; //使能输出

    PWMA_PS = 0x00;  //高级 PWM 通道输出脚选择位
    PWMA_PS |= PWM1_3; //选择 PWM1_3 通道
//    PWMA_PS |= PWM2_3; //选择 PWM2_3 通道
//    PWMA_PS |= PWM3_3; //选择 PWM3_3 通道
//    PWMA_PS |= PWM4_3; //选择 PWM4_3 通道

    PWMA_BKR = 0x80; //使能主输出
    PWMA_IER = 0x01; //使能中断
    PWMA_CR1 |= 0x01; //开始计时

    EA = 1;     //打开总中断

    while (1)
    {
    }
}

/******************** 中断函数 **************************/
void PWMA_ISR() interrupt 26
{
    if(PWMA_SR1 & 0X01)
    {
        PWMA_SR1 &=~0X01;
        PWM1_Duty = T_SinTable[PWM_Index];
        if(++PWM_Index >= 200)        PWM_Index = 0;

        PWMA_CCR1H = (u8)(PWM1_Duty >> 8); //设置占空比时间
        PWMA_CCR1L = (u8)(PWM1_Duty);
    }
    PWMA_SR1 = 0;
}





欢迎光临 (http://www.51hei.com/bbs/) Powered by Discuz! X3.1