Cuadrículas de ocupación
Visión general
Las cuadrículas de ocupación se utilizan para representar un área de trabajo del robot como una cuadrícula discreta. La información sobre el entorno se puede recopilar con sensores en tiempo real o cargar a partir de conocimientos previos. Para detectar obstáculos en el entorno del robot, con frecuencia se usan telémetros láser, sensores de impacto, cámaras y sensores de profundidad.
Las cuadrículas de ocupación se utilizan en algoritmos robóticos como la planificación de rutas (consulte mobileRobotPRM
(Robotics System Toolbox) o plannerRRT
). Se utilizan en aplicaciones de mapeo para integrar información de sensores en un mapa discreto, en la planificación de rutas para encontrar rutas libres de colisiones y para localizar robots en un entorno conocido (consulte monteCarloLocalization
o matchScans
). Puede crear mapas con diferentes tamaños y resoluciones para adaptarlos a cada aplicación.
Para mapas de ocupación en 3-D, consulte occupancyMap3D
.
Para las cuadrículas de ocupación 2D, existen dos representaciones:
Cuadrícula de ocupación binaria (ver
binaryOccupancyMap
)Cuadrícula de probabilidad de ocupación (ver
occupancyMap
)
Una cuadrícula de ocupación binaria utiliza valores true
para representar el espacio de trabajo ocupado (obstáculos) y valores false
para representar el espacio de trabajo libre. Esta cuadrícula muestra dónde están los obstáculos y si un robot puede moverse por ese espacio. Utilice la cuadrícula de ocupación binaria si el tamaño de la memoria es un factor en su aplicación.
Una cuadrícula de ocupación de probabilidad utiliza valores de probabilidad para crear una representación de mapa más detallada. Esta representación es el método preferido para usar cuadrículas de ocupación. Normalmente, esta cuadrícula se conoce simplemente como cuadrícula de ocupación. Cada celda de la cuadrícula de ocupación tiene un valor que representa la probabilidad de ocupación de la celda. Los valores próximos a 1 representan una gran certeza de que la celda contiene un obstáculo. Los valores próximos a 0 representan la certeza de que la celda no está ocupada y está libre de obstáculos. Los valores probabilísticos pueden ofrecer una mayor fiabilidad de objetos y mejorar el rendimiento de ciertas aplicaciones con algoritmos.
Las cuadrículas de ocupación binarias y de probabilidad comparten varias propiedades y detalles de algoritmos. Las coordenadas de cuadrícula y del mundo real se aplican a ambos tipos de cuadrículas de ocupación. La función de inflación también se aplica a ambas cuadrículas, pero cada cuadrícula la implementa de forma diferente. Los efectos de la representación de logit y la saturación de probabilidad se aplican solo a las cuadrículas de ocupación de probabilidad.
Coordenadas del mundo real, de cuadrícula y locales
Cuando trabaje con cuadrículas de ocupación en MATLAB®, puede usar coordenadas mundiales, locales o de cuadrícula.
El marco de referencia absoluto en el que opera el robot se denomina marco del mundo real en la cuadrícula de ocupación. La mayoría de las operaciones se realizan en el marco mundial y es la selección predeterminada cuando se utilizan funciones MATLAB en esta toolbox. Las coordenadas del mundo real se utilizan como un marco de coordenadas absoluto con un origen fijo. Los puntos se pueden especificar con cualquier resolución. Sin embargo, todas las ubicaciones se convierten en ubicaciones de cuadrícula debido a los límites de almacenamiento de datos y de resolución del propio mapa.
El marco local hace referencia al marco egocéntrico de un vehículo que se desplaza por el mapa. Las propiedades GridOriginInLocal
y LocalOriginInWorld
definen el origen de la cuadrícula en coordenadas locales y la ubicación relativa del marco local en las coordenadas mundiales. Puede ajustar este marco local usando la función move
. Para ver un ejemplo de uso del marco local como mapa egocéntrico para emular un vehículo que se mueve y envía obstáculos locales, consulte Cree mapas de ocupación egocéntricos utilizando sensores de distancia.
Las coordenadas de cuadrícula definen la resolución real de la cuadrícula de ocupación y las ubicaciones finitas de los obstáculos. El origen de las coordenadas de la cuadrícula está en la esquina superior izquierda de la cuadrícula, y la primera ubicación tiene un índice de (1,1)
. Sin embargo, la propiedad GridLocationInWorld
de la cuadrícula de ocupación en MATLAB define la esquina inferior izquierda de la cuadrícula en coordenadas mundiales. Al crear un objeto de cuadrícula de ocupación, propiedades como XWorldLimits
y YWorldLimits
se definen mediante la entrada width
, height
y resolution
. Esta figura muestra una representación visual de estas propiedades y la relación entre las coordenadas del mundo real y de cuadrícula.
Inflación de coordenadas
Tanto la cuadrícula de ocupación binaria como la normal tienen la opción de inflar obstáculos. Esta inflación se utiliza para añadir un factor de seguridad en los obstáculos y crear zonas de seguridad entre el robot y el obstáculo en el entorno. La función inflate
de un objeto de cuadrícula de ocupación convierte el radius
especificado al número de celdas redondeadas hacia arriba del valor resolution*radius
. Cada algoritmo utiliza este valor de celda por separado para modificar los valores alrededor de los obstáculos.
Cuadrícula de ocupación binaria
La función inflate
toma cada celda ocupada y la infla directamente agregando espacio ocupado alrededor de cada punto. Este ejemplo básico de inflación ilustra cómo se usa el valor de radio.
Agrandar obstáculos en una cuadrícula de ocupación binaria
Este ejemplo muestra cómo crear el mapa, definir las ubicaciones de los obstáculos y agrandarlos en un radio de 1 m. Las gráficas adicionales de la figura ayudan a ilustrar la inflación y el desplazamiento debido a la conversión a ubicaciones de cuadrícula.
Cree una cuadrícula de ocupación binaria. Defina la ocupación de la posición [5,5].
map = binaryOccupancyMap(10,10,5); setOccupancy(map,[5 5], 1);
Agrande los espacios ocupados del mapa en 1 m.
inflate(map,1); show(map)
Represente la ubicación original y la posición de cuadrícula convertida, y trace el círculo original. Como puede ver en esta gráfica, el centro de la cuadrícula está en [4.9 4.9], habiéndose desplazado desde la ubicación [5 5]. A partir de ahí se traza un círculo de 1 m y las celdas que tocan este círculo se marcan como ocupadas. La figura se amplía al área relevante.
hold on theta = linspace(0,2*pi); x = 4.9+cos(theta); % x circle coordinates y = 4.9+sin(theta); % y circle coordinates plot(5,5,'*b','MarkerSize',10) % Original location plot(4.9,4.9,'xr','MarkerSize',10) % Grid location center plot(x,y,'-r','LineWidth',2); % Circle of radius 1m. axis([3.6 6 3.6 6]) ax = gca; ax.XTick = [3.6:0.2:6]; ax.YTick = [3.6:0.2:6]; grid on legend('Original Location','Grid Center','Inflation')
Como puede ver en la figura anterior, incluso las celdas que apenas se superponían con el radio de inflación se etiquetan como ocupadas.
Cuadrículas de ocupación
La función inflate
utiliza el radio de inflación para realizar inflación probabilística. La inflación probabilística actúa como un operador máximo local y encuentra los valores de probabilidad más altos para las celdas cercanas. La función inflate
utiliza esta definición para inflar los valores de probabilidad más altos en toda la cuadrícula. Esta inflación aumenta el tamaño de los lugares ocupados y crea una zona de amortiguamiento para que los robots sorteen los obstáculos. Este ejemplo muestra cómo funciona la inflación con un rango de valores de probabilidad.
Inflar obstáculos en una cuadrícula de ocupación
Este ejemplo muestra cómo el método de inflación realiza una inflación probabilística de los obstáculos para inflar su tamaño y crear una zona de amortiguamiento para áreas con una mayor probabilidad de obstáculos.
Cree un mapa vacío de 10 m x 10 m.
map = occupancyMap(10,10,10);
Actualizar la ocupación de ubicaciones mundiales con valores específicos en pvalues
.
x = [1.2; 2.3; 3.4; 4.5; 5.6]; y = [5.0; 4.0; 3.0; 2.0; 1.0]; pvalues = [0.2 0.4 0.6 0.8 1]; updateOccupancy(map,[x y],pvalues) figure show(map)
Inflar las áreas ocupadas en un radio determinado. Los valores de ocupación más grandes se escriben sobre valores más pequeños. Puede copiar su mapa de antemano para revertir cualquier cambio no deseado.
savedMap = copy(map); inflate(map,0.5) figure show(map)
Representación de probabilidades logarítmicas de valores de probabilidad
Cuando se utilizan cuadrículas de ocupación con valores de probabilidad, el objetivo es estimar la probabilidad de la ubicación de los obstáculos para su uso en aplicaciones de robótica en tiempo real. La clase occupancyMap
utiliza una representación de log-odds de los valores de probabilidad para cada celda. Cada valor de probabilidad se convierte en un valor logarítmico de probabilidades correspondiente para el almacenamiento interno. El valor se vuelve a convertir en probabilidad cuando se accede. Esta representación actualiza eficientemente los valores de probabilidad con la menor cantidad de operaciones. Por lo tanto, puede integrar rápidamente datos de sensores en el mapa.
La representación logarítmica de las probabilidades utiliza la siguiente ecuación:
Nota
Los valores de probabilidades logarítmicas se almacenan como valores int16
. Este tipo de datos limita la resolución de los valores de probabilidad a ±0,001 pero mejora enormemente el tamaño de la memoria y permite la creación de mapas más grandes.
Saturación de probabilidad
Al actualizar una cuadrícula de ocupación con observaciones utilizando la representación de probabilidades logarítmicas, los valores tienen un rango de –∞ a ∞. Este rango significa que si un robot observa una ubicación como una puerta cerrada varias veces, el valor de las probabilidades logarítmicas para esta ubicación se vuelve innecesariamente alto o el valor de probabilidad se satura. Si luego la puerta se abre, el robot necesita observar la puerta abierta muchas veces antes de que la probabilidad cambie de ocupada a libre. En entornos dinámicos, desea que el mapa reaccione a los cambios para realizar un seguimiento más preciso de los objetos dinámicos.
Para evitar esta saturación, actualice la propiedad ProbabilitySaturation
, que limita los valores de probabilidad mínimo y máximo permitidos al incorporar múltiples observaciones. Esta propiedad es un límite superior e inferior de los valores de probabilidades de registro y permite que el mapa se actualice rápidamente según los cambios en el entorno. Los valores mínimo y máximo predeterminados de los límites de saturación son [0.001 0.999]
. Para entornos dinámicos, los valores sugeridos son al menos [0.12 0.97]
. Considere modificar este rango si el mapa no se actualiza con la suficiente rapidez para realizar múltiples observaciones.
Consulte también
binaryOccupancyMap
| occupancyMap
| occupancyMap3D