fixNode
Descripción
Ejemplos
Optimizar gráfico de factores simples
Crea una gráfica de factores.
fg = factorGraph;
Defina dos estados de pose aproximados del robot.
rstate = [0 0 0; 1 1 pi/2];
Defina la medida de pose relativa entre dos nodos de la odometría como la diferencia de pose entre los estados con algo de ruido. La medida relativa debe estar en el marco de referencia del segundo nodo, por lo que debe rotar la diferencia de posición para estar en el marco de referencia del segundo nodo.
posediff = diff(rstate);
rotdiffso2 = so2(posediff(3),"theta");
transformedPos = transform(inv(rotdiffso2),posediff(1:2));
odomNoise = 0.1*rand;
measure = [transformedPos posediff(3)] + odomNoise;
Cree un factor de dos poses SE(2) con la medida relativa. Luego agregue el factor al gráfico de factores para crear dos nodos.
ids = generateNodeID(fg,1,"factorTwoPoseSE2");
f = factorTwoPoseSE2(ids,Measurement=measure);
addFactor(fg,f);
Obtenga el estado de ambos nodos de pose.
stateDefault = nodeState(fg,ids)
stateDefault = 2×3
0 0 0
0 0 0
Como estos nodos son nuevos, tienen valores de estado predeterminados. Idealmente, antes de optimizar, deberías asignar una estimación aproximada de la pose absoluta. Esto aumenta la posibilidad de que la función optimize
encuentre el mínimo global. De lo contrario , optimize
puede quedar atrapado en el mínimo local, produciendo una solución subóptima.
Mantenga el estado del primer nodo en el origen y establezca el estado del segundo nodo en una posición xy aproximada en [0.9 0.95]
y una rotación theta de pi/3
radianes. En aplicaciones prácticas, puede utilizar mediciones de sensores de su odometría para determinar el estado aproximado de cada nodo de pose.
nodeState(fg,ids(2),rstate(2,:))
ans = 1×3
1.0000 1.0000 1.5708
Antes de optimizar, guarde el estado del nodo para poder volver a optimizarlo según sea necesario.
statePriorOpt1 = nodeState(fg,ids);
Optimice los nodos y verifique los estados de los nodos.
optimize(fg); stateOpt1 = nodeState(fg,ids)
stateOpt1 = 2×3
-0.1038 0.8725 0.1512
1.1038 0.1275 1.8035
Tenga en cuenta que después de la optimización, el primer nodo no permaneció en el origen porque, aunque el gráfico tiene la estimación inicial del estado, no tiene ninguna restricción en la posición absoluta. El gráfico solo tiene la medida de pose relativa, que actúa como una restricción para la pose relativa entre los dos nodos. Entonces el gráfico intenta reducir el coste relacionado con la pose relativa, pero no con la pose absoluta. Para proporcionar más información al gráfico, puede corregir el estado de los nodos o agregar un factor de medición previo absoluto.
Restablezca los estados y luego arregle el primer nodo. Luego verifique que el primer nodo esté fijo.
nodeState(fg,ids,statePriorOpt1); fixNode(fg,ids(1)) isNodeFixed(fg,ids(1))
ans = logical
1
Vuelva a optimizar el gráfico de factores y obtenga los estados de los nodos.
optimize(fg)
ans = struct with fields:
InitialCost: 1.8470
FinalCost: 1.8470e-16
NumSuccessfulSteps: 2
NumUnsuccessfulSteps: 0
TotalTime: 8.2970e-05
TerminationType: 0
IsSolutionUsable: 1
OptimizedNodeIDs: 1
FixedNodeIDs: 0
stateOpt2 = nodeState(fg,ids)
stateOpt2 = 2×3
0 0 0
1.0815 -0.9185 1.6523
Tenga en cuenta que después de optimizar este tiempo, el estado del primer nodo permaneció en el origen.
Argumentos de entrada
graph
— Gráfico de factores que contiene nodos para arreglar
factorGraph
objeto
Gráfico de factores que contiene nodos para arreglar, especificado como un objeto factorGraph
.
nodeIDs
— ID de nodos para arreglar o liberar
N vector fila de elementos de números enteros no negativos
ID de los nodos que se van a fijar o liberar dentro del gráfico de factores, especificados como un vector fila de elementos N de enteros no negativos. N es el número total de nodos a reparar o liberar.
flag
— Nuevo estado de corrección del nodo
true
o 1
(predeterminado) | false
o 0
Nuevo estado de corrección del nodo, especificado como 1
(true
) o 0
(false
Si se especifica como true
, la función repara el nodo para que la función optimize
no cambie el estado del nodo. Si se especifica como false
, la función libera el nodo durante la optimización.
Capacidades ampliadas
Generación de código C/C++
Genere código C y C++ mediante MATLAB® Coder™.
Historial de versiones
Introducido en R2022aR2023a: Reparar o liberar varios nodos a la vez
fixNode
ahora admite reparar o liberar más de un nodo a la vez especificando nodeIDs
como vector de ID de nodo.
Comando de MATLAB
Ha hecho clic en un enlace que corresponde a este comando de MATLAB:
Ejecute el comando introduciéndolo en la ventana de comandos de MATLAB. Los navegadores web no admiten comandos de MATLAB.
Select a Web Site
Choose a web site to get translated content where available and see local events and offers. Based on your location, we recommend that you select: .
You can also select a web site from the following list:
How to Get Best Site Performance
Select the China site (in Chinese or English) for best site performance. Other MathWorks country sites are not optimized for visits from your location.
Americas
- América Latina (Español)
- Canada (English)
- United States (English)
Europe
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)