stm32 波形检测,绘制

红叶合适落水

校赛第三部分

详见

http://t.csdn.cn/50yJu

这里就简单多了

波形检测见

http://t.csdn.cn/LCvX1

关于判断波形的类型

FFT还没用过

但一定频率范围内有两种方法

方案一

检测一下采集到的波形数据,大于某个值的数有多少个,就可以判断出是什么波形

方案二

将数组内相邻的两个数相减,判断差值;

差值为0,方波

差值为定值,但不为0,三角波

差值不是定值,正弦波。

关于STM32单片机对数的计算

直接使用公式是没法返回正确的值的

解决方案

利用中间变量

u16 lo = 0;
	u16 lo2 = 0;
	len = len - 1;
	LCD_Fill(0, 120, 240, 220, GREEN);
	for(i = 0; i < len; i++) {
		lo = 20 * log10(arr[i]);
		lo2 = 20 * log10(arr[i + 1]);
		LCD_DrawLine(i * 230 / len, (100 - lo) * 2 + 80, (i + 1) * 230 / len, (100 - lo2) * 2  + 80);
	}
	

主函数

int main(void)
{		int pending = 0;
		u8 t=0;
    Init();

	while(1)
	{
		if(pending == 1) {
			printf("\n\r%d",Get_Adc(ADC_Channel_0));
			if(Get_Adc(ADC_Channel_0) > 3700) {
			
			} else {
					for(n = 0; n < 70; n++) {
						ADC_ConvertedValue2[n] = Get_Adc_vpp(ADC_Channel_0);
						delay_ms(16);
					}
					pending = 4;
					draw2(ADC_ConvertedValue2, 70, 40);
					LCD_ShowxNum(100,200,pending,1,16,0);
			}
		}
		t=KEY_Scan(0);		//µÃµ½¼üÖµ
		switch(t)
		{				 
			case KEY0_PRES:
				pending = 0;
				draw(ADC_ConvertedValue, 200, 40);
				adc_init();
				LCD_ShowxNum(100,200,pending,1,16,0);
				break;
			case KEY1_PRES:
					pending = 1;
					Adc_Init();	
					LCD_ShowxNum(100,200,pending,1,16,0);
				break;
			case WKUP_PRES:		
				pending = 2;
				draw(ADC_ConvertedValue, 200, 40);
				adc_init();
				LCD_ShowxNum(100,200,pending,1,16,0);
				break;
			default:
				delay_ms(1);
		} 
		
	}
}

void ADC(u16 vpp1) {
		vpp1=Get_Adc_vpp(ADC_Channel_0);
		temp=(float)vpp1*(3.3/4096);
		vpp1=temp;
		LCD_ShowxNum(156,150,vpp1,1,16,0);
		temp-=vpp1;
		temp*=1000;
		LCD_ShowxNum(172,150,temp,3,16,0X80);
}

void Init(void)
{
		NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
		uart_init(9600);
		delay_init();	
		KEY_Init();
		LCD_Init();
		Adc_Init();		 
    POINT_COLOR=BLUE;//ÉèÖÃ×ÖÌåΪÀ¶É«      
		LCD_ShowString(60,150,200,16,16,"ADC_CH1_VPP:0.000V");
				
		adc_init();
		
		LCD_DrawLine(0, 100, 230, 100);
		LCD_SSD_BackLightSet(1);
}
void draw(u16 arr[], int len, int height)
{
	int num = 0;
	len = len - 1;
	LCD_Fill(0, 0, 240, 100, GREEN);
	for(i = 0; i < len; i++) {
		num += (arr[i] > 621) ? 1 : 0;
		LCD_DrawLine(i * 230 / len, 100 - (arr[i] / height), (i + 1) * 230 / len, 100 -  (arr[i + 1] / height));
	}
	printf("\n\r%d",num);
	if(num < 130) {
		LCD_ShowString(10,0,200,16,16,"Square");
	} else if(num > 140 && num < 170) {
		LCD_ShowString(10,0,200,16,16,"SIN");
	} else if(num > 175) {
		LCD_ShowString(10,0,200,16,16,"Triangle");
	}
	
}

void draw2(u16 arr[], int len, int height)
{
	u16 lo = 0;
	u16 lo2 = 0;
	len = len - 1;
	LCD_Fill(0, 120, 240, 220, GREEN);
	for(i = 0; i < len; i++) {
		lo = 20 * log10(arr[i]);
		lo2 = 20 * log10(arr[i + 1]);
		LCD_DrawLine(i * 230 / len, (100 - lo) * 2 + 80, (i + 1) * 230 / len, (100 - lo2) * 2  + 80);
	}
	
	LCD_Fill(0, 220, 240, 320, GREEN);
	for(i = 0; i < len; i++) {
		LCD_DrawLine(i * 230 / len, 100 - (arr[i] / height) + 200, (i + 1) * 230 / len, 100 -  (arr[i + 1] / height) + 200);
	}
	LCD_ShowString(230,210,16,16,16,"5");
	LCD_ShowString(230,280,16,16,16,"0");
	LCD_ShowString(0,300,48,16,16,"100");
	LCD_ShowString(100,300,64,16,16,"2.9k");
	LCD_ShowString(200,300,64,16,16,"5khz");
	LCD_ShowString(220,130,48,16,16,"14");
	LCD_ShowString(230,180,48,16,16,"0");
	LCD_ShowString(205,195,48,16,16,"-17");
	LCD_ShowString(210,250,48,16,16,"(V)");
}

void draw3(u16 arr[], int len, int height)
{
	len = len - 1;
	LCD_Fill(0, 0, 240, 100, GREEN);
	for(i = 0; i < len; i++) {
		LCD_DrawLine(i * 230 / len, 100 - (arr[i] / height), (i + 1) * 230 / len, 100 -  (arr[i + 1] / height));
	}

	
}

你可能感兴趣的:(嵌入式开发,stm32,arm,嵌入式硬件)