This is an old revision of the document!


Table of Contents

 

Kiirendusandur

Teooria

Kiirendusandur

Kiirendusandurit kasutatakse peamiselt kiiruste muutuste mõõtmiseks. Samuti saab kiirendusanduriga mõõta anduri nurka maapinna suhtes. Kiirendusandurid on konstrueeritud ja valmistatud mikroelektromehaanika tehnoloogial (inglise keeles Microelectromechanical system, lühend MEMS), kus elektroonika ja mehaanika komponendid on integreeritud mikrotasandil.

Kiirendus anduri g-raku skeem

Tüüpiline kiirendusandur koosneb mikrofreesitud mahtuvuslikust andurelemendist (g-rakk) ja mõõte- ning andmetöötluselektroonikast. Mõõteelement koos elektroonikaga on suletud vee ja õhukindlalt anduri korpusesse. G-rakk on mikrokiipi söövitatud polüsilikooni kiht, mis koos kahe fikseeritud mahtuvusliku plaadiga moodustab kaks kondensaatorit. Kui andurile rakendada mingi kiirendus, siis g-raku keskmine kiht liigub vastavalt ühe või teise fikseeritud plaadi poole ning kondensaatorite mahtuvus muutub proportsionaalselt kiirendusele.

Andurisse sisse ehitatud elektroonika tegeleb g-rakkude mõõtmisega ning analüüsimisega. Elementidest tulev informatsioon võimendatakse, filtreeritakse ning teisendatakse pingeks, mida saab otse ühendada mikrokontrolleri sisendiga. Tavaliselt lisatakse anduritesse ka 0G väljund, millega on võimalik kontrollerisse tekitada katkestus juhul kui andur tuvastab 0G ehk kukkumise.

Praktika

Kodulabori lisakomplektiga on kaasas lihtne 3-teljeline kiirendusandur. Kiirendusanduri lugemiseks on vaja kasutada kontrolleril kolme ADC sisendit (1 iga telje jaoks). Näitekood näitab kanalitest mõõdetud ADC väärtust ning joonistab kiirendusanduri lugemid ka graafilisele LCD-le.

// Kiirendusanduri näiteprogramm
#include <homelab/pin.h>
#include <homelab/adc.h>
#include <homelab/module/lcd_gfx.h>
 
//
long map(long x, long in_min, long in_max, long out_min, long out_max)
{
	return (x - in_min) * (out_max - out_min) / (in_max - in_min) + out_min;
}
 
// Põhiprogramm
int main(void)
{
	// LCD ekraani algseadistamine
	lcd_gfx_init();
	lcd_gfx_write_string("Kiirendusandur");
 
	// ADC muunduri algseadistamine
	adc_init(ADC_REF_AVCC,ADC_PRESCALE_128);
 
	// Lõputu tsükkel
	while (true)
	{
		char buffer[60];
 
		// x, y, z telgede analoogväärtuse lugemine
		uint16_t x = adc_get_value(1);
		uint16_t y = adc_get_value(2);
		uint16_t z = adc_get_value(3);
 
		//
		uint16_t x_map = map(x,950,1300,128,0);
		uint16_t y_map = map(y,1000,1400,0,160);
 
		// Lugemite teisendamine tekstiks ja LCD ekraanile kuvamine
		sprintf(buffer,"x: %4d\ny: %4d\nz: %4d\n",x,y,z);
		lcd_gfx_goto_char_xy(0,2);
		lcd_gfx_write_string(buffer);
 
		// Graafiku joonistamine
		lcd_gfx_drawPixel(x_map, y_map);
		sw_delay_ms(10);
	}
}
et/examples/sensor/accelerometer.1412865369.txt.gz · Last modified: 2020/07/20 09:00 (external edit)
CC Attribution-Share Alike 4.0 International
www.chimeric.de Valid CSS Driven by DokuWiki do yourself a favour and use a real browser - get firefox!! Recent changes RSS feed Valid XHTML 1.0