Ir al contenido principal

FollowLine: controlador con dos PID

Con el fin de mejorar la entrada y salida de curva, los principales problemas que tení­a hasta el momento, he decidido incorporar un segundo PID. De este modo, tendrá un controlador para el estado de curva y otro para el estado de recta, con sus correspondientes constantes ajustadas. El gran desafío es como definir correctamente que es curva y que recta. Bien, tras darle algunas vueltas, creo que la opción más sencilla es comprobar si tres puntos tomados a distintas alturas de la lí­nea están alineados o no. En caso de que no lo estén, asumiré que el robot se encuentra en una curva o cualquier otro estado que no sea un recta. La forma de calcular si los puntos están alineados es sencilla. Teniendo tres puntos A, B y C estos pertenecen a la misma línea si: distancia(A,B) + distancia(B,C) = distancia(A,C). Además, hay que añadir una pequeña tolerancia para que funcione correctamente.

Tras ajustar las constantes de cada controlador manualmente, mediante prueba y error, el robot se comporta muy bien en las dos situaciones, permitiendome subir la velocidad. Sin embargo las entradas y salidas de curva siguen siendo deficientes. Revisando el código, me he dado cuenta de que dentro de cada controlador tenía dos variables que conservaban su valor entre frames. Esto es correcto, el problema es que cuando el robot encuentra una nueva curva, por ejemplo, el valor de dichas variables no es el de por defecto (0), si no que tienen un valor que proviene de la curva anterior. Por suerte tiene fácil solución, con resetear las variables del controlador que no está en uso en cada iteración es suficiente.

Una vez arreglado ese detalle, el comportamiento mejora, pero todaví­a es muy brusco en algunas partes. Para suavizarlo he decidido incorporar un buffer de diez unidades donde almaceno el estado del robot (curva o recta) en cada iteración. De este modo puedo establecer la regla de que pase a usarse el controlador de recta sólo si anteriormente se han detectado al menos diez rectas. En cuanto en el buffer entre una curva el controlador seleccionado sería el de curva. 

Aunque parece algo sencillo, he notado una gran mejoría en el comportamiento al incorporarlo. Ahora mismo las entradas y salidas de curva son mucho más suaves. Por otra parte, al incluir dos controladores he suprimido las reglas de control que había introducido antes, ya que realmente no estaban aportando mucho. Tras las mejoras el código es mucho más limpio y claro, a la vez que el rendimiento del robot ha mejorado. He podido completar una vuelta en 1min40s aunque he rebajado un poco la velocidad para ganar más seguridad. Con la estrategia que he venido siguiendo creo que estoy cerca del límite y no creo que pueda conseguir mejorar mucho más mi tiempo. Posiblemente mediante otro camino se pueda, pero no se me ocurre como.




Comentarios

Entradas populares de este blog

Reconstruccion3D: emparejamiento de puntos y cálculo del punto 3D

Como se comentaba en la entrada anterior, una vez tenemos la línea epipolar calculada podemos buscar el punto homólogo correspondiente. Para ello es necesario establecer una métrica para comparar ambos puntos. Tomar simplemente los valores RGB de los puntos no parece la forma más fiable, puesto que puede ser que haya más de un punto similar. Lo ideal sería tomar una región o parche centrada en los puntos. De esta forma la comparación será mucho más fiable y discriminante a lo largo de la epipolar. Es necesario establecer una métrica para comparar ambos parches. Una de las más sencillas es el MSE (Mean Square Error), que promedia el resultado de restar los valores en escala de grises de cada uno de los elementos del parche. Existen otras métricas como comparar histogramas o la correlación, pero considero que es mejor comenzar con la más simple. Como se trata de una diferencia, hay que calcular el MSE entre todas las posibles combinaciones a lo largo de la epipolar. El punto...

FollowLine: primera aproximación

Para poner en práctica las ideas expuestas en la entrada anterior he realizado una primera aproximación al algoritmo de comportamiento. En el enunciado de la práctica se recomienda usar un controlador tipo PID para estimar el error, pero para este intento he decidido omitirlo. El objetivo es simplemente aprender a controlar el robot actuando en consecuencia al error cometido. He extraído tres puntos de control a diferentes alturas de la imagen referencia, con los que he dibujado la línea ideal de trayectoria en recta. En cada iteración calculo el punto medio del ancho de la línea y estimo la distancia con el punto de referencia, en principio solo para el punto a media altura. Según la magnitud del error he fijado una serie de reglas para establecer la velocidad de avance y de giro. Si el error es muy grande la velocidad de avance debe de ser pequeña y la de giro grande. Sin embargo, cuando el error es pequeño la velocidad de avance se puede aumentar al mismo tiempo que se disminuye la ...

Reconstruccion3D: Descripción y primeros pasos

En esta práctica se abordará el tema de la reconstrucción de puntos 3D a partir de dos cámaras calibradas. Para ello, gracias al entorno de Gazebo, contamos con un robot que incorpora un par estéreo calibrado del que se conoce su posición y separación. Al mundo de Grazebo se le han añadido una serie de objetos 3D de forma que las cámaras puedan captarlos para efectuar la reconstrucción. Así mismo, también tenemos a nuestra disposión un visor de puntos 3D a través del cual podremos ver el resultado. Al igual que en la práctica anterior, se parte de un script donde poder añadir código y una serie de librerías que facilitarán muchas operaciones. Para efectuar una reconstrucción es necesario conocer la posición que ocupa el punto 3D en las dos imágenes. Obviamente no se dispone de dicha información, por lo que hay que escoger un punto en una de las imágenes y buscar su homólogo en la otra. Es importante escoger bien los puntos, ya que cuanta más textura contengan más fácil será enc...