DE102019213676B3 - Robot control - Google Patents

Robot control Download PDF

Info

Publication number
DE102019213676B3
DE102019213676B3 DE102019213676.1A DE102019213676A DE102019213676B3 DE 102019213676 B3 DE102019213676 B3 DE 102019213676B3 DE 102019213676 A DE102019213676 A DE 102019213676A DE 102019213676 B3 DE102019213676 B3 DE 102019213676B3
Authority
DE
Germany
Prior art keywords
freedom
degrees
steps
maximum value
changes
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
DE102019213676.1A
Other languages
German (de)
Inventor
Manuel Kaspar
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
KUKA Deutschland GmbH
Original Assignee
KUKA Deutschland GmbH
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by KUKA Deutschland GmbH filed Critical KUKA Deutschland GmbH
Priority to DE102019213676.1A priority Critical patent/DE102019213676B3/en
Application granted granted Critical
Publication of DE102019213676B3 publication Critical patent/DE102019213676B3/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • BPERFORMING OPERATIONS; TRANSPORTING
    • B25HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
    • B25JMANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
    • B25J9/00Programme-controlled manipulators
    • B25J9/16Programme controls
    • B25J9/1602Programme controls characterised by the control system, structure, architecture
    • B25J9/161Hardware, e.g. neural networks, fuzzy logic, interfaces, processor

Landscapes

  • Engineering & Computer Science (AREA)
  • Automation & Control Theory (AREA)
  • Physics & Mathematics (AREA)
  • Artificial Intelligence (AREA)
  • Evolutionary Computation (AREA)
  • Fuzzy Systems (AREA)
  • Mathematical Physics (AREA)
  • Software Systems (AREA)
  • Robotics (AREA)
  • Mechanical Engineering (AREA)
  • Feedback Control In General (AREA)

Abstract

Die vorliegende Erfindung betrifft ein Verfahren zum Steuern eines Roboters (10), der eine Anzahl DoFvon steuerbaren Freiheitsgraden (x, y, z, α, β, γ) aufweist, wobei:- in einem oder mehreren ersten von mehreren Schritten (S10) Änderungen in den Freiheitsgraden einer ersten Teilmenge der Freiheitsgrade, die wenigstens einen und höchstens DoF-1 der Freiheitsgrade aufweist, jeweils auf einen Maximalwert begrenzt sind, wobei dieser Maximalwert jeweils höchstens 10% eines Maximalwerts einer Änderung in dem jeweiligen Freiheitsgrad in wenigstens einem anderen der mehreren Schritte beträgt; und- in einem oder mehreren zweiten der mehreren Schritte (S20) Änderungen in den Freiheitsgraden einer zweiten Teilmenge der Freiheitsgrade, die wenigstens einen und höchstens DoF-1 der Freiheitsgrade aufweist und von der ersten Teilmenge wenigstens teilweise verschieden ist, jeweils auf einen Maximalwert begrenzt sind, wobei dieser Maximalwert jeweils höchstens 10% eines Maximalwerts einer Änderung in dem jeweiligen Freiheitsgrad in wenigstens einem anderen der mehreren Schritte beträgt; wobei Änderungen in den Freiheitsgraden eines zur ersten Teilmenge komplementären ersten Rests der Freiheitsgrade in dem ersten Schritt bzw. den ersten Schritten und Änderungen in den Freiheitsgraden eines zur zweiten Teilmenge komplementären zweiten Rests der Freiheitsgrade in dem zweiten Schritt bzw. den zweiten Schritten von einem Regler (20) mittels maschinellen Lernens kommandiert werden.The present invention relates to a method for controlling a robot (10) which has a number DoF of controllable degrees of freedom (x, y, z, α, β, γ), wherein: changes in one or more first of several steps (S10) in the degrees of freedom of a first subset of the degrees of freedom, which has at least one and at most DoF-1 of the degrees of freedom, are each limited to a maximum value, this maximum value in each case at most 10% of a maximum value of a change in the respective degree of freedom in at least one other of the several steps is; and in one or more second of the plurality of steps (S20) changes in the degrees of freedom of a second subset of the degrees of freedom, which has at least one and at most DoF-1 of the degrees of freedom and is at least partially different from the first subset, are each limited to a maximum value , this maximum value being at most 10% of a maximum value of a change in the respective degree of freedom in at least one other of the plurality of steps; where changes in the degrees of freedom of a first remainder of the degrees of freedom complementary to the first subset in the first step or the first steps and changes in the degrees of freedom of a second remainder of the degrees of freedom complementary to the second subset in the second step or the second steps by a controller ( 20) can be commanded by means of machine learning.

Description

Die vorliegende Erfindung betrifft ein Verfahren und System zum Steuern eines Roboters sowie ein Computerprogrammprodukt zur Durchführung des Verfahrens.The present invention relates to a method and system for controlling a robot and a computer program product for carrying out the method.

Aus betriebsinterner Praxis sind Regler bekannt, die mittels maschinellen Lernens Änderungen in Freiheitsgraden von Roboter kommandieren und so den Roboter steuern.From in-house practice, controllers are known that use machine learning to command changes in the robot's degrees of freedom and thus control the robot.

Die DE 10 2019 001 207 A1 betrifft einen kollaborativen Roboter zum Bearbeiten eines Werkstücks, der ein Roboterwerkzeug zum Bearbeiten des Werkstücks und eine Modusanwahlvorrichtung zum Überführen des kollaborativen Roboters in einen Lernmodus und in einen Arbeitsmodus aufweist und dazu konfiguriert ist, im Lernmodus eine Arbeitsbewegung des Roboterwerkzeugs zum Bearbeiten des Werkstücks zu erlernen und im Arbeitsmodus die im Lernmodus erlernte Arbeitsbewegung durchzuführen, wobei der Lernmodus so konfiguriert ist, dass der kollaborative Roboter im Lernmodus die Arbeitsbewegung des Roboterwerkzeugs an dem zu bearbeitenden Werkstück erlernt.The DE 10 2019 001 207 A1 relates to a collaborative robot for processing a workpiece, which has a robot tool for processing the workpiece and a mode selection device for transferring the collaborative robot into a learning mode and in a working mode and is configured to learn a working movement of the robot tool for processing the workpiece in the learning mode and to perform the work movement learned in the learning mode in the work mode, the learning mode being configured so that the collaborative robot learns the work movement of the robot tool on the workpiece to be processed in the learning mode.

Die DE 10 2018 009 008 A1 betrifft eine Steuervorrichtung und eine Maschinenlernvorrichtung, die eine Steuerung zum Greifen eines Objekts mit geringer Reaktionskraft ermöglichen, wobei die in der Steuervorrichtung umfasste Maschinenlernvorrichtung eine Statusbeobachtungseinheit, die Greifobjektformdaten zu einer Form des Greifobjekts als Statusvariable beobachtet, die einen aktuellen Status einer Umgebung darstellt, eine Kennzeichnungsdatenerfassungseinheit, die Greifbreitendaten, die eine Breite der Hand des Roboters beim Greifen des Greifobjekts darstellen, als Kennzeichnungsdaten erfasst, und eine Lerneinheit umfasst, die ein Lernen unter Verwendung der Statusvariable und der Kennzeichnungsdaten so durchführt, dass die Greifobjektformdaten mit den Greifbreitendaten assoziiert werden.The DE 10 2018 009 008 A1 relates to a control device and a machine learning device that enable control for gripping an object with a low reaction force, the machine learning device included in the control device having a status observation unit that observes the shape of the gripped object shape data on a shape of the gripped object as a status variable representing a current status of an environment, an identification data acquisition unit that acquires grasping width data representing a width of the hand of the robot when grasping the grasped object as identification data, and comprises a learning unit that performs learning using the status variable and the identification data so that the grasped object shape data is associated with the grasping width data.

Die DE 10 2018 001 026 A1 betrifft ein mit einer Robotersteuerungsvorrichtung versehenes Robotersystem, wobei die Robotersteuerungsvorrichtung eine Betriebssteuerungseinheit und eine lernende Steuerungseinheit umfasst, die eine lernende Steuerung ausführt, in welcher ein Schwingungskorrekturbetrag zum Korrigieren einer an einem Steuerungszielabschnitt eines Roboters generierten Schwingung berechnet wird, und der Schwingungskorrekturbetrag bei einem nächsten Mal in dem Betriebsbefehl verwendet wird.The DE 10 2018 001 026 A1 relates to a robot system provided with a robot control device, the robot control device comprising an operation control unit and a learning control unit that executes learning control in which a vibration correction amount for correcting a vibration generated at a control target portion of a robot is calculated and the vibration correction amount the next time in the operation command is used.

Die DE 10 2017 011 361 A1 betrifft eine maschinelle Lernvorrichtung zum Lernen des Betriebs eines Roboters und eines Laserscanners, die eine Zustandsbeobachtungseinheit, die einen Zustand eines Spitzenendes des Roboters, an dem der Laserscanner montiert ist, und einen Zustand eines optischen Bauteils in dem Laserscanner als Zustandsdaten beobachtet, eine Einheit zum Erzielen von Bestimmungsdaten, die mindestens eines von einer Bearbeitungszeit des Roboters, an dem der Laserscanner montiert ist, einem Antriebsstrom, der den Roboter antreibt, einer Führungsbahn des Laserscanners, einer Durchgangszeit über eine verarbeitungsfähige Fläche, an welcher der Laserscanner 13 eine Verarbeitung ausführt, und einem Abstand zwischen dem Roboter und einem Teil, an dem der Laserscanner eine Verarbeitung ausführt, als Bestimmungsdaten empfängt, und eine Lerneinheit umfasst, die den Betrieb des Roboters und des Laserscanners basierend auf einer Ausgabe der Zustandsbeobachtungseinheit und einer Ausgabe der Einheit zum Erzielen von Bestimmungsdaten erlernt.The DE 10 2017 011 361 A1 relates to a machine learning device for learning the operation of a robot and a laser scanner that includes a state observation unit that observes a state of a tip end of the robot on which the laser scanner is mounted and a state of an optical component in the laser scanner as state data, a unit for achieving of determination data including at least one of a processing time of the robot on which the laser scanner is mounted, a drive current that drives the robot, a guide path of the laser scanner, a passage time over a processable surface on which the laser scanner 13 performs processing, and a A distance between the robot and a part on which the laser scanner performs processing receives as determination data, and comprises a learning unit that explains the operation of the robot and the laser scanner based on an output of the state observation unit and an output of the unit for obtaining v on determination data learned.

Die DE 10 2017 105 598 A1 betrifft ein Energieversorgungssystem für ein Elektrofahrzeug, aufweisend: eine Schiene, ein erstes Batterie-Pack, ein zweites Batterie-Pack und eine Antrieb-Vorrichtung.The DE 10 2017 105 598 A1 relates to a power supply system for an electric vehicle, comprising: a rail, a first battery pack, a second battery pack and a drive device.

Die DE 10 2016 012 227 A1 betrifft ein Verfahren zur automatischen Lagekorrektur eines Roboterarms eines Roboters mit folgenden Schritten: Anfahren einer Soll-Position durch einen Roboterarm eines Roboters; Bestimmen einer durch den Roboterarm tatsächlich erreichten Ist-Position; Lernen einer Lagekorrektur durch den Roboter anhand einer Abweichung der Ist-Position von der Soll-Position mittels eines Deeplearning-Algorithmus.The DE 10 2016 012 227 A1 relates to a method for automatically correcting the position of a robot arm of a robot with the following steps: approaching a target position by a robot arm of a robot; Determining an actual position actually reached by the robot arm; Learning of a position correction by the robot based on a deviation of the actual position from the target position using a deep learning algorithm.

Aufgabe der vorliegenden Erfindung ist es, die Steuerung eines Roboters zu verbessern.The object of the present invention is to improve the control of a robot.

Diese Aufgabe wird durch ein Verfahren mit den Merkmalen des Anspruchs 1 gelöst. Ansprüche 12, 13 stellen ein System bzw. Computerprogrammprodukt zur Durchführung eines hier beschriebenen Verfahrens unter Schutz. Die Unteransprüche betreffen vorteilhafte Weiterbildungen.This object is achieved by a method with the features of claim 1. Claims 12, 13 provide a system or computer program product for performing a method described here under protection. The subclaims relate to advantageous developments.

Nach einer Ausführung der vorliegenden Erfindung weist ein Roboter eine Anzahl DoF von, insbesondere an, steuerbaren Freiheitsgraden auf.According to one embodiment of the present invention, a robot has a number of DoF of, in particular, controllable degrees of freedom.

In einer Ausführung weist der Roboter einen Roboterarm mit wenigstens drei, insbesondere wenigstens sechs, in einer Ausführung wenigstens sieben, (Bewegungs)Achsen bzw. Gelenken, in einer Ausführung Drehachsen bzw. -gelenken, und Antriebe, insbesondere Elektromotoren, zum Verstellen dieser Gelenke auf.In one embodiment, the robot has a robot arm with at least three, in particular at least six, in one embodiment at least seven, (movement) axes or joints, in one embodiment rotary axes or joints, and drives, in particular electric motors, for adjusting these joints .

Durch wenigstens drei (Dreh)Gelenke kann in einer Ausführung ein Endeffektor des Roboterarms vorteilhaft in drei Raumrichtungen verschoben werden, durch wenigstens sechs (Dreh)Gelenke vorteilhaft zusätzlich beliebig orientiert werden, durch wenigstens sieben (Dreh)Gelenke vorteilhaft mit verschiedenen Roboterposen, insbesondere unter Vermeidung von Kollisionen und/oder mit jeweils optimierten Posen.In one embodiment, an end effector of the robot arm can advantageously be shifted in three spatial directions by at least three (rotary) joints, by at least six (rotary) joints advantageously also be oriented as desired, by at least seven (rotary) joints, advantageously with different robot poses, in particular while avoiding collisions and / or with each optimized poses.

Die vorliegende Erfindung ist, insbesondere aufgrund ihrer meist komplexen, nichtlinearen Kinematik besonders für solche Roboter geeignet, ohne jedoch hierauf beschränkt zu sein. So kann der Roboter in einer Ausführung zusätzlich oder alternativ eine mobile Basis, insbesondere ein Fahrwerk, aufweisen, in einer Ausführung ein fahrerloses Transportfahrzeug („Automated Guided Vehicle“, AGV) sein. Hierfür ist die vorliegende Erfindung, insbesondere aufgrund der komplexen, dynamischen Umgebung ebenfalls besonders geeignet.The present invention is particularly suitable for such robots, in particular because of its mostly complex, non-linear kinematics, but without being restricted thereto. Thus, in one embodiment, the robot can additionally or alternatively have a mobile base, in particular a chassis, and in one embodiment it can be a driverless transport vehicle (“Automated Guided Vehicle”, AGV). The present invention is also particularly suitable for this, in particular because of the complex, dynamic environment.

Nach einer Ausführung der vorliegenden Erfindung sind, insbesondere werden, zum Steuern des Roboters, insbesondere zur Durchführung einer vorgegebenen Aufgabe,

  • - in einem oder mehreren Schritten, die vorliegend ohne Beschränkung der Allgemeinheit als erste Schritte einer Mehrzahl von Schritten bezeichnet werden, (die bzw. eventuelle) Änderungen in den, insbesondere allen, Freiheitsgraden einer ersten, insbesondere vorgegebenen, (echten) Teil- bzw. Untermenge der DoF Freiheitsgrade, die wenigstens einen und höchstens (DoF-1) der Freiheitsgrade aufweist, jeweils auf einen Maximalwert begrenzt, wobei dieser Maximalwert (des bzw. in dem jeweiligen Freiheitsgrad(s)) jeweils (betragsmäßig) höchstens 10%, insbesondere höchstens 1%, in einer Ausführung höchstens 0,1%, eines, insbesondere kommandierten oder möglichen bzw. zulässigen, Maximalwerts einer Änderung in d(ies)em jeweiligen Freiheitsgrad in wenigstens einem anderen der Schritte der Mehrzahl von Schritten beträgt, und
  • - in einem oder mehreren Schritten der Mehrzahl von Schritten, die vorliegend ohne Beschränkung der Allgemeinheit als zweite Schritte bezeichnet werden, (die bzw. eventuelle) Änderungen in den, insbesondere allen, Freiheitsgraden einer zweiten, insbesondere vorgegebenen, (echten) Teil- bzw. Untermenge der DoF Freiheitsgrade, die wenigstens einen und höchstens (DoF-1) der Freiheitsgrade aufweist und von der ersten Teilmenge wenigstens teilweise verschieden ist, jeweils auf einen Maximalwert begrenzt, wobei dieser Maximalwert (des bzw. in dem jeweiligen Freiheitsgrad(s)) jeweils (betragsmäßig) höchstens 10%, insbesondere höchstens 1%, in einer Ausführung höchstens 0,1%, eines, insbesondere kommandierten oder möglichen bzw. zulässigen, Maximalwerts einer Änderung in d(ies)em jeweiligen Freiheitsgrad in wenigstens einem anderen der Schritte der Mehrzahl von Schritten beträgt,
wobei
  • - (die bzw. eventuelle) Änderungen in den Freiheitsgraden eines zur ersten Teilmenge komplementären ersten Rests der Freiheitsgrade und in einer Ausführung (die bzw. eventuelle) auf den jeweiligen Maximalwert begrenzten Änderungen in den Freiheitsgraden der ersten Teilmenge in dem bzw. den ersten Schritt(en) und
  • - (die bzw. eventuelle) Änderungen in den Freiheitsgraden eines zur zweiten Teilmenge komplementären zweiten Rests der Freiheitsgrade und in einer Ausführung (die bzw. eventuelle) auf den jeweiligen Maximalwert begrenzten Änderungen in den Freiheitsgraden der zweiten Teilmenge in dem bzw. den zweiten Schritt(en),
von einem Regler mittels maschinellen Lernens kommandiert werden.According to one embodiment of the present invention, in order to control the robot, in particular to carry out a given task,
  • - in one or more steps, which in the present case are referred to as the first steps of a plurality of steps without loss of generality, (the or possible) changes in the, in particular all, degrees of freedom of a first, in particular predetermined, (real) partial or Subset of the DoF degrees of freedom, which has at least one and at most (DoF-1) of the degrees of freedom, each limited to a maximum value, this maximum value (of or in the respective degree of freedom (s)) in each case (in terms of amount) at most 10%, in particular at most 1%, in one embodiment at most 0.1%, of a, in particular commanded or possible or permissible, maximum value of a change in the respective degree of freedom in at least one other of the steps of the plurality of steps, and
  • - in one or more steps of the plurality of steps, which in the present case are referred to as second steps without loss of generality, (the or possible) changes in the, in particular all, degrees of freedom of a second, in particular predetermined, (real) partial or Subset of the DoF degrees of freedom, which has at least one and at most (DoF-1) of the degrees of freedom and is at least partially different from the first subset, each limited to a maximum value, this maximum value (of or in the respective degree of freedom (s)) (in terms of amount) no more than 10%, in particular no more than 1%, in one embodiment no more than 0.1%, a, in particular commanded or possible or permissible, maximum value of a change in d (ies) em respective degree of freedom in at least one other of the steps of the plurality of steps,
in which
  • - (the or possible) changes in the degrees of freedom of a first remainder of the degrees of freedom which are complementary to the first subset and in one embodiment (the or possible) changes in the degrees of freedom of the first subset in the first step (s) limited to the respective maximum value ( en) and
  • - (the or possible) changes in the degrees of freedom of a second remainder of the degrees of freedom, which is complementary to the second subset, and in one embodiment (the or possible) changes in the degrees of freedom of the second subset in the second step or steps limited to the respective maximum value ( en),
can be commanded by a controller using machine learning.

In einer Ausführung sind, insbesondere werden,

  • - in einem oder mehreren Schritten der Mehrzahl von Schritten, die vorliegend ohne Beschränkung der Allgemeinheit als dritte Schritte bezeichnet werden, (die bzw. eventuelle) Änderungen in den, insbesondere allen, Freiheitsgraden einer dritten, insbesondere vorgegebenen, (echten) Teil- bzw. Untermenge der DoF Freiheitsgrade, die wenigstens einen und höchstens (DoF-1) der Freiheitsgrade aufweist und von der ersten und zweiten Teilmenge wenigstens teilweise verschieden ist, jeweils auf einen Maximalwert begrenzt, wobei dieser Maximalwert (des bzw. in dem jeweiligen Freiheitsgrad(s)) jeweils (betragsmäßig) höchstens 10%, insbesondere höchstens 1%, in einer Ausführung höchstens 0,1%, eines, insbesondere kommandierten oder möglichen bzw. zulässigen, Maximalwerts einer Änderung in d(ies)em jeweiligen Freiheitsgrad in wenigstens einem anderen der Schritte der Mehrzahl von Schritten beträgt, wobei (die bzw. eventuelle) Änderungen in den Freiheitsgraden eines zur dritten Teilmenge komplementären dritten Rests der Freiheitsgrade und in einer Ausführung (die bzw. eventuelle) auf den jeweiligen Maximalwert begrenzten Änderungen in den Freiheitsgraden der dritten Teilmenge in dem bzw. den dritten Schritt(en) von dem Regler mittels maschinellen Lernens kommandiert werden.
In one embodiment are, in particular,
  • - in one or more steps of the plurality of steps, which in the present case are referred to as third steps without loss of generality, (the or possible) changes in the, in particular all, degrees of freedom of a third, in particular predetermined, (real) partial or Subset of the DoF degrees of freedom, which has at least one and at most (DoF-1) of the degrees of freedom and is at least partially different from the first and second subset, each limited to a maximum value, this maximum value (of or in the respective degree of freedom (s)) ) in each case (in terms of amount) a maximum of 10%, in particular a maximum of 1%, in one embodiment a maximum of 0.1%, a, in particular commanded or possible or permissible, maximum value of a change in d (ies) em respective degree of freedom in at least one other of the steps of the plurality of steps, with (the or possible) changes in the degrees of freedom of a complementary to the third subset n third remainder of the degrees of freedom and in one embodiment (the or possible) changes in the degrees of freedom of the third subset limited to the respective maximum value in the third step (s) are commanded by the controller by means of machine learning.

Weist der Roboter beispielsweise DoF = 6 Freiheitsgrade {x, y, z, α, β, γ} auf, so kann eine erste Teilmenge {α, β, γ}, der hierzu komplementäre erste Rest entsprechend {x, y, z} sein, eine zweite Teilmenge {x, y, z, α, β}, der hierzu komplementäre zweite Rest entsprechend {γ}, und eine dritte Teilmenge {x, y, z, γ}, der hierzu komplementäre dritte Rest entsprechend {α, β}. For example, if the robot has DoF = 6 degrees of freedom {x, y, z, α, β, γ}, then a first subset can be {α, β, γ}, the first remainder complementary to this can be {x, y, z} , a second subset {x, y, z, α, β}, the complementary second residue corresponding to {γ}, and a third subset {x, y, z, γ}, the complementary third residue corresponding to {α, β }.

Dann sind bzw. werden in einem oder mehreren ersten Schritt(en)

  • - Änderungen im Freiheitsgrad α auf einen Maximalwert αmax begrenzt, der (betragsmäßig) höchstens 10%, insbesondere höchstens 1%, in einer Ausführung höchstens 0,1%, eines, insbesondere kommandierten oder möglichen bzw. zulässigen, Maximalwerts einer Änderung in diesem Freiheitsgrad α in einem oder mehreren dritten Schritt(en) beträgt;
  • - Änderungen im Freiheitsgrad β auf einen Maximalwert βmax begrenzt, der (betragsmäßig) höchstens 10%, insbesondere höchstens 1%, in einer Ausführung höchstens 0,1%, eines, insbesondere kommandierten oder möglichen bzw. zulässigen, Maximalwerts einer Änderung in diesem Freiheitsgrad β in dem bzw. den dritten Schritt(en) beträgt; und
  • - Änderungen im Freiheitsgrad γ auf einen Maximalwert γmax begrenzt, der (betragsmäßig) höchstens 10%, insbesondere höchstens 1%, in einer Ausführung höchstens 0,1%, eines, insbesondere kommandierten oder möglichen bzw. zulässigen, Maximalwerts einer Änderung in diesem Freiheitsgrad γ in einem oder mehreren zweiten Schritt(en) beträgt; beispielsweise also Änderungen in allen rotatorischen Freiheitsgraden auf einen (verglichen mit den zweiten bzw. dritten Schritten) niedrige(re)n Maximalwert begrenzt, in dem bzw. den zweiten Schritt(en)
  • - Änderungen im Freiheitsgrad x auf einen Maximalwert xmax begrenzt, der (betragsmäßig) höchstens 10%, insbesondere höchstens 1%, in einer Ausführung höchstens 0,1%, eines, insbesondere kommandierten oder möglichen bzw. zulässigen, Maximalwerts einer Änderung in diesem Freiheitsgrad x in dem bzw. den ersten Schritt(en) beträgt;
  • - Änderungen im Freiheitsgrad y auf einen Maximalwert ymax begrenzt, der (betragsmäßig) höchstens 10%, insbesondere höchstens 1%, in einer Ausführung höchstens 0,1%, eines, insbesondere kommandierten oder möglichen bzw. zulässigen, Maximalwerts einer Änderung in diesem Freiheitsgrad y in dem bzw. den ersten Schritt(en) beträgt;
  • - Änderungen im Freiheitsgrad z auf einen Maximalwert zmax begrenzt, der (betragsmäßig) höchstens 10%, insbesondere höchstens 1%, in einer Ausführung höchstens 0,1%, eines, insbesondere kommandierten oder möglichen bzw. zulässigen, Maximalwerts einer Änderung in diesem Freiheitsgrad z in dem bzw. den ersten Schritt(en) beträgt;
  • - Änderungen im Freiheitsgrad α auf einen Maximalwert αmax begrenzt, der (betragsmäßig) höchstens 10%, insbesondere höchstens 1%, in einer Ausführung höchstens 0,1%, eines, insbesondere kommandierten oder möglichen bzw. zulässigen, Maximalwerts einer Änderung in diesem Freiheitsgrad α in dem bzw. den dritten Schritt(en) beträgt; und
  • - Änderungen im Freiheitsgrad β auf einen Maximalwert βmax begrenzt, der (betragsmäßig) höchstens 10%, insbesondere höchstens 1%, in einer Ausführung höchstens 0,1%, eines, insbesondere kommandierten oder möglichen bzw. zulässigen, Maximalwerts einer Änderung in diesem Freiheitsgrad β in dem bzw. den dritten Schritt(en) beträgt; beispielsweise also Änderungen in allen translatorischen und zwei rotatorischen Freiheitsgraden auf einen (verglichen mit den ersten bzw. dritten Schritten) niedrige(re)n Maximalwert begrenzt, und in dem bzw. den dritten Schritt(en)
  • - Änderungen im Freiheitsgrad x auf einen Maximalwert xmax begrenzt, der (betragsmäßig) höchstens 10%, insbesondere höchstens 1%, in einer Ausführung höchstens 0,1%, eines, insbesondere kommandierten oder möglichen bzw. zulässigen, Maximalwerts einer Änderung in diesem Freiheitsgrad x in dem bzw. den ersten Schritt(en) beträgt;
  • - Änderungen im Freiheitsgrad y auf einen Maximalwert ymax begrenzt, der (betragsmäßig) höchstens 10%, insbesondere höchstens 1%, in einer Ausführung höchstens 0,1%, eines, insbesondere kommandierten oder möglichen bzw. zulässigen, Maximalwerts einer Änderung in diesem Freiheitsgrad y in dem bzw. den ersten Schritt(en) beträgt;
  • - Änderungen im Freiheitsgrad z auf einen Maximalwert zmax begrenzt, der (betragsmäßig) höchstens 10%, insbesondere höchstens 1%, in einer Ausführung höchstens 0,1%, eines, insbesondere kommandierten oder möglichen bzw. zulässigen, Maximalwerts einer Änderung in diesem Freiheitsgrad z in dem bzw. den ersten Schritt(en) beträgt; und
  • - Änderungen im Freiheitsgrad γ auf einen Maximalwert γmax begrenzt, der (betragsmäßig) höchstens 10%, insbesondere höchstens 1%, in einer Ausführung höchstens 0,1%, eines, insbesondere kommandierten oder möglichen bzw. zulässigen, Maximalwerts einer Änderung in diesem Freiheitsgrad γ in dem bzw. den zweiten Schritt(en) beträgt
beispielsweise also Änderungen in allen translatorischen und dem anderen der rotatorischen Freiheitsgrade auf einen (verglichen mit den ersten bzw. zweiten Schritten) niedrige(re)n Maximalwert begrenzt.Then are or will be in one or more first step (s)
  • - Changes in the degree of freedom α limited to a maximum value α max , which (in terms of amount) does not exceed 10%, in particular a maximum of 1%, in an execution at most 0.1%, in particular a commanded or possible or permissible, maximum value of a change in this degree of freedom α in one or more third step (s);
  • - Changes in the degree of freedom β limited to a maximum value β max which (in terms of amount) does not exceed 10%, in particular a maximum of 1%, in one embodiment a maximum of 0.1%, of a, in particular commanded or possible or permissible, maximum value of a change in this degree of freedom β in the third step (s); and
  • - Changes in the degree of freedom γ limited to a maximum value γ max which (in terms of amount) at most 10%, in particular at most 1%, in one embodiment at most 0.1%, of a, in particular commanded or possible or permissible, maximum value of a change in this degree of freedom γ in one or more second step (s); For example, changes in all rotational degrees of freedom are limited to a (compared to the second or third steps) low (re) n maximum value, in the second step (s)
  • - Changes in the degree of freedom x limited to a maximum value x max which (in terms of amount) does not exceed 10%, in particular a maximum of 1%, in one embodiment a maximum of 0.1%, of a, in particular commanded or possible or permissible, maximum value of a change in this degree of freedom x in the first step (s);
  • - Changes in the degree of freedom y limited to a maximum value y max which (in terms of amount) does not exceed 10%, in particular a maximum of 1%, in one embodiment a maximum of 0.1%, of a, in particular commanded or possible or permissible, maximum value of a change in this degree of freedom y in the first step (s);
  • - Changes in the degree of freedom z limited to a maximum value z max , which (in terms of amount) at most 10%, in particular at most 1%, in one embodiment at most 0.1%, of a, in particular commanded or possible or permissible, maximum value of a change in this degree of freedom z in the first step (s);
  • - Changes in the degree of freedom α limited to a maximum value α max which (in terms of amount) at most 10%, in particular at most 1%, in one embodiment at most 0.1%, of a, in particular commanded or possible or permissible, maximum value of a change in this degree of freedom α in the third step (s); and
  • - Changes in the degree of freedom β limited to a maximum value β max which (in terms of amount) does not exceed 10%, in particular a maximum of 1%, in one embodiment a maximum of 0.1%, of a, in particular commanded or possible or permissible, maximum value of a change in this degree of freedom β in the third step (s); For example, changes in all translational and two rotational degrees of freedom are limited to a (compared to the first or third steps) low (re) n maximum value, and in the third step (s)
  • - Changes in the degree of freedom x limited to a maximum value x max which (in terms of amount) does not exceed 10%, in particular a maximum of 1%, in one embodiment a maximum of 0.1%, of a, in particular commanded or possible or permissible, maximum value of a change in this degree of freedom x in the first step (s);
  • - Changes in the degree of freedom y limited to a maximum value y max which (in terms of amount) does not exceed 10%, in particular a maximum of 1%, in one embodiment a maximum of 0.1%, of a, in particular commanded or possible or permissible, maximum value of a change in this degree of freedom y in the first step (s);
  • - Changes in the degree of freedom z limited to a maximum value z max , which (in terms of amount) at most 10%, in particular at most 1%, in one embodiment at most 0.1%, of a, in particular commanded or possible or permissible, maximum value of a change in this degree of freedom z in the first step (s); and
  • - Changes in the degree of freedom γ limited to a maximum value γ max which (in terms of amount) at most 10%, in particular at most 1%, in one embodiment at most 0.1%, of a, in particular commanded or possible or permissible, maximum value of a change in this degree of freedom γ in the second step (s)
For example, changes in all translational and the other of the rotational degrees of freedom are limited to a (compared to the first or second steps) low (re) n maximum value.

Wie vorstehend erwähnt, impliziert die Bezeichnung „erste“, „zweite“ und „dritte“ nicht notwendigerweise eine chronologische Reihenfolge.As mentioned above, the terms “first”, “second” and “third” do not necessarily imply a chronological order.

Durch diese (starke) Begrenzung der Änderungen in den Freiheitsgraden der jeweiligen Teilmengen kann das maschinelle Lernen in einer Ausführung verbessert werden, insbesondere seine Geschwindigkeit, Konvergenz, Zuverlässigkeit und/oder das (gelernte) Verhalten des Roboters, insbesondere die Ausführung einer vorgegebenen Aufgabe durch den Roboter. Durch die Verwendung unterschiedlicher Teilmengen können in einer Ausführung vorteilhaft trotzdem alle DoF Freiheitsgrade genutzt bzw. realisiert werden.Due to this (strong) limitation of the changes in the degrees of freedom of the respective subsets, machine learning can be improved in one execution, in particular its speed, convergence, reliability and / or the (learned) behavior of the robot, in particular the execution of a given task by the Robot. By using different subsets, all DoF degrees of freedom can advantageously be used or implemented in one embodiment.

Die Schritte sind in einer Ausführung, insbesondere aufeinanderfolgende, Schritte, insbesondere Zeitschritte, des Reglers bzw. Regelschritte, insbesondere Regeltaktschritte. Unter einem Steuern wird vorliegend auch ein Regeln bzw. ein Kommandieren auf Basis von (vorgegebenen) Soll- und (erfassten) Ist-Werten verstanden.In one embodiment, the steps are, in particular, successive steps, in particular time steps, of the controller or control steps, in particular control clock steps. In the present case, controlling is also understood to mean regulating or commanding on the basis of (specified) setpoint and (recorded) actual values.

Die 1 bis (Dof - 1) Freiheitsgrade einer Teilmenge Ω = {φi, ..., φn} der DoF Freiheitsgrade {φ1, ..., φDoF} und die Freiheitsgrade {φ1, ..., φ(i-1), φ(n+1), ..., φDoF} des zu dieser Teilmenge komplementären Rests π der DoF Freiheitsgrade ergeben in einer Ausführung zusammen die DoF Freiheitsgrade (DoF = Anzahl der Freiheitsgrade der Teilmenge + Anzahl der Freiheitsgrade des komplementären Rests).The 1 until (Dof - 1) degrees of freedom of a subset Ω = {φ i , ..., φ n } of the DoF degrees of freedom {φ 1 , ..., φ DoF } and the degrees of freedom {φ 1 , ..., φ (i -1) , φ (n + 1) , ..., φ DoF } of the remainder π of the DoF degrees of freedom complementary to this subset result in one embodiment together the DoF degrees of freedom (DoF = number of degrees of freedom of the subset + number of degrees of freedom of the complementary Rest).

In einer Ausführung ist jeder der DoF Freiheitsgrade des Roboters Element wenigstens eines der Reste, so dass in jedem der DoF Freiheitsgrade des Roboters in wenigstens einem der Schritte eine (weniger begrenzte) Änderung kommandiert werden kann. In einer Ausführung weisen zwei oder mehr der Teilmengen jeweils paarweise wenigstens einen gemeinsamen Freiheitsgrad auf und unterscheiden sich durch wenigstens einen Freiheitsgrad, der nur Element der einen Teilmenge, nicht aber Element der anderen Teilmenge ist.In one embodiment, each of the DoF degrees of freedom of the robot is an element of at least one of the residues, so that in each of the DoF degrees of freedom of the robot, a (less limited) change can be commanded in at least one of the steps. In one embodiment, two or more of the subsets each have at least one common degree of freedom in pairs and differ by at least one degree of freedom, which is only an element of one subset but not an element of the other subset.

In einer Ausführung weisen, insbesondere sind, die DoF Freiheitsgrade kartesische Freiheitsgrade, insbesondere eines Endeffektors des Roboters (auf), in einer Ausführung eine kartesische Position in einer, zwei oder drei Raumrichtungen und/oder eine Orientierung bzw. Verdrehung um eine, zwei oder drei Achsen, beispielsweise Euler- oder Kardanwinkel oder dergleichen, in einer Ausführung alle, insbesondere sechs und/oder kartesische, Freiheitsgrade, insbesondere eines Endeffektors, des Roboters oder diejenigen), insbesondere kartesischen, Freiheitsgrade, insbesondere eines Endeffektors, des Roboters, die zur Durchführung einer bzw. der vorgegebenen Aufgabe erforderlich sind, zu deren Durchführung der Roboter mittels des Verfahrens bzw. Systems gesteuert wird. In einer Ausführung sind die kartesischen Freiheitsgrade in einem umgebungsfesten oder roboterbasisfesten oder endeffektorfesten Referenzsystem. In einer Ausführung weisen die DoF Freiheitsgrade einen oder mehrere Redundanzparameter, beispielsweise eine Ellbogenstellung eines siebenachsigen Roboterarms oder dergleichen, auf.In one embodiment, the DoF degrees of freedom have, in particular, Cartesian degrees of freedom, in particular an end effector of the robot, in one embodiment a Cartesian position in one, two or three spatial directions and / or an orientation or rotation by one, two or three Axes, for example Euler or cardan angles or the like, in one embodiment all, in particular six and / or Cartesian, degrees of freedom, in particular of an end effector, of the robot or those), in particular Cartesian, degrees of freedom, in particular of an end effector, of the robot that are required to carry out a or the specified task are required, for the execution of which the robot is controlled by means of the method or system. In one embodiment, the Cartesian degrees of freedom are in an environment-proof or robot-based or endeffector-proof reference system. In one embodiment, the DoF degrees of freedom have one or more redundancy parameters, for example an elbow position of a seven-axis robot arm or the like.

Soll also beispielsweise der Roboter mit seinem Endeffektor ein Werkstück ohne Orientierungsänderung an einer willkürlichen Stelle absetzen, können die DoF Freiheitsgrade die drei translatorischen kartesischen Freiheitsgrade des Endeffektors aufweisen, insbesondere sein. Soll hingegen der sechsachsige Roboter zum Beispiel mit seinem Endeffektor ein Werkstück gegebenenfalls unter Orientierungsänderung in eine Aufnahme einsetzen, können die DoF Freiheitsgrade die drei translatorischen und drei rotatorischen Freiheitsgrade des Endeffektors aufweisen, insbesondere sein. If, for example, the robot with its end effector is to place a workpiece at an arbitrary point without changing its orientation, the DoF degrees of freedom can have, in particular, the three translational Cartesian degrees of freedom of the end effector. On the other hand, if the six-axis robot, for example with its end effector, is to insert a workpiece into a receptacle, possibly with a change in orientation, the DoF degrees of freedom can have, in particular, the three translational and three rotational degrees of freedom of the end effector.

Durch die Verwendung dieser Freiheitsgrade kann in einer Ausführung der Roboter besonders vorteilhaft, insbesondere zuverlässig(er), schnell(er) und/oder intuitiv(er), gesteuert werden.By using these degrees of freedom, in one embodiment the robot can be controlled particularly advantageously, in particular reliably (more), quickly (more) and / or intuitively (more).

In einer Ausführung kommandiert der Regler die Änderungen mittels (eines) Operational Space Control (Frameworks).In one embodiment, the controller commands the changes using (an) operational space control (framework).

Hierdurch kann in einer Ausführung bei kartesischen Freiheitsgraden der Roboter besonders vorteilhaft, insbesondere zuverlässig(er), schnell(er) und/oder intuitiv(er), gesteuert werden.As a result, in one embodiment with Cartesian degrees of freedom, the robot can be controlled particularly advantageously, in particular reliably (more), quickly (more) and / or intuitively (more).

In einer Ausführung weisen einer oder mehrere der Reste der Freiheitsgrade (jeweils) nur translatorische Freiheitsgrade auf. In einer Weiterbildung weisen einer oder mehrere der Reste der Freiheitsgrade (jeweils) nur einen (insbesondere unterschiedlichen) translatorischen Freiheitsgrad und/oder einer oder mehrere der Reste der Freiheitsgrade (jeweils) nur zwei oder mehr translatorische Freiheitsgrade auf.In one embodiment, one or more of the remainder of the degrees of freedom (each) have only translational degrees of freedom on. In a further development, one or more of the remainder of the degrees of freedom (each) have only one (in particular different) translational degree of freedom and / or one or more of the remainder of the degrees of freedom (each) only have two or more translational degrees of freedom.

Zusätzlich oder alternativ weisen in einer Ausführung einer oder mehrere der Reste der Freiheitsgrade (jeweils) nur rotatorische Freiheitsgrade auf. In einer Weiterbildung weisen einer oder mehrere der Reste der Freiheitsgrade (jeweils) nur einen (insbesondere unterschiedlichen) rotatorischen Freiheitsgrad und/oder einer oder mehrere der Reste der Freiheitsgrade (jeweils) nur zwei oder mehr rotatorische Freiheitsgrade auf.Additionally or alternatively, in one embodiment, one or more of the remainder of the degrees of freedom (each) only have rotational degrees of freedom. In a further development, one or more of the remainder of the degrees of freedom (each) have only one (in particular different) rotational degree of freedom and / or one or more of the remainder of the degrees of freedom (each) only have two or more rotational degrees of freedom.

Dem liegt die Erkenntnis zugrunde, dass in einer Ausführung durch die Aufteilung in translatorische und rotatorische Freiheitsgrade das maschinelle Lernen, insbesondere seine Geschwindigkeit, Konvergenz, Zuverlässigkeit und/oder das (gelernte) Verhalten des Roboters verbessert werden kann, insbesondere die Ausführung einer vorgegebenen Aufgabe durch den Roboter.This is based on the knowledge that, in one embodiment, the division into translational and rotational degrees of freedom can improve machine learning, in particular its speed, convergence, reliability and / or the (learned) behavior of the robot, in particular the execution of a given task the robot.

Dabei kann in einer Ausführung durch die Beschränkung auf nur einen translatorischen bzw. rotatorischen Freiheitsgrad in wenigstens einem der Schritte das maschinelle Lernen verbessert werden, insbesondere seine Geschwindigkeit, Konvergenz und/oder Zuverlässigkeit. Durch die Kombination von zwei oder drei translatorischen bzw. rotatorischen Freiheitsgraden in wenigstens einem der Schritte kann in einer Ausführung das (gelernte) Verhalten des Roboters verbessert werden, insbesondere die Ausführung einer vorgegebenen Aufgabe durch den Roboter. Als besonders vorteilhaft hat sich die Kombination von drei translatorischen Freiheitsgrade in einem Rest und die Aufteilung der einzelnen rotatorischen Freiheitsgrade in jeweils einen Rest oder auch eine Kombination von zwei rotatorischen Freiheitsgraden erwiesen.In one embodiment, the machine learning can be improved, in particular its speed, convergence and / or reliability, by restricting it to only one translational or rotational degree of freedom in at least one of the steps. By combining two or three translational or rotational degrees of freedom in at least one of the steps, the (learned) behavior of the robot can be improved in one embodiment, in particular the execution of a predetermined task by the robot. The combination of three translational degrees of freedom in a remainder and the division of the individual rotational degrees of freedom into a remainder or a combination of two rotatory degrees of freedom has proven to be particularly advantageous.

Zusätzlich oder alternativ weisen in einer Ausführung einer oder mehrere der Reste der Freiheitsgrade wenigstens, in einer Weiterbildung nur, einen translatorischen und wenigstens, in einer Weiterbildung nur, einen rotatorischen Freiheitsgrad auf.Additionally or alternatively, in one embodiment, one or more of the remainder of the degrees of freedom have at least, in one development only, one translational and at least, in one development only, one rotational degree of freedom.

Durch die Kombination von, insbesondere nur, einem translatorischen und, insbesondere nur, einem rotatorischen Freiheitsgrad in wenigstens einem der Schritte kann in einer Ausführung das (gelernte) Verhalten des Roboters verbessert werden, insbesondere die Ausführung einer vorgegebenen Aufgabe durch den Roboter.By combining, in particular only, one translational and, in particular, only one rotational degree of freedom in at least one of the steps, the (learned) behavior of the robot can be improved in one embodiment, in particular the execution of a predetermined task by the robot.

In einer Ausführung sind einer oder mehrere der Maximalwerte, auf den (jeweils) eine Änderung in einem Freiheitsgrad einer der Teilmengen begrenzt ist, gleich Null, in einer Weiterbildung wird die entsprechende Änderung (hierzu) mit Null multipliziert. Hierdurch kann in einer Ausführung das (gelernte) Verhalten des Roboters verbessert werden, insbesondere die Ausführung einer vorgegebenen Aufgabe durch den Roboter.In one embodiment, one or more of the maximum values to which (in each case) a change in a degree of freedom of one of the subsets is limited to zero, in a further development the corresponding change is multiplied by zero (for this purpose). As a result, the (learned) behavior of the robot can be improved in one embodiment, in particular the execution of a predetermined task by the robot.

Zusätzlich oder alternativ sind in einer Ausführung einer oder mehrere der Maximalwerte, auf den (jeweils) eine Änderung in einem Freiheitsgrad einer der Teilmengen begrenzt ist, ungleich Null, in einer Weiterbildung wird die entsprechende Änderung (hierzu) mit einer entsprechenden Sigmoid-Funktion bzw. einem entsprechend kleinen, insbesondere konstanten, Faktor multipliziert. Hierdurch können sich in einer Ausführung insbesondere numerische und/oder analytische Vorteile beim maschinellen Lernen ergeben.Additionally or alternatively, one or more of the maximum values to which a change in a degree of freedom of one of the subsets is limited are not equal to zero, in a further development the corresponding change (for this purpose) is measured with a corresponding sigmoid function or multiplied by a correspondingly small, in particular constant, factor. This can result in particular numerical and / or analytical advantages in machine learning in one embodiment.

Ein Maximalwert, auf den eine Änderung in einem Freiheitsgrad einer der Teilmengen in einem der Schritte begrenzt ist, wird bzw. ist in einer Ausführung nicht in Abhängigkeit von dem Maximalwert der Änderung in diesem Freiheitsgraden in dem wenigstens einen anderen der (Mehrzahl der) Schritte verändert oder gewählt bzw. ermittelt bzw. bestimmt. So kann beispielsweise durch Multiplikation von ermittelten Änderungen in den Freiheitsgraden der Teilmenge mit 0,1 bzw. 0,01 bzw. 0,001, gegebenenfalls mittels Sigmoid-Funktion(en), in dem einen (der) Schritt(e) und Multiplikation von ermittelten Änderungen dieser Freiheitsgrade mit (ungefähr) 1 in dem anderen (der) Schritt(e) die erfindungsgemäße Begrenzung auf Maximalwerte realisiert werden. Entsprechend sind bzw. werden in einer Ausführung einer oder mehrere der Maximalwerte, auf die jeweils eine Änderung in einem Freiheitsgrad einer der Teilmengen begrenzt ist bzw. wird, konstant und/oder vor dem Betrieb bzw. Steuern des Roboters vorgegeben. Insofern versteht sich die Bezugnahme auf Maximalwerte von Änderungen in wenigstens einem anderen der (Mehrzahl der) Schritt(e) lediglich als (quantitative) Bezugsgröße, ohne dass sich die Maximalwerte, auf die Änderungen in Freiheitsgraden einer Teilmenge in einem Schritt begrenzt werden bzw. sind, mit den Maximalwerten von Änderungen in diesen Freiheitsgraden in anderen Schritten ändern müssen.A maximum value to which a change in a degree of freedom of one of the subsets in one of the steps is limited is or is not changed in one embodiment as a function of the maximum value of the change in this degree of freedom in the at least one other of the (plurality of) steps or chosen or determined or determined. For example, by multiplying determined changes in the degrees of freedom of the subset by 0.1 or 0.01 or 0.001, if necessary by means of a sigmoid function (s), in one (the) step (s) and multiplying determined changes of these degrees of freedom with (approximately) 1 in the other (the) step (s) the limitation according to the invention to maximum values can be implemented. Correspondingly, in one embodiment, one or more of the maximum values, to which a change in a degree of freedom of one of the subsets is or will be limited, are constant and / or specified before the robot is operated or controlled. In this respect, the reference to maximum values of changes in at least one other of the (majority of) step (s) is understood to be merely a (quantitative) reference variable, without the maximum values being limited to the changes in degrees of freedom of a subset in a step Having to change in other steps with the maximum values of changes in these degrees of freedom.

In einer Ausführung werden (auch) in den Freiheitsgraden der Teilmengen zunächst gegebenenfalls von Null verschiedene Änderungen ermittelt und (erst) anschließend auf den jeweiligen Maximalwert begrenzt, in einer Ausführung mit Null bzw. einer entsprechenden Sigmoid-Funktion multipliziert oder dergleichen. Hierdurch kann in einer Ausführung das maschinelle Lernen, insbesondere seine Geschwindigkeit, Konvergenz und/oder Zuverlässigkeit, verbessert werden.In one embodiment, changes other than zero are (also) initially determined in the degrees of freedom of the subsets and (only) then limited to the respective maximum value, in one embodiment multiplied by zero or a corresponding sigmoid function or the like. As a result, machine learning, in particular its speed, convergence and / or reliability, can be improved in one embodiment.

In einer Ausführung ist, insbesondere wird, eine Reihenfolge der Schritte fest vorgegeben. Beispielsweise können zyklisch zunächst ein oder mehrere aufeinanderfolgende Reste jeweils nur translatorische Freiheitsgrade einzeln oder in Kombination und ein oder mehrere darauf folgende Reste jeweils nur rotatorische Freiheitsgrade einzeln oder in Kombination und/oder jeweils Kombinationen von einem oder mehreren translatorischen und einem oder mehreren rotatorischen Freiheitsgraden aufweisen.In one embodiment, in particular, a sequence of the steps is fixedly predetermined. For example, one or more successive remainders can cyclically initially only have translational degrees of freedom individually or in combination and one or more subsequent remainders each only have rotational degrees of freedom individually or in combination and / or in each case combinations of one or more translational and one or more rotational degrees of freedom.

In einer Weiterbildung ist, insbesondere wird, die Reihenfolge der Schritte durch bzw. in Abhängigkeit von eine(r) Benutzereingabe („benutzereingabenabhängig“) fest vorgegeben, in einer Ausführung vor dem Durchführen der Aufgabe. In einer Ausführung wird dem Benutzer hierzu eine Auswahl der möglichen Schritte angezeigt. In a further development, in particular, the sequence of the steps is fixedly specified by or as a function of a user input (“user input dependent”), in one execution before the task is carried out. In one embodiment, the user is shown a selection of the possible steps for this purpose.

Hierdurch kann in einer Ausführung das maschinelle Lernen, insbesondere seine Geschwindigkeit, Konvergenz, Zuverlässigkeit und/oder das (gelernte) Verhalten des Roboters verbessert werden.As a result, machine learning, in particular its speed, convergence, reliability and / or the (learned) behavior of the robot can be improved in one embodiment.

Allerdings kann dies dazu führen, dass in manchen Schritten keine Änderung kommandiert bzw. dieser Schritt unnötig sozusagen nur abgewartet wird.However, this can mean that in some steps no change is commanded or that this step is unnecessarily just waited for, so to speak.

In einer Ausführung wird eine Reihenfolge der Schritte, in einer Ausführung benutzereingabenabhängig, durch den Regler variabel vorgegeben, in einer Ausführung während des Durchführens der Aufgabe.In one embodiment, a sequence of the steps, in one embodiment dependent on user input, is variably predefined by the controller, in one embodiment while the task is being carried out.

Hierdurch kann in einer Ausführung das maschinelle Lernen, insbesondere seine Geschwindigkeit, Konvergenz, Zuverlässigkeit und/oder das (gelernte) Verhalten des Roboters verbessert werden.As a result, machine learning, in particular its speed, convergence, reliability and / or the (learned) behavior of the robot can be improved in one embodiment.

Dabei kann in einer Ausführung durch bzw. in Abhängigkeit von eine(r) Benutzereingabe ausgewählt werden bzw. sein, ob die Reihenfolge der Schritte, insbesondere benutzereingabenabhängig, fest vorgegeben sein oder durch den Regler variabel vorgegeben werden soll. Zusätzlich oder alternativ kann in einer Ausführung die variable Vorgabe durch den Regler durch bzw. in Abhängigkeit von eine(r) Benutzereingabe konditioniert bzw. ihrerseits benutzereingabenabhängig sein, beispielsweise, indem der Benutzer vorgibt, welche Schrittfolgen überhaupt zulässig bzw. durch den Regler vorgebbar sind oder dergleichen. In einer Ausführung wird dem Benutzer hierzu eine entsprechende Auswahl- bzw. Eingabemöglichkeit angezeigt.In one embodiment, a user input can be used to select or be dependent on whether the sequence of the steps, in particular depending on user input, is to be predefined or variably predefined by the controller. Additionally or alternatively, in one embodiment, the variable specification by the controller can be conditioned by or as a function of a user input or, in turn, be dependent on user input, for example by the user specifying which step sequences are permitted or can be specified by the controller or like that. In one embodiment, the user is shown a corresponding selection or input option for this purpose.

Hierdurch kann in einer Ausführung das maschinelle Lernen, insbesondere seine Geschwindigkeit, Konvergenz, Zuverlässigkeit und/oder das (gelernte) Verhalten des Roboters verbessert werden.As a result, machine learning, in particular its speed, convergence, reliability and / or the (learned) behavior of the robot can be improved in one embodiment.

In einer Ausführung gibt der Regler die Reihenfolge der Schritte mittels eines oder mehrerer Auswahlparameter, insbesondere kaskadiert, vor, in einer Weiterbildung mittels eines, insbesondere primären, Auswahlparameters, ob der jeweilige Rest nur translatorische bzw. nur rotatorische Freiheitsgrade aufweist oder nicht, und/oder mittels wenigstens eines, insbesondere sekundären, Auswahlparameters, welche (Gruppe) der translatorischen bzw. rotatorischen Freiheitsgrade der jeweilige Rest aufweist.In one embodiment, the controller specifies the sequence of the steps by means of one or more selection parameters, in particular cascaded, in a further development by means of a, in particular primary, selection parameter, whether the respective remainder has only translational or only rotational degrees of freedom or not, and / or by means of at least one, in particular secondary, selection parameter, which (group) of the translational or rotational degrees of freedom the respective remainder has.

Hierdurch kann in einer Ausführung das maschinelle Lernen, insbesondere seine Geschwindigkeit, Konvergenz, Zuverlässigkeit und/oder das (gelernte) Verhalten des Roboters verbessert werden.As a result, machine learning, in particular its speed, convergence, reliability and / or the (learned) behavior of the robot can be improved in one embodiment.

In einer Ausführung sind, insbesondere werden, die Freiheitsgrade von einem oder mehreren der Reste bzw. der entsprechenden komplementären Teilmenge(n) fest vorgegeben, in einer Weiterbildung durch bzw. in Abhängigkeit von eine(r) Benutzereingabe, in einer Ausführung vor dem Durchführen der Aufgabe. Beispielsweise kann ein Benutzer durch entsprechende Eingabe festlegen, dass ein Rest bzw. eine Teilmenge nur drei translatorischen Freiheitsgrade oder nur einen bzw. welchen translatorischen Freiheitsgrad oder nur einen oder zwei bzw. welche(n) rotatorische(n) Freiheitsgrad(e) aufweisen soll. In einer Ausführung wird dem Benutzer hierzu eine entsprechende Auswahl- bzw. Eingabemöglichkeit angezeigt.In one embodiment, in particular, the degrees of freedom of one or more of the remainders or the corresponding complementary subset (s) are fixedly predetermined, in one development by or as a function of a user input, in one embodiment before the execution of the Task. For example, a user can specify through appropriate input that a remainder or a subset should have only three translational degrees of freedom or only one or which translational degree of freedom or only one or two or which rotational degree (s) of freedom (s). In one embodiment, the user is shown a corresponding selection or input option for this purpose.

Hierdurch kann in einer Ausführung das maschinelle Lernen, insbesondere seine Geschwindigkeit, Konvergenz, Zuverlässigkeit und/oder das (gelernte) Verhalten des Roboters verbessert werden.As a result, machine learning, in particular its speed, convergence, reliability and / or the (learned) behavior of the robot can be improved in one embodiment.

Zusätzlich oder alternativ werden in einer Ausführung die Freiheitsgrade von einem oder mehreren der Reste bzw. der entsprechenden komplementären Teilmenge(n), in einer Ausführung benutzereingabenabhängig, durch den Regler variabel vorgegeben, in einer Ausführung während des Durchführens der Aufgabe.Additionally or alternatively, in one embodiment the degrees of freedom of one or more of the remainders or the corresponding complementary subset (s) are variably specified by the controller, in one embodiment depending on user input, in one embodiment while the task is being carried out.

Hierdurch kann in einer Ausführung das (gelernte) Verhalten des Roboters verbessert werden.As a result, the (learned) behavior of the robot can be improved in one embodiment.

Dabei kann in einer Ausführung durch bzw. in Abhängigkeit von eine(r) Benutzereingabe ausgewählt werden bzw. sein, ob, insbesondere benutzereingabenabhängig, fest vorgegebene Reste bzw. Teilmengen und/oder durch den Regler variabel vorgegebene Reste bzw. Teilmengen verwendet werden. Zusätzlich oder alternativ kann in einer Ausführung die variable Vorgabe von einem oder mehreren der Reste bzw. Teilmengen durch den Regler durch bzw. in Abhängigkeit von eine(r) Benutzereingabe konditioniert bzw. ihrerseits benutzereingabenabhängig sein, beispielsweise, indem der Benutzer vorgibt, welche Kombinationen von Freiheitsgraden zulässig sind oder dergleichen. In einer Ausführung wird dem Benutzer hierzu eine entsprechende Auswahl- bzw. Eingabemöglichkeit angezeigt.In one embodiment, a user input can be used to select or be dependent on whether, in particular as a function of user input, fixed predetermined remainders or subsets and / or residues or subsets variably predefined by the controller are used. Additionally or alternatively, in one embodiment, the variable specification of one or more of the remainders or subsets by the controller can be conditioned by or as a function of a user input or, in turn, be dependent on user input, for example by the user specifying which combinations of Degrees of freedom are permissible or the like. In one embodiment, the user is shown a corresponding selection or input option for this purpose.

Hierdurch kann in einer Ausführung das maschinelle Lernen, insbesondere seine Geschwindigkeit, Konvergenz, Zuverlässigkeit und/oder das (gelernte) Verhalten des Roboters verbessert werden.As a result, machine learning, in particular its Speed, convergence, reliability and / or the (learned) behavior of the robot can be improved.

In einer Ausführung wird Reinforcement Learning, vorzugsweise Deep Reinforcement Learning, insbesondere ein (Deep) Reinforcement Learning Algorithmus, verwendet, um mittels des Reglers die Änderungen zu kommandieren und/oder die Reihenfolge der Schritte und/oder die Freiheitsgrade wenigstens einer der Teilmengen vorzugeben. Insbesondere hierzu weist der Regler in einer Ausführung wenigstens ein künstliches Neuronales Netz, vorzugsweise ein Deep Neuronal Network, insbesondere mit mehreren Dense layers in einer Ausführung ein Convolutional Neuronal Network auf.In one embodiment, reinforcement learning, preferably deep reinforcement learning, in particular a (deep) reinforcement learning algorithm, is used to command the changes by means of the controller and / or to specify the sequence of the steps and / or the degrees of freedom of at least one of the subsets. In particular for this purpose, the controller has in one embodiment at least one artificial neural network, preferably a deep neural network, in particular with several dense layers in one embodiment a convolutional neural network.

Für dieses maschinelle Lernen ist die vorliegende Idee einer Begrenzung, insbesondere Nullung bzw., wenigstens im Wesentlichen, Unterdrückung, von kommandierten Änderungen in einem Teil der DoF steuerbaren, insbesondere kartesischen, Freiheitsgrade in verschiedenen (Regler)Schritten, insbesondere bei (einem) Operational Space Control (Framework), besonders vorteilhaft, wobei durch dieses maschinelle Lernen, insbesondere in Kombination mit einem oder mehreren der hier genannten Merkmale, das (gelernte) Verhalten des Roboters besonders vorteilhaft verbessert werden kann.For this machine learning, the present idea of a limitation, in particular zeroing or, at least essentially, suppression, of commanded changes in a part of the DoF is controllable, in particular Cartesian, degrees of freedom in different (controller) steps, in particular in (one) operational space Control (framework), particularly advantageous, it being possible through this machine learning, in particular in combination with one or more of the features mentioned here, to improve the (learned) behavior of the robot in a particularly advantageous manner.

In einer Ausführung weist das künstliche Neuronale Netz des Reglers ein erstes Teilnetz, das auf Basis von Eingangs-, insbesondere Sensordaten Soll-Änderungen in den DoF Freiheitsgraden ermittelt, und ein zweites Teilnetz auf, das auf Basis dieser Eingangsdaten diese Soll-Änderungen in den Freiheitsgraden der jeweiligen Teilmenge auf den jeweiligen Maximalwert begrenzt, insbesondere hierzu die Reihenfolge der Schritte und/oder die Freiheitsgrade wenigstens einer der Teilmengen vorgibt.In one embodiment, the artificial neural network of the controller has a first sub-network that determines target changes in the DoF degrees of freedom on the basis of input, in particular sensor data, and a second sub-network that uses these input data to determine these target changes in the degrees of freedom the respective subset is limited to the respective maximum value, in particular for this purpose the sequence of the steps and / or the degrees of freedom of at least one of the subsets specifies.

Hierdurch kann in einer Ausführung das maschinelle Lernen besonders vorteilhaft, insbesondere differenzierbar, realisiert werden, insbesondere daher in einer Ausführung ein(en) Backpropagation Algorithmus aufweisen bzw. verwendet werden.As a result, machine learning can be implemented particularly advantageously, in particular differentiable, in one embodiment, in particular therefore have or use a backpropagation algorithm in one embodiment.

Nach einer Ausführung der vorliegenden Erfindung ist ein System, insbesondere hard und/oder Software , insbesondere programmtechnisch, zur Durchführung eines hier beschriebenen Verfahrens eingerichtet und/oder weist auf:

  • - Mittel zum Begrenzen von (den bzw. eventuellen) Änderungen in den, insbesondere allen, Freiheitsgraden einer ersten, insbesondere vorgegebenen, Teil- bzw. Untermenge der DoF Freiheitsgrade, die wenigstens einen und höchstens (DoF-1) der Freiheitsgrade aufweist, in einem oder mehreren ersten Schritt(en) einer Mehrzahl von Schritten jeweils auf einen Maximalwert, wobei dieser Maximalwert jeweils (betragsmäßig) höchstens 10%, insbesondere höchstens 1%, in einer Ausführung höchstens 0,1%, eines, insbesondere kommandierten oder möglichen bzw. zulässigen, Maximalwerts einer Änderung in dem jeweiligen Freiheitsgrad in wenigstens einem anderen der (Mehrzahl der) Schritte beträgt, und
  • - Mittel zum Begrenzen von (den bzw. eventuellen) Änderungen in den, insbesondere allen, Freiheitsgraden einer zweiten, insbesondere vorgegebenen, Teil- bzw. Untermenge der DoF Freiheitsgrade, die wenigstens einen und höchstens (DoF-1) der Freiheitsgrade aufweist und von der ersten Teilmenge wenigstens teilweise verschieden ist, in einem oder mehreren zweiten Schritt(en) der Mehrzahl der Schritte jeweils auf einen Maximalwert, wobei dieser Maximalwert jeweils (betragsmäßig) höchstens 10%, insbesondere höchstens 1%, in einer Ausführung höchstens 0,1%, eines, insbesondere kommandierten oder möglichen bzw. zulässigen, Maximalwerts einer Änderung in dem jeweiligen Freiheitsgrad in dem jeweiligen Freiheitsgrad in wenigstens einem anderen der (Mehrzahl der) Schritte beträgt,
  • - und in einer Weiterbildung Mittel zum Begrenzen von (den bzw. eventuellen) Änderungen in den, insbesondere allen, Freiheitsgraden einer dritten, insbesondere vorgegebenen, Teil- bzw. Untermenge der DoF Freiheitsgrade, die wenigstens einen und höchstens (DoF-1) der Freiheitsgrade aufweist und von der ersten und zweiten Teilmenge wenigstens teilweise verschieden ist, in einem oder mehreren dritten Schritt(en) der Mehrzahl der Schritte jeweils auf einen Maximalwert, wobei dieser Maximalwert jeweils (betragsmäßig) höchstens 10%, insbesondere höchstens 1%, in einer Ausführung höchstens 0,1%, eines, insbesondere kommandierten oder möglichen bzw. zulässigen, Maximalwerts einer Änderung in dem jeweiligen Freiheitsgrad in wenigstens einem anderen der (Mehrzahl der) Schritte beträgt, und
  • - einen Regler zum Kommandieren von
    • - (den bzw. eventuellen) Änderungen in den Freiheitsgraden eines zur ersten Teilmenge komplementären ersten Rests der Freiheitsgrade und in einer Ausführung (den bzw. eventuellen) auf den jeweiligen Maximalwert begrenzten Änderungen in den Freiheitsgraden der ersten Teilmenge in dem bzw. den ersten Schritt(en) und
    • - (den bzw. eventuellen) Änderungen in den Freiheitsgraden eines zur zweiten Teilmenge komplementären zweiten Rests der Freiheitsgrade und in einer Ausführung (den bzw. eventuellen) auf den jeweiligen Maximalwert begrenzten Änderungen in den Freiheitsgraden der zweiten Teilmenge in dem bzw. den zweiten Schritt(en),
    • - und in einer Weiterbildung (den bzw. eventuellen) Änderungen in den Freiheitsgraden eines zur dritten Teilmenge komplementären dritten Rests der Freiheitsgrade und in einer Ausführung (den bzw. eventuellen) auf den jeweiligen Maximalwert begrenzten Änderungen in den Freiheitsgraden der dritten Teilmenge in dem bzw. den dritten Schritt(en),
    mittels maschinellen Lernens.
According to one embodiment of the present invention, a system, in particular hardware and / or software, in particular in terms of programming, is set up to carry out a method described here and / or has:
  • Means for limiting (the or possible) changes in the, in particular all, degrees of freedom of a first, in particular predetermined, subset or subset of the DoF degrees of freedom, which has at least one and at most (DoF-1) of the degrees of freedom in one or several first step (s) of a plurality of steps each to a maximum value, this maximum value in each case (in terms of amount) at most 10%, in particular at most 1%, in one implementation at most 0.1%, one, in particular commanded or possible or permissible , Maximum value of a change in the respective degree of freedom in at least one other of the (plurality of) steps, and
  • - Means for limiting (the or possible) changes in the, in particular all, degrees of freedom of a second, in particular predetermined, subset or subset of the DoF degrees of freedom, which has at least one and at most (DoF-1) of the degrees of freedom and from the first subset is at least partially different, in one or more second step (s) of the plurality of steps each to a maximum value, this maximum value in each case (in terms of amount) at most 10%, in particular at most 1%, in one embodiment at most 0.1%, a, in particular commanded or possible or permissible, maximum value of a change in the respective degree of freedom in the respective degree of freedom in at least one other of the (plurality of) steps,
  • - and in a further development means for limiting (the or possible) changes in the, in particular all, degrees of freedom of a third, in particular predetermined, subset or subset of the DoF degrees of freedom, the at least one and at most (DoF-1) of the degrees of freedom and is at least partially different from the first and second subset, in one or more third step (s) of the plurality of steps each to a maximum value, this maximum value in each case (in terms of amount) at most 10%, in particular at most 1%, in one embodiment at most 0.1%, in particular a commanded or possible or permissible, maximum value of a change in the respective degree of freedom in at least one other of the (majority of) steps, and
  • - a controller for commanding
    • - (the or possible) changes in the degrees of freedom of a first remainder of the degrees of freedom that are complementary to the first subset and in one embodiment (the or possible) changes in the degrees of freedom of the first subset in the first step (s) limited to the respective maximum value ( en) and
    • - (the or possible) changes in the degrees of freedom of a second remainder of the degrees of freedom complementary to the second subset and limited in one embodiment (the or possible) to the respective maximum value Changes in the degrees of freedom of the second subset in the second step (s),
    • - and in a further development (the or possible) changes in the degrees of freedom of a third remainder of the degrees of freedom, which is complementary to the third subset, and in an embodiment (the or possible) changes in the degrees of freedom of the third subset limited to the respective maximum value in the or the third step (s),
    using machine learning.

In einer Ausführung weist das System bzw. seine Mittel bzw. sein Regler auf:

  • - Mittel zum Kommandieren der Änderung mittels Operational Space Control;
  • - Mittel zur, insbesondere benutzereingabenabhängigen, Vorgabe der Reihenfolge der Schritte;
  • - Mittel zur Vorgabe der Reihenfolge der Schritte mittels wenigstens eines Auswahlparameters; und/oder
  • - Mittel zur, insbesondere benutzereingabenabhängigen, Vorgabe der Freiheitsgrade wenigstens eines der Reste.
In one embodiment, the system or its means or its controller has:
  • - Means for commanding the change by means of operational space control;
  • - Means for specifying the sequence of the steps, in particular depending on user input;
  • - Means for specifying the sequence of the steps by means of at least one selection parameter; and or
  • - Means for, in particular user input-dependent, specification of the degrees of freedom of at least one of the remainders.

Ein Mittel im Sinne der vorliegenden Erfindung kann hard- und/oder softwaretechnisch ausgebildet sein, insbesondere eine, vorzugsweise mit einem Speicher- und/oder Bussystem daten- bzw. signalverbundene, insbesondere digitale, Verarbeitungs-, insbesondere Mikroprozessoreinheit (CPU), Graphikkarte (GPU) oder dergleichen, und/oder ein oder mehrere Programme oder Programmmodule aufweisen. Die Verarbeitungseinheit kann dazu ausgebildet sein, Befehle, die als ein in einem Speichersystem abgelegtes Programm implementiert sind, abzuarbeiten, Eingangssignale von einem Datenbus zu erfassen und/oder Ausgangssignale an einen Datenbus abzugeben. Ein Speichersystem kann ein oder mehrere, insbesondere verschiedene, Speichermedien, insbesondere optische, magnetische, Festkörper- und/oder andere nicht-flüchtige Medien aufweisen. Das Programm kann derart beschaffen sein, dass es die hier beschriebenen Verfahren verkörpert bzw. auszuführen imstande ist, sodass die Verarbeitungseinheit die Schritte solcher Verfahren ausführen kann und damit insbesondere den Roboter steuern kann. Ein Computerprogrammprodukt kann in einer Ausführung ein, insbesondere nichtflüchtiges, Speichermedium zum Speichern eines Programms bzw. mit einem darauf gespeicherten Programm aufweisen, insbesondere sein, wobei ein Ausführen dieses Programms ein System bzw. eine Steuerung, insbesondere einen Computer, dazu veranlasst, ein hier beschriebenes Verfahren bzw. einen oder mehrere seiner Schritte auszuführen.A means within the meaning of the present invention can be designed in terms of hardware and / or software, in particular a processing, in particular microprocessor unit (CPU), graphics card (GPU), preferably a data or signal connected to a memory and / or bus system, in particular digital processing unit ) or the like, and / or one or more programs or program modules. The processing unit can be designed to process commands that are implemented as a program stored in a memory system, to acquire input signals from a data bus and / or to output output signals to a data bus. A storage system can have one or more, in particular different, storage media, in particular optical, magnetic, solid-state and / or other non-volatile media. The program can be designed in such a way that it embodies or is capable of executing the methods described here, so that the processing unit can execute the steps of such methods and can thus in particular control the robot. In one embodiment, a computer program product can have, in particular, a non-volatile storage medium for storing a program or with a program stored on it, with the execution of this program causing a system or a controller, in particular a computer, to generate a program described here Process or one or more of its steps.

In einer Ausführung werden ein oder mehrere, insbesondere alle, Schritte des Verfahrens vollständig oder teilweise automatisiert durchgeführt, insbesondere durch das System.In one embodiment, one or more, in particular all, steps of the method are carried out completely or partially automatically, in particular by the system.

In einer Ausführung weist das System den Roboter auf.In one embodiment, the system has the robot.

Weitere Vorteile und Merkmale ergeben sich aus den Unteransprüchen und den Ausführungsbeispielen. Hierzu zeigt, teilweise schematisiert:

  • 1: ein System zum Steuern eines Roboters nach einer Ausführung der vorliegenden Erfindung;
  • 2: ein Verfahren zum Steuern des Roboters nach einer Ausführung der vorliegenden Erfindung; und
  • 3: einen Teil eines Systems zum Steuern eines Roboters nach einer weiteren Ausführung der vorliegenden Erfindung.
Further advantages and features emerge from the subclaims and the exemplary embodiments. This shows, partly schematically:
  • 1 : a system for controlling a robot according to an embodiment of the present invention;
  • 2 : a method of controlling the robot according to an embodiment of the present invention; and
  • 3 Fig. 3 shows part of a system for controlling a robot according to another embodiment of the present invention.

1 zeigt ein System zum Steuern eines siebenachsigen Roboter(arm)s 10 mit einem Endeffektor 11 nach einer Ausführung der vorliegenden Erfindung. 1 shows a system for controlling a seven-axis robot (arm) 10 with an end effector 11 according to an embodiment of the present invention.

In einer nicht dargestellten Abwandlung kann der Roboter auch ein anderer Roboter, insbesondere ein sechsachsiger Roboterarm sein.In a modification not shown, the robot can also be another robot, in particular a six-axis robot arm.

Eine Robotersteuerung kommuniziert mit dem Roboter(arm) 10, steuert insbesondere dessen Achsanatriebe und erhält von diesen aktuelle Ist-Werte der Gelenkwinkel q1 - q7 sowie Gelenkmomente T1 - T7 .A robot controller communicates with the robot (arm) 10 , controls in particular its axle drives and receives current actual values of the joint angle from them q 1 - q 7 as well as joint moments T 1 - T 7 .

Hierzu weist die Steuerung einen Regler 20 mit einem künstlichen Neuronalen Netz 21 und einem Operational Space Control Framework 22 auf.The controller has a regulator for this purpose 20th with an artificial neural network 21st and an operational space control framework 22nd on.

Das Neuronale Netz 21 liefert mittels Reinforcement Learning Soll-Werte für Änderungen in drei translatorischen Freiheitsgraden x, y, z und Soll-Werte für Änderungen in drei rotatorischen Freiheitsgraden α, β, γ des Endeffektors 11 in einem endeffektorfesten Referenzsystem. In einer nicht dargestellten Abwandlung kann auch ein roboterbasis- oder umgebungsfestes Referenzsystem verwendet werden.The neural network 21st uses reinforcement learning to provide target values for changes in three translational degrees of freedom x , y , z and target values for changes in three rotational degrees of freedom α , β , γ of the end effector 11 in an endeffector-proof reference system. In a modification that is not shown, a reference system that is robot-based or fixed to the environment can also be used.

Im Ausführungsbeispiel umfasst eine fest vorgegebene erste Teilmenge die drei rotatorischen Freiheitsgrade α, β, γ, der hierzu komplementäre erste Rest entsprechend die drei translatorischen Freiheitsgraden x, y, z.In the exemplary embodiment, a fixed, predetermined first subset comprises the three rotational degrees of freedom α , β , γ , the complementary first remainder corresponding to the three translational degrees of freedom x , y , z .

Eine fest vorgegebene zweite Teilmenge umfasst die drei translatorischen Freiheitsgrade x, y, z und den rotatorischen Freiheitsgrad γ, der hierzu komplementäre zweite Rest entsprechend die beiden rotatorischen Freiheitsgraden α, β. A fixed, predetermined second subset comprises the three translational degrees of freedom x , y , z and the rotational degree of freedom γ , the complementary second remainder corresponding to the two rotational degrees of freedom α , β .

Eine fest vorgegebene dritte Teilmenge umfasst die drei translatorischen Freiheitsgraden x, y, z und die beiden rotatorischen Freiheitsgraden α, β, der hierzu komplementäre dritte Rest entsprechend nur den rotatorischen Freiheitsgrad γ.A fixed, predetermined third subset includes the three translational degrees of freedom x , y , z and the two rotational degrees of freedom α , β , the complementary third remainder corresponding to only the rotational degree of freedom γ .

Das Neuronalen Netz 21 liefert außerdem mittels Reinforcement Learning Werte für zwei kaskadierte Auswahlparameter P1 ∈ [0, 1], P2 ∈ [0, 1].The neural network 21st also provides values for two cascaded selection parameters P 1 ∈ [0, 1], P 2 ∈ [0, 1] by means of reinforcement learning.

Liegt in einem Reglerschritt der erste Auswahlparameterwert P1 unter 0,5, werden in diesem Reglerschritt, beispielsweise durch (Multiplikation mit) entsprechende(n) Sigmoid-Funktionen, die vom Neuronalen Netz 21 gelieferten bzw. ermittelten Soll-Werte für Änderungen in den drei rotatorischen Freiheitsgraden α, β, γ auf Null gesetzt, beispielsweise mit Null multipliziert, oder auf einen sehr kleinen Maximalwert begrenzt, beispielsweise mit 0,1 oder mit 0,01 oder mit 0,001 multipliziert, die Soll-Werte für Änderungen in drei translatorischen Freiheitsgraden x, y, z hingegen unverändert weitergeleitet, beispielsweise mit einem Faktor > 0,9, insbesondere 1, multipliziert, und mittels des Operational Space Control Frameworks 22 auf entsprechende Soll-Werte für die Achsen bzw. Achsantriebe abgebildet (2: Schritt S10).If the first selection parameter value is in a controller step P 1 below 0.5, in this control step, for example by (multiplication by) corresponding (n) sigmoid functions generated by the neural network 21st Delivered or determined target values for changes in the three rotational degrees of freedom α , β , γ set to zero, for example multiplied by zero, or limited to a very small maximum value, for example multiplied by 0.1 or 0.01 or 0.001, the target values for changes in three translational degrees of freedom x , y , z however, forwarded unchanged, for example by a factor> 0.9, in particular 1, multiplied, and by means of the Operational Space Control Framework 22nd mapped to corresponding target values for the axes or axle drives ( 2 : Step S10 ).

Beträgt in einem Reglerschritt der erste Auswahlparameterwert P1 hingegen wenigstens 0,5 und der zweite Auswahlparameterwert P2 weniger als 0,5, werden in diesem Reglerschritt, beispielsweise durch (Multiplikation mit) entsprechende(n) Sigmoid-Funktionen, die vom Neuronalen Netz 21 gelieferten bzw. ermittelten Soll-Werte für Änderungen in den drei translatorischen Freiheitsgraden x, y, z und Soll-Werte für Änderungen in den zwei rotatorischen Freiheitsgraden α, β auf Null gesetzt, beispielsweise mit Null multipliziert, oder auf einen sehr kleinen Maximalwert begrenzt, beispielsweise mit 0,1 oder mit 0,01 oder mit 0,001 multipliziert, der Soll-Wert für eine Änderung im rotatorischen Freiheitsgrad γ hingegen unverändert weitergeleitet, beispielsweise mit einem Faktor > 0,9, insbesondere 1, multipliziert, und mittels des Operational Space Control Frameworks 22 auf entsprechende Soll-Werte für die Achsen bzw. Achsantriebe abgebildet (2: Schritt S20).Is the first selection parameter value in a controller step P 1 however, at least 0.5 and the second selection parameter value P 2 less than 0.5 are used in this control step, for example by (multiplication by) the corresponding sigmoid functions generated by the neural network 21st Delivered or determined target values for changes in the three translational degrees of freedom x , y , z and target values for changes in the two rotational degrees of freedom α , β set to zero, for example multiplied by zero, or limited to a very small maximum value, for example multiplied by 0.1 or by 0.01 or by 0.001, the target value for a change in the rotational degree of freedom γ however, forwarded unchanged, for example by a factor> 0.9, in particular 1, multiplied, and by means of the Operational Space Control Framework 22nd mapped to corresponding target values for the axes or axle drives ( 2 : Step S20 ).

Beträgt in einem Reglerschritt der erste Auswahlparameterwert P1 wenigstens 0,5 und der zweite Auswahlparameterwert P2 wenigstens 0,5, werden in diesem Reglerschritt, beispielsweise durch (Multiplikation mit) entsprechende(n) Sigmoid-Funktionen, die vom Neuronalen Netz 21 gelieferten bzw. ermittelten Soll-Werte für Änderungen in drei translatorischen Freiheitsgraden x, y, z und der Soll-Wert für eine Änderung im rotatorischen Freiheitsgrad γ auf Null gesetzt, beispielsweise mit Null multipliziert, oder auf einen sehr kleinen Maximalwert begrenzt, beispielsweise mit 0,1 oder mit 0,01 oder mit 0,001 multipliziert, die Soll-Werte für Änderungen in den zwei rotatorischen Freiheitsgraden α, β hingegen unverändert weitergeleitet, beispielsweise mit einem Faktor > 0,9, insbesondere 1, multipliziert, und mittels des Operational Space Control Frameworks 22 auf entsprechende Soll-Werte für die Achsen bzw. Achsantriebe abgebildet (2: Schritt S30).Is the first selection parameter value in a controller step P 1 at least 0.5 and the second selection parameter value P 2 at least 0.5 are determined in this control step, for example by (multiplication by) the corresponding sigmoid functions generated by the neural network 21st Delivered or determined target values for changes in three translational degrees of freedom x , y , z and the target value for a change in the rotational degree of freedom γ set to zero, for example multiplied by zero, or limited to a very small maximum value, for example multiplied by 0.1 or by 0.01 or by 0.001, the target values for changes in the two rotational degrees of freedom α , β however, forwarded unchanged, for example by a factor> 0.9, in particular 1, multiplied, and by means of the Operational Space Control Framework 22nd mapped to corresponding target values for the axes or axle drives ( 2 : Step S30 ).

Auf diese Weise werden primär (vgl. P1 ) Translation und Rotation und in einer zweiten Kaskade (vgl. P2 ) Rotation um die z-Achse und Rotationen um die x- und y-Achse getrennt, wobei der Reinforcement Learning Algorithmus selbst lernt, wann er welche dieser Bewegungsarten ausführen soll.In this way, primarily (cf. P 1 ) Translation and rotation and in a second cascade (cf. P 2 ) Rotation around the z-axis and rotations around the x- and y-axis separately, whereby the reinforcement learning algorithm itself learns when it should perform which of these types of movement.

In einer nicht dargestellten Abwandlung kann die Reihenfolge der Schritte auch fest vorgegeben sein, also beispielsweise zyklisch jeweils

  • - in einem ersten Schritt eines Zyklus nur die Soll-Werte für Änderungen in drei translatorischen Freiheitsgraden x, y, z unverändert weitergeleitet und die Soll-Werte für Änderungen in den drei rotatorischen Freiheitsgraden α, β, γ auf Null gesetzt bzw. auf einen sehr kleinen Maximalwert begrenzt werden;
  • - in einem darauffolgenden zweiten Schritt des Zyklus nur der Soll-Wert für eine Änderung im rotatorischen Freiheitsgrad γ unverändert weitergeleitet und die Soll-Werte für Änderungen in drei translatorischen Freiheitsgraden x, y, z und Soll-Werte für Änderungen in den zwei rotatorischen Freiheitsgraden α, β auf Null gesetzt bzw. auf einen sehr kleinen Maximalwert begrenzt werden; und
  • - in einem darauffolgenden dritten, letzten Schritt des Zyklus die Soll-Werte für Änderungen in den zwei rotatorischen Freiheitsgraden α, β unverändert weitergeleitet und die Soll-Werte für Änderungen in drei translatorischen Freiheitsgraden x, y, z und der Soll-Wert für eine Änderung im rotatorischen Freiheitsgrad γ auf Null gesetzt bzw. auf einen sehr kleinen Maximalwert begrenzt werden;
oder zyklisch jeweils
  • - in einem ersten Schritt eines Zyklus nur der Soll-Wert für eine Änderungen in einem ersten der drei translatorischen Freiheitsgraden x, y, z unverändert weitergeleitet und die Soll-Werte für Änderungen in den anderen beiden der drei translatorischen Freiheitsgraden x, y, z sowie die Soll-Werte für Änderungen in den drei rotatorischen Freiheitsgraden α, β, γ auf Null gesetzt bzw. auf einen sehr kleinen Maximalwert begrenzt werden;
  • - in einem darauffolgenden zweiten Schritt des Zyklus nur der Soll-Wert für eine Änderungen in einem zweiten der drei translatorischen Freiheitsgraden x, y, z unverändert weitergeleitet und die Soll-Werte für Änderungen in den anderen beiden der drei translatorischen Freiheitsgraden x, y, z sowie die Soll-Werte für Änderungen in den drei rotatorischen Freiheitsgraden α, β, γ auf Null gesetzt bzw. auf einen sehr kleinen Maximalwert begrenzt werden;
  • - in einem darauffolgenden dritten Schritt des Zyklus nur der Soll-Wert für eine Änderungen in einem dritten, letzten der drei translatorischen Freiheitsgraden x, y, z unverändert weitergeleitet und die Soll-Werte für Änderungen in den anderen beiden der drei translatorischen Freiheitsgraden x, y, z sowie die Soll-Werte für Änderungen in den drei rotatorischen Freiheitsgraden α, β, γ auf Null gesetzt bzw. auf einen sehr kleinen Maximalwert begrenzt werden;
  • - in einem darauffolgenden vierten Schritt des Zyklus nur der Soll-Wert für eine Änderungen in einem ersten der drei rotatorischen Freiheitsgraden α, β, γ unverändert weitergeleitet und die Soll-Werte für Änderungen in den anderen beiden der drei drei rotatorischen Freiheitsgraden α, β, γ sowie die Soll-Werte für Änderungen in den drei translatorischen Freiheitsgraden x, y, z auf Null gesetzt bzw. auf einen sehr kleinen Maximalwert begrenzt werden;
  • - in einem darauffolgenden fünften Schritt des Zyklus nur der Soll-Wert für eine Änderungen in einem zweiten der drei rotatorischen Freiheitsgraden α, β, γ unverändert weitergeleitet und die Soll-Werte für Änderungen in den anderen beiden der drei drei rotatorischen Freiheitsgraden α, β, γ sowie die Soll-Werte für Änderungen in den drei translatorischen Freiheitsgraden x, y, z auf Null gesetzt bzw. auf einen sehr kleinen Maximalwert begrenzt werden; und
  • - in einem darauffolgenden sechsten, letzten Schritt des Zyklus nur der Soll-Wert für eine Änderungen in einem dritten, letzten der drei rotatorischen Freiheitsgraden α, β, γ unverändert weitergeleitet und die Soll-Werte für Änderungen in den anderen beiden der drei rotatorischen Freiheitsgraden α, β, γ sowie die Soll-Werte für Änderungen in den drei translatorischen Freiheitsgraden x, y, z auf Null gesetzt bzw. auf einen sehr kleinen Maximalwert begrenzt werden.
In a modification that is not shown, the sequence of the steps can also be fixed, that is, for example, cyclically in each case
  • - In a first step of a cycle, only the target values for changes in three translational degrees of freedom x , y , z forwarded unchanged and the target values for changes in the three rotational degrees of freedom α , β , γ set to zero or limited to a very small maximum value;
  • - In a subsequent second step of the cycle, only the target value for a change in the rotational degree of freedom γ forwarded unchanged and the target values for changes in three translational degrees of freedom x , y , z and target values for changes in the two rotational degrees of freedom α , β set to zero or limited to a very small maximum value; and
  • - In a subsequent third, last step of the cycle, the target values for changes in the two rotational degrees of freedom α , β forwarded unchanged and the target values for changes in three translational degrees of freedom x , y , z and the target value for a change in the rotational degree of freedom γ set to zero or limited to a very small maximum value;
or cyclically each
  • - In a first step of a cycle, only the target value for a change in a first of the three translational degrees of freedom x , y , z forwarded unchanged and the target values for changes in the other two of the three translational degrees of freedom x , y , z as well as the target values for changes in the three rotational degrees of freedom α , β , γ set to zero or limited to a very small maximum value;
  • - In a subsequent second step of the cycle, only the target value for a change in a second of the three translational degrees of freedom x , y , z forwarded unchanged and the target values for changes in the other two of the three translational degrees of freedom x , y , z as well as the target values for changes in the three rotational degrees of freedom α , β , γ set to zero or limited to a very small maximum value;
  • - In a subsequent third step of the cycle, only the target value for a change in a third, last of the three translational degrees of freedom x , y , z forwarded unchanged and the target values for changes in the other two of the three translational degrees of freedom x , y , z as well as the target values for changes in the three rotational degrees of freedom α , β , γ set to zero or limited to a very small maximum value;
  • - In a subsequent fourth step of the cycle, only the target value for a change in a first of the three rotational degrees of freedom α , β , γ forwarded unchanged and the target values for changes in the other two of the three rotational degrees of freedom α , β , γ as well as the target values for changes in the three translational degrees of freedom x , y , z set to zero or limited to a very small maximum value;
  • - In a subsequent fifth step of the cycle, only the target value for a change in a second of the three rotational degrees of freedom α , β , γ forwarded unchanged and the target values for changes in the other two of the three rotational degrees of freedom α , β , γ as well as the target values for changes in the three translational degrees of freedom x , y , z set to zero or limited to a very small maximum value; and
  • - In a subsequent sixth, last step of the cycle, only the setpoint value for a change in a third, last of the three rotational degrees of freedom α , β , γ forwarded unchanged and the target values for changes in the other two of the three rotational degrees of freedom α , β , γ as well as the target values for changes in the three translational degrees of freedom x , y , z set to zero or limited to a very small maximum value.

3 zeigt ein künstliches Neuronales Netz 100 eines Reglers eines zu 1 analogen Systems zum Steuern eines Roboters nach einer weiteren Ausführung der vorliegenden Erfindung, so dass auf die vorstehende Beschreibung Bezug genommen und nachfolgend nur auf Unterschiede eingegangen wird. 3 shows an artificial neural network 100 a controller one to 1 analog system for controlling a robot according to a further embodiment of the present invention, so that reference is made to the above description and only differences are discussed below.

Das Neuronale Netz der Ausführung der 3 weist eine(n) Eingang(sschicht) 101 für Eingangs-, insbesondere Sensordaten, beispielsweise die Gelenkwinkel q1 - q7 sowie Gelenkmomente T1 - T7 , und mehrere Schichten 102 auf, die diese Eingangs- bzw. Sensordaten auf Ausgänge 103, beispielsweise die vorstehend erläuterten Änderungen in den drei translatorischen Freiheitsgraden x, y, z und in den drei rotatorischen Freiheitsgraden α, β, γ, abbilden und somit ein erstes Teilnetz des künstliches Neuronales Netzes 100 bilden.The neural network executing the 3 has an input (s) layer 101 for input, in particular sensor data, for example the joint angles q 1 - q 7 as well as joint moments T 1 - T 7 , and several layers 102 which these input or sensor data to outputs 103 , for example the changes explained above in the three translational degrees of freedom x , y , z and in the three rotational degrees of freedom α , β , γ , and thus a first sub-network of the artificial neural network 100 form.

Außerdem weist das Neuronale Netz in Art eines Seitenzweiges weitere Schichten 104 auf, die die Eingangs- bzw. Sensordaten auf so viele Ausgänge 105 abbilden wie maximal einzelne Aktionen durchgeführt werden sollen, und somit ein zweites Teilnetz des künstliches Neuronales Netzes 100 bilden.In addition, the neural network has further layers in the manner of a side branch 104 that the input or sensor data on so many outputs 105 map the maximum number of individual actions to be carried out, and thus a second sub-network of the artificial neural network 100 form.

Dadurch kann der Reinforcement Learning Algorithmus flexibel lernen, insbesondere über das zweite Teilnetz selektiv die Werte der Ausgänge 103 des ersten Teilnetzes näherungsweise oder absolut unverändert an eine Ausgabe 106 für das Operational Space Control Framework 22 weiterleiten oder näherungsweise oder absolut zu Null setzen.This allows the reinforcement learning algorithm to learn flexibly, in particular selectively the values of the outputs via the second subnetwork 103 of the first subnetwork approximately or absolutely unchanged to an output 106 for the Operational Space Control Framework 22nd forward or set approximately or absolutely to zero.

BezugszeichenlisteList of reference symbols

1010
Roboter(arm)Robot (arm)
1111
EndeffektorEnd effector
2020th
ReglerRegulator
2121st
künstliches Neuronales Netzartificial neural network
2222nd
Operational Space ControlOperational Space Control
100100
künstliches Neuronales Netzartificial neural network
101101
Eingang(sschicht)Entrance (shift)
102102
Schichten des ersten TeilnetzesLayers of the first subnet
103103
Ausgänge des ersten TeilnetzesOutputs of the first subnet
104104
Schichten des zweiten TeilnetzesLayers of the second subnet
105105
Ausgänge des zweiten TeilnetzesOutputs of the second subnet
106106
Ausgabeoutput
q1 - q7 q 1 - q 7
GelenkwinkelJoint angle
T1 - T7 T 1 - T 7
GelenkmomentJoint moment
x, y, zx, y, z
(Änderungen in) translatorische(n) kartesische(n) Freiheitsgrade(n)(Changes in) translational Cartesian degrees of freedom
α, β, γα, β, γ
(Änderungen in) rotatorische(n) kartesische(n) Freiheitsgrade(n)(Changes in) rotatory Cartesian degrees of freedom
P1, P2 P 1 , P 2
AuswahlparameterSelection parameters

Claims (13)

Verfahren zum Steuern eines Roboters (10), der eine Anzahl DoFvon steuerbaren Freiheitsgraden (x, y, z, α, β, γ) aufweist, wobei das Verfahren eine Mehrzahl von Schritten aufweist, wobei die Mehrzahl größer oder gleich zwei ist: - in einem oder mehreren ersten von Schritten (S10) der Mehrzahl von Schritten Änderungen in den Freiheitsgraden einer ersten Teilmenge der Freiheitsgrade, die wenigstens einen und höchstens DoF-1 der Freiheitsgrade aufweist, jeweils auf einen Maximalwert begrenzt sind, wobei dieser Maximalwert jeweils höchstens 10% eines Maximalwerts einer Änderung in dem jeweiligen Freiheitsgrad in wenigstens einem anderen der mehreren Schritte beträgt; und - in einem oder mehreren zweiten Schritten (S20) der Mehrzahl von Schritten Änderungen in den Freiheitsgraden einer zweiten Teilmenge der Freiheitsgrade, die wenigstens einen und höchstens DoF-1 der Freiheitsgrade aufweist und von der ersten Teilmenge wenigstens teilweise verschieden ist, jeweils auf einen Maximalwert begrenzt sind, wobei dieser Maximalwert jeweils höchstens 10% eines Maximalwerts einer Änderung in dem jeweiligen Freiheitsgrad in wenigstens einem anderen der mehreren Schritte beträgt; wobei wenigstens Änderungen in den Freiheitsgraden eines zur ersten Teilmenge komplementären ersten Rests der Freiheitsgrade in dem ersten Schritt bzw. den ersten Schritten und Änderungen in den Freiheitsgraden eines zur zweiten Teilmenge komplementären zweiten Rests der Freiheitsgrade in dem zweiten Schritt bzw. den zweiten Schritten von einem Regler (20) mittels maschinellen Lernens kommandiert werden.A method for controlling a robot (10) having a number DoF of controllable degrees of freedom (x, y, z, α, β, γ), the method comprising a plurality of steps, the plurality being greater than or equal to two: - In one or more first of steps (S10) of the plurality of steps, changes in the degrees of freedom of a first subset of the degrees of freedom, which has at least one and at most DoF-1 of the degrees of freedom, are each limited to a maximum value, this maximum value in each case at most 10 % of a maximum value of a change in the respective degree of freedom in at least one other of the plurality of steps; and - In one or more second steps (S20) of the plurality of steps, changes in the degrees of freedom of a second subset of the degrees of freedom, which has at least one and at most DoF-1 of the degrees of freedom and is at least partially different from the first subset, each limited to a maximum value are, this maximum value being at most 10% of a maximum value of a change in the respective degree of freedom in at least one other of the plurality of steps; in which at least changes in the degrees of freedom of a first remainder of the degrees of freedom complementary to the first subset in the first step or the first steps and changes in the degrees of freedom of a second remainder of the degrees of freedom complementary to the second subset in the second step or the second steps by a controller ( 20) can be commanded by means of machine learning. Verfahren nach Anspruch 1, dadurch gekennzeichnet, dass: - in einem oder mehreren dritten Schritten (S30) der Mehrzahl von Schritten Änderungen in den Freiheitsgraden einer dritten Teilmenge der Freiheitsgrade, die wenigstens einen und höchstens DoF-1 der Freiheitsgrade aufweist und von der ersten und zweiten Teilmenge wenigstens teilweise verschieden ist, jeweils auf einen Maximalwert begrenzt sind, wobei dieser Maximalwert jeweils höchstens 10% eines Maximalwerts einer Änderung in dem jeweiligen Freiheitsgrad in wenigstens einem anderen der mehreren Schritte beträgt; wobei Änderungen in den Freiheitsgraden eines zur dritten Teilmenge komplementären dritten Rests der Freiheitsgrade in dem dritten Schritt bzw. den dritten Schritten von dem Regler (20) mittels maschinellen Lernens kommandiert werden.Procedure according to Claim 1 , characterized in that: - in one or more third steps (S30) of the plurality of steps, changes in the degrees of freedom of a third subset of the degrees of freedom which has at least one and at most DoF-1 of the degrees of freedom and of the first and second subset at least partially is different, are each limited to a maximum value, this maximum value being at most 10% of a maximum value of a change in the respective degree of freedom in at least one other of the plurality of steps; changes in the degrees of freedom of a third remainder of the degrees of freedom, which is complementary to the third subset, in the third step or the third steps are commanded by the controller (20) by means of machine learning. Verfahren nach einem der vorhergehenden Ansprüche, dadurch gekennzeichnet, dass die DoF Freiheitsgrade kartesische Freiheitsgrade (x, y, z, α, β, γ) des Roboters aufweisen.Method according to one of the preceding claims, characterized in that the DoF degrees of freedom have Cartesian degrees of freedom (x, y, z, α, β, γ) of the robot. Verfahren nach dem vorhergehenden Anspruch, dadurch gekennzeichnet, dass wenigstens einer der Reste der Freiheitsgrade nur einen oder mehrere translatorische Freiheitsgrade (x, y, z) aufweist und/oder wenigstens einer der Reste der Freiheitsgrade nur einen oder mehrere rotatorische Freiheitsgrade (α, β, γ) aufweist und/oder wenigstens einer der Reste der Freiheitsgrade wenigstens einen translatorische und wenigstens einen rotatorischen Freiheitsgrad aufweist.Method according to the preceding claim, characterized in that at least one of the remainder of the degrees of freedom has only one or more translational degrees of freedom (x, y, z) and / or at least one of the remainder of the degrees of freedom has only one or more rotational degrees of freedom (α, β, γ) and / or at least one of the remainder of the degrees of freedom has at least one translational and at least one rotational degree of freedom. Verfahren nach einem der vorhergehenden Ansprüche, dadurch gekennzeichnet, dass wenigstens einer der Maximalwerte, auf den eine Änderung in einem Freiheitsgrad einer der Teilmengen begrenzt ist, gleich Null ist und/oder wenigstens einer der Maximalwerte, auf den eine Änderung in einem Freiheitsgrad einer der Teilmengen begrenzt ist, von Null verschieden ist.Method according to one of the preceding claims, characterized in that at least one of the maximum values to which a change in a degree of freedom of one of the subsets is limited is equal to zero and / or at least one of the maximum values to which a change in a degree of freedom of one of the subsets is is limited, is different from zero. Verfahren nach einem der vorhergehenden Ansprüche, dadurch gekennzeichnet, dass der Regler (20) die Änderungen mittels Operational Space Control (22) kommandiert.Method according to one of the preceding claims, characterized in that the controller (20) commands the changes by means of operational space control (22). Verfahren nach einem der vorhergehenden Ansprüche, dadurch gekennzeichnet, dass eine Reihenfolge der Schritte fest vorgegeben ist oderdurch den Regler variabel vorgegeben wird.Method according to one of the preceding claims, characterized in that a sequence of the steps is fixed or is variably predetermined by the controller. Verfahren nach dem vorhergehenden Anspruch, dadurch gekennzeichnet, dass der Regler die Reihenfolge der Schritte mittels wenigstens eines Auswahlparameters (P1, P2) vorgibt.Method according to the preceding claim, characterized in that the controller specifies the sequence of the steps by means of at least one selection parameter (P 1 , P 2 ). Verfahren nach einem der vorhergehenden Ansprüche, dadurch gekennzeichnet, dass die Freiheitsgrade wenigstens einer der Teilmengen bzw. wenigstens eines der Reste fest vorgegeben sind und/oder die Freiheitsgrade wenigstens einer der Teilmengen bzw. wenigstens eines der Reste durch den Regler variabel vorgegeben werden.Method according to one of the preceding claims, characterized in that the degrees of freedom of at least one of the subsets or at least one of the remainders are fixed and / or the degrees of freedom of at least one of the subsets or at least one of the remainders are variably predefined by the controller. Verfahren nach einem der vorhergehenden Ansprüche, dadurch gekennzeichnet, dass der Regler die Änderungen mittels Reinforcement Learning kommandiert und/oder die Reihenfolge der Schritte und/oder die Freiheitsgrade wenigstens einer der Teilmengen bzw. wenigstens eines der Reste mittels Reinforcement Learning vorgibt und/oder wenigstens ein künstliches neuronales Netz (21; 100) aufweist.Method according to one of the preceding claims, characterized in that the controller commands the changes by means of reinforcement learning and / or specifies the sequence of the steps and / or the degrees of freedom of at least one of the subsets or at least one of the remainder by means of reinforcement learning and / or at least one artificial neural network (21; 100). Verfahren nach dem vorhergehenden Anspruch, dadurch gekennzeichnet, dass der das künstliche neuronale Netz (100) ein erstes Teilnetz (102, 103), das auf Basis von Eingangsdaten (q1 - q7, T1 - T7) Soll-Änderungen in den DoF Freiheitsgraden ermittelt, und ein zweites Teilnetz (104, 105) aufweist, das auf Basis der Eingangsdaten die Soll-Änderungen in den Freiheitsgraden der jeweiligen Teilmenge auf den jeweiligen Maximalwert begrenzt.Method according to the preceding claim, characterized in that the artificial neural network (100) is a first sub-network (102, 103), which on the basis of input data (q 1 - q 7 , T 1 - T 7 ) determines target changes in the DoF degrees of freedom, and has a second subnetwork (104, 105) which, based on the input data, has the Target changes in the degrees of freedom of the respective subset limited to the respective maximum value. System zum Steuern eines Roboters), der eine Anzahl DoF von steuerbaren Freiheitsgraden (x, y, z, α, β, γ) aufweist, wobei das System zur Durchführung eines Verfahrens nach einem der vorhergehenden Ansprüche eingerichtet ist.System for controlling a robot) which has a number DoF of controllable degrees of freedom (x, y, z, α, β, γ), the system being set up to carry out a method according to one of the preceding claims. Computerprogrammprodukt mit einem Programmcode, der auf einem von einem Computer lesbaren Medium gespeichert ist, zur Durchführung eines Verfahrens nach einem der vorhergehenden Ansprüche 1 bis 11.Computer program product with a program code, which is stored on a medium readable by a computer, for carrying out a method according to one of the preceding Claims 1 to 11 .
DE102019213676.1A 2019-09-10 2019-09-10 Robot control Active DE102019213676B3 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
DE102019213676.1A DE102019213676B3 (en) 2019-09-10 2019-09-10 Robot control

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
DE102019213676.1A DE102019213676B3 (en) 2019-09-10 2019-09-10 Robot control

Publications (1)

Publication Number Publication Date
DE102019213676B3 true DE102019213676B3 (en) 2020-09-17

Family

ID=72289669

Family Applications (1)

Application Number Title Priority Date Filing Date
DE102019213676.1A Active DE102019213676B3 (en) 2019-09-10 2019-09-10 Robot control

Country Status (1)

Country Link
DE (1) DE102019213676B3 (en)

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE102016012227A1 (en) * 2016-10-13 2017-04-20 Daimler Ag Method for automatic position correction of a robot arm
DE202017105598U1 (en) * 2016-09-15 2018-05-24 Google LLC (n.d.Ges.d. Staates Delaware) Deep reinforcement learning system for robotic manipulation
DE102017011361A1 (en) * 2016-12-16 2018-06-21 Fanuc Corporation MACHINE LEARNING DEVICE, ROBOT SYSTEM AND MASCHINAL LEARNING METHOD FOR LEARNING THE OPERATION OF A ROBOT AND A LASER SCANNER
DE102018001026A1 (en) * 2017-02-15 2018-08-16 Fanuc Corporation ROBOTIC SYSTEM WITH A LEARNING CONTROL FUNCTION AND LEARNING CONTROL PROCEDURE
DE102018009008A1 (en) * 2017-11-22 2019-05-23 Fanuc Corporation Control device and machine learning device
DE102019001207A1 (en) * 2018-02-19 2019-08-22 Boll Automation Gmbh Collaborative robot and method for operating a collaborative robot and use for machining a workpiece

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE202017105598U1 (en) * 2016-09-15 2018-05-24 Google LLC (n.d.Ges.d. Staates Delaware) Deep reinforcement learning system for robotic manipulation
DE102016012227A1 (en) * 2016-10-13 2017-04-20 Daimler Ag Method for automatic position correction of a robot arm
DE102017011361A1 (en) * 2016-12-16 2018-06-21 Fanuc Corporation MACHINE LEARNING DEVICE, ROBOT SYSTEM AND MASCHINAL LEARNING METHOD FOR LEARNING THE OPERATION OF A ROBOT AND A LASER SCANNER
DE102018001026A1 (en) * 2017-02-15 2018-08-16 Fanuc Corporation ROBOTIC SYSTEM WITH A LEARNING CONTROL FUNCTION AND LEARNING CONTROL PROCEDURE
DE102018009008A1 (en) * 2017-11-22 2019-05-23 Fanuc Corporation Control device and machine learning device
DE102019001207A1 (en) * 2018-02-19 2019-08-22 Boll Automation Gmbh Collaborative robot and method for operating a collaborative robot and use for machining a workpiece

Similar Documents

Publication Publication Date Title
DE102015004932B4 (en) Simulation device for several robots
EP2987592B1 (en) Method for programming an industrial robot and associated industrial robot
DE102016013731A1 (en) Robotic system with features to simplify training and improve operational performance through learning
DE102016108077B4 (en) Method for setting load parameters and device for setting load parameters
DE102014202145A1 (en) A method of programming an industrial robot and associated industrial robots
DE202015105595U1 (en) Absolute robot-assisted positioning method
DE102019006725B4 (en) control device and control system
EP3966731A1 (en) Machine learning an object detection process using a robot-guided camera
DE102011108282A1 (en) Numerical control for a multi-axis machine for machining a tilted working plane
DE102019118637A1 (en) AUTOMATIC PATH GENERATION DEVICE
DE102019205651B3 (en) Method and system for carrying out robot applications
DE102019000890B4 (en) Robot system for executing learning control based on machining results and related control method
DE102018112370B4 (en) Directional collision detection for a robot manipulator
DE102017213651A1 (en) Handling device with a robot and method and computer program
EP3471928A1 (en) Configuring and/or controlling a robot arrangement
EP3802013A1 (en) Force control for a robot
DE102019213676B3 (en) Robot control
EP3710900B1 (en) Method and system for defining or learning a robot command
DE102014207067A1 (en) Method for the partially automated production of workpieces at a MRK workstation and associated MRK workstation
DE102018207919B3 (en) robot control
DE102020200165A1 (en) Robot control device and method for controlling a robot
DE102019007382A1 (en) Numerical control
DE112008003870T5 (en) A method and system for controlling an industrial robot in accordance with a motion control parameter set
WO2023072630A2 (en) Method and system for controlling a load-carrying robot and for determining a parameter of the load of the robot
DE102020209866B3 (en) Method and system for operating a robot

Legal Events

Date Code Title Description
R012 Request for examination validly filed
R016 Response to examination communication
R018 Grant decision by examination section/examining division
R020 Patent grant now final