Summary
This paper shows how an omnidirectional robot can learn to correct inaccuracies when driving, or even learn to use corrective motor commands when a motor fails, whether partially or completely. Driving inaccuracies are unavoidable, since not all wheels have the same grip on the surface, or not all motors can provide exactly the same power. When a robot starts driving, the real system response differs from the ideal behavior assumed by the control software. Also, malfunctioning motors are a fact of life that we have to take into account. Our approach is to let the control software learn how the robot reacts to instructions sent from the control computer. We use a neural network, or a linear model for learning the robot's response to the commands. The model can be used to predict deviations from the desired path, and take corrective action in advance, thus increasing the driving accuracy of the robot. The model can also be used to monitor the robot and assess if it is performing according to its learned response function. If it is not, the new response function of the malfunctioning robot can be learned and updated. We show, that even if a robot loses power from a motor, the system can re-learn to drive the robot in a straight path, even if the robot is a black-box and we are not aware of how the commands are applied internally.
Zusammenfassung
In diesem Artikel zeigen wir, wie ein vierrädriger holonomer Roboter Ungenauigkeiten beim Fahren korrigieren kann, indem die Regelungswerte für die Motoren geeignet modifiziert werden. Diese Verfahren arbeiten auch im Falle eines Motordefekts. Die Steuerung wird automatisch so angepasst, dass mit nur drei Motoren gefahren werden kann. Eine unpräzise Steuerung ist im Allgemeinen nicht zu vermeiden, denn die Räder können eine unterschiedliche Haftreibung mit dem Untergrund haben, Motoren haben durch Fertigungstoleranzen und Verschleiss unterschiedliche Leistungsmerkmale. Außerdem sind die Modelle zur Steuerung der Motoren oft so einfach gehalten, dass sie nicht exakt die physikalischen Eigenschaften widerspiegeln. Manchmal fallen Motoren aus, dies sollte ebenfalls berücksichtigt werden. Bei unserem Ansatz lernt die Steuerungssoftware, wie der Roboter auf unterschiedliche Befehle reagiert und passt die Befehle dementsprechend an, bevor sie an den Roboter übergeben werden. Dafür benutzen wir ein neuronales Netz oder ein lineares Modell, um die Bewegung des Roboters vorherzusagen. Die Abweichungen der tatsächlichen Bewegung bezüglich der gewünschten Bewegung kann dann benutzt werden, um geeignetere Befehle zu wählen. Dies verbessert die Fahrweise des Roboters erheblich. Das gelernte Modell kann außerdem dazu genutzt werden, um den Zustand des Roboters fortlaufend zu testen. Falls eine zu große Abweichung zur Wirklichkeit besteht, kann ein anderes Modell gewählt werden oder ein neues gelernt werden. Wenn ein Motor eines Roboters an Leistung verliert, kann für diesen Roboter eine spezielle Vorhersage trainiert werden, damit der Roboter wieder akkurat fährt. Gerade wenn wenig Informationen über den Roboter zur Verfügung stehen oder der Roboter aus anderen Gründen nicht modifiziert werden kann, ist eine optimale Steuerung möglich.
© Oldenbourg Verlag