Odométrie

De testwiki
Version datée du 14 décembre 2023 à 08:42 par 45.84.53.58 (discussion) (Modèle direct)
(diff) ← Version précédente | Version actuelle (diff) | Version suivante → (diff)
Aller à la navigation Aller à la recherche
Odométrie d'un robot ; la distance parcourue par chacune des roues est identique, mais les positions finales sont différentes.

L’odométrie est une technique permettant d'estimer la position d'un véhicule en mouvement. Le terme vient du grec hodos (voyage) et metron (mesure)[1]. Cette mesure de bas niveau est présente sur quasiment tous les robots mobiles, grâce à des capteurs embarqués permettant de mesurer le déplacement du robot (de ses roues).

Principe

L'odométrie repose sur la mesure individuelle des déplacements des roues pour reconstituer le mouvement global du robot. En partant d'une position initiale connue et en intégrant les déplacements mesurés, on peut ainsi calculer à chaque instant la position courante du véhicule.

Modèle de déplacement

Pour calculer le mouvement global du robot à partir des mesures odométriques, il est nécessaire de disposer d'un modèle décrivant le déplacement du robot. L'exemple le plus courant en robotique est celui d'un robot dont le déplacement est contrôlé par le différentiel de vitesse entre les deux roues motrices.

On note :

  • dg et dd les déplacements respectifs des roues gauche et droite ;
  • vg et vd les vitesses respectives des roues gauches et droite ;
  • x,y,θ les coordonnées du robot (position et orientation dans le sens trigonométrique) ;
  • d le déplacement du robot ;
  • v la vitesse du robot ;
  • e l'écart entre les deux roues ;
  • xO, yO et R les coordonnées du centre O du cercle trajectoire et le rayon de celui-ci.

Modèle direct

Si on suppose que la trajectoire du robot est un cercle de rayon R parcouru à la vitesse angulaire dθdt (R>0). si le cercle est parcouru dans le sens trigonométrique, alors on a :

v=Rdθdt

Dans ce cas, les vitesses des roues sont données par :

{vg=(Re2)dθdt=(Re2)vRvd=(R+e2)dθdt=(R+e2)vR

On a donc construit un modèle direct du déplacement du robot (i.e. un modèle permettant de calculer les vitesses vg et vd des roues en fonction des paramètres de la trajectoire globale v et R.

Modèle inverse

L'odométrie va cependant nécessiter la connaissance du modèle inverse du déplacement du robot : connaissant les mesures odométriques, on cherche à retrouver les paramètres de la trajectoire. On peut supposer qu'à chaque instant et durant un intervalle de temps très court, la trajectoire du robot s'apparente à un cercle. Il suffit donc d'inverser le modèle direct précédemment construit pour un cercle, et on pourra reconstruire le rayon de courbure local de la trajectoire et la vitesse du robot.

L'inversion du système précédent donne :

{v=vg+vd2R=e2vd+vgvdvg

Calcul d'odométrie

On est maintenant en mesure de mettre à jour la position du robot en temps réel :

  • à chaque instant, les mesures odométriques donnent les déplacements des roues dg et dd depuis l'instant précédent ;
  • le modèle inverse (dans lequel l'intervalle de temps a été éliminé et les vitesses remplacées par des déplacements) permet de calculer le déplacement d du robot et le rayon de courbure instantané R de la trajectoire ;
  • on calcule le changement d'orientation dθ du robot et les coordonnées du centre O du cercle trajectoire :
dθ=dR
{xO=xRcos(θπ2)yO=yRsin(θπ2)
  • on met à jour la position du robot :
{θθ+dθxxO+Rcos(θπ2)yyO+Rsin(θπ2)

Liens externes

Notes et références

Modèle:Références

Modèle:Portail