博客
关于我
离散波形的产生方法--正弦、余弦、三角波、方波、锯齿波
阅读量:535 次
发布时间:2019-03-07

本文共 2096 字,大约阅读时间需要 6 分钟。

生成波形函数

以下是一些常用的波形生成函数,适用于多种应用场景。这些函数可以根据需求进行参数调整,生成不同类型的波形。

1. 生成正弦波

int GenSineWave(int numElements, float64 amplitude, float64 frequency, float64 *phase, float64 *sineWave) {    int i = 1;    for(; i <= numElements; ++i) {        sineWave[i-1] = amplitude * sin(PI/180.0 * (*phase + 360.0 * frequency * i));    }    *phase = fmod(*phase + frequency * 360.0 * numElements, 360.0);    return 0;}

注意frequency = 1 / numElements

2. 生成方波

int GenSquareWave(int numElements, float64 amplitude, float64 frequency, float64 *phase, float64 dutyCycle, float64 *squareWave) {    int i = 0;    for(; i < numElements; ++i) {        float64 phase_i = fmod(*phase + 360.0 * frequency * i, 360.0);        squareWave[i] = (phase_i / 360.0) <= dutyCycle / 100.0 ? amplitude : -amplitude;    }    *phase = fmod(*phase + frequency * 360.0 * numElements, 360.0);    return 0;}

3. 生成锯齿波

int GenSawtoothWave(int numElements, float64 amplitude, float64 frequency, float64 *phase, float64 *sawtoothWave) {    int i = 0;    for(; i < numElements; ++i) {        float64 phase_i = fmod(*phase + 360.0 * frequency * i, 360.0);        float64 percentPeriod = phase_i / 360.0;        float64 dat = amplitude * 2.0 * percentPeriod;        sawtoothWave[i] = percentPeriod <= 0.5 ? dat : dat - 2.0 * amplitude;    }    *phase = fmod(*phase + frequency * 360.0 * numElements, 360.0);    return 0;}

4. 生成三角波

int GenTriangleWave(int numElements, float64 amplitude, float64 frequency, float64 *phase, float64 *triangleWave) {    int i = 0;    for(; i < numElements; ++i) {        float64 phase_i = fmod(*phase + 360.0 * frequency * i, 360.0);        float64 percentPeriod = phase_i / 360.0;        float64 dat = amplitude * 4.0 * percentPeriod;        if (percentPeriod <= 0.25) {            triangleWave[i] = dat;        } else if (percentPeriod <= 0.75) {            triangleWave[i] = 2.0 * amplitude - dat;        } else {            triangleWave[i] = dat - 4.0 * amplitude;        }    }    *phase = fmod(*phase + frequency * 360.0 * numElements, 360.0);    return 0;}

这些函数可以根据具体需求进行调整,例如改变频率、幅度和相位等参数,生成不同类型的波形。确保输入参数合理,避免超出范围。

转载地址:http://hpwnz.baihongyu.com/

你可能感兴趣的文章
opencv图像分割2-GMM
查看>>
OpenCV(1)读写图像
查看>>
OpenCV:概念、历史、应用场景示例、核心模块、安装配置
查看>>
Openlayers高级交互(10/20):绘制矩形,截取对应部分的地图并保存
查看>>
Openlayers高级交互(19/20): 地图上点击某处,列表中显示对应位置
查看>>
openlayers:圆孔相机根据卫星经度、纬度、高度、半径比例推算绘制地面的拍摄的区域
查看>>
OpenMCU(一):STM32F407 FreeRTOS移植
查看>>
OpenMMLab | S4模型详解:应对长序列建模的有效方法
查看>>
OpenMMLab | 【全网首发】Llama 3 微调项目实践与教程(XTuner 版)
查看>>
OpenMMLab | 面向多样应用需求,书生·浦语2.5开源超轻量、高性能多种参数版本
查看>>
OpenPPL PPQ量化(4):计算图的切分和调度 源码剖析
查看>>
OpenPPL PPQ量化(5):执行引擎 源码剖析
查看>>
Openresty框架入门详解
查看>>
OpenResty(2):OpenResty开发环境搭建
查看>>
openshift搭建Istio企业级实战
查看>>
Openstack 之 网络设置静态IP地址
查看>>
OpenStack 网络服务Neutron详解
查看>>
Openstack(两控制节点+四计算节点)-1
查看>>
Openstack企业级云计算实战第二、三期培训即将开始
查看>>
OpenStack创建虚拟机实例实战
查看>>