====== Control de motores con Arduino ======
**Un motor de corriente continua** (denominado también motor DC por las iniciales en inglés direct current) es una máquina que convierte energía eléctrica en mecánica, provocando un movimiento rotatorio, gracias a la acción de un campo magnético.
{{:guias:guias:drivers:img_0128.gif}}
Un motor de corriente continua se compone principalmente de dos partes: El estátor (carcasa exterior) crea un campo magnético. El rotor es la parte interior que gira, alimentado con corriente directa a través de delgas, que están en contacto alternante con escobillas fija.
Adaptado de [[https://bricolabs.cc/wiki/guias/control_de_motores|Wikipedia]]
===== Introducción =====
Esta página está dedicada al control de motores con Arduino. Específicamente motores de corriente contínua estándar. Existen algunos motores DC especiales como los motores paso a paso o sin escobillas (brushless en inglés) que no serán tratados aquí. Una buena parte de la información servirá para otras plataformas como Raspberry Pi, pero en general las librerías de programación y los esquemas estarán dedicados en exclusiva a Arduino.
Arduino tiene pines de entrada y de salida para comunicarse físicamente con su entorno. Los pines de salida pueden dar una pequeña cantidad de energía que sirve por ejemplo para encender un LED, pero no pueden alimentar a un motor. Para ello necesitamos un circuito que haga de intermediario. Este circuito, el controlador o driver de motores, tomará energía de otra fuente (una pila, batería o equivalente) y siguiendo las instrucciones de Arduino hará funcionar el motor.
{{:proyectos:redbot:redbot_5.jpg?400}}
Existen muchos drivers diferentes, pero para poder controlar bien un motor necesitamos dos características fundamentales:
* Que permitan invertir el sentido de giro del motor.
* Que permitan graduar la velocidad de giro del motor.
===== Drivers con Puentes H =====
El circuito básico que permite las dos funciones que dijimos es un puente H. Un motor DC cambia el sentido de giro cuado invertimos los polos positivo y negativo en sus bornes, y este circuito juega con una serie de interruptores para hacer ese cambio de polaridad. Podemos construir un puente H con cuatro interruptores, pero lo que usaremos es un [[https://es.m.wikipedia.org/wiki/Circuito_integrado|circuito integrado]] que tiene esos interruptores -o puertas- y las abrirá y cerrará siguiendo instrucciones del Arduino.
{{:proyectos:redbot:redbot_6.jpg?400}}
===== Señales PWM =====
Un motor DC está preparado para funcionar a una tensión que nos dará el fabricante. Si le damos una tensión menor girará más despacio, llegando en el extremo a pararse. Así regulamos la velocidad.
Arduino no puede (con excepciones) regular directamente los voltios que salen por un pin, pero puede hacer una pequeña 'trampa' que se llama PWM y que tiene como resultado una acción parecida a bajar la tensión. En la [[https://es.wikipedia.org/wiki/Modulaci%C3%B3n_por_ancho_de_pulsos|wikipedia]] puede verse una explicación de su funcionamiento, pero eso excede nuestro objetivo aquí. Lo importante y que nos interesa ahora es:
* Arduino puede generar señales PWM y así simular una tensión menor en voltios.
* Esta señal sirve para controlar motores a través de un puente H (¡¡¡con una señal 'verdadera' no se puede!!!).
* Los motores DC aceptan esta señal 'falsa' y podemos ajustar así la velocidad.
No todos los pines de Arduino pueden hacer esta función [[https://cdn.arduino.cc/reference/en/language/functions/analog-io/analogWrite/|PWM]]. En los diagramas de funcionamiento de cada modelo puede verse cuáles la tienen y cuáles no.
===== Librerías de programación =====
La programación de Arduino, igual que muchos lenguajes, permite la creación de nuevas instrucciones en forma de librerías.
Para utilizar un driver combinaremos salidas PWM con salidas digitales en las que las opciones son apagado (LOW) o apagado (HIGH). Cada driver tiene su tabla lógica para funcionar. Un ejemplo de código para mover un motor podría ser este:
analogWrite(9, 200);
digitalWrite(8, HIGH);
digitalWrite(7, LOW);
Sin embargo en lugar trabajar con los pines uno a uno, lo haremos indirectamente con librerías que transformarán ese código en algo más sencillo como 'robot.adelante'. Están pensadas para robots de dos ruedas (o cuatro, pero funcionando dos a dos) y darle instrucciones sencillas del tipo: avanza, retrocede, gira, frena.
nombredelrobot.forward(128,128,1000);
nombredelrobot.reverse(128,128,1000);
nombredelrobot.rotate(128,128,1000);
nombredelrobot.rotate(128,128,-1000);
nombredelrobot.brake(1000);
Hemos tratado de que las librerías tengan todas las mismas instrucciones con independencia del driver. Están alojadas en Github y también allí están los detalles para su uso. Como todo el material de Bricolabs son libres, puedes hacer con ellas lo que quieras.
===== Conexionado general =====
Un driver de motores, tal y como se puede ver en el diagrama de bloques de arriba, tendrá una serie de cables que van al Arduino (líneas de control), una entrada de energía conectada a una fuente como una batería o similar (línea de potencia) y las líneas que van finalmente a los motores.
{{:old:archivo:sapoconcho_fritzing_800.jpg?400}}
Algunas placas para robótica como la [[https://bricolabs.es/wiki/proyectos/raptor#raptor_pcb|PCB de Raptor]] tienen todo integrado: el Arduino, el driver y la alimentacion, y no tendremos que cablear nada. Esto puede ser cómodo pero también poco flexible.
===== Características generales de los drivers =====
Cuando elegimos un driver para nuestro proyecto -de robot móvil o lo que queramos- debemos tener en cuenta varias cosas:
* Cuántos motores vamos a controlar. Hay circuitos integrados -y placas- que pueden controlar 1, 2, 4, 6 o el número que se nos ocurra.
* Qué potencia (consumo en mA) necesitan esos motores. El driver deberá dara esa potencia o más.
* Qué tensión de alimentación (en V) tienen los motores.
Si la potencia es suficiente podremos conectar dos motores en paralelo a una misma salida de un driver. También podemos conectar varios drivers (iguales o no) pero necesitaremos un Arduino con muchas salidas (como el [[https://www.arduino.cc/en/Main/arduinoBoardMega2560|Mega 2560]]) o un circuito más especializado con otro tipo de comunicación.
Además tendremos en cuenta, en función de nuestro proyecto, el tamaño del driver. Para proyectos en miniatura como [[https://bricolabs.cc/wiki/proyectos/sapoconcho|Sapoconcho]] elegimos un driver muy pequeño.
===== Drivers más utilizados en proyectos DIY/DIWO =====
A continuación vamos a detallar una lista de drivers utilizados muy comunmente en proyectos de robótica casera, que conocemos de nuestros propios proyectos y para los que hemos creado librerías. La lista incluye:
* L9110
* L298N
* L297D
* TB6612FNG
* DRV8835
Si el motor una vez conectado no gira en el sentido deseado podemos cambiarlo muy fácilmente tanto en el hardware (intermabiando los cables del motor o del driver) como en el software (cambiando los pines en la programación).
==== L9110 ====
Este pequeño driver (y su gemelo HG7881) sirve para controlar motores de entre 2.5 y 12 voltios y con un consumo máximo de 800 mA. El integrado sirve para controlar sólo un motor, pero habitualmente se monta en placas con dos unidades para controlar dos motores. Es el que utilizamos para los motores de tipo N20 del Sapoconcho.
{{:guias:guias:drivers:controlador-motor-dual-dc_-l9110s-02.png?400}}
La típica placa doble tiene cuatro fichas para atornillar los cables de los motores y seis pines:
* Dos de control PWM para el motor A (A-IA, A-IB).
* Dos para el motor B (idem, B-IA, B-IB).
* Dos de alimentación desde las pilas o baterías (VCC, GND).
La conexión ya la hemos visto para un Arduino Pro Micro. Para un cualquier otro es similar, buscando siempre 4 pines PWM.
{{:old:archivo:sapoconcho_fritzing_800.jpg?500}}
La lógica de operación de la placa para cada uno de los motores es la siguiente (la tabla indica la señal en cada pin para el motor A).
^Pin^Giro adelante^Giro atrás^Parada|
|AI-A|pwm|0|0|
|AI-B|0|pwm|0|
Librerías de funcionaminto para L9110: en este enlace de [[https://github.com/felixstdp/sapoconcho|Github]] puedes descargar los archivos L9110.cpp y L9110.h. Deberás instalarlos en la carpeta de librerías de Arduino. En ese mismo enlace puedes descargar varios ejemplos de programas para tu robot y ver la sintaxis para llamar a las funciones de movimiento.
Una vez conectado el driver e instaladas las librerías deberás elegir un nombre para tu robot, y decirle en qué pines has conectado el driver (en el ejemplo los pines 3, 5, 6 y 9), y para eso comenzar tus programas de este modo:
#include
L9110 nombredelrobot(3,5,6,9); // A-IA, A-IB, B-IA, B-IB
A continuación ya puedes usar dentro de tu código las funciones de movimiento de la librería para moverte adelante, atras, girar y frenar.
==== L298N ====
Este driver es bastante mayor, tanto en tamaño como en potencia. Sirve para controlar motores de entre 6 y 50 voltios y con un consumo máximo de 2 A. Un mismo integrado sirve para controlar dos motores. Es el que usamos en el proyecto R2D2.
{{:guias:guias:drivers:l298-2-channel-motor-driver.jpg?400|}}
La típica placa tiene seis fichas para atornillar los cables de los motores y la alimentación (más una salida regulada de 5 v) y seis pines:
* Tres pines de control para el motor A, dos de ellos digitales (IN1, IN2) y uno PWM (ENA).
* Otro tres con el mismo esquema para el motor B (IN3, IN4, ENB).
La operación del driver tiene la siguiente lógica (la tabla indica la señal en cada pin para el motor A).
^Pin^Giro adelante^Giro atrás^Parada|
|IN1|LOW|HIGH|LOW|
|IN2|HIGH|LOW|LOW|
|ENA|pwm|pwm|0|
Esquema de conexión con Arduino UNO
{{:guias:guias:drivers:driver_298_arduino_uno.png?500|}}
Librerías de funcionaminto para L298N: en este enlace de [[https://github.com/felixstdp/drivers/tree/master/L298N|Github]] puedes descargar los archivos L298N.cpp y L298N.h. Deberás como siempre instalarlos en la carpeta de librerías de Arduino y empezar los programas con este código.
#include
L298N nombredelrobot(3,5,6,9,11,12); // IN1, IN2, IN3, IN4, ENA, ENB
Las funciones de movimiento son similares a las del L9110.
=== Shield Ardumoto ===
Una versión especial del driver L298N viene ya premontado en una shield de Sparkfun para Arduino que se llama [[https://www.sparkfun.com/products/14129|Ardumoto]]. Las línaes de control ya están cableadas en las pistas de la shield y una vez pinchada sobre un Arduino UNO sólo hay que conectar la alimentación y los motores.
{{:guias:guias:drivers:ardumoto_shield_hookup_guide-02.jpg?400|}}
La lógica de funcionamiento es la misma y las librerías de programación puedes encontrarlas [[https://github.com/felixstdp/drivers/tree/master/ardumoto|aquí]]. Ahora no hay que indicar los pines de conexión porque están fijados, por lo que la cabecera del programa es más simple.
#include
ardumoto nombredelrobot;
==== L293D ====
Este driver puede encontrarse montado en una placa independiente, en una shield (que puede controlar hasta 4 motores con dos integrados) o el integrado suelto, que es como lo vamos a ver aquí ahora. Puede controlar dos motores entre 4.5 y 25 voltios y con un consumo máximo de 600 mA.
El esquema de conexión es el siguiente:
{{:guias:guias:drivers:l293d.png?500|}}
La lógica de funcionamiento es la misma que en el L298N y por tanto la librería anterior es válida sin cambios. Tiene dos pines de dirección (digitales) y uno PWM (enable) por cada lado del integrado. Tambien dos entradas de alimentación, para los motores y para el propio integrado.
{{:guias:l293d_e.png?400|}}
=== Adafruit Motor Shield ===
Adafruit ha creado una shield con dos L293D para cuatro motores y puedes intentar crear tu propia librería fijándote en la estructura de las nuestras. Pero en realidad [[http://playground.arduino.cc/Main/AdafruitMotorShield|Adafruit]] ya hizo ese trabajo por ti.
{{:guias:guias:drivers:img_0127.png?400|}}
==== TB6612FNG ====
Este driver de Toshiba es pequeño pero matón. Puede controlar dos motores entre 4.5 y 13.5 voltios y con un consumo máximo de 1 A sontenido, admitiendo picos de 3.2 A por canal. Tiene además integrada una protección térmica para que no podamos quemarlo. Es el que usamos en el proyecto [[https://bricolabs.cc/wiki/proyectos/raptor|Raptor]] y allí hay instrucciones detalladas para conectarlo.
Utiliza una lógica similar a la de los L298D y L293D, pero con un séptimo pin de control que permite poner toda la placa en stand-by parando los dos motores a la vez. Las conexiones entre un Arduino UNO y el driver pueden verse aquí.
{{:guias:driver_6612_arduino_uno.png?500|}}
Una característica especial de este driver, como el L293D, es que tiene dos entradas de alimentación. Una para los motores, con la tensión de estos (4.5 a 13.5 voltios, etiquetada como VM) y otra para el propio driver, que puede tomarse del propio pin de 5 voltios de Arduino (VCC).
=== Redbot ===
El driver TB6612FNG también es el que integra la [[https://www.sparkfun.com/products/12097|placa Redbot]] de SparkFun, para la que creamos la librería [[https://github.com/felixstdp/mobilerobot.ino|RobotMovil]].
{{:proyectos:redbot:redbot_4.jpg?400|}}
La documentación de esta librería y un curso completo para hacer robots con esta placa está en el proyecto [[https://bricolabs.cc/wiki/proyectos/redbot|RedBot]].
==== DRV8835 ====
Este pequeño driver tiene un uso similar al L9110 con cuatro pines PWM y es capaz de dar 1.2A (puntas de 1.5A) a dos motores con tensiones hasta 11V. Tiene una entrada de alimentación para el propio driver que puede usar los 5v de Arduino.
Es el driver que integra la shield [[https://www.pololu.com/product/2510|Zumo]] de Pololu y para él hemos escrito la [[https://github.com/brico-labs/ArduinoDCmotorDrivers/tree/master/PololuSumo|librería]].
===== El Anillo Único =====
También hemos creado una [[https://github.com/brico-labs/ArduinoDCmotorDrivers/tree/master/mobilerobot|librería]] capaz de cotrolar cualquiera de estos drivers. Su código quizás sea algo más complejo para interpretar y modificar por no programadores, pero es muy práctica.
===== Equipo =====
* [[:user:felixstdp|Félix]]
* [[:user:salvari|Sergio]]
* Rafa Couto
* Manuel
===== Enlaces =====
* [[https://github.com/felixstdp/drivers|Repositorio de todo el proyecto en Github (Bricolabs)]]
* [[http://www.luisllamas.es/2016/08/arduino-motor-dc-tb6612fng/|Utilización del TB6612 (por Luis Llamas)]]