apostila de programação - DAINF

Propaganda
4/12/2013
ROBÔ F
APOSTILA DE PROGRAMAÇÃO
Projeto CNPq-Vale/DAINF/UTFPR-CT | PET-ECO
ROBÔ F
APOSTILA DE PROGRAMAÇÃO
SUMÁRIO
INTRODUÇÃO
3
PENSAMENTO COMPUTACIONAL
4
INTERFACE DE PROGRAM AÇÃO DO ROBÔ F
5
DEFINIÇÕES BÁSICAS
COMANDOS DA API DO ROBÔ F
EXEMPLO DE UTILIZAÇÃO DA INTERFACE
5
5
10
PROBLEMAS FÁCEIS
11
AVANÇAR EM METROS
ROBÔ L IMPADOR 1
SENSOR DE ESTACIONAMENTO 1
SENSOR DE ESTACIONAMENTO 2
SAIA DA M INHA F RENTE
12
12
13
13
13
PROBLEMAS INTERMEDIÁRIO
14
CODIGO ALIENÍGENA
CODIGO ALIENÍGENA 2
AJ UDANTE DE BOMBEIRO
JOGOS OLÍMPICOS
T RIÂNGULO EQUILÁTERO
DESENHAR POLÍGONOS R EGULARES
VIRANDO COM AJ UDA
BARREIRAS ORTOGONAIS
ACELERANDO E R EDUZINDO
BARULHO DO M OTOR
RACE D AY
ROBÔ L IMPADOR 2
15
16
17
18
18
19
19
19
20
20
21
22
PROBLEMAS DIFÍCEIS
23
DESENHO PELA T RAJ ETÓRIA
ROBÔ S EGUIDOR
GATO E R ATO
GATO E R ATO 2
ROBÔ M OTORISTA
ROBÔ AUTÔNOMO
24
25
26
26
27
28
CONCEITOS BÁSICOS DE ELETRÔNICA
29
2
APOSTILA DE PROGRAMAÇÃO
ROBÔ F
INTRODUÇÃO
Este material serve de apoio ao curso introdutório de robótica e computação baseado na interface
de programação Robô F. Durante o curso serão abordados os assuntos básicos de programação
que são ensinados no início dos cursos de “Sistemas de Informação” e “Engenharia de
Computação” juntamente com alguns tópicos iniciais de eletrônica. Basicamente a apostila reúne
alguns problemas clássicos de programação moldados de forma que possam ser solucionados
usando o Robô F. Para resolver os problemas o estudante pode usar o software de programação
visual desenvolvido pelo PET-ECO, uma interface gráfica que permite organizar comandos na
forma de um fluxograma que então é enviado ao robô, que executa os passos. Na interface
também há a opção de simular o funcionamento do Robô F em um ambiente controlado, além
disso, pode-se monitorar as leituras de sensores e o posicionamento tanto do robô simulado como
do real.
3
ROBÔ F
APOSTILA DE PROGRAMAÇÃO
PENSAMENTO COMPUTACIONAL
Ao pensar em computação as pessoas comumente não a veem como algo diretamente
dependente dos seres humanos. Costuma-se imaginar a programação de computadores como
algo distante do mundo tangível, quase mágico, quando na verdade o cerne da programação está
em qualquer atividade cotidiana: o pensamento computacional.
Pensar computacionalmente inclui ver as coisas de forma lógica e cadenciada, como um passo-apasso para resolver um problema ou realizar uma tarefa (a isso podemos chamar de algoritmo),
mas não se resume a isso. Inclui todas as áreas do conhecimento, humanas, exatas e biológicas.
A palavra-chave no pensamento computacional é abstração. A abstração na computação é feita
de forma muito ampla, se lida não somente com números e respostas exatas, mas com situações
reais e que a princípio parecem simplórias (um bom exemplo, e adiantando o que veremos mais à
frente, como fazer um robô se movimentar sem bater nas pessoas ou obstáculos ao redor) se faz
necessário pensar em situações limite e em todas as coisas que podem dar errado.
Outro conceito essencial no pensamento computacional é a automação. Isso significa mecanizar a
abstração o máximo possível, deixando o “trabalho pesado” para as máquinas.
Relacionados diretamente com a automação e a abstração estão os algoritmos. Um algoritmo é
uma sequência finita e bem definida de passos que, quando executados, realizam uma tarefa
específica ou resolvem um problema. Ele é composto por ações sim ples e bem definidas (não
pode haver ambiguidade, ou seja, cada instrução representa uma ação que deve ser entendida e
realizada). Exemplos de algoritmos variam de triviais, como receitas de culinária e manuais de
instruções, à softwares que controlam trânsito de dados na web.
Na computação, algoritmos são geralmente ensinados em pseudocódigos, que representam a
resolução de um problema usando estruturas de decisão típicas de linguagens de programação.
Dentro desse raciocínio, é possível e desejável aglomerar em uma mesma estrutura vários
comandos simples que estejam relacionados à mesma tarefa. A essas estruturas chamamos de
funções.
4
APOSTILA DE PROGRAMAÇÃO
ROBÔ F
INTERFACE DE PROGRAMAÇÃO DO ROBÔ F
Definições Básicas
A linguagem de programação visual é composta de:
1.
2.
3.
4.
5.
6.
7.
Comandos disponíveis na API de programação dos robôs (ver abaixo)
Bloco de comandos sequenciais;
Loop: assumir que para o módulo 1 só existe while
Função com argumentos;
Variáveis sem tipificação;
Variáveis vetoriais;
Operadores
a. Aritméticos básicos (4 operações)
b. Relacionais (maior, menor, maior ou igual, menor ou igual, diferente).
c. Lógicos (and, or).
Comandos da API do Robô F
move
wait
rotate
var
read
print
if...else
while
move
move ( r1, r2 );
Move o robô, sendo r1 e r2 a roda esquerda e direita respectivamente. Cada roda recebe um valor
inteiro de velocidade relativa, sendo 0 a roda parada, 100 a velocidade máxima para frente e 100 a velocidade máxima para trás do motor.
Exemplo
move (100, 100);
Move o robô em linha reta para frente com velocidade máxima.
5
ROBÔ F
APOSTILA DE PROGRAMAÇÃO
wait
wait ( t );
wait ( t ) serve para controlar o tempo de um comando. O tempo é regulado pelo parâmetro inteiro
t, e é medido em milissegundos.
Exemplo
move (100, 100);
wait (1000);
move (0, 0);
Faz o robô acionar os motores em velocidade máxima para frente por 1 segundo e depois parar.
rotate
rotate ( a );
Rotaciona o robô em torno de seu próprio eixo ao fazer as rodas girarem em sentidos opostos na
mesma velocidade. Recebe o parâmetro angular inteiro a (-360 a 360). Valores positivos
rotacionam o robô no sentido horário e valores negativos rotacionam o robô no sentido antihorário.
Exemplo
rotate (90);
Rotaciona o robô 90º no sentido horário.
6
APOSTILA DE PROGRAMAÇÃO
ROBÔ F
var
var <nome>;
Cria uma variável , ou seja, reserva um espaço de memória para guardar uma variável de
qualquer tipo (números inteiros, reais, caracteres, etc.). O comando também aceita vetores de
tamanho variável.
Exemplo
var x = 0;
Cria uma variável de nome x e atribui o valor zero a ela.
var v;
v = [10,20];
Cria um vetor com 2 posições preenchidas com 10 e 20.
7
ROBÔ F
APOSTILA DE PROGRAMAÇÃO
read
read ( Device, var );
Comando usado para guardar valor de uma variável lida pelo sensor. Recebe um parâmetro
Device, que é um dos dispositivos do robô (bússola, sensor de distância e sensores de refletância)
e guarda o valor recebido na variável var.
Exemplo
var y;
read (Bussola, y);
Cria uma variável y e guarda o valor lido da bússola em y, no caso um número inteiro
representando um ângulo (0 a 359º).
print
print ( <formato>, [var1, ..., varN] )
Exibe uma mensagem na tela. O formato é delimitado por aspas duplas (“”) e pode conter a
expressão %v, que será substituída pela variável fornecida como parâmetro.
Exemplo
var x = 5;
print (“O valor de x é: %x”, x);
Exibe a mensagem: “O valor de x é: 5”.
8
APOSTILA DE PROGRAMAÇÃO
ROBÔ F
if...else
If (condição ) { ... } else { ... }
O comando if (Se),serve para fazer um caminho alternativo . Irá executar um bloco de comandos
apenas se determinada condição for satisfeita. O comando else (Senão) executa um bloco caso a
condição não seja satisfeita
Exemplo
if (x >= 120)
{
x = 0;
}
else
{
x = x + 10;
}
O valor da variável x será zerado se a variável apresentar um valor maior ou igual a 120. Caso
contrário a variável é incrementada em 10 unidades.
9
ROBÔ F
APOSTILA DE PROGRAMAÇÃO
while
while ( condição )
Comando de loop de repetição. Irá executar um bloco de comandos enquanto uma determinada
condição for satisfeita.
Exemplo
while (x < 120)
{
x = x + 10;
}
Enquanto o valor da variável x é menor que 120 a variável tem seu valor incrementado em 10
unidades.
Exemplo de Utilização da Interface
Pequeno texto tutorial de como usar o programa
IMAGENS COM LEGENDA DOS BOTOES E DESCIRÇÃO DE SUAS FUNÇÕES
10
APOSTILA DE PROGRAMAÇÃO
ROBÔ F
Problemas Fáceis
11
ROBÔ F
APOSTILA DE PROGRAMAÇÃO
Avançar em metros
Objetivo: aprender funções, condicionais básicas.
Conhecimentos envolvidos: movimento retilíneo uniforme (Física)
Enunciado: Faça uma função chamada andar_metros, que recebe como argumento uma
distancia, contendo a distância em metros que o robô irá percorrer. Considerando uma velocidade
fixa de 0.1 m/s, calcule o tempo necessário, em segundos, de execução do comando
avancar(v,t) para os valores de distancia.
Provocação: verifique através do sensor de distância se é possível andar a quantidade de metros
armazenada em distancia.
Robô Limpador 1
Objetivo: Utilizar funções de movimento.
Conhecimentos envolvidos: Nenhum
Enunciado: Você está desenvolvendo um robô que limpa o chão (como a imagem acima), o robô
possui cerdas limpadoras e um aspirador de pó, ele deve andar pela casa e recolher o máximo de
sujeira que encontrar. Como seu primeiro desafio nesse projeto ensine o robô a andar em ziguezague:
12
APOSTILA DE PROGRAMAÇÃO
ROBÔ F
Sensor de estacionamento 1
Objetivo: aprender o funcionamento de um LED
Conhecimentos envolvidos: corrente e tensão em um LED
Enunciado: adicione um LED vermelho e um verde no robô. Deixe o LED vermelho aceso
enquanto o robô não estiver na posição final desejada. Quando o robô alcançar a posição final,
apagar o LED vermelho e acender o LED verde.
Sensor de estacionamento 2
Objetivo: aprender o funcionamento de um LED
Conhecimentos envolvidos: corrente e tensão em um LED
Enunciado: Faça um indicador de distância usando três LEDs que varie de 10 em 10 centímetros.
Coloque três LEDs enfileirados. Quando o robô estiver a uma distância de 40 cm ou mais,
acender um LED. Acender mais um LED a cada 10 cm aproximados do obstáculo.



3 LEDs: de 20 a 29 cm
2 LEDs: de 30 a 39 cm
1 LED: 40 cm ou mais
Saia da M inha Frente
Objetivo: aprender laços infinitos, tomada de decisão, leitura de sensores e laços de repetição.
Conhecimentos envolvidos: lógica.
Enunciado: O Robô F deve executar os seguintes procedimentos:
a) se o leitor de distância não detectou nenhum objeto, o robô anda em frente;
b) se o leitor de distância detectou algo a menos de 40 cm, então o robô deve virar 90 graus e
recomeçar o algoritmo do procedimento a).
Comportamento: Este algoritmo deve fazer com que o robô ande pelo ambiente desviando de
todos os obstáculos encontrados por ele.
13
ROBÔ F
APOSTILA DE PROGRAMAÇÃO
Problemas Intermediários
14
APOSTILA DE PROGRAMAÇÃO
ROBÔ F
Codigo Alienígena
Objetivo: Utilizar arrays e sensor de refletância.
Conhecimentos envolvidos: Váriaveis, arrays, condicionais aninhadas, laços de repetição
Enunciado:
Durante a expedição arqueológica em marte outro artefato foi encontrado: Uma placa branca com
traços pretos. A placa possui uma mensagem oculta, você descobriu que cada letra do código é
formada por linhas em alturas diferentes e que as cinco primeiras letras são relacionadas ao nosso
alfabeto pela relação:
a: 1 linha
b: 2 linha
r: 3 linha
c: 4 linha
d: 5 linha
Ensine o robô a ler a mensagem usando o sensor de refletância.
15
ROBÔ F
APOSTILA DE PROGRAMAÇÃO
Codigo Alienígena 2
Objetivo: Utilizar sensor de distância.
Conhecimentos envolvidos: Variáveis, condicionais aninhados, laços de repetição, sensores
Enunciado:
Você está em uma expedição arqueológica em marte no ano de 2044 e seu grupo acaba de
encontrar vestígios de uma civilização alienígena pré histórica. Um dos artefatos parece uma
mensagem codificada com o formato de uma engrenagem. Estudos foram feitos e descobriu-se
que cada seção ("dente da engrenagem") representa uma letra, onde a distancia do centro até a
borda as tornam diferentes, e que o artefato deve der lido em sentido horário. Decodifique a
mensagem por meio do código das regras abaixo:
o : >130
i : > 120
r : > 100
m : > 90
c : > 70
s : > 60
p : > 40
(as distancias estão em cm)
16
APOSTILA DE PROGRAMAÇÃO
ROBÔ F
Ajudante de Bombeiro
Objetivo: Movimentos complexos
Conhecimentos envolvidos: Variáveis (flags), laços de repetição
Enunciado:
No caso de incendios é comum que as pessoas tenham pouca visibilidade por causa da fumaça e
se percam em locais que não conheçam. Seu robô possui uma lanterna e vai ajudar as pessoas a
saírem do prédio com segurança, mas * **antes deve encontra-las** *. Ensine o robô a chegar ao
fim do caminho proposto onde estão as vitimas, lembrando que ele não conhece o terreno.
17
ROBÔ F
APOSTILA DE PROGRAMAÇÃO
Jogos Olímpicos
Conhecimentos: Geometria básica, estruturas de repetição, estruturas condicionais.
Enunciado: Você foi selecionado para as Olimpíadas Mundiais de Róbotica na modalidade
"dança sincronizada". Você deverá programar o seu robô de forma que ele execute a tarefa
pedida e assim deixar o seu país orgulhoso com o ouro.
A dança sincronizada consiste basicamente em receber um número N, que deverá ser
representado numa variável no seu programa, e mandar o robô andar descrevendo um polígono
regular (que tem todos os lados iguais) com o número de lados igual a N. O seu robô não poderá
passar da velocidade 80 pois senão ele será desclassificado. O seu robô deve andar dois
segundos em cada lado do polígono. Caso N seja melhor que dois, seu programa não deverá
fazer nada.
A sua equipe precisa de você para ganhar o ouro!
Triângulo Equilátero
Objetivo: comandos avançar, recuar e ler bússola. Verificar se o aluno aprendeu a realizar uma
sequência de comandos simples.
Conhecimentos envolvidos: geometria
Enunciado: Faça um programa que, ao receber um número inteiro a, faça o Robô F andar em um
triângulo equilátero imaginário de a centímetros de aresta. Recordar-se que um triângulo
equilátero possui ângulos internos de 60o. O robô começa a percorrer o triângulo imaginário na
direção para a qual estiver apontando.
Provocação: o aluno pode, ao invés de repetir o código três vezes, criar um laço condicional para
fazer as tarefas de girar 60º e percorrer a distância a.
18
APOSTILA DE PROGRAMAÇÃO
ROBÔ F
Desenhar Polígonos Regulares
Objetivo: Aprender os comandos básicos do robô, o uso de funções e lógica de programação.
Conhecimentos envolvidos: ângulos (matemática), geometria
Enunciado: adapte o código usado para desenhar um triângulo equilátero para desenhar um
quadrado. Depois use o código recém-criado para desenhar um pentágono. Depois um hexágono,
ou seja, faça uma função que receba o número de lados que o polígono regular deve ter e
desenhe a figura.
Virando com ajuda
Objetivo: aprender funções, condicionais simples, loop, recursão simples.
Conhecimentos envolvidos: ângulos retos (matemática)
Enunciado: Faça uma função virando que recebe como argumento um inteiro virar. Se virar ==
1, o robô vira 90 graus a direita, se virar == 2, o robô anda 10 cm, vira 90 graus a direita, anda 10
cm, vira 90 graus a direita, e depois anda mais 10 cm e vira 90 graus a direita.
Provocação: chame a própria função com virar == 1 dentro de um loop para fazer as conversões
à direita no segundo caso.
Barreiras Ortogonais
Objetivo: aprender laços condicionais e laços de número fixo
Conhecimentos envolvidos: ângulos retos (matemática)
Enunciado: o RobôF deve sair da origem (ponto circular), avançar em direção às barreiras (se
aproximar o máximo possível - 20 cm) na sequência indicada na figura e parar a frente da última
das barreiras.
Provocação: caso o programa que fez tenha mais que 8 linhas, tente reduzi-la para o mínimo que
conseguir.
Aplicação de eletrônica
Implementar a mesma aplicação eletrônica do problema “Saia da minha frente”
19
ROBÔ F
APOSTILA DE PROGRAMAÇÃO
Acelerando e Reduzindo
Objetivo: aprender laços de repetição, contadores, comando avançar e recuar.
Conhecimentos envolvidos: lógica
Enunciado: Faça um programa no qual dado um i, que inicialmente é zero e vai até 255, acelere
o robô usando este i como velocidade. Para cada i o robô deve andar por 10 ms. Depois de
alcançar 255 o i deve decrescer novamente até zero fazendo com que o robô desacelere. Repita a
operação, mas desta vez ao invés de avançar o robô deve recuar.
Comportamento: Este algoritmo deve fazer com que o robô acelere gradualmente até o seu
máximo e depois desacelere até zero. Depois o robô acelerará na marcha ré e depois
desacelerará até zero.
Provocação: O problema é resolvido com no máximo 4 Whiles.
Barulho do M otor
Objetivo: trabalhar com variações de frequência
Conhecimentos envolvidos: funcionamento de buzzer, sinais periódicos.
Enunciado: Utilize um buzzer para simular o “som do motor” do robô, variando a frequência do
som emitido de acordo com a velocidade do motor, quando o motor estiver de vagar o som deve
ser grave e conforme acelera o som torna-se mais agudo.
20
APOSTILA DE PROGRAMAÇÃO
ROBÔ F
Race Day
Objetivo: aprender laços condicionais infinitos, operadores lógicos, resolução de problemas
práticos.
Conhecimentos envolvidos: conjuntos (matemática), lógica booleana.
Enunciado: o Robô F está treinando para uma competição de seguidores de linha. A competição
é composta por três etapas, com três circuitos diferentes. O objetivo principal é dar duas voltas
completas no circuito sem perder a linha. A primeira etapa é um circuito é um circuito oval simples.
Na segunda etapa, o circuito contém uma pista interna em cada reta, similar a um pit-stop, e o
robô deve passar pelo menos uma vez por uma delas. Na terceira, e última, etapa são
adicionadas duas linhas no centro do circuito original, formando um oito “deitado”. Nessa etapa o
robô deve passar pelo menos uma vez pelas linhas centrais e deve seguir reto no cruzamento.
1
2
3
21
ROBÔ F
APOSTILA DE PROGRAMAÇÃO
Robô Limpador 2
Objetivo: Utilizar bussola e movimento em conjunto
Conhecimentos envolvidos:Sensores e Movimento
Enunciado:
Seu novo desafio no desenvolvimento do robô limpador é fazer o robô conseguir desviar de
objetos, no caso, os pés das cadeiras embaixo de uma mesa. Os pés estão alinhados e o robô
deve fazer um movimento composto por semi-circulos ao redor dos mesmos, como mostrado
abaixo:
Ilustração:
___
___
.' '. .' '. .' '.
/
\ /
\ /
/ O \/ O \/
|
|
|
^
22
___
___
.' '. .'
\ /
\ /
O \/ O \/
|
|
...>
O
APOSTILA DE PROGRAMAÇÃO
ROBÔ F
Problemas Difíceis
23
ROBÔ F
APOSTILA DE PROGRAMAÇÃO
Desenho pela Trajetória
Objetivo: Aprender os comandos básicos do robô e o uso de funções
Conhecimentos envolvidos: ângulos (matemática)
Enunciado: Mova o robô fazendo que sua trajetória forme uma pétala de flor parecida com a da
figura abaixo
Provocação: Crie uma função com o código anterior e usando esta função faça o seguinte
desenho.
24
APOSTILA DE PROGRAMAÇÃO
ROBÔ F
Robô Seguidor
Objetivo: aprender laços condicionais, laços infinitos, tomada de decisão, leitura de sensores.
Conhecimentos envolvidos: lógica
Enunciado: O RobôF deve encontrar o objeto mais próximo no seu entorno e, ao encontrá-lo, se
posicionar de frente ao objeto ajustando sua distância para 30cm. Você deve dar uma margem de
erro de 2 cm, ou seja, um valor entre 28 e 32cm é aceitável. Tal margem de erro serve para
corrigir a imprecisão do sensor. Você deve verificar se, após parar, a distância é a desejada e,
caso contrário, calibrá-la. Após ter se posicionado, o objeto pode ser movido (apenas para frente e
para trás) e o RobôF deverá manter a mesma distância de 30 cm do objeto.
Provocação: faça o robô conhecer o ambiente ao redor e tomar decisões.
25
ROBÔ F
APOSTILA DE PROGRAMAÇÃO
Gato e Rato
Objetivo: aprender as dificuldades de iteração em tempo real, loops.
Conhecimentos envolvidos: operações com ângulos, busca.
Enunciado: esse problema consiste em uma perseguição entre dois robôs, o gato perseguindo o
rato. O rato é mais devagar que o gato, por isso está sempre mudando a sua trajetória para
despistar o gato. O gato, apesar de ser mais rápido, tem dificuldades em fazer curvas e é
facilmente despistado pelo rato. Por isso, a cada mudança de direção do rato ele tem que parar e
buscar em que direção ele foi. O seu papel é programar o gato.
Gato e Rato2
Objetivo: trabalhar com variações de luminosidade
Conhecimentos envolvidos: funcionamento de LDR, lógica condicional.
Enunciado: Utilize um LDR no robô seguidor (gato) para monitorar a luminosidade a que ele está
exposto. Quando o rato “entrar no buraco” (ambiente com baixa luminosidade) o gato deve parar
de segui-lo, caso o gato entre no buraco ele deve retornar para o lado de fora. Resumindo, o robô
perseguidor deve evitar ambientes com baixa luminosidade.
26
APOSTILA DE PROGRAMAÇÃO
ROBÔ F
Robô M otorista
Objetivo: aprender laços condicionais e laços de número fixo
Conhecimentos envolvidos: lógica e leis de trânsito
Enunciado: Imagine a figura a seguir como uma cidade, os quadrados verdes são as quadras
(casas). O robô faria o percurso desenhado pela linha amarela repetidamente, variando as
direções em que escolhe em cada cruzamento. Quando chegasse ao cruzamento central deve
parar por um instante na “faixa de pedestres” representada por 2 linhas pretas paralelas(cor preta
indica quando o robô deve parar) e só poderia andar novamente quando não detectasse nenhum
pedestre a sua frente(provavelmente algum objeto colocado na faixa).
Provocação: Esse problema poderia tornar-se mais desafiador ao introduzir mais robôs na
“cidade” fazendo o percurso em amarelo e seguindo as mesmas regras citadas anteriormente,
porém agora além de cuidar com os pedestres o robô deve dar a preferência nos cruzamentos ao
robô que vai virar a direita e manter uma distância mínima do robô que segue a sua frente.
Lógica utilizada
Este problema possivelmente envolve todos os sensores do robô e exige que seja dividida em
problemas menores mais fácies de resolver. Por exemplo: inicialmente faz-se o robô seguir a linha
amarela e parar nas linhas pretas utilizando os sensores de refletância e lógica condicional (IF),
separadamente cria-se uma lógica para fazer o robô parar caso algum objeto esteja a uma
distância mínima dele. Em seguida combinar esses dois procedimentos dentro de um laço de
repetição para que ele fique percorrendo a cidade. Futuramente se o robô for capaz de medir a
distância percorrida e juntando essa informação com a orientação da bússola é possível montar
um mapa na interface de programação com o percurso a ser seguido e predeterminar a rotina do
robô, este só a alteraria caso surgisse algum pedestre ou outro robô a sua frente.
27
ROBÔ F
APOSTILA DE PROGRAMAÇÃO
Robô Autônomo
Objetivo: trabalhar com variações de luminosidade
Conhecimentos envolvidos: funcionamento de LDR, lógica condicional, acionamento de LEDs
Enunciado: Equipe cada robô que trafega na cidade com um par de LEDs de alto brilho na parte
traseira (lanternas traseiras) e um LDR na parte dianteira, dessa forma o robô que seguir o
percurso atrás de outro deve manter uma distância em relação ao robô da frente baseado em
certo nível de luminosidade. Por exemplo: se a luminosidade detectada pelo LDR for muito alta
isso significa que o robô a sua frente está muito próximo e então é preciso reduzir a velocidade
para evitar uma batida.
28
APOSTILA DE PROGRAMAÇÃO
ROBÔ F
CONCEITOS BÁSICOS DE ELETRÔNICA
Tensão, M edida em volts [V]


Contínua: Diferença de potencial elétrico existente entre dois pontos, pode ser gerada por
diversos processos.
Alternada: Tensão em um condutor que varia no tempo de forma periódica. Utilizada para
transmissão de energia.
Corrente m edida em am peres [A]
Fluxo de carga elétrica em um condutor, Coulombs por segundo...
Potência, m edida em watts [W]
Taxa de dissipação ou consumo de energia em um dispositivo. Joules por segundo. Para corrente
contínua:
Lei de Ohm
Ao submeter um condutor a uma determinada tensão surge uma corrente diretamente
proporcional. A relação entra a tensão e corrente é dada por uma constante R (resistência elétrica
do material).
Leis de Kirchoff;
1. Lei dos nós: “A soma de todas as correntes que “entram” e “partem” de um nó é zero”.
2. Lei das malhas: “Ao percorrer uma malha e contabilizar todas as quedas de tensão a
tensão final deve ser zero.”
Divisor de tensão e corrente (associação de resistores)
Funcionam ento de resistor, LED, LDR, e buzzer
29
Download