单片机方波,锯齿波,三角波,正弦波C程序
时间: 2023-08-08 18:08:05 浏览: 330
以下是51单片机的C程序,实现方波、锯齿波、三角波、正弦波的产生:
```c
#include <reg52.h>
#include <math.h>
#define PI 3.14159265358979323846
// 定义DAC输出引脚
sbit DAC_CS = P1^4;
// 执行DAC输出操作
void DAC_Output(unsigned int value)
{
DAC_CS = 0; // 使能DAC芯片
P0 = (value >> 8) & 0xFF; // 输出高8位数据
P0 = value & 0xFF; // 输出低8位数据
DAC_CS = 1; // 禁止DAC芯片
}
// 产生方波
void generateSquareWave(unsigned int frequency, unsigned int dutyCycle)
{
unsigned int period = 1000000 / frequency; // 计算周期,单位为微秒
unsigned int highTime = period * dutyCycle / 100; // 计算高电平时间,单位为微秒
unsigned int lowTime = period - highTime; // 计算低电平时间,单位为微秒
unsigned int counter = 0; // 计数器
while (1)
{
if (counter < highTime)
{
DAC_Output(4095); // 输出最大值
}
else
{
DAC_Output(0); // 输出最小值
}
counter++;
if (counter >= period)
{
counter = 0;
}
delay_us(1); // 延时1微秒
}
}
// 产生锯齿波
void generateSawtoothWave(unsigned int frequency)
{
unsigned int period = 1000000 / frequency; // 计算周期,单位为微秒
unsigned int value = 0; // DAC输出数据
unsigned int step = 4095 / period; // 计算每个计数周期的步进值
unsigned int counter = 0; // 计数器
while (1)
{
DAC_Output(value); // 输出DAC数据
value += step;
if (value > 4095)
{
value = 0;
}
counter++;
if (counter >= period)
{
counter = 0;
}
delay_us(1); // 延时1微秒
}
}
// 产生三角波
void generateTriangleWave(unsigned int frequency)
{
unsigned int period = 1000000 / frequency; // 计算周期,单位为微秒
unsigned int value = 0; // DAC输出数据
unsigned int step = 4095 / (period / 2); // 计算每个计数周期的步进值
unsigned int counter = 0; // 计数器
unsigned char direction = 0; // 方向标志,0为上升,1为下降
while (1)
{
DAC_Output(value); // 输出DAC数据
if (direction == 0)
{
value += step;
if (value >= 4095)
{
value = 4095;
direction = 1;
}
}
else
{
value -= step;
if (value <= 0)
{
value = 0;
direction = 0;
}
}
counter++;
if (counter >= period)
{
counter = 0;
}
delay_us(1); // 延时1微秒
}
}
// 产生正弦波
void generateSineWave(unsigned int frequency)
{
unsigned int period = 1000000 / frequency; // 计算周期,单位为微秒
double radian = 0; // 正弦波的弧度值
unsigned int value = 0; // DAC输出数据
unsigned int counter = 0; // 计数器
while (1)
{
value = (unsigned int)((sin(radian) + 1) * 2047.5); // 计算DAC输出数据
DAC_Output(value); // 输出DAC数据
radian += 2 * PI / (period * 1000000) * 10; // 计算下一个弧度值
if (radian >= 2 * PI)
{
radian = 0;
}
counter++;
if (counter >= period)
{
counter = 0;
}
delay_us(1); // 延时1微秒
}
}
void main()
{
generateSquareWave(50, 50); // 产生50Hz,占空比为50的方波
// generateSawtoothWave(50); // 产生50Hz的锯齿波
// generateTriangleWave(50); // 产生50Hz的三角波
// generateSineWave(50); // 产生50Hz的正弦波
}
```
需要注意的是,以上代码只提供了参考实现,具体实现时需要根据具体情况进行调整。同时,DAC输出数据的精度、输出模式等也需要根据具体硬件平台进行设置。
阅读全文