Robotuko „akys”

linijos sekimo daviklis   Kadangi rungtis – linijos sekimas, mūsų robotukas turi aptikti tą liniją. Linijos aptikimui naudosime infraraudonųjų spindulių daviklius. Pats daviklis sudarytas iš infraraudonųjų spindulių (IR) siūstuvo – IR šviesos diodo, IR imtuvo – IR foto diodo ir komparatoriaus, kuris analoginį signalą pavers į skaitmeninį.

   Baltas paviršius atspindi spindulius, juodas paviršius juos sugeria. Kadangi nera tokių idealių baltų-juodų paviršių kurie sugeria visu 100 procentų – tam reikalingas komapratorius. Mes matuojame atsispindinčius IR, todėl reguliuojame komparatorių pavyzdžiui taip, kad jei IR yra iki 30 procentų – tai bus juodas paviršius – loginis 0, jei daugiau nei 30 procentų – baltas paviršius – loginis 1. Reguliavimas ir jautrumas bus nustatyti bandymo metu, jautrumas priklausys nuo išorinio apšvietimo, paviršiaus, atstumo iki linijos ir t.t.

 

Arduino + MAX7219 + Led matrica 8×8

Seniai jau darytas projektas tik niekaip negalėjau (nesugebėjau) aprašyti jo. Kilo idėja Arduino pajungti prie šviesos diodų matricos panaudojant MAX7219 Led valdiklį (draiverį). Kas įdomausia – į vieną eilę 3 valdymo laidais galima pajungti iki 8 tokių modulių. Gaunama 8×64 taškų eilutė.

Pati schema elementari, plokštė gavosi 6cmx6cm

programos kodas:

#include „LedControl.h“
int devices = 3; //moduliu skaicius
LedControl lc = LedControl (10, 12, 11, devices);

unsigned long delaytime = 50;
int row;
int col;
int address;

void setup (){
	for (int address = 0; address < devices; address++){
		lc.shutdown (address, false);
		lc.setIntensity (address, 12);
		lc.clearDisplay (address);}
	}

void clr_disp (int dev){
	delay (1000);
	for (address = 0; address < dev; address++){
		lc.clearDisplay (address);}
	}

void fill_pixel (int dev){
	for (row = 0; row < 8; row++){
		for (address = 0; address < dev; address++){
			for (col = 0; col < 8; col++){
				delay (delaytime);
				lc.setLed (address, row, col, true);}
			}
		}
	}

void fill_col_right (int dev, int b){
	for (address = 0; address < dev; address++){
		for (col = 0; col < 8; col++){
			delay (delaytime);
			lc.setColumn (address, col, b);}
		}
	}

void fill_col_left (int dev, int b){
	for (address = dev-1; address >= 0; address--){
		for (col = 7; col >= 0; col--;){
			delay (delaytime);
			lc.setColumn (address, col, b);}
		}
	}

void fill_row_down (int dev, int b){
	for (row = 0; row < 8; row++){
		for (address = 0; address < dev; address++){
			lc.setRow (address, row, b);}
			delay (delaytime);
		}
	}

void fill_row_up (int dev, int b){
	for (row = 7; row >= 0; row--;){
		for( address = 0; address < dev; address++){
			lc.setRow (address, row, b);}
			delay (delaytime);
		}
	}

void loop (){
	clr_disp (devices);
	fill_col_right (devices, 255);
	fill_row_down (devices, 0);
	fill_row_up (devices, 255);
	fill_col_left (devices, 0);
	}

 

ir gabalėlis youtubo

Pirmieji „žingsniai”

Pirmieji "žingsniai", na ne pirmieji, testuota buvo ir anksčiau ir klaidos taisytos, bet dabar jau važiuoja be problemų (kol kas)

Robotuko struktūrinė schema Ver 2

Pradėjus testuoti realius važiavimus išlindo pirmieji povandeniniai akmenys 🙂 Juk kitaip ir negali būti. Robotukas važiavo max. 2 sekundes, o paskui "užlinkdavo" kontroleris. Bėdos – kolektoriniai varikliukai. Juose stovi šepetėliai, kurie stipriai kibirkščiuoja, sukelia elektromagnetinius trukdžius ir visos tos "šiukšlės" persiduodavo kontroleriui, aišku jis to neištverdavo ir pasakydavo – "Nea, aš taip nežaidžiu". Prie viso to dar 5V reguliatorius ant kontrolerio nesugebėjo išspausti reikiamo galimgumo varikliukų užmaitinimui, todėl sprendimas – papildomas blokas su 5V reguliatoriumi ir kondensatorių (C) filtrais kiekvienam varikliukui.

robotuku strukturine schema ver 2

Filtrų bloko schema:

filtru blokas

Spausdintinė plokštė:

istrasuota plokste

o čia jei kas užsimanys DipTrace visi failiukai

filtru ir maitinimo blokas

va tokia "grožybė" gavosi, radiatorių reikės dėti didesnį – vis tik šyla jis.