C语言生成正弦波测试数据易懂版本

以往生成正弦波数据, 各个参数之间的关系总是不明确, 现在这个函数的代码非常明确的区分了各个参数之间的相互关系.

#include <stdio.h>
#include <math.h>

/**
 * @brief 生成正弦波测试数据
 * 
 * @param data 存放生成的数据的数组
 * @param n 数据的长度 一共采样了多少个点
 * @param sample_rate 采样率 (每秒多少个点)
 * @param amplitude 正弦波的振幅 
 * @param phase 正弦波的初始相位
 * @param frequency 正弦波的频率 
*/
void generateSinData(float data[], int n, float sample_rate , float amplitude, float phase, float frequency) {  
    float time_step = 1.0f / sample_rate; // 每个样本的时间间隔(秒)  
    float a; // 角度(弧度制)  
    float zaosheng; // 噪声项  
      
    // 可选:设置随机数种子以确保每次运行都得到不同的随机噪声  
    // std::srand(static_cast<unsigned int>(std::time(nullptr)));  
  
    for (int i = 0; i < n; i++) {  
        // 计算时间(秒),并转换为角度  
        float time = i * time_step;  
        a = 2 * PI * frequency * time + phase;  
          
        // 添加噪声项(如果需要的话)  
        // zaosheng = 0.1f * (static_cast<float>(std::rand()) / RAND_MAX - 0.5f);  
        zaosheng = 0; // 暂时设为0,如果你想添加噪声可以去掉注释  
          
        // 计算正弦波加上噪声  
        data[i] = amplitude * sin(a) + zaosheng;  
    }  
} 



#define N 2000

int main() {
    
    float data[N];
    float amplitude = 44.0; // 初始振幅
    float phase = 0.5 * PI;  // 初始相位
    float frequency = 10.0; // 初始频率

    generateSinData(data, N, 1000.0f, amplitude, phase,frequency);

    //输出data到文件
    FILE *fp;
    fp = fopen("data.txt", "w");
    for (int i = 0; i < 1000; i++) {
        fprintf(fp, "%f\n", data[i]);
    }
    fclose(fp);
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值