Mudanças entre as edições de "Garoando em linha"

De Garoa Hacker Clube
Ir para navegação Ir para pesquisar
m
 
(53 revisões intermediárias por um outro usuário não estão sendo mostradas)
Linha 1: Linha 1:
 
Kit sendo desenvolvido para o [[Nós Robôs]] constituido de todos componentes necessários para um seguidor de linha básico, com um tutorial passo-a-passo.
 
Kit sendo desenvolvido para o [[Nós Robôs]] constituido de todos componentes necessários para um seguidor de linha básico, com um tutorial passo-a-passo.
   
A proposta é ser o mais didático possível e preparado para quem tem pouco ou nenhum conhecimento em Arduino, eletrônica ou robótica.
+
A proposta é ser o mais didático possível e preparado para quem tem pouco ou nenhum conhecimento em Arduino, eletrônica ou robótica. Nesta página haverá conteúdo um pouco menos amigável, porém ideal para se estudar após compreender tudo contido no [[Garoando em linha#Passo-a-Passo|Passo-a-Passo]].
   
 
==Responsáveis==
 
==Responsáveis==
Linha 8: Linha 8:
 
==Visão Geral==
 
==Visão Geral==
 
[[Arquivo:Kit_garoando.jpg|400px]]
 
[[Arquivo:Kit_garoando.jpg|400px]]
  +
[[Arquivo:Chassi.JPG|400px]]
   
  +
==Dimensões==
==Componentes do Kit==
 
  +
[[Arquivo:Medidaspneu_garoando.png|400px]]
  +
[[Arquivo:medidaschassi_garoando.jpg|400px]]
  +
  +
==Hardware==
  +
===Componentes do Kit===
   
 
<gallery>
 
<gallery>
  +
File:chassi_garoando.jpg| 1x Chassi de Acrílico
File:Chassi.JPG|1x Chassi de acrílico com 2x rodas, 2x motores, 2x encoders e 1x suporte para pilhas com adaptador para alimentar o Arduino
 
  +
File:rodas_garoando.jpg|2x Rodas com Pneus
  +
File:rodauni_garoando.jpg|1x Roda Universal
  +
File:Motores garoando.jpg| 2x Motores (1:48)
  +
File:encoders_garoa.jpg|2x Encoders, 1x Botão Liga-Desliga, 4x Suportes
  +
File:parafusos_garoando.jpg| 14x Parafusos, 10x Porcas, 4x Espaçadores
  +
File:suportepilha_garoando.jpg| 1x Suporte para Pilhas
  +
File:p4macho_garoando.jpg| 1x Adaptador P4 Macho
 
File:Motor drive shield.JPG|1x Motor Drive Shield L293D
 
File:Motor drive shield.JPG|1x Motor Drive Shield L293D
  +
File:IRsensor.JPG|6x Sensores de Refletância Infravermelhos
File:ArduinoUno R3.jpg|1x Arduino Uno R3 (ou compatível)"*"
 
File:IRsensor.JPG|4x Sensores de Refletância Infravermelhos
 
 
File:Hc-sr04-ultrasonic-sensor-500x500.jpg|1x Sensor de Ultrasom
 
File:Hc-sr04-ultrasonic-sensor-500x500.jpg|1x Sensor de Ultrasom
  +
File:ArduinoUno R3.jpg|1x Arduino Uno R3 (ou compatível)"*"
 
</gallery>
 
</gallery>
   
"*" Não incluso dentro do kit pois há vários Arduinos disponíveis no Garoa
+
"*" Não incluso dentro do kit pois há vários disponíveis no Garoa
  +
  +
===Montagem do Chassi===
  +
[[Arquivo:Montagem garoando.jpg|400px]]
  +
  +
Há incluso no kit um pequeno manual de montagem que apresenta todos componentes básicos e um passo-a-passo de como montá-lo.
  +
  +
O mesmo pode ser acessado em formato PDF abaixo:
  +
<code>
  +
[https://garoa.net.br/wiki/Arquivo:Assemble_garoando.pdf Clique aqui para baixar]
  +
</code>
  +
  +
Futuramente será incluído um manual mais amigável e didático, por enquanto está disponível apenas o fornecido pelo fabricante do chassi.
  +
===Motores===
  +
[[Arquivo:Motores_garoando.jpg|200px]]
  +
  +
{| class="wikitable"
  +
|-
  +
! Voltagem
  +
| DC 3V || DC 5V || DC 6V
  +
|-
  +
! Corrente
  +
| 100mA || 100mA || 120mA
  +
|-
  +
! Taxa de Redução
  +
| colspan="3" style="text-align: center;" | 48:1
  +
|-
  +
! RPM (Com pneu)
  +
| 100 || 190 || 240
  +
|-
  +
! Diametro do Pneu
  +
| colspan="3" style="text-align: center;" | 66mm
  +
|-
  +
! Velocidade (m/minuto)
  +
| 20 || 39 || 48
  +
|-
  +
! Peso do Motor
  +
| colspan="3" style="text-align: center;" | 50g
  +
|-
  +
! Tamanho do Motor
  +
| colspan="3" style="text-align: center;" | 70mm*22mm*18mm
  +
|-
  +
! Ruído
  +
| colspan="3" style="text-align: center;" | <65dB
  +
|}
  +
  +
===Sensor de Ultrasom HC-SR04===
  +
[[Arquivo:Hc-sr04-ultrasonic-sensor-500x500.jpg|200px]]
  +
  +
{| class="wikitable"
  +
|-
  +
! Pinagem
  +
| VCC || Trig (Disparo) || Echo (Recepção) || GND
  +
|}
  +
  +
{| class="wikitable"
  +
|-
  +
! Voltagem
  +
| DC 5V
  +
|-
  +
! Corrente (em repouso)
  +
| < 2 mA
  +
|-
  +
! Saída
  +
| Alto 5V / Baixo 0V
  +
|-
  +
! Ângulo
  +
| < 15º
  +
|-
  +
! Distância
  +
| 2 a 450 cm
  +
|-
  +
! Resolução
  +
| 0,3 cm
  +
|}
  +
===Pinos utilizados pelo Motor Drive Shield L293D===
  +
Todos os '''pinos analógicos estão livres''' e acessíveis pelo próprio shield L293D sem a necessidade de um screw (wing) shield. Estes pinos também podem ser utilizados como '''pinos digitais 14 a 19'''.
  +
Há também uma linha de '''5V''' e uma de '''GND''' juntamente dos pinos A0-A5.
  +
  +
Os pinos digitais '''2''' (acessível pelo shield L293D) e '''13''' '''não são utilizados'''.
  +
  +
O pino digital '''11''' só é utilizado se o motor DC 1 ou stepper 1 estiver sendo utilizado.
  +
  +
O pino digital '''3''' só é utilizado se o motor DC 2 ou stepper 1 estiver sendo utilizado.
  +
  +
O pino digital '''5''' só é utilizado se o motor DC 3 ou stepper 2 estiver sendo utilizado.
  +
  +
O pino digital '''6''' só é utilizado se o motor DC 4 ou stepper 2 estiver sendo utilizado.
  +
  +
Os pinos digitais '''4''', '''7''', '''8''' e '''12''' são utilizados se qualquer motor/stepper estiver sendo utilizado através do 74HC595 serial-to-parallel.
  +
  +
Os pinos digitais '''9''' e '''10''' são utilizados nos servos, #1 e #2 respectivamente.
  +
  +
===Montagem do Arduino e Shield===
  +
  +
===Montagem dos Sensores===
  +
  +
==Software==
  +
  +
Há um repositório no GitHub destinado para que sejam disponibilizados todos sketches produzidos para este kit.
  +
  +
https://github.com/haoji/Garoando-em-Linha
  +
  +
Já está disponível um sketch padrão e uma versão especial para o evento [[Jovem Hacker]].
  +
  +
===Arduino IDE===
  +
  +
===Bibliotecas===
  +
====Como instalar====
  +
====Sensor de Ultrasom HC-SR04====
  +
Esta biblioteca torna obter leituras com o HC-SR04 muito mais fácil com código amigável.
  +
  +
[[Arquivo:HC-SR04medindo_garoando.jpg|500px]]
  +
  +
Foto de [http://www.jra.so/ J.Rodrigo] do [http://www.ardublog.com Ardublog].
  +
  +
=====Onde baixar=====
  +
A biblioteca está disponível no GitHub: https://github.com/haoji/Ultrasonic-HC-SR04
  +
  +
<code>
  +
[https://github.com/haoji/Ultrasonic-HC-SR04/archive/master.zip Clique aqui para baixar]
  +
</code>
  +
  +
Copie a pasta "Ultrasonic" para a pasta "libraries". Veja [https://garoa.net.br/wiki/Garoando_em_linha#Como_instalar como Instalar] se tiver dúvidas.
  +
  +
=====Alterando TimeOut Padrão=====
  +
Por padrão a biblioteca limita o alcance do sensor a ~51cm utilizando um timeout de 3ms. O timeout limita o tempo de execução da função pulsein() para obter resultados mais precisos.
  +
A fórmula para se obter o timeout é a seguinte:
  +
<code>
  +
centímetros * 58 = timeout
  +
</code>
  +
  +
Substitua:
  +
<code>
  +
Ultrasonic ultrasonic(9,8); // (Trig PIN,Echo PIN)
  +
</code>
  +
Por:
  +
<code>
  +
Ultrasonic ultrasonic(9,8,3000); // (Trig PIN,Echo PIN, Timeout máximo em µs )
  +
</code>
  +
E modifique 3000 pelo valor em µs adequado obtido pela fórmula acima
  +
  +
=====Exemplo: Plug & Play=====
  +
  +
Inserir o sensor nos pinos digitais 7, 6, 5, 4 virado para o lado oposto ao Arduino.
  +
  +
Veja: https://github.com/elrodri/Ultrasonic-HC-SR04/wiki/Plug-&-Play
  +
  +
<code>
  +
// Ultrasonic - Library for HR-SC04 Ultrasonic Ranging Module.
  +
// Rev.4 (06/2012)
  +
// J.Rodrigo ( www.jra.so )
  +
// more info at www.ardublog.com
  +
  +
#include <Ultrasonic.h>
  +
  +
Ultrasonic ultrasonic(5,6); // (Trig PIN,Echo PIN)
  +
  +
void setup() {
  +
Serial.begin(9600);
  +
pinMode(4, OUTPUT); // VCC pin
  +
pinMode(7, OUTPUT); // GND ping
  +
digitalWrite(4, HIGH); // VCC +5V mode
  +
digitalWrite(7, LOW); // GND mode
  +
}
  +
  +
void loop()
  +
{
  +
Serial.print(ultrasonic.Ranging(CM)); // CM (centímetros) ou INC (inches - polegadas)
  +
Serial.println(" cm" );
  +
delay(100);
  +
}
  +
</code>
  +
  +
=====Exemplo: Exibir distância no console serial=====
  +
  +
<code>
  +
// Ultrasonic - Library for HR-SC04 Ultrasonic Ranging Module.
  +
// Rev.4 (06/2012)
  +
// J.Rodrigo ( www.jra.so )
  +
// more info at www.ardublog.com
  +
  +
#include <Ultrasonic.h>
  +
  +
Ultrasonic ultrasonic(9,8); // (Trig PIN,Echo PIN)
  +
  +
void setup() {
  +
Serial.begin(9600);
  +
}
  +
  +
void loop()
  +
{
  +
Serial.print(ultrasonic.Ranging(CM)); // CM (centímetros) ou INC (inches - polegadas)
  +
Serial.println(" cm" );
  +
delay(100);
  +
}
  +
</code>
  +
  +
=====Exemplo: Exibir distância em um display LCD=====
  +
<code>
  +
// Ultrasonic - Library for HR-SC04 Ultrasonic Ranging Module.
  +
// Rev.4 (06/2012)
  +
// J.Rodrigo ( www.jra.so )
  +
// more info at www.ardublog.com
  +
  +
#include <Ultrasonic.h>
  +
#include <LiquidCrystal.h>
  +
  +
LiquidCrystal lcd(12, 11, 5, 4, 3, 2); // LCD arduino library
  +
  +
Ultrasonic ultrasonic(9,8); // (Trig PIN,Echo PIN)
  +
  +
void setup() {
  +
lcd.begin(16, 2);
  +
}
  +
  +
void loop()
  +
{
  +
lcd.clear();
  +
lcd.setCursor(0, 0);
  +
lcd.print(ultrasonic.Ranging(CM)); // CM (centímetros) ou INC (inches - polegadas)
  +
lcd.print("cm");
  +
delay(100);
  +
}
  +
</code>
  +
  +
=====Exemplo: Obter tempo em ms do disparo à recepção=====
  +
<code>
  +
// Ultrasonic - Library for HR-SC04 Ultrasonic Ranging Module.
  +
// Rev.4 (06/2012)
  +
// J.Rodrigo ( www.jra.so )
  +
// more info at www.ardublog.com
  +
  +
#include <Ultrasonic.h>
  +
  +
Ultrasonic ultrasonic(9,8); // (Trig PIN,Echo PIN)
  +
  +
void setup() {
  +
Serial.begin(9600);
  +
}
  +
  +
void loop()
  +
{
  +
Serial.print(ultrasonic.Timing());
  +
Serial.println(" ms" ); // milisegundos
  +
delay(100);
  +
}
  +
</code>
  +
  +
=====Exemplo: Utilizar mais de um sensor em conjunto=====
  +
<code>
  +
// Ultrasonic - Library for HR-SC04 Ultrasonic Ranging Module.
  +
// Rev.4 (06/2012)
  +
// J.Rodrigo ( www.jra.so )
  +
// more info at www.ardublog.com
  +
  +
#include <Ultrasonic.h>
  +
  +
Ultrasonic ultraleft(9,8); // (Trig PIN,Echo PIN)
  +
Ultrasonic ultraright(6,7); // (Trig PIN,Echo PIN)
  +
  +
void setup() {
  +
Serial.begin(9600);
  +
}
  +
  +
void loop()
  +
{
  +
Serial.print("Left: ");
  +
Serial.print(ultraleft.Ranging(CM)); // CM (centímetros) ou INC (inches - polegadas)
  +
Serial.print(" cm " );
  +
delay(50);
  +
Serial.print("Right: ");
  +
Serial.print(ultraright.Ranging(CM)); // CM (centímetros) ou INC (inches - polegadas)
  +
Serial.println(" cm" );
  +
delay(50);
  +
}
  +
</code>
  +
  +
====Motor Drive Shield L293D====
  +
=====Onde baixar=====
  +
A biblioteca está disponível no GitHub: https://github.com/haoji/Adafruit-Motor-Shield-library
  +
  +
<code>
  +
[https://github.com/haoji/Adafruit-Motor-Shield-library/archive/master.zip Clique aqui para baixar]
  +
</code>
  +
  +
Renomeie a pasta baixada para "AFMotor" e a mova para a pasta "libraries". Veja [https://garoa.net.br/wiki/Garoando_em_linha#Como_instalar como Instalar] se tiver dúvidas.
  +
  +
=====Exemplo: Controlando um motor DC=====
  +
  +
<code>
  +
// AFMotor - Biblioteca para o Motor Drive Shield L293D.
  +
// Ladyada ( adafruit.com )
  +
// mais info em learn.adafruit.com/adafruit-motor-shield/
  +
  +
#include <AFMotor.h>
  +
  +
AF_DCMotor motor(2, MOTOR12_64KHZ); // cria motor #2, 64KHz pwm
  +
  +
void setup() {
  +
Serial.begin(9600);
  +
Serial.println("Testando motor!");
  +
  +
motor.setSpeed(200); // define a velocidade para 200/255
  +
}
  +
  +
void loop() {
  +
Serial.print("tick");
  +
  +
motor.run(FORWARD); // girar para a frente
  +
delay(1000);
  +
  +
Serial.print("tock");
  +
motor.run(BACKWARD); // girar para trás
  +
delay(1000);
  +
  +
Serial.print("tack");
  +
motor.run(RELEASE); // parado
  +
delay(1000);
  +
}
  +
</code>
  +
  +
===Sketch===
  +
  +
==Passo-a-Passo==
  +
  +
==Referências==
  +
* Datasheet sensor de refletância infravermelho TCRT5000: http://www.vishay.com/docs/83760/tcrt5000.pdf
  +
  +
* Datasheet sensor de ultrasom HC-SR04: http://www.micropik.com/PDF/HCSR04.pdf
  +
  +
* Exemplo de uso do TCRT5000: http://www.bajdi.com/analogread-from-a-tcrt5000-sensor/
  +
  +
* Outro exemplo de uso do TCRT5000: http://www.bajdi.com/volga-the-line-following-robot/
  +
  +
* Exemplo de uso do HC-SR04 utilizando biblioteca que já devolve a distância em cm: http://letsmakerobots.com/node/30209
  +
  +
* Praticamente tudo sobre o Motor Drive Shield L293D com biblioteca: http://learn.adafruit.com/downloads/pdf/adafruit-motor-shield.pdf
  +
  +
* Arduino Playground, Adafruit Motor Shield: http://playground.arduino.cc/Main/AdafruitMotorShield
  +
  +
* Mais sobre o Motor Shield: http://learn.adafruit.com/adafruit-motor-shield/
  +
   
 
[[Categoria:Kits]]
 
[[Categoria:Kits]]
 
[[Categoria:Projetos]]
 
[[Categoria:Projetos]]
  +
[[Categoria:Arduino]]

Edição atual tal como às 12h26min de 21 de fevereiro de 2017

Kit sendo desenvolvido para o Nós Robôs constituido de todos componentes necessários para um seguidor de linha básico, com um tutorial passo-a-passo.

A proposta é ser o mais didático possível e preparado para quem tem pouco ou nenhum conhecimento em Arduino, eletrônica ou robótica. Nesta página haverá conteúdo um pouco menos amigável, porém ideal para se estudar após compreender tudo contido no Passo-a-Passo.

Responsáveis

Haoji

Visão Geral

Kit garoando.jpg Chassi.JPG

Dimensões

Medidaspneu garoando.png Medidaschassi garoando.jpg

Hardware

Componentes do Kit

"*" Não incluso dentro do kit pois há vários disponíveis no Garoa

Montagem do Chassi

Montagem garoando.jpg

Há incluso no kit um pequeno manual de montagem que apresenta todos componentes básicos e um passo-a-passo de como montá-lo.

O mesmo pode ser acessado em formato PDF abaixo:

Clique aqui para baixar

Futuramente será incluído um manual mais amigável e didático, por enquanto está disponível apenas o fornecido pelo fabricante do chassi.

Motores

Motores garoando.jpg

Voltagem DC 3V DC 5V DC 6V
Corrente 100mA 100mA 120mA
Taxa de Redução 48:1
RPM (Com pneu) 100 190 240
Diametro do Pneu 66mm
Velocidade (m/minuto) 20 39 48
Peso do Motor 50g
Tamanho do Motor 70mm*22mm*18mm
Ruído <65dB

Sensor de Ultrasom HC-SR04

Hc-sr04-ultrasonic-sensor-500x500.jpg

Pinagem VCC Trig (Disparo) Echo (Recepção) GND
Voltagem DC 5V
Corrente (em repouso) < 2 mA
Saída Alto 5V / Baixo 0V
Ângulo < 15º
Distância 2 a 450 cm
Resolução 0,3 cm

Pinos utilizados pelo Motor Drive Shield L293D

Todos os pinos analógicos estão livres e acessíveis pelo próprio shield L293D sem a necessidade de um screw (wing) shield. Estes pinos também podem ser utilizados como pinos digitais 14 a 19. Há também uma linha de 5V e uma de GND juntamente dos pinos A0-A5.

Os pinos digitais 2 (acessível pelo shield L293D) e 13 não são utilizados.

O pino digital 11 só é utilizado se o motor DC 1 ou stepper 1 estiver sendo utilizado.

O pino digital 3 só é utilizado se o motor DC 2 ou stepper 1 estiver sendo utilizado.

O pino digital 5 só é utilizado se o motor DC 3 ou stepper 2 estiver sendo utilizado.

O pino digital 6 só é utilizado se o motor DC 4 ou stepper 2 estiver sendo utilizado.

Os pinos digitais 4, 7, 8 e 12 são utilizados se qualquer motor/stepper estiver sendo utilizado através do 74HC595 serial-to-parallel.

Os pinos digitais 9 e 10 são utilizados nos servos, #1 e #2 respectivamente.

Montagem do Arduino e Shield

Montagem dos Sensores

Software

Há um repositório no GitHub destinado para que sejam disponibilizados todos sketches produzidos para este kit.

https://github.com/haoji/Garoando-em-Linha

Já está disponível um sketch padrão e uma versão especial para o evento Jovem Hacker.

Arduino IDE

Bibliotecas

Como instalar

Sensor de Ultrasom HC-SR04

Esta biblioteca torna obter leituras com o HC-SR04 muito mais fácil com código amigável.

HC-SR04medindo garoando.jpg

Foto de J.Rodrigo do Ardublog.

Onde baixar

A biblioteca está disponível no GitHub: https://github.com/haoji/Ultrasonic-HC-SR04

Clique aqui para baixar

Copie a pasta "Ultrasonic" para a pasta "libraries". Veja como Instalar se tiver dúvidas.

Alterando TimeOut Padrão

Por padrão a biblioteca limita o alcance do sensor a ~51cm utilizando um timeout de 3ms. O timeout limita o tempo de execução da função pulsein() para obter resultados mais precisos. A fórmula para se obter o timeout é a seguinte: centímetros * 58 = timeout

Substitua:

Ultrasonic ultrasonic(9,8); // (Trig PIN,Echo PIN)

Por:

Ultrasonic ultrasonic(9,8,3000); // (Trig PIN,Echo PIN, Timeout máximo em µs )

E modifique 3000 pelo valor em µs adequado obtido pela fórmula acima

Exemplo: Plug & Play

Inserir o sensor nos pinos digitais 7, 6, 5, 4 virado para o lado oposto ao Arduino.

Veja: https://github.com/elrodri/Ultrasonic-HC-SR04/wiki/Plug-&-Play

// Ultrasonic - Library for HR-SC04 Ultrasonic Ranging Module.
// Rev.4 (06/2012)
// J.Rodrigo ( www.jra.so )
// more info at www.ardublog.com

#include <Ultrasonic.h>

Ultrasonic ultrasonic(5,6); // (Trig PIN,Echo PIN)

void setup() {
  Serial.begin(9600);
  pinMode(4, OUTPUT); // VCC pin
  pinMode(7, OUTPUT); // GND ping
  digitalWrite(4, HIGH); // VCC +5V mode  
  digitalWrite(7, LOW);  // GND mode
}

void loop()
{
  Serial.print(ultrasonic.Ranging(CM)); // CM (centímetros) ou INC (inches - polegadas)
  Serial.println(" cm" );
  delay(100);
}

Exemplo: Exibir distância no console serial

// Ultrasonic - Library for HR-SC04 Ultrasonic Ranging Module.
// Rev.4 (06/2012)
// J.Rodrigo ( www.jra.so )
// more info at www.ardublog.com

#include <Ultrasonic.h>

Ultrasonic ultrasonic(9,8); // (Trig PIN,Echo PIN)

void setup() {
 Serial.begin(9600);
}

void loop()
{
 Serial.print(ultrasonic.Ranging(CM)); // CM (centímetros) ou INC (inches - polegadas)
 Serial.println(" cm" );
 delay(100);
}

Exemplo: Exibir distância em um display LCD

// Ultrasonic - Library for HR-SC04 Ultrasonic Ranging Module.
// Rev.4 (06/2012)
// J.Rodrigo ( www.jra.so )
// more info at www.ardublog.com

#include <Ultrasonic.h>
#include <LiquidCrystal.h>

LiquidCrystal lcd(12, 11, 5, 4, 3, 2); // LCD arduino library

Ultrasonic ultrasonic(9,8); // (Trig PIN,Echo PIN)

void setup() {
lcd.begin(16, 2);
}

void loop()
{
  lcd.clear();
  lcd.setCursor(0, 0);
  lcd.print(ultrasonic.Ranging(CM)); // CM (centímetros) ou INC (inches - polegadas)
  lcd.print("cm");
  delay(100);
}

Exemplo: Obter tempo em ms do disparo à recepção

// Ultrasonic - Library for HR-SC04 Ultrasonic Ranging Module.
// Rev.4 (06/2012)
// J.Rodrigo ( www.jra.so )
// more info at www.ardublog.com

#include <Ultrasonic.h>

Ultrasonic ultrasonic(9,8); // (Trig PIN,Echo PIN)

void setup() {
  Serial.begin(9600); 
}

void loop()
{
  Serial.print(ultrasonic.Timing());
  Serial.println(" ms" ); // milisegundos
  delay(100);
}

Exemplo: Utilizar mais de um sensor em conjunto

// Ultrasonic - Library for HR-SC04 Ultrasonic Ranging Module.
// Rev.4 (06/2012)
// J.Rodrigo ( www.jra.so )
// more info at www.ardublog.com

#include <Ultrasonic.h>

Ultrasonic ultraleft(9,8);   // (Trig PIN,Echo PIN)
Ultrasonic ultraright(6,7);  // (Trig PIN,Echo PIN)

void setup() {
  Serial.begin(9600); 
}

void loop()
{
  Serial.print("Left: ");
  Serial.print(ultraleft.Ranging(CM)); // CM (centímetros) ou INC (inches - polegadas)
  Serial.print(" cm     " );
  delay(50);
  Serial.print("Right: ");
  Serial.print(ultraright.Ranging(CM)); // CM (centímetros) ou INC (inches - polegadas)
  Serial.println(" cm" );
  delay(50);
}

Motor Drive Shield L293D

Onde baixar

A biblioteca está disponível no GitHub: https://github.com/haoji/Adafruit-Motor-Shield-library

Clique aqui para baixar

Renomeie a pasta baixada para "AFMotor" e a mova para a pasta "libraries". Veja como Instalar se tiver dúvidas.

Exemplo: Controlando um motor DC

// AFMotor - Biblioteca para o Motor Drive Shield L293D.
// Ladyada ( adafruit.com )
// mais info em learn.adafruit.com/adafruit-motor-shield/

#include <AFMotor.h>
 
AF_DCMotor motor(2, MOTOR12_64KHZ); // cria motor #2, 64KHz pwm
 
void setup() {
  Serial.begin(9600);           
  Serial.println("Testando motor!");
  
  motor.setSpeed(200);     // define a velocidade para 200/255
}
 
void loop() {
  Serial.print("tick");
  
  motor.run(FORWARD);      // girar para a frente
  delay(1000);
 
  Serial.print("tock");
  motor.run(BACKWARD);     // girar para trás
  delay(1000);
  
  Serial.print("tack");
  motor.run(RELEASE);      // parado
  delay(1000);
}

Sketch

Passo-a-Passo

Referências