C语言生成常见波形数据

最近无聊,研究上C语言的一些程序,感觉波形生成还是挺有用的

这里主要生成了正弦,方波,三角波 ,锯齿波,指数波形等

首先看看效果,

这里把生成的数据用python画了出来,程序在最后

正弦,调用参数

wave_gen(1000,10,100,sin);

波形长度1000个(1s),频率10hz,幅值100,类型为sin

方波,调用参数

wave_gen(1000,5,0.1,squ);

波形长度1000,频率5hz,占空比10%,类型为方波

锯齿波,调用参数

wave_gen(1000,5,0.1,saw);

波形长度1000(ms),频率5hz,斜率0.1(相对于时间ms而言),波形类型为锯齿波

三角波,调用参数

wave_gen(1000,5,10,tri);

波形长度1000ms,频率5hz,斜率10(相对于时间ms而言),波形类型为三角波,其实也就是特殊的锯齿波

x/2的积分,即x^2指数函数

调用参数wave_gen(1000,5,2,inte);

波形长度1000,频率5hz,2次幂,积分(指数)波形

剩下的一些波形还有点问题,就不演示了

贴下代码

cpp 复制代码
#include "stdio.h"
#include "stdlib.h"
#include "string.h"
#include "math.h"

#define PI 3.14159265
float *ydata,*xdata;
#define sin 0 //正弦 
#define squ 1 //方波 
#define saw 2 //锯齿波 
#define tri 3 //三角波 
#define inte 4 //积分 x^2 
#define diff 5
#define gauss 6 // 高斯白噪声 
void wave_gen(int len,float fre,float rate,char type){//生成波形长度ms,波形频率 ,波形参数,波形类型 
	int i,wave_cnt=0,wave_sw_value=1000/fre;
	ydata = (float *)malloc(sizeof(float)*len);
	xdata = (float *)malloc(sizeof(float)*len);
	for(i=0;i<len;i++){
		if(wave_cnt>=wave_sw_value) wave_cnt=0;
		switch(type){
			case sin:
				ydata[i] =  rate*sinf(2*wave_cnt*PI/wave_sw_value);
				break;
			case squ:
				ydata[i] =  wave_cnt < rate*wave_sw_value ? 1:0;	
				break;
			case saw:
				ydata[i] =  rate*wave_cnt;			
				break;
			case tri:
				ydata[i] =  rate*(wave_cnt>wave_sw_value/2 ? wave_sw_value-wave_cnt: wave_cnt);	
				break;
			case inte:
			    ydata[i] =  (pow(wave_cnt,rate));	
				break; 
			case diff:
				ydata[i] =  2*wave_cnt;	
				break;
			case gauss:
				ydata[i] = (20.0 / (10 * sqrt(2.0 * 3.14159))) * exp(-((wave_cnt/1.0 - 10) * (wave_cnt/1.0 - 10)) / (2.0 * 10 * 10));
				break;
		}
		xdata[i] = i;
		wave_cnt++;
	}
	
}
int main(){
	int i=0;
	wave_gen(1000,5,2,inte);
	for(i=0;i<1000;i++){
		printf("%.2f,",ydata[i]);
	}
	return 0;
}

同时也上传仓库了:opencaneve: 开源STM32HAL ESP8266 ESP32 python Android Windows把我学习到的以及找到的可以用的代码分享出来python记录打卡信息 ESP32蓝牙鼠标 开源windows串口助手 - Gitee.com

相关推荐
众创岛22 分钟前
iframe的属性获取
开发语言·javascript·ecmascript
一个处女座的程序猿O(∩_∩)O29 分钟前
Python基础知识大全:从零开始掌握Python核心语法
开发语言·python
小陈工33 分钟前
Python Web开发入门(十一):RESTful API设计原则与最佳实践——让你的API既优雅又好用
开发语言·前端·人工智能·后端·python·安全·restful
计算机安禾1 小时前
【数据结构与算法】第28篇:平衡二叉树(AVL树)
开发语言·数据结构·数据库·线性代数·算法·矩阵·visual studio
csbysj20201 小时前
网站主机技术概述
开发语言
froginwe111 小时前
jQuery 事件方法详解
开发语言
爱编码的小八嘎2 小时前
C语言完美演绎6-21
c语言
echome8882 小时前
JavaScript Promise 与 async/await 实战:5 个高频异步编程场景的优雅解决方案
开发语言·javascript·ecmascript
xcLeigh2 小时前
IoTDB Java 原生 API 实战:SessionPool 从入门到精通
java·开发语言·数据库·api·iotdb·sessionpool
杜子不疼.2 小时前
Java 智能体学习避坑指南:3 个常见误区,新手千万别踩,高效少走弯路
java·开发语言·人工智能·学习