DE102009006256A1 - Verfahren zur Vermeidung von Kollisionen gesteuert beweglicher Teile einer Anlage - Google Patents

Verfahren zur Vermeidung von Kollisionen gesteuert beweglicher Teile einer Anlage Download PDF

Info

Publication number
DE102009006256A1
DE102009006256A1 DE102009006256A DE102009006256A DE102009006256A1 DE 102009006256 A1 DE102009006256 A1 DE 102009006256A1 DE 102009006256 A DE102009006256 A DE 102009006256A DE 102009006256 A DE102009006256 A DE 102009006256A DE 102009006256 A1 DE102009006256 A1 DE 102009006256A1
Authority
DE
Germany
Prior art keywords
braking
vehicle
controlled
distance
volume
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.)
Granted
Application number
DE102009006256A
Other languages
English (en)
Other versions
DE102009006256B4 (de
Inventor
Udo Frese
Holger Täubig
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.)
Deutsches Forschungszentrum fuer Kuenstliche Intelligenz GmbH
Original Assignee
Deutsches Forschungszentrum fuer Kuenstliche Intelligenz 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 Deutsches Forschungszentrum fuer Kuenstliche Intelligenz GmbH filed Critical Deutsches Forschungszentrum fuer Kuenstliche Intelligenz GmbH
Priority to DE102009006256.4A priority Critical patent/DE102009006256B4/de
Priority to PCT/DE2010/000090 priority patent/WO2010085944A1/de
Publication of DE102009006256A1 publication Critical patent/DE102009006256A1/de
Application granted granted Critical
Publication of DE102009006256B4 publication Critical patent/DE102009006256B4/de
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

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/1674Programme controls characterised by safety, monitoring, diagnostic
    • B25J9/1676Avoiding collision or forbidden zones
    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B2219/00Program-control systems
    • G05B2219/30Nc systems
    • G05B2219/39Robotics, robotics to robotics hand
    • G05B2219/39082Collision, real time collision avoidance
    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B2219/00Program-control systems
    • G05B2219/30Nc systems
    • G05B2219/39Robotics, robotics to robotics hand
    • G05B2219/39097Estimate own stop, brake time, then verify if in safe distance
    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B2219/00Program-control systems
    • G05B2219/30Nc systems
    • G05B2219/49Nc machine tool, till multiple
    • G05B2219/49141Detect near collision and slow, stop, inhibit movement tool
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02PCLIMATE CHANGE MITIGATION TECHNOLOGIES IN THE PRODUCTION OR PROCESSING OF GOODS
    • Y02P90/00Enabling technologies with a potential contribution to greenhouse gas [GHG] emissions mitigation
    • Y02P90/02Total factory control, e.g. smart factories, flexible manufacturing systems [FMS] or integrated manufacturing systems [IMS]

Landscapes

  • Engineering & Computer Science (AREA)
  • Robotics (AREA)
  • Mechanical Engineering (AREA)
  • Control Of Position, Course, Altitude, Or Attitude Of Moving Bodies (AREA)
  • Manipulator (AREA)

Abstract

Verfahren zur Vermeidung von Kollisionen gesteuert beweglicher Teile einer Anlage mit einer Anlagensteuerung, wobei das oder die gesteuert bewegliche(n) Teil(e) aus mindestens zwei durch einen gesteuert beweglichen Mechanismus verbundenen starren Körpern besteht/bestehen und an jedem Körper ein körperfestes 3-D-Koordinatensystem definiert wird und jeder Körper in besagtem körperfesten 3-D-Koordinatensystem als 3-D-Volumen beschrieben und das 3-D-Volumen als konvexe Hülle einer endlichen Menge von Punkten (p)zzgl. eines Pufferradius r > = 0 nach der Definition $F1 dargestellt wird.

Description

  • Die vorliegende Erfindung betrifft ein Verfahren zur Vermeidung von Kollisionen gesteuert beweglicher bzw. bewegter Teile einer Anlage (Anlagenteile), insbesondere von Roboterarmen und Fahrzeugen, speziell von fahrerlosen Transportsystemen (FTS), und ganz allgemein ein Verfahren zur Vermeidung von Kollisionen gesteuert relativ zueinander beweglicher bzw. bewegter Objekte. Insbesondere dient das Verfahren dazu, gesteuert bewegte Teile einer Anlage zu überwachen und rechtzeitig einen Halt auszulösen, bevor diese miteinander oder mit anderen (unbeweglichen) Teilen bzw. der unbeweglichen Umgebung kollidieren. Gesteuert bewegliche Teile in diesem Sinne sind insbesondere, aber nicht ausschließlich: a) Roboterar me, Achsentische, Portalkräne oder allgemein jede zyklenfreie Hintereinanderschaltung von rotatorischen oder linearen Gelenken und außerdem b) Fahrzeuge und Fahrzeuge, auf denen solche Hintereinanderschaltungen von Gelenken montiert sind.
  • Es gibt sehr ausgefeilte Lösungen für a-priori-Bahnplanung, bei denen die Bahn im Computer auf Kollision getestet und dann in eine Anlage (z. B. einen Roboterarm) geladen wird. Dazu bedarf es aber einer festen Bahn. Bei einer manuellen oder sensorgeführten Steuerung der Roboterbewegung geht dies nicht.
  • Zum Stand der Technik gehört ebenfalls das Testen der aktuellen Stellung eines Roboters auf Distanz zu Hindernissen, so dass in einem festen Sicherheitsabstand zum Hindernis gebremst werden kann. Dies ist aber nur für kleine Geschwindigkeiten praktikabel. Unterschiedliche Teile des Roboters bewegen sich nämlich sehr unterschiedlich schnell und brauchen sehr unterschiedliche Bremswege. Außerdem hat der Bremsweg eine Richtung, nämlich die Bewegungsrichtung, während ein Sicherheitsabstand in allen Richtungen und an allen Punkten eines Roboters gleich wirkt. Dadurch wird bei höheren Geschwindigkeiten der Sicherheitsabstand so konservativ, dass das System oft stockt, obwohl dies unnötig wäre.
  • US-6,678,582 von W. El-Houssaine, „Method and control device for avoiding collisions between cooperating robots”, schlägt vor, statt der aktuellen Stellung die Stellung auf Kollision zu testen, bei der ein Roboter anhalten wird. Das ist besser, weil es keinen Sicherheitsabstand in allen Richtungen aufschlägt, sondern die Bewegungsrichtung berücksichtigt. Es ist aber nicht wirklich sicher, weil es nicht ausschließt, dass es während des Bremens zu einer Kollision kommt, die am nominellen Haltepunkt dann schon wieder vorbei wäre. Das ist praktisch unerwünscht, vor allen Dingen aber entsteht dadurch ein (rechtliches) Risiko, das Hersteller nicht eingehen möchten.
  • Da viele Lösungen sehr rechenintensiv sind, existieren bereits viele Ansätze zur Reduzierung der Rechenzeit. Werden Roboter und Umgebung in n Teile zerlegt, müssen im Prinzip n2 Paa re auf Kollision getestet werden. In dem US-Patent Nr. 5,056,031 von M. Nakano et al., „Apparatus for detecting the collision of moving objects”, wird eine Hierarchie von Volumina aufgebaut, so dass, wenn ein Paar von Obervolumina eine bestimmte Distanz hat, alle ihre Paare von Untervolumina mindestens dieselbe Distanz haben. Diese Strategie funktioniert gut, ist aber nicht ganz einfach zu implementieren. Außerdem hängt die Rechenzeit von der Stellung des Roboters ab. Weiterhin ist es bei solchen Hierarchien schwierig, Bremswege mit einzubeziehen, weil sich dann die auf Kollision zu überprüfenden Volumina mit dem Betriebszustand des Roboters ändern und es unmöglich wird, Hilfsinformationen aus der Robotergeometrie vorab zu berechnen.
  • Der vorliegenden Erfindung liegt somit die Aufgabe zugrunde, ein Verfahren zur Vermeidung von Kollisionen gesteuert relativ zueinander bewegter Objekte, insbesondere Anlagenteile, wie Roboterarme und fahrerloser Transportsysteme, bereitzustellen, das Bremswege detailliert mit einbezieht und bei vergleichbarer Rechengenauigkeit gegenüber dem Stand der Technik weniger Rechenzeit benötigt.
  • Erfindungsgemäß wird diese Aufgabe gelöst durch ein Verfahren zur Vermeidung von Kollisionen gesteuert beweglicher Teile einer Anlage mit einer Anlagensteuerung, wobei das oder die gesteuert bewegliche(n) Teile(e) aus mindestens zwei durch einen gesteuert beweglichen Mechanismus verbundenen starren Körpern besteht/bestehen und an jedem Körper ein körperfestes 3D-Koordinatensystem definiert wird und jeder Körper in besagtem körperfesten 3D-Koordinatensystem als 3D-Volumen beschrieben und das 3D-Volumen als konvexe Hülle einer endlichen Menge von Punkten (pi)n i=1 zzgl. eines Pufferradius r >= 0 nach der Definition
    Figure 00030001
    dargestellt wird, umfassend die Durchführung der nachfolgenden Schritte in jedem Takt der Anlagensteuerung:
    • a) für jeden gesteuert beweglichen Mechanismus Bestimmen einer Grenze bzgl. seiner Position, innerhalb derer er bei einer sofortigen Bremsung zum Stillstand kommen würde,
    • b) für jeden Körper der Anlage Berechnen von Bremszonen als 3D-Volumina in der Darstellung nach (1) im körperfesten und im weltfesten 3D-Koordinatensystem und in allen Koordinatensystemen dazwischen in der Kette gesteuert beweglicher Mechanismen, die den jeweiligen Körper mit der weltfesten Umgebung verbinden, wobei die Bremszonen berechnet werden, indem, von der bekannten Darstellung nach (1) des Körpers startend, sukzessive der Effekt jedes gesteuert beweglichen Mechanismus entlang dieser Kette eingerechnet wird, indem für jeden ursprünglichen Punkt pi seine Bewegung beim Bremsen des gesteuert beweglichen Mechanismus nach a) durch ein Volumen V(ri; (pij)j=1 n), dargestellt mit Pufferradien ri und Punktenpij, nach (1) überdeckt wird, die resultierenden Punkte zu einer konvexen Hülle zusammengeführt werden und der ursprüngliche Pufferradius um das Maximum der ri erhöht wird,
    • c) Bestimmen über alle Paare von Körpern die Distanz zwischen ihren Bremszonen in einem gemeinsamen, insbesondere im ersten gemeinsamen, Koordinatensystem der beiden in b) auftretenden Ketten von gesteuert beweglichen Mechanismen,
    • d) wenn mindestens eine der bestimmten Distanzen den Wert Null aufweist, Anhalten oder Verlangsamen zumindest eines Teilbereichs der Anlage.
  • Das Verfahren verhindert jegliche Kollision von Körpern der Anlage, sowohl verschiedener gesteuert beweglicher Teile miteinander, als auch eine Selbstkollision eines gesteuert beweglichen Teils, wie z. B. einem Roboterarm.
  • Gemäß einer besonderen Ausführungsform der Erfindung sind die Körper in dem jeweiligen 3D-Volumen, das nach (1) dargestellt ist, nur enthalten und werden sie nicht direkt dargestellt. Dadurch wird unverändert eine Kollision der Körper verhindert, da das Verfahren eine Kollision der 3D-Volumina, in denen sie enthalten sind, verhindert, aber das 3D-Volumen kann geometrisch einfacher gestaltet sein als der Körper selbst, wodurch in (1) weniger Punkte benötigt und Rechenzeit gespart wird.
  • Weiterhin kann vorgesehen sein, dass ein oder mehrere Körper in der Vereinigung von mehreren 3D-Voluminaen, die nach (1) dargestellt sind, enthalten sind und für die Berechnungen in Schritt b) alle diese drei 3D-Volumina verwendet werden. Dies erlaubt, nicht konvexe Körper darzustellen, indem sie in konvexe 3D-Volumina unterteilt werden.
  • Gemäß einer weiteren besonderen Ausführungsform der Erfindung kann vorgesehen sein, dass der bzw. mindestens ein gesteuert beweglicher Mechanismus ein Drehgelenk mit Antrieb und Winkelpositionssensor umfasst.
  • Günstigerweise wird für ein Drehgelenk folgende Formel in Schritt b) benutzt:
    Figure 00050001
    mit pλi = Rot(a, (1 – λ)θ0 + λθ1)pi oder
    Figure 00060001
    mit d = 1 – cosϕoder
    Figure 00060002
    oder V(r, (p0i , p1i ' qi)ni=1 ),mit
    Figure 00070001
    wobei θ0 die Unter- und θ1 die Obergrenze aus Schritt a) für die Winkelposition des betrachteten Drehgelenkes ist und V(r, (pi)n i=1) die Darstellung der Bremszone vor Einrechnung des Effektes des Drehgelenkes ist.
  • Auch kann vorgesehen sein, dass der bzw. mindestens ein gesteuert beweglicher Mechanismus ein Lineargelenk mit Antrieb und Positionssenor umfasst.
  • Vorteilhafterweise wird für ein Lineargelenk folgende Formel in Schritt b) benutzt:
    Figure 00070002
    oder V(r; (pi + t0a,pi + t1a)ni=1 ),wobei t0 die Unter- und t1 die Obergrenze aus Schritt a) für die Position des betrachteten Lineargelenkes ist und V(r, (pi)n i=1) die Darstellung der Bremszone vor Einrechnung des Effektes des Lineargelenkes ist.
  • Alternativ oder zusätzlich kann der bzw. mindestens ein gesteuert beweglicher Mechanismus ein Fahrwerk eines Fahrzeugs mit angetriebenen und/oder gelenkten Rädern und Positionssensor umfassen. Selbstverständlich kann das Fahrzeug auch einen anderen Antrieb, wie z. B. einen Kettenantrieb, aufweisen.
  • Insbesondere kann dabei vorgesehen sein, dass für ein Fahrzeug die Grenze nach Schritt a) als Untermenge seines Konfigurationsraums definiert wird, wobei der Konfigurationsraum aus dreidimensionalen Vektoren besteht, deren ersten beiden Komponenten die x- und y-Position eines gewählten Referenzpunktes des Fahrzeuges angeben und dessen dritte Komponente θ den Winkel der Orientierung des Fahrzeugs angibt und wobei besagte Untermenge als konvexe Hülle von endlich vielen Konfigurationen (kj)j=1 m im Konfigurationsraum dargestellt wird:
    Figure 00080001
    wobei die Komponenten der Konfigurationen kj wie folgt bezeichnet werden:
    Figure 00080002
  • Vorteilhafterweise kann vorgesehen sein, dass für ein Fahrzeug folgende Formel für die Einberechnung des Effektes des Fahrzeugbremsens verwendet wird:
    Figure 00080003
    Figure 00090001
    wobei V(r, (pi)n i=1) die Darstellung der Bremszone vor Einrechnung des Effektes dieses Fahrzeugs ist.
  • Insbesondere kann dabei vorgesehen, dass für ein Fahrzeug die Grenze seiner Position nach Schritt a) als zurückgelegte Strecke s und vollzogener Drehwinkel α definiert wird, wobei
    Figure 00090002
    die Position des Fahrzeugs nach dem Bremsen (120) relativ zur Position vor dem Bremsen (122) als homogene Matrix angibt.
  • Gemäß einer weiteren besonderen Ausführungsform kann vorgesehen sein, dass für ein Fahrzeug folgende Formel für die Einberechnung des Effektes des Fahrzeugbremsens verwendet wird: V(r, (p0i , p1i , qi)ni=1 mit pλi = T(λs, λα)·pi und qi = p0i + Q(α)·12 (p1i + p0i )und
    Figure 00100001
    oder mit qλi = T(λs, λα)·q01 ,wobei V(r, (pi)n i=1) die Darstellung der Bremszone vor Einrechnung des Effektes dieses Fahrzeugs ist, h eine natürliche Zahl ist und die Multiplikation von T(s, α) und Q(α) mit einem 3D-Vektor im Sinne einer homogenen Matrix durch Anfügen einer 1 interpretiert wird. Die Zahl h ist dabei ein frei wählbarer Qualitätsparameter. Je größer h ist, desto exakter ist die Näherung, aber auch desto mehr Punkte entstehen und desto größer ist die Rechenzeit.
  • Gemäß einer weiteren besonderen Ausführungsform der Erfindung weist die Anlage Körper auf, die durch verschiedene gesteuert bewegliche Mechanismen verbunden sind.
  • Vorteilhafterweise werden in Schritt a) Messunsicherheiten der Positionsgeber auf die Grenzen aufgeschlagen.
  • Alternativ oder zusätzlich werden vorteilhafterweise in Schritt a) Reaktionszeiten bei der Bestimmung der Grenzen aufgeschlagen.
  • Insbesondere kann dabei vorgesehen sein, dass der Aufschlag ein Produkt aus Reaktionszeit und Geschwindigkeit umfasst.
  • Zweckmäßigerweise wird zum Pufferradius die Hälfte eines globalen Sicherheitsabstands addiert.
  • Gemäß einer besonderen Ausführungsform der Erfindung werden in Schritt c) die Distanzen mittels des GJK(Gilbert-Johnson-Keerthi)-Algorithmus bestimmt. Es können aber auch andere Algorithmen verwendet werden.
  • In einer besonders bevorzugten Ausführungsform kann vorgesehen sein, dass es über mindestens zwei Takte der Anlagensteuerung durchgeführt wird und in Schritt c) für jede Bremszone i deren Änderung seit dem letzten Takt als pauschaler Änderungsradius δri abgeschätzt und daraus eine Schranke für die Distanzen aller Paare von Bremszonen hergeleitet wird, indem von der Distanz der Paare von Bremszonen i und j aus dem letzten Takt die Änderungsradien δri + δrj abgezogen werden, sowie eine feste Anzahl von Iterationen des GJK-Algorithmus durchgeführt wird, zuerst für die Paare von Bremszonen, bei denen die berechnete Distanz den Wert 0 aufweist, danach reihum, und wenn danach immer noch die Distanz eines Paares den Wert 0 aufweist, zumindest ein Teilbereich der Anlage angehalten oder verlangsamt wird. Auf diese Weise lässt sich die Rechenzeit besonders stark reduzieren und auf einen festen Wert beschränken. Letzteres ermöglicht erst bzw. erleichtert die Integration des Verfahrens in eine Anlagen- bzw. Robotersteuerung.
  • Insbesondere kann als pauschaler Änderungsradius einer Bremszone j die folgende Formel verwendet werden:
    Figure 00120001
    wobei V(r, (pi)n i=1) die Darstellung der Bremszone j im letzten Takt und V(r', (pi')n i=1) die Darstellung der Bremszone j im aktuellen Takt ist.
  • Weiterhin kann vorgesehen sein, dass die Positionsgeber Linear- oder Winkelgeber sind.
  • Vorteilhafterweise wird aus mindestens einer für einen Körper berechneten Bremszone ein Schutzfeld für einen an besagtem Körper angebrachten Laserscanner berechnet. Dadurch wird das Verfahren auf von einem Laserscanner sensoriell erfasste Hindernisse, insbesondere Personen, erweitert.
  • Günstigerweise wird zur Berechnung des Schutzfeldes das 3D-Volumen der Bremszone in eine vorzugsweise horizontale Ebene transformiert oder projiziert.
  • Günstigerweise kann auf die Grenzen in Schritt a) ein zusätzlicher Aufschlag erfolgen, um frühzeitiger und sanfter anzuhalten.
  • Zweckmäßigerweise können vorher festgelegte Paare von Körpern von der Bestimmung der Distanz in c) und der Überprüfung in d) ausgenommen werden, weil ihre Kollision zur plan mäßigen Arbeit der Anlage gehört. Insbesonders gilt dies für Paare von Körpern, die durch einen gesteuert beweglichen Mechanismus verbunden sind, weil sie sich an der Stelle, wo dieser Mechanismus sitzt, automatisch berühren.
  • Der Erfindung liegt die überraschende Erkenntnis zugrunde, dass durch die spezielle Darstellung der Körper, nämlich als konvexe Hüllen mit Pufferradius, und durch die dadurch mögliche spezielle Berechnung der Bremszonen eine geringere Datenmenge und damit ein geringerer Rechenaufwand zur Berechnung von Kollisionen erforderlich sind.
  • Die Verfahren gemäß den Ansprüchen 1 bis 21 arbeiten ausschließlich auf einer vorkonfigurierten Geometrie, d. h. auf einer bekannten Geometrie der Anlage, also der beweglichen Teile, Werkstücke und Umgebung, und gemessenen Positionen und verwenden keine sensorielle Erfassung von Hindernissen. Die Verwendung der Bremszonen zur Bestimmung von Schutzfeldern gemäß besonderen Ausführungsformen in Ansprüchen 22 und 23 der Erfindung dienen zusätzlich der sensoriellen Absicherung von Personen vor Kollisionen mit Teilen einer Anlage, insbesondere mit Roboterarmen und FTS bzw. Fahrzeugen.
  • Weitere Merkmale und Vorteile der Erfindung ergeben sich aus den beigefügten Ansprüchen und der nachfolgenden Beschreibung, in der Ausführungsbeispiele anhand der schematischen Zeichnungen im einzelnen erläutert sind, in denen:
  • 1 eine schematische Darstellung einer beispielhaften Anwendungssituation für das erfindungsgemäße Verfahren in einer Anlage (Industrieanlage) zeigt;
  • 2 beispielhaft die Darstellung eines 3D-Volumens nach (1) zeigt;
  • 3 zwei Näherungsmöglichkeiten für die Berechnung der Bremszone eines Drehgelenks zeigt;
  • 4 zwei weitere Näherungsmöglichkeiten für die Berechnung der Bremszone eines Drehgelenks zeigt;
  • 5 eine weitere Näherungsmöglichkeit für die Berechnung der Bremszone eines Drehgelenks zeigt;
  • 6 bis 9 Schritte der Berechnung der Bremszonen von Teilen einer Anlage in verschiedenen Koordinatensystemen zeigen;
  • 10 eine Bremszone in zwei aufeinanderfolgenden Takten einer Anlagensteuerung zeigt;
  • 11 ein Fahrzeug beim Bremsen entlang einer Kreisbahn und die dabei relevanten Koordinatensysteme zeigt; und
  • 12 zwei Näherungsmöglichkeiten zur Berechnung der Bremszone eines Fahrzeugs zeigt.
  • 1 zeigt eine Anlage, die folgende Anlagenteile umfasst: Ein Fahrzeug 10, einen Roboterarm 12 auf dem Fahrzeug 10, einen stationären Roboterarm 14, ein Förderband 16 und eine Trennwand 18. Die Anlagenteile bestehen aus starren Körpern, von denen lediglich einige beispielhaft mit der Bezugszahl 19 gekennzeichnet sind, an denen jeweils ein 3D-Koordinatensystem festgelegt ist (s. Dreiergruppen von Pfeilen in der Figur). Die Körper sind jeweils durch gesteuert bewegliche Mechanismen, d. h. Mechanismen zur gesteuerten Bewegung, verbunden (in der Figur in den Ursprüngen der Koordinatensysteme). Die Drehgelenke der Roboterarme 12 und 14, das Fahrzeug 10 und das Förderband 16 stellen in diesem Beispiel die gesteuert beweglichen Mechanismen dar. Für den unbeweglichen Teil der Anlage ist ein weltfestes Koordinatensystem (Weltkoordinatensystem) 20 definiert.
  • Nachfolgend werden zuerst Verfahren zur Vermeidung von Kollisionen gesteuert beweglicher Teile einer Anlage ohne Berücksichtigung von Fahrzeugen und ohne Berücksichtigung von sensoriell erfassten Personen als Hindernisse beschrieben. Die Verfahren lassen sich grob wie folgt skizzieren:
  • Überblick
  • Vor Inbetriebnahme des Systems wird die Geometrie der Anlage einkonfiguriert. Sie wird als eine Menge starrer, konvexer Körper, die gegebenenfalls durch gesteuert bewegliche Mechanismen, hier bewegliche Gelenke, verbunden sind, dargestellt.
  • Die nachfolgenden Schritte a)–d) werden in jedem Takt einer Anlagensteuerung durchgeführt:
    • a) Für jeden gesteuert beweglichen Mechanismus wird aus dem Messwert des Positionsgebers und dessen Ableitung der Bremsweg, d. h. eine Grenze bzgl. seiner Position, innerhalb derer er bei einer sofortigen Bremsung zum Stillstand kommen würde, berechnet. Hat ein Gelenk nur einen Freiheitsgrad, ist die Grenze ein Intervall, beispielsweise für ein Drehgelenk ein Winkelintervall oder für ein Lineargelenk ein Streckenintervall. Unsicherheiten im Positionsgeber können hier aufgeschlagen werden.
    • b) Mit Hilfe der in Schritt a) bestimmten Grenzen werden für jeden Körper Bremszonen, also die beim Bremsen überstrichenen 3D-Volumina berechnet („swept volume”). Dazu wird jeder Körper schrittweise von seinem körperfesten Koordinatensystem ins weltfeste Koordinatensystem überführt entlang der Kette gesteuert beweglicher Mechanismen, die den jeweiligen Körper mit der weltfesten Umgebung verbinden. Bei jedem dieser Schritte wird der Effekt des jeweils betrachteten gesteuert beweglichen Mechanismus mit einberechnet. Verfahren, die dies für die verschiedenen Arten gesteuert beweglicher Mechanismen leisten, werden im folgenden beschrieben.
    • c) Für alle (relevanten) Paare von Körpern wird die Distanz zwischen ihren Bremszonen in einem gemeinsamen Koordinatensystem, zweckmässigerweise im ersten gemeinsamen, bestimmt. Dazu kann der GJK-Algorithmus verwendet werden. Dieser ist bspw. in E. Gilbert, D. Johnson, S. Keerthi, „A fast procedure for computing the distance between complex objects in 3D space", IEEE Journal an Robotics and automation, Band 4, Nr. 2, 1988, und C. Ericson, "The Gilbert-Johnson-Keerthi (GJK) algorithm", in Sicgraph Conference Plenary Talk, 2004, beschrieben, deren Inhalt durch Bezugnahme hierin voll umfänglich aufgenommen wird.
    • d) Ergibt sich für mindestens eine der Distanzen der Wert 0, wird die Anlage gestoppt oder verlangsamt.
  • Der Schlüsselbegriff im Verfahren ist der Begriff der Bremszone eines bestimmten Körpers in einem bestimmten Koordinatensystem. Dies ist abstrakt ein 3D-Volumen bestehend aus allen Punkten in besagtem Koordinatensystem, die sich bei zumindest einer Kombination von Positionen für die gesteuert beweglichen Mechanismen der Anlage in besagtem Körper befinden, wobei sich jede Position innerhalb der in a) bestimmten Grenzen bewegt. Anschaulich ist dies das Volumen in besagtem Koordinatensystem, das von besagtem Körper überdeckt wird („swept volume”), wenn die gesteuert beweglichen Mechanismen der Anlage sich innerhalb der in a) bestimmten Grenzen bewegen.
  • Diese Vorgehensweise wurde z. B. von A. Fuhrmann und E. Schömer, „A general method for computing the regional space of mechanisms", Proceedings of the ASME Design Engineering Technical Conference 2001, beschrieben, deren Inhalt durch Bezugnahme hierin vollumfänglich aufgenommen wird. Das dort vorgeschlagene Verfahren ist allerdings nicht für den Einsatz in Echtzeit gedacht und dafür auch viel zu langsam. Bei dem erfindungsgemäßen Verfahren werden die Bremszonen genähert berechnet, so dass die konkret im Rechner repräsentierten Bremszonen ggf. größer sind als die oben definierte abstrakte Bremszone. Dies beeinträchtigt nicht die Sicherheit des Verfahrens, macht aber eine Berechnung in Echtzeit und damit einen Einsatz in einer Anlagensteuerung erst möglich.
  • In der Praxis sind meistens bestimmte Sicherheitsabstände vorgeschrieben und müssen Messunsicherheiten sowie Reaktionszeiten berücksichtigt werden, damit eine Kollision vermieden werden kann. Diese werden in das Verfahren wie folgt eingebracht: Die Hälfte des globalen Sicherheitsabstandes wird im Pufferradius (siehe unten) aller Körper der Szene addiert. Messunsicherheiten sowie Reaktionszeiten multipliziert mit der Geschwindigkeit werden auf die in Schritt a) bestimmten Grenzen aufgeschlagen.
  • Im Endeffekt heißt dies, dass das Verfahren eine Anlage noch rechtzeitig stoppen kann, wenn es in einem ersten Takt, in dem zwei Bremszonen kollidieren (mathematisch schneiden), eine Bremsung einleitet. Es geht also in dem Verfahren darum, zu bestimmen, ob zwei Bremszonen kollidieren.
  • Erfindungsgemäß werden alle vorkommenden 3D-Volumina (Körper, Bremszonen, Zwischenergebnisse der Bremszonenberechnungen) als konvexe Hülle einer endlichen Menge von Punkten zzgl. eines Pufferradius r gemäß Gl. (1)
    Figure 00170001
    dargestellt. D. h., dass im Computer ein 3D-Volumen V(r, (pi)i=1 n) als ein Array von 3D-Punkten mit den Punkten pi und ein Pufferradius r repräsentiert wird.
  • In dem Spezialfall r = 0, beschreibt V(0; (pi)n i=1) einen konvexen Polyeder mit pi als potentiellen Ecken.
  • Im Unterschied zur üblichen Darstellung in der Computational Geometry wird auf eine explizite Verknüpfung der Ecken über Kanten und Flächen verzichtet. Es können sogar einzelne der pi im Inneren des Polyeders liegen. Dadurch wird die algorithmische Behandlung viel einfacher und ist sie frei von Fehlerquellen durch numerische Sonderfälle, wie z. B. (fast) doppelte Ecken oder Kanten.
  • Durch den zusätzlichen Pufferradius können runde Geometrien mit wenig Punkten eng umschlossen werden. Beispielsweise beschreibt V(r; (p)) eine Kugel, V(r; (p1, p2)) einen Zylinder mit Kugelkappen und V(r; (p1, p2, p3)) eine abgerundete Dreiecksplatte. Der Pufferradius erlaubt außerdem, bei Berechnungen Näherungsfehler aufzuschlagen, so dass die präsentierten Verfahren konservative Näherungen berechnen, d. h., dass das berechnete Volumen garantiert das exakte Volumen enthält und aber ggf. etwas größer ist. Diese Darstellung ist die überraschende Erkenntnis, welche erlaubt, in Schritten a)–d) so schnell zu berechnen, dass das Verfahren in einer Anlagensteuerung in Echtzeit eingesetzt werden kann.
  • 2 zeigt ein Beispiel für V(r; (pi)n i=1), das aus Darstellungsgründen zweidimensional gezeigt ist. Das Beispiel hat n = 3 Punkte p1, p2, p3 deren konvexe Hülle als 30 gezeigt ist. Die konvexe Hülle 30 wird in alle Richtungen um den Radius r vergrößert, was ein effektives Volumen 32 ergibt.
  • Im folgenden wird der Teil von Schritt c) beschrieben, bei dem der Effekt eines gesteuert beweglichen Mechanismus in die Bremszone mit einberechnet wird. Diese Rechnung geht jeweils aus von einer Darstellung nach (1) der Bremszone des jeweiligen Körpers in dem Koordinatensystem, das sich mit dem gesteuert beweglichen Mechanismus mitbewegt, als Eingabe. Sie berechnet eine Darstellung nach (1) der Bremszone dieses Körpers in dem Koordinatensystem, relativ zu dem sich der gesteuert bewegliche Mechanismus bewegt, als Ergebnis. Die Rechnung wird als Formel beschrieben, wobei für jede Art von gesteuert beweglicher Mechanismus eine andere Formel nötig ist. Es werden für jede Art von gesteuert beweglicher Mechanismus mehrere alternative Formeln beschrieben, die meist verschiedene Kompromisse zwischen Genauigkeit und Rechenzeit realisieren.
  • Formeln zur Einberechnung des Effektes verschiedener Arten gesteuert beweglicher Mechanismen
  • Im folgenden werden Gleichungen der Form Operation (V(r; (pi)ni=1 ), Grenzen) = V(...) (2)verwendet. Eine solche Gleichung sagt aus, wie im Algorithmus Operation (...) auf ein im Rechner repräsentiertes Volumen, meist eine Bremszone, angewendet wird. Dieses (Eingabe-)Volumen ist abstrakt V(r; (pi)n i=1), im Rechner konkret gegeben durch den Radius r und die Punkte pi. Die konkrete Formel steckt in der Klammer von V(...) auf der rechten Seite der Gl. (2), die konkret angibt, was mit dem Radius r und den Punkten pi geschieht, damit Ergebnisradius und Ergebnispunkte das Ergebnisvolumen darstellen. Operation (V, Grenzen) für ein 3D-Volumen V ist dabei abstrakt definiert als die Menge aller Punkte, die überstrichen werden, wenn ein 3D-Volumen V von einem bestimmten gesteuert beweglichen Mechanismus innerhalb der als Parameter gegebenen Grenzen bewegt.
  • Insgesamt sagt so eine Gleichung dann aus, dass die konkrete Rechnung auf den konkreten Daten die abstrakte Operation auf den, durch die konkreten Daten beschriebenem abstrakten 3D-Volumen ausführt.
  • In den meisten Fällen steht in der Gleichung kein „=”, sondern ein „⊂”. Dies bedeutet, dass die angegebene Rechnung nicht exakt sondern näherungsweise ist. Die Näherung erfolgt aber konservativ, so dass das konkrete Ergebnis (rechte Seite von Gl. 2) nur größer, nie kleiner als das abstrakte Ergebnis (linke Seite von Gl. 2) ist. Darin liegt ein wesentlicher Beitrag der Erfindung, da diese Eigenschaft garantiert, dass die Näherungen sicher sind.
  • Im nachfolgenden werden die verschiedenen Operationen für die unterschiedlichen gesteuert beweglichen Mechanismen und die dazugehörigen Formeln nach dem Muster von Gl. 2 beschrieben. Dort, wo mehrere Formeln angegeben werden, sind diese alternativ.
  • Koordinatentransformation
  • K1 Ein 3D-Volumen V(r; (pi)i=1 n) kann einfach in ein anderes Koordinatensystem mittels einer Koordinatentransformation transformiert werden, indem alle Punkte pi transformiert werden. Für eine Koordinatentransformation R ∊
    Figure 00200001
    und Translation t ∊
    Figure 00200002
    gilt also R·V(r; (pi)ni=1 ) + t = V(r; (R·pi + t)ni=1 ) (3).
  • Dies setzt voraus, dass R Längen enthält (Starrkörpertransformation, orthonomal ist); andernfalls muss r mit dem größten Singulärwert von R multipliziert werden. K1 wird in Schritt c) verwendet, um ein 3D-Volumen in ein Koordinatensystem umzurechnen, bei dem der gesteuert bewegliche Mechanismus im Ursprung liegt, weil die folgenden Formeln dies voraussetzen.
  • Berechnung der Bremszone eines Lineargelenks
  • Gegeben ist ein Volumen V(r; (pi)n i=1), konkret eine Bremszone in Koordinaten, die sich mit einem Lineargelenk mitbewegen. Es soll das Volumen berechnet werden, das dieses überstreicht, wenn sich das Lineargelenk zwischen Positionsuntergrenze t0 und Positionsobergrenze t1 entlang der Translationsrichtung des Lineargelenkes a bewegt. Das Ergebnis wird errechnet in dem Koordinatensystem, relativ zu dem sich das Lineargelenk bewegt. Das heißt, dass der Effekt des Bremsens dieses Lineargelenkes in das Volumen mit einberechnet werden soll. Das zu errechnende Volumen ist also abstrakt Trans(V, a, t0, t1) = {υ + λa|υ ∊ V, λ ∊ [t0, ..., t1]} (4),
    Figure 00210001
  • Dabei ist t0 die Unter- und t1 die Obergrenze aus Schritt a) für die Position des betrachteten Lineargelenkes und V die Bremszone vor Einrechnung des Effektes des Lineargelenkes.
  • T0 Die erste Möglichkeit zur Näherung besteht darin, in Gleichung (4) λ = (t0 + t1)/2 festzusetzen und den entstehenden Fehler |a| (t1 – t0)/2 auf r aufzuschlagen:
    Figure 00210002
  • T1 Die zweite Möglichkeit ist exakt, verdoppelt aber die Zahl der Punkte in der Darstellung. Sie erzeugt für jeden ursprünglichen Punkt pi einen Punkt pi + t0a und einen Punkt pi + t1a. Alle weiteren Punkten pi + λa, λ ∊ [t0 ... t1] sind darin durch die Definition der Darstellung als konvexe Hülle automatisch eingeschlossen. Trans(V(r; (pi)ni=1 ), a, t0, t1) = (8) V(r; (pi + t0a, pi + t1a)ni=1 ) (9)
  • Diese Technik wurde im Jahre 2004 in „The Gilbert-Johnson-Keerthi (GJK) Algorithm" in SICGRAPH Conference Plimary Talk, von C. Ericson vorgestellt, dessen Inhalt hierin durch Bezugnahme vollumfänglich aufgenommen werden soll.
  • Berechnung der Bremszone eines Drehgelenks
  • Gegeben ist ein Volumen V(r; (pi)n i=1), konkret eine Bremszone, in Koordinaten, die sich mit einem Drehgelenk mitbewegen. Es soll das Volumen berechnet werden, das dieses überstreicht, wenn sich das Drehgelenk zwischen Winkelpositionsuntergrenze θ0 und Winkelpositionsobergrenze θ1 um seine Drehachse a bewegt. Das Ergebnis wird berechnet in dem Koordinatensystem, relativ zu dem sich das Drehgelenk bewegt. Das heißt, dass der Effekt des Bremsens dieses Drehgelenkes in das Volumen mit einberechnet werden soll. Das zu berechnende Volumen ist also abstrakt.
    Figure 00220001
    dabei ist Rot (a, α) die Rotationsmatrix um den Nullpunkt, die Achse a und den Winkel α, entsprechend der Rodriguez-Formel gemäß „A mathematical introduction into robotic manipulation", R. Murray, Z. Li and S. Sastry, CRC, 1. Auflage, 22. März 1994, 2006, deren Inhalt durch Bezugnahme hierin voll umfänglich aufgenommen wird. Weiterhin ist θ0 die Unter- und θ1 die Obergrenze aus Schritt a) für die Winkelposition des betrachteten Drehgelenkes und V die Bremszone vor Einrechnung des Effektes des Drehgelenkes.
  • Es sei im folgenden für ein durch V(r, (pi)n i=1) dargestelltes Volumen pλi = Rot(a, (1 – λ)θ0 + λθ1)pi (12)die rotierten Punkte zwischen Anfang (λ = 0) und Ende (λ = 1) des Kreisbogens (40), den pi durchläuft, wenn sich das Drehgelenk von Winkelposition θ0 nach θ1 bewegt.
  • R0a Die einfachste Näherung setzt analog zu T0 λ = (t0 + t1)/2 und schlägt den daraus resultierenden Fehler von ≤ maxi|pi|(θ1 – θ0)/2 auf den Radius r auf (s. 3 links). Dies liefert
    Figure 00230001
  • Gemäß 3 links bewegt sich ein Punkt pi kreisförmig zwischen den Winkeln θ0(pi 0) und θ1(pi 1). Der dabei überstrichene Kreisbogen (40) wird durch eine Kreisfläche (42), dargestellt durch Formel (14), überdeckt. Der Mittelpunkt pi 1/2 liegt in der Mitte des Kreisbogens und der Radius entspricht der Länge des Bogensegmentes (ϕ|pi|).
  • R0b Eine bessere Näherung erhält man nach dem Prinzip in 3 rechts durch die Formel
    Figure 00230002
  • Gemäß 3 rechts wird der Kreisbogen (40) durch einen Kreis gemäß Formel (16) überdeckt, dessen Mittelpunkt (46) bei cosϕ pi 1/2, also in der Mitte beider Endpunkte (pi 0), (pi 1) liegt. Der Radius ist sinϕ|pi|.
  • R1a Eine noch bessere Näherung erhält man, indem für jeden ursprünglichen Punkt pi Anfangspunkt pi 0 und Endpunkt pi 1 des Kreisbogens (40) ins Ergebnis übernommen werden. Durch die Definition der Darstellung als konvexe Hülle ist damit automatisch die Strecke zwischen beiden Punkten enthalten. Es verbleibt als Fehler der Abstand zwischen dieser und dem exakten Kreisbogen (40). Dieser Abstand ist ≤ (1 – cosϕ)|pi|. und wird auf den Radius aufgeschlagen. Es ergibt sich folgende Formel:
    Figure 00240001
  • Der Preis für die genauere Näherung ist eine Verdoppelung der Punktzahl. 4 links zeigt, dass der Kreisbogen (40) durch die konvexe Hülle seiner Endpunkte (pi 0, pi 1) zuzüglich eines Radius von (1 – cosϕ)|pi| überdeckt wird.
  • R1b Eine noch bessere Näherung wird dadurch erreicht, dass die Strecke (5658) zwischen den beiden eingefügten Punkten, wie in 4 rechts gezeigt, in die Mitte des Kreisbogens gelegt wird. Dann ergibt sich der geringste Radius.
  • Figure 00240002
  • Gemäß 4 rechts wird der Kreisbogen (40) überdeckt durch das Oval (54), nämlich die die konvexe Hülle seiner verschobenen Endpunkte pi 0 + dpi 1/2/2 (56) und pi 1 + dpi 1/2/2 (58) gemäß Formel (22) zuzüglich eines Pufferradius von (1 – cosϕ)|pi|/2.
  • R1c Für denkbare Vereinfachungen des Verfahrens mag es von Vorteil sein, auf den Pufferradius zu verzichten. Es ist auch möglich, eine konservative Näherung zu berechnen, die den Pufferradius nicht erhöht, dafür aber aus jedem Punkt drei Punkte macht, um den Kreisbogen in einem Dreieck einzuschließen, wie dies in 5 gezeigt ist. Wird der Kreisbogen ohne Pufferradius überdeckt, werden drei Punkte benötigt. Diese konservative Näherung ist allerdings merklich weniger eng, selbst als die 2-Punkte-Näherung (siehe R1b).
  • Figure 00250001
  • Gemäß 5 wird der Kreisbogen (40) überdeckt von der konvexen Hülle (60) von Anfangspunkt (pi 0) und Endpunkt (pi 1) und dem Schnittpunkt qi der Tangenten in Anfangs- und Endpunkt.
  • R1d Die in R1a bis R1c beschriebenen Näherungen lassen sich um den Preis einer erhöhten Punktzahl weiter verbessern, indem der Kreisbogen in Teile geteilt wird, jeder Teil des Kreisbogens getrennt genähert wird und die resultierenden Punkte zusammengefasst werden. Der Fehler an der Außenseite des Kreisbogens lässt sich so beliebig reduzieren. Der Fehler an der Innenseite ergibt sich aber allein schon durch die Beschränkung auf konvexe Volumina, wodurch unvermeidlich immer die konvexe Hülle des Kreisbogens überdeckt wird. Die Anzahl der eingefügten Punkte multipliziert sich mit jedem Gelenk entlang einer Kette gesteuert beweglicher Mechanismen. Daher ist diese Technik eher für den Fall eines Fahrzeugs (siehe unten) als für Roboterarme interessant.
  • Berechnung der Bremszonen aller Körper eine Anlage
  • Die vorangehende Beschreibung definiert Operationen, mit denen der Effekt eines gesteuert beweglichen Mechanismus, also eines Lineargelenkes oder eines Drehgelenkes, in eine Bremszone mit einberechnet wird. Im folgenden wird beschrieben, wie diese Operationen nacheinander auf 3-D Volumina angewandt werden, um für alle Körper einer Anlage die Bremszonen in allen relevanten Koordinatensystem zu berechnen. Dieses Verfahren, zusammen mit den vorangehenden Operationen, definiert Schritt b) gemäß einer besonderen Ausführungsform des erfindungsgemäßen Verfahrens.
  • In einer Anlage, auf die die Erfindung angewendet wird, ist jeder Körper durch eine Kette von gesteuert beweglichen Mechanismen mit der weltfesten Umgebung verbunden. Diese Kette korrespondiert zu einer Kette von Koordinatentransformationen, vom körperfesten Koordinatensystem ins weltfeste Koordinatensystem. Dabei hat jeder gesteuert bewegliche Mechanismus zwei Koordinatensysteme, die beide ihren Ursprung an dem Punkt haben, wo die Bewegung ansetzt (z. B. die Drehachse), und von denen sich eines mit dem gesteuert beweglichen Mechanismus mitbewegt und sich der gesteuert bewegliche Mechanismus relativ zu dem anderen bewegt. Dadurch besteht die Kette von Koordinatentransformationen abwechselnd aus einer festen Transformation zwischen zwei gesteuert beweglichen Mechanismen, die nur von der Geometrie der Anlage abhängt, und einer variablen Koordinatentransformation zwischen den beiden oben beschrieben Koordinatensystemen eines gesteuert beweglichen Mechanismus, die von der veränderlichen Position des gesteuert beweglichen Mechanismus selbst abhängt. Dies entspricht der üblichen Definition einer Vorwärtskinematik, wie bspw. in Kapitel 3 von „A mathematical introduction into robotic manipulation", R. Murray, Z. Li und S. Sastry, CRC, 1. Auflage, 22. März 1994, 2006, beschrieben ist.
  • In Schritt b) gemäß einer besonderen Ausführungsform des erfindungsgemäßen Verfahrens werden für jeden Körper sukzessive Bremszonen in allen Koordinatensystemen in obiger Kette, vom körperfesten Koordinatensystem bis zum weltfesten Koordinatensystem berechnet. All diese Bremszonen sind abstrakt 3D-Volumina und werden konkret im Rechner als konvexe Hülle mit Pufferradius nach Gleichung (1) dargestellt. Das Verfahren startet mit der Bremszone des Körpers im körperfesten Koordinatensystem, welches das vorab einkonfigurierte 3D-Volumen des Körpers selbst ist. Danach werden sukzessive alle Koordinatentransformationen der oben beschriebenen Kette auf das 3D-Volumen angewandt. Dabei wird eine feste Koordinatentransformationen über K1 (3) angewandt, die variable Koordinatentransformation eines Lineargelenkes wahlweise über T0 (7) oder T1 (9) und die variable Koordinatentransformation eines Drehgelenkes wahlweise über R0a (14), R0b (16), R1a (19), R1b (22), R1c (24) oder R1d. Dabei wird R0b (14) oder R1b (22) bevorzugt. Die Wahl zwischen den Alternativen T0 oder T1 und R0b oder R1b ist ein Kompromiss zwischen Genauigkeit und Rechenzeit und könnte z. B. vorab vorkonfiguriert werden. Dabei ist besonders bei einem Roboterarm empfehlenswert, die vorderen Drehgelenke mit R0a und die hinteren mit R1b zu berechnen um einen guten Kompromiss zu erreichen.
  • 6 bis 9 stellen ein Beispiel für das Vorgehen gemäß einer besonderen Ausführungsform des Verfahrens dar.
  • 6 zeigt einen Roboter 80 in Draufsicht von oben. Er besteht aus einem Drehgelenk J1, gefolgt von einer Gabel (90, 92) und zwei parallelen weiteren Drehgelenken J2a, J2b. Die Umgebung ist fest im Weltkoordinatensystem definiert aus 4 Körpern: 3 Strecken, dargestellt als konvexe Hülle zweier Punkte ohne Pufferradius (82, 84, 86), und einem Oval, dargestellt als konvexe Hülle zweier Punkte mit Pufferradius (88). Die Gabel ist fest im Koordinatensystem J1, das sich mit dem 1. Gelenk dreht, und besteht aus zwei Körpern, dargestellt als Ovale (90, 92). Die Körper 94 und 96 sind fest in den Koordinatensystemen J2a bzw. J2b, die sich mit den Gelenken J1 und J2a bzw. J2b mitdrehen, und werden dargestellt als Oval. Die Punkte, die zur Definition der Körper in dieser Darstellung als V(r, (pi)n i=1) dienen, sind jeweils als graue Kreuze markiert. In diesem Beispiel sei für die Rechnungen in 79 angenommen, dass sich alle Gelenke mit gewisser Geschwindigkeit nach links drehen.
  • 7 zeigt die Bremszonen in den Koordinatensystemen J2a und J2b aus 6. In (a) von 7 ist die Bremszone von Körper 94 in J2a der ursprüngliche Körper, da dieser in J2a fest ist. Andere Körper haben keine Bremszonen in diesem Koordinatensystem, da Bremszonen eines Körpers vom körperfesten bis zum weltfesten Koordinatensystem berechnet werden. In (b) von 7 gilt analoges für Körper 96 in J2b.
  • 8 zeigt die Bremszonen im Koordinatensystem J1 aus 6. Die beiden Körper (90), (92) sind fest in J1, so dass ihre Bremszonen die ursprünglichen Körper sind. In die Bremszonen der Körper 94 und 96 aus 7, welche die Körper selbst sind, wird die Bremsung der Gelenke J2a bzw. J2b einberechnet (nach R1b (24)). Dadurch entsteht aus jedem der beiden Punkte eine gedrehte und eine ungedrehte Kopie. Das Ergebnis (98, 100) ist die konvexe Hülle dieser vier Punkte, bei der zufällig zwei Punkte identisch sind, weil sie auf der Drehachse liegen. Die Entfernung zwischen Körper 94 und Körper 96 wird mit diesen Bremszonen 98 und 100 berechnet, so dass Gelenk 1 keinen Einfluss auf sie hat.
  • Schließlich zeigt 9 die Bremszonen im weltfesten Koordinatensystem für das Beispiel von 6. Die Umgebung (82, 84, 86, 88) ist fest in der Welt, so dass die ursprünglichen Körper gleichzeitig Bremszonen im weltfesten Koordinatensystem sind. In die Bremszonen (90, 92, 98, 100) in J1 wird die Bremsung von Gelenk J1 einberechnet (R1b (24)). Dadurch verdoppeln sich die Punkte in den vier betroffenen Bremszonen (102, 104, 106, 108). Die Distanz zwischen allen Roboterteilen und der Welt wird mit diesen Bremszonen berechnet.
  • Berechnung der Distanz zwischen den Bremszonen
  • In Schritt c) gemäß einer besonderen Ausführungsform des erfindungsgemäßen Verfahrens wird für jedes Paar von Körpern die Distanz ihrer den Bremszonen mit bspw. dem bekannten GJK-Algorithmus bestimmt. Der GJK-Algorithmus benötigt dafür eine von vornherein nicht bekannte Anzahl von Iterationen. Wie in dem Artikel von Gilbert et al. vorgeschlagen, wird der Algorithmus mit dem Ergebnis aus dem letzten Takt der Anlagensteuerung gestartet und die Iteration abgebrochen, sobald der Algorithmus eine untere Schranke für die Distanz > 0 berechnet hat. Beides reduziert die Rechenzeit erheblich.
  • Maßgeblich für die Berechnung der Distanz sind Bremszonen in einem gemeinsamen Koordinatensystem, zweckmässigerweise im ersten gemeinsamen Koordinatensystem. In dem Beispiel in 8 wird beispielsweise die Distanz zwischen Körpern 94 und 96 mit den Bremszonen 98 und 100 im Koordinatensystem J1 bestimmt, d. h. die Bewegung von J1 beeinflusst die Distanz nicht.
  • Nicht gegeneinander getestet werden außerdem Paare von Körpern, zwischen denen kein gesteuert beweglicher Mechanismus liegt, die sich also nicht relativ zueinander bewegen. Außerdem können Paare von Körpern als nicht zu testen vorkonfiguriert werden. Dies ist nötig, weil z. B. die beiden Seiten eines gesteuert beweglichen Mechanismus geometrisch immer kollidieren.
  • Beschränkung der Rechenzeit durch Fortschreiben von Distanzschranken
  • Das vorangehend beschriebene Verfahren gemäß einer besonderen Ausführungsform der vorliegenden Erfindung ist verhältnismäßig schnell. Es können aber trotzdem zwei Rechenzeitprobleme vorliegen. Zum einen werden alle Paare von Körpern überprüft bzw. getestet. Dadurch wächst die Rechenzeit quadratisch mit der Anzahl an Körpern.
  • Viele Verfahren im Stand der Technik verwenden eine Hierarchie so genannter Bounding-Volumina, um dieses Problem zu lösen. Wenn zwei Obervolumina eine gewisse Distanz aufweisen, so ist die Distanz für alle Paare von Untervolumina mindestens genauso groß. Haben also zwei Bounding-Volumina eine genügend hohe Distanz, braucht die Distanz aller Untervolumina nicht berechnet zu werden. Diese Vorgehensweise ist bei einer besonderen Ausführungsform des erfindungsgemäßen Verfahrens auch möglich, ist aber grundsätzlich eher kompliziert. Daher soll sie zumindest in einer besonderen Ausführungsform des erfindungsgemäßen Verfahrens vermieden werden, um das Verfahren besonders einfach zu halten, insbesondere für einen sicherheitsgerichteten Einsatz. Außerdem berechnen viele Algorithmen zur Distanzberechnung Informationen aus der Geometrie der beteiligten Volumina vor, um später Rechenzeit zu sparen. Dies ist hier nicht möglich, weil Bremszonen sich abhängig von der Geschwindigkeit ändern.
  • Ein zweites Rechenzeitproblem besteht darin, dass die Berechnung der Distanz mit dem GJK-Algorithmus eine von vornherein unbekannte Anzahl an Iterationen benötigt. In einer Anlagensteuerung (ebenso einer Robotersteuerung) laufen aber alle Prozesse in einem festen Takt. Dadurch müsste ein Vielfaches der mittleren Rechenzeit für das Verfahren reserviert werden, damit auch unter ungünstigen Bedingungen die Taktzeit eingehalten werden kann.
  • Um diesen beiden Rechenzeitproblemen zu begegnen, wird das vorangehend beschriebene Verfahren noch einmal verfeinert werden. Dadurch wird die Rechenzeit sehr viel kleiner und auf einen festen Wert beschränkt.
  • Dazu wird für jede Bremszone j ihre Änderung seit dem letzten Takt einer Anlagensteuerung als pauschaler Änderungsradius δrj abgeschätzt. So ein δrj muss die Eigenschaft haben, dass sich kein Punkt der Bremszone j seit dem letzten Takt um mehr als δrj bewegt hat. Er wird berechnet als
    Figure 00300001
    wobei V(r', (p'i)n i=1) die Darstellung der Bremszone j aus dem aktuellen Takt und V(r, (pi)n i=1) die Darstellung der Bremszone j aus dem letzten Takt ist.
  • 10 zeigt die Berechnung des Änderungsradius nach (26) aus einer Bremszone V(r, (pi)n i=1) des letzten Taktes (110) und der entsprechenden Bremszone V(r', (p'i)n i=1) des aktuellen Taktes (112).
  • Aus den Änderungradien wird eine Schranke für die Distanz aller Paare von Bremszonen hergeleitet, indem von der Distanz der Bremszonen i und j aus dem letzten Takt die Änderungsradien δri + δrj abgezogen werden. Es ergibt sich eine untere Schranke für die aktuelle Distanz. An Stelle von neu berechneten Distanzen werden also Distanzschranken von Takt zu Takt fortgeschrieben. Zusätzlich dazu wird eine feste Anzahl an Iterationen des GJK-Algorithmus durchgeführt. Zuerst für die Paare, bei denen obige Fortschreibung Distanzschranke 0 ergeben hat, danach reihum. Ist danach immer noch für ein Paar die Distanzschranke gleich 0, wird die Anlage gestoppt gemäß Schritt d).
  • Dieses Verfahren begründet sich aus zwei Überlegungen. Erstens, so lange eine Distanzschranke 0 ist, muss auf ihr eine GJK-Iteration durchgeführt werden, denn wenn sie 0 bleibt, kann eine Kollision nicht ausgeschlossen werden und es muss in Schritt d) gestoppt werden. Sind alle Distanzschranken > 0, macht es trotzdem Sinn, GJK-Iterationen durchzuführen, weil dadurch die aktualisierten Distanzschranken größer werden könnten und dann in späteren Takten mehr GJK-Iterationen für andere Distanzschranken verwendet werden können. Der Algorithmus arbeitet sozusagen vor.
  • Das erfindungsgemäße Verfahren hat zumindest in besonderen Ausführungsformen wichtige Vorzüge:
    Es ist adaptiv in Bezug auf Geschwindigkeit und Entfernungen und überwindet die Problematik quadratischer Rechenzeit. Die δrj entsprechen grob der im Takt zurückgelegten Strecke. D. h., wenn sich die Anlage langsamer bewegt, stehen mehr Takte, also mehr GJK-Iterationen, zur Verfügung. Für viele Paare von Bremszonen sind die Distanzen eh groß, z. B. weil sich die Anlage gerade weit von der Umgebung entfernt, oder für solche Paare, die zu weit entfernten Körpern gehören. Dann muss diese Distanzschranke selten neu berechnet werden und es reicht fast immer eine einzelne GJK-Iteration aus. Außerdem bewegt sich natürlich kein Körper nahe an allen Teilen der Umgebung. Der Algorithmus ist demzufolge immer sicher, benötigt wenige Iterationen und leitet nur in absoluten Ausnahmefällen einen unnötigen Halt ein.
  • Als Beispiel sei ein Paar von Bremszonen betrachtet, das relativ weit, z. B. einen Meter voneinander entfernt ist und von dem sich eine Bremszone pro Takt einen Zentimeter hin- und herbewegt. Eine hohe Entfernung ist durchaus typisch für die meisten Paare von Bremszonen. Durch das Fortschreiben entsprechend dem Änderungsradius sinkt die Distanzschranke in jedem Takt um einen Zentimeter, so dass nach 100 Takten der Algorithmus eine Distanzschranke von 0 hat und mit einer GJK-Iteration nachrechnen muss, wie groß die Distanz wirklich ist (in diesem Beispiel würde eine GJK-Iteration reichen). Effektiv muss in diesem Beispiel nur jeden 100-sten Takt eine GJK-Iteration durchgeführt werden. 99 von 100 Takte kommen mit den zwei Subtraktionen der Änderungsradien aus.
  • Nachfolgend wird ein Verfahren gemäß einer besonderen Ausführungsform der vorliegenden Erfindung beschrieben, mit dem Kollisionen von gesteuert beweglichen bzw. bewegten Fahrzeugen, insbesondere fahrerlosen Transportsystemen (FTS) mit einem geringeren Rechenaufwand als bisher vermieden werden können. Anders als bei z. B. Roboterarmen sind bei einem derartigen Fahrzeug Position und/oder Orientierung in Bezug auf die Welt variabel, haben einen Bremsweg, aber sind nicht durch eine Abfolge gesteuert beweglicher Mechanismen mit einem einzelnen Freiheitsgrad, wie z. B. Dreh- oder Lineargelenke, beschreibbar. Vielmehr wird in einer Ausführungsform des erfindungsgemäßen Verfahrens ein Fahrzeug als ein einzelner gesteuert beweglicher Mechanismus mit drei Freiheitsgraden betrachtet. Das Fahrzeug muss dazu seine Position (x, y) und Orientierung (θ) in der Ebene und deren zeitliche Ableitung, also seine Geschwindigkeit messen. Der Vektor (x, y) beschreibt dabei die Position eines fest gewählten Referenzpunktes am Fahrzeug in der Welt und zusammen mit θ eine Transformation vom körperfestes Koordinatensystem am Fahrzeug ins weltfeste Koordinatensystem.
  • Definition der Grenzen der Position beim Bremsen eines Fahrzeugs
  • Da ein Fahrzeug einen gesteuert beweglichen Mechanismus mit drei Freiheitsgraden darstellt, ist die Definition von Positionsgrenzen, die beim Bremsen eingehalten werden, in Schritt a) komplizierter als das Bestimmen einer Unter- und Obergrenze. Gemäß einer besonderen Ausführungsform werden die Positionsgrenzen eines Fahrzeugs in Schritt a) statt dessen als konvexe Teilmenge seines Konfigurationsraums definiert, wobei der Konfigurationsraum aus 3D-Vektoren mit den Komponenten (x, y, θ) besteht und wobei besagte Untermenge als konvexe Hülle von endlich vielen Konfigurationen (kj)m j=1 im Konfigurationsraum dargestellt wird:
    Figure 00330001
    wobei die Komponenten der Konfigurationen kj wie folgt bezeichnet werden:
    Figure 00330002
  • Jede Konfiguration k definiert eine Koordinatentransformation vom körperfesten Koordinatensystem am Fahrzeug ins weltfeste Koordinatensystem.
  • Figure 00330003
  • Dies ist eine homogene Transformationsmatrix, die Rotation und Translation kombiniert. Zur Vereinfachung der Notation sei daher, wie üblich vereinbart, dass 3D-Ortsvektoren, besonders die pi bei Multiplikation mit einer homogenen 4×4 Matrix, mit einer impliziten 1 als vierte Komponente versehen werden.
  • Berechnung der Bremszone eines Fahrzeugs
  • Gesucht ist die Menge aller Punkte im Weltkoordinatensystem, die von einem am Fahrzeug körperfesten 3D-Volumen überstrichen werden, wenn das Fahrzeug alle in K((kj)m j=1) definierten Konfigurationen durchläuft. Dies lässt sich abstrakt wie folgt darstellen: Brake(V, K) = {T(k)·υ|υ ∊ V, k ∊ K} (30),wobei V besagtes 3D-Volumen und K besagte Menge von Konfigurationen ist.
  • F1a Die Vorgehensweise ist analog zu Näherung R1a bei Drehgelenken. Für ein nach (1) definiertes 3D-Volumen V(r; (pi)n i=1), konkret eine Bremszone und eine als konvexe Hülle definierte Menge von Konfigurationen K((kj)m j=1), wird für jedes Paar i, j der Punkt pi vom körperfesten Koordinatensystem ins weltfeste Koordinatensystem gemäß kj transformiert. Alle entstehenden Punkte werden in einer konvexen Hülle zusammengefasst. Wäre die Drehung linear in θ, wären alle Zwischenwerte durch die Definition als konvexe Hülle schon automatisch enthalten. So wird die Nichtlinearität der Drehung abgeschätzt und ihr Effekt auf r addiert.
  • Figure 00340001
  • Vereinfachte Definition der Grenzen der Position beim Bremsen eines Fahrzeugs
  • Nimmt man an, dass das Fahrzeug 122 (siehe 11) beim Bremsen einer exakten Kreisbahn 126 folgt, mit dem sogenannten Drehzentrum 124 als Mittelpunkt, ergibt sich eine einfachere Lösung analog zu einer der Näherungen R0a–R1d für ein Drehgelenk.
  • 11 zeigt die zugrunde liegende Situation. Die Konfiguration des Fahrzeugs am Ende des Bremsens 120 wird relativ zur Konfiguration am Anfang des Bremsens 122 unter der Annahme einer Kreisbahn 126 durch zwei Parameter (s, α) beschrieben. Der Parameter s beschreibt dabei die auf der Kreisbahn zurückgelegte Bremsweglänge (vorzeichenbehaftet) und α die Änderung der Orientierung (bezüglich θ). Fahrzeuge können kontinuierlich von einer Kurve in Geradeausfahrt übergehen. Dabei wandert das Drehzentrum ins Unendliche. Deshalb wird, anders als beim Drehgelenk, eine Version der Formeln verwendet, bei der Geradeausfahrt keinen Sonderfall darstellt und insbesondere der Nullpunkt des Koordinatensystems nicht im Drehzentrum liegen muss. Die erfindungsgemäße Art der Darstellung leistet dies. Eine Geradeausfahrt entsteht für α = 0 und s ≠ 0.
  • Durch Angabe der Konfiguration des Fahrzeugs beim Anfang des Bremsens 122 und der Parameter (s, α) werden dadurch die Grenzen der Position des Fahrzeugs im Schritt a) definiert. Als Ersatz für (28) definiert folgende Formel die Transformation vom körperfesten Koordinatensystem des Fahrzeugs am Ende des Bremsens zum körperfesten Koordinatensystem am Anfang des Bremsens.
  • Figure 00350001
  • Gegeben ist ein 3D-Volumen V(r; (pi)n i=1), konkret eine Bremszone, in Koordinaten, die sich mit dem Fahrzeug mitbewegen. Es soll das 3D-Volumen berechnet werden, das dieses überstreicht, wenn sich das Fahrzeug zwischen Positionsuntergrenze (0, 0) und Positionsobergrenze (s, α) gemäß der Kreisbahnannahme bewegt. Das Ergebnis wird berechnet im körperfesten Koordinatensystem des Fahrzeuges am Anfang des Bremsens, eine Umrechnung ins weltfeste Koordinatensystem kann später über K1 erfolgen. Das heißt, dass der Effekt des Bremsens dieses Fahrzeugs in das Volumen mit einberechnet werden soll. Das zu berechnende Volumen ist also abstrakt Rot(V, s, α) = {T(λs, λα)·υ|λ ∊ [0 ... 1], υ ∊ V} (35)
  • Nachfolgend werden zwei Näherungen von Rot(V(r; (pi)n i=1), s, α) beschrieben, die ohne einen Aufschlag auf den Pufferradius r auskommen.
  • F1c Gemäß 12 links wird eine R1c entsprechende Näherung angegeben, die für jeden Punkt pi aus dem ursprünglichen 3D-Volumen den aus pi entstehenden Kreisbogen 126 in ein Dreieck 130 einschließt. Dadurch werden aus jedem Punkt pi im ursprünglichen 3D-Volumen drei Punkte. Das Dreieck besteht aus dem Anfangspunkt pi 0, dem Endpunkt pi 1 und zusätzlich dem Schnittpunkt qi der Tangenten im Anfangs- und Endpunkt. Die Punkte werden wie folgt berechnet:
    Figure 00360001
  • F1d Gemäß 12 rechts wird der Kreisbogen 126 von F1c in h gleiche Teile eingeteilt, jeder Teil einzeln genähert. Dabei ist die Teilbogenlänge jeweils s/h und die Winkeländerung α/h. Der gesamte Kreisbogen 126 wird dann durch die konvexe Hülle aller dieser Punkte überdeckt. Dabei liegen Anfangs- und Endpunkte der Teilbögen pi k/h für k = 0 ... h bis auf den Anfangspunkt (k = 0) des ersten Teilbogens und den Endpunkt (k = h) des letzten Teilbogens in der konvexen Hülle der anderen Punkte. Daher werden sie zweckmäßigerweise weggelassen. Wirklich berechnet werden also der Anfangspunkt pi 0 und der Endpunkt pi 1 des Kreisbogens 126 und die Tangentenschnittpunkte (qi k/h für k = 0 ... h – 1) aller Teilbögen. Es entstehen damit h + 2 anstatt drei Punkte zu jedem Punkt pi des ursprünglichen 3D-Volumens. V(r; (pi)n i=1).
  • Figure 00370001
  • Zum gleichen Ergebnis gelangt man, indem man alle qi k/h für k = 1 ... h – 1 aus qi 0 errechnet nach qλi = T(λs, λα)·q0i (44)
  • Absicherung gegen sensoriell erfasste Hindernisse, insbesondere Personen
  • Bei den vorangehend beschriebenen Verfahren werden nur Umgebungen betrachtet, die geometrisch vorkonfiguriert sind und bei denen gesteuert bewegliche Teile einer Anlage mit Positions- bzw. Winkelgebern versehen sind, aber bei denen weitere Objekte oder Personen in der Anlage nicht sensoriell erfasst werden. Besagte Verfahren lassen sich auf von einem Laserscanner sensoriell erfasste Hindernisse, insbesondere Personen, erweitern. Dies geschieht, indem aus den Bremszonen Schutzfelder für einen Laserscanner berechnet werden, die dieser dann überwacht. Laserscanner tasten die Umgebung mit einem Laserstrahl ab und messen dadurch in der Ebene in jeder Richtung die Entfernung zum nächsten Hindernis. Ein Schutz feld gibt für jeden Strahl des Laserscanners, also jeden Winkel in der Ebene an, bis zu welcher Entfernung vom Laserscanner die Umgebung frei von Hindernissen sein muss. Befindet sich in diesem Bereich ein Hindernis, vornehmlich eine Person, stoppt der Laserscanner die Anlage.
  • In der Praxis gibt es zwei besonders interessante Einsatzfälle: a) ein Roboterarm mit festem Laserscanner und b) ein Fahrzeug oder fahrerloses Transportsystem (FTS) mit einem am Fahrzeug befindlichen Laserscanner. Letztgenannter Fall weist eine weitere Besonderheit auf. Es müssen Position und Orientierung des Fahrzeugs nicht gemessen werden, da das Schutzfeld relativ zum Fahrzeug definiert ist. Trotzdem geht seine Geschwindigkeit in die Berechnung des Bremsweges ein. Diese Sondersituation ergibt sich daraus, dass der Laserscanner am Fahrzeug befestigt ist, aber Hindernisse wahrnimmt, die als fest in der Welt angenommen werden.
  • Zur Berechnung der Schutzfelder wird ein 3D-Volumen V(r; (pi)n i=1) beispielsweise einfach durch Weglassen der Z-Koordinate in die Ebene transformiert. Auf den resultierenden Punkten wird ein Konvexe-Hüllen-Algorithmus (z. B. Graham-Scan) angewandt, der die Punkte, die Ecken der konvexen Hülle bilden, entgegen den Uhrzeigersinn zu einem Polygon durchnummeriert. Das Polygon wird durch Kreise von r um die Ecken und Parallelen zu den Kanten um r erweitert. Alle in Frage kommenden Strahlen des Laserscanners werden mit allen Kanten und Kreisen geschnitten. Für jeden Strahl ist das Schutzfeld die größte Entfernung eines solchen Schnittes.
  • Zusammenfassend lässt sich somit folgendes festhalten:
  • Zumindest in besonderen Ausführungsformen der Erfindung wird die Bewegung von einem oder mehreren Roboterarm(en) überwacht und rechtzeitig ein Halt ausgelöst, bevor der Roboterarm selbstkollidiert oder die Roboterarme miteinander oder mit der Umgebung kollidieren. Dies vermeidet Unfälle in Situationen, wo der Roboter nicht immer exakt dieselbe Bahn ab fährt, z. B. beim Einlernen von Bahnen, dem so genannten teach-in, oder bei sensorgeführten Arbeiten. Das Verfahren dient zur Kollisionsvermeidung mit geometrisch vorab bekannten Hindernissen, also in der Basisversion nicht zum Schutz von Personen.
  • Weiterhin kann das Verfahren auf gesteuert bewegliche Fahrzeuge oder FTS, auf denen sich auch Roboterarme befinden können, und auf sensoriell erfasste Hindernisse erweitert bzw. zugeschnitten werden. Dadurch dient das Verfahren auch zur Kollisionsvermeidung mit Personen.
  • Die in der vorstehenden Beschreibung, in den Zeichnungen sowie in den Ansprüchen offenbarten Merkmale der Erfindung können sowohl einzeln als auch in beliebigen Kombinationen für die Verwirklichung der Erfindung in ihren verschiedenen Ausführungsformen wesentlich sein.
  • 10
    Fahrzeug
    12
    Roboterarm
    14
    stationärer Roboterarm
    16
    Förderband
    18
    Trennwand
    19
    starrer Körper
    20
    Weltkoordinatensystem
    30
    konvexe Hülle
    32
    effektive Hülle
    p1, p2, p3
    Punkte
    r
    Radius
  • ZITATE ENTHALTEN IN DER BESCHREIBUNG
  • Diese Liste der vom Anmelder aufgeführten Dokumente wurde automatisiert erzeugt und ist ausschließlich zur besseren Information des Lesers aufgenommen. Die Liste ist nicht Bestandteil der deutschen Patent- bzw. Gebrauchsmusteranmeldung. Das DPMA übernimmt keinerlei Haftung für etwaige Fehler oder Auslassungen.
  • Zitierte Patentliteratur
    • - US 6678582 [0004]
    • - US 5056031 [0005]
  • Zitierte Nicht-Patentliteratur
    • - E. Gilbert, D. Johnson, S. Keerthi, „A fast procedure for computing the distance between complex objects in 3D space”, IEEE Journal an Robotics and automation, Band 4, Nr. 2, 1988 [0048]
    • - C. Ericson, ”The Gilbert-Johnson-Keerthi (GJK) algorithm”, in Sicgraph Conference Plenary Talk, 2004 [0048]
    • - A. Fuhrmann und E. Schömer, „A general method for computing the regional space of mechanisms”, Proceedings of the ASME Design Engineering Technical Conference 2001 [0050]
    • - 2004 in „The Gilbert-Johnson-Keerthi (GJK) Algorithm” in SICGRAPH Conference Plimary Talk, von C. Ericson [0069]
    • - „A mathematical introduction into robotic manipulation”, R. Murray, Z. Li and S. Sastry, CRC, 1. Auflage, 22. März 1994, 2006 [0070]
    • - Kapitel 3 von „A mathematical introduction into robotic manipulation”, R. Murray, Z. Li und S. Sastry, CRC, 1. Auflage, 22. März 1994, 2006 [0084]
    • - Gilbert et al. [0091]

Claims (25)

  1. Verfahren zur Vermeidung von Kollisionen gesteuert beweglicher Teile (10; 12; 14; 16) einer Anlage mit einer Anlagensteuerung, wobei das oder die gesteuert bewegliche(n) Teile(e) aus mindestens zwei durch einen gesteuert beweglichen Mechanismus verbundenen starren Körpern (19) besteht/bestehen und an jedem Körper ein körperfestes 3D-Koordinatensystem definiert wird und jeder Körper in besagtem körperfesten 3D-Koordinatensystem als 3D-Volumen beschrieben und das 3D-Volumen als konvexe Hülle einer endlichen Menge von Punkten (pi)n i=1 zzgl. eines Pufferradius r >= 0 nach der Definition
    Figure 00420001
    dargestellt wird, umfassend die Durchführung der nachfolgenden Schritte in jedem Takt der Anlagensteuerung: a) für jeden gesteuert beweglichen Mechanismus Bestimmen einer Grenze bzgl. seiner Position, innerhalb derer er bei einer sofortigen Bremsung zum Stillstand kommen würde, b) für jeden Körper der Anlage Berechnen von Bremszonen als 3D-Volumina in der Darstellung nach (1) im körperfesten und im weltfesten 3D-Koordinatensystem und in allen Koordinatensystemen dazwischen in der Kette gesteuert beweglicher Mechanismen, die den jeweiligen Körper mit der weltfesten Umgebung verbinden, wobei die Bremszonen berechnet werden, indem, von der bekannten Darstellung nach (1) des Körpers startend, sukzessive der Effekt jedes gesteuert beweglichen Mechanismus entlang dieser Kette eingerechnet wird, indem für jeden ursprünglichen Punkt pi seine Bewegung beim Bremsen des gesteuert beweglichen Mechanismus nach a) durch ein Volumen V(ri; (pij)n j=1), dargestellt mit Pufferradien ri und Punkten pij, nach (1) überdeckt wird, die resultierenden Punkte zu einer konvexen Hülle zusammengeführt werden und der ursprüngliche Pufferradius um das Maximum der ri erhöht wird, c) Bestimmen über alle Paare von Körpern die Distanz zwischen ihren Bremszonen in einem gemeinsamen, insbesondere im ersten gemeinsamen, Koordinatensystem der beiden in b) auftretenden Ketten von gesteuert beweglichen Mechanismen, d) wenn mindestens eine der bestimmten Distanzen den Wert Null aufweist, Anhalten oder Verlangsamen zumindest eines Teilbereichs der Anlage.
  2. Verfahren nach Anspruch 1, dadurch gekennzeichnet, dass die Körper in dem jeweiligen 3D-Volumen, das nach (1) dargestellt ist, nur enthalten sind und nicht direkt dargestellt werden.
  3. Verfahren nach Anspruch 1 oder 2, dadurch gekennzeichnet, dass ein oder mehrere Körper in der Vereinigung von mehreren 3D-Volumen, die nach (1) dargestellt sind, enthalten sind und für die Berechnungen in Schritt b) alle diese 3D-Volumen verwendet werden.
  4. Verfahren nach einem der Ansprüche 1 bis 3, dadurch gekennzeichnet, dass der bzw. mindestens ein gesteuert beweglicher Mechanismus ein Drehgelenk mit Antrieb und Winkelpositionssensor umfasst.
  5. Verfahren nach Anspruch 4, dadurch gekennzeichnet, dass für ein Drehgelenk folgende Formel in Schritt b) benutzt wird:
    Figure 00430001
    mit pλi = Rot(a, (1 – λ)θ0 + λθ1)pi oder
    Figure 00440001
    mit d = 1 – cosϕoder
    Figure 00440002
    oder V(r, (p0i , p1i , pi)ni=1 mit
    Figure 00450001
    durchgeführt wird, wobei θ0 die Unter- und θ1 die Obergrenze aus Schritt a) für die Winkelposition des betrachteten Drehgelenkes ist und V(r, (pi)n i=1) die Darstellung der Bremszone vor Einrechnung des Effektes des Drehgelenkes ist.
  6. Verfahren nach einem der Ansprüche 1 bis 3, dadurch gekennzeichnet, dass der bzw. mindestens ein gesteuert beweglicher Mechanismus ein Lineargelenk mit Antrieb und Positionssensor umfasst.
  7. Verfahren nach Anspruch 6, dadurch gekennzeichnet, dass für ein Lineargelenk folgende Formel in Schritt b) benutzt wird:
    Figure 00450002
    oder V(r; (pi + t0a,pi + t1a)ni=1 ),wobei t0 die Unter- und t1 die Obergrenze aus Schritt a) für die Position des betrachteten Lineargelenkes ist und V(r, (pi)n i=1) die Darstellung der Bremszone vor Einrechnung des Effektes des Lineargelenkes ist.
  8. Verfahren nach einem der Ansprüche 1 bis 3, dadurch gekennzeichnet, dass der bzw. mindestens ein gesteuert beweglicher Mechanismus ein Fahrwerk eines Fahrzeuges mit angetriebenen und/oder gelenkten Rädern und Positionssensor umfasst.
  9. Verfahren nach Anspruch 8, dadurch gekennzeichnet, dass für ein Fahrzeug die Grenze nach Schritt a) als Untermenge seines Konfigurationsraums definiert wird, wobei der Konfigurationsraum aus dreidimensionalen Vektoren besteht, deren ersten beiden Komponenten die x- und y-Position eines gewählten Referenzpunktes des Fahrzeuges angeben und dessen dritte Komponente θ den Winkel der Orientierung des Fahrzeugs angibt und wobei besagte Untermenge als konvexe Hülle von endlich vielen Konfigurationen (kj)m j=1 im Konfigurationsraum dargestellt wird:
    Figure 00460001
    wobei die Komponenten der Konfigurationen kj wie folgt bezeichnet werden:
    Figure 00460002
  10. Verfahren nach Anspruch 9, dadurch gekennzeichnet, dass für ein Fahrzeug folgende Formel für die Einberechnung des Effektes des Fahrzeugbremsens verwendet wird:
    Figure 00460003
    Figure 00470001
    wobei V(r, (pi)n i=1) die Darstellung der Bremszone vor Einrechnung des Effektes dieses Fahrzeugs ist.
  11. Verfahren nach Anspruch 8, dadurch gekennzeichnet, dass für ein Fahrzeug (122) das Bremsen auf einer Kreisbahn angenommen wird und die Grenze seiner Position in a) auf der Kreisbahn als zurückgelegte Strecke s und vollzogener Drehwinkel α berechnet wird, wobei
    Figure 00470002
    die Position des Fahrzeugs nach dem Bremsen (120) relativ zur Position vor dem Bremsen (122) als homogene Matrix angibt.
  12. Verfahren nach Anspruch 11, dadurch gekennzeichnet, dass für ein Fahrzeug folgende Formel für die Einberechnung des Effektes des Fahrzeugbremsens verwendet wird: V(r, (p0i , p1i , qi)ni=1 )mit pλi = T(λs, λα)·pi und qi = p0i + Q(α)·12 (p1i – p0i ),und
    Figure 00480001
    oder mit qλi = T(λs, λα)·q0i ,wobei V(r, (pi)n i=1) die Darstellung der Bremszone vor Einrechnung des Effektes dieses Fahrzeugs ist, h eine natürliche Zahl ist und die Multiplikation von T(s, α) und Q(α) mit einem 3D-Vektor im Sinne einer homogenen Matrix durch Anfügen einer 1 interpretiert wird.
  13. Verfahren nach einem der vorangehenden Ansprüche, dadurch gekennzeichnet, dass die Anlage Körper aufweist, die durch verschiedene gesteuert bewegliche Mechanismen verbunden sind.
  14. Verfahren nach einem der Ansprüche 4 bis 13, dadurch gekennzeichnet, dass in Schritt a) Messunsicherheiten der Positionsgeber auf die Grenzen aufgeschlagen werden.
  15. Verfahren nach einem der Ansprüche 4 bis 14, dadurch gekennzeichnet, dass in Schritt a) Reaktionszeiten bei der Bestimmung der Grenzen aufgeschlagen werden.
  16. Verfahren nach Anspruch 15, dadurch gekennzeichnet, dass der Aufschlag ein Produkt aus Reaktionszeit und Geschwindigkeit umfasst.
  17. Verfahren nach einem der vorangehenden Ansprüche, dadurch gekennzeichnet, dass zum Pufferradius die Hälfte eines globalen Sicherheitsabstands addiert wird.
  18. Verfahren nach einem der vorangehenden Ansprüche, dadurch gekennzeichnet, dass in Schritt c) die Distanzen mittels des GJK(Gilbert-Johnson-Keerthi)-Algorithmus bestimmt werden.
  19. Verfahren nach Anspruch 18, dadurch gekennzeichnet, dass es über mindestens zwei Takte der Anlagensteuerung durchgeführt wird und in Schritt c) für jede Bremszone i deren Änderung seit dem letzten Takt als pauschaler Änderungsradius δri abgeschätzt und daraus eine Schranke für die Distanzen aller Paare von Bremszonen hergeleitet wird, indem von der Distanz der Paare von Bremszonen i und j aus dem letzten Takt die Änderungsradien δri + δrj abgezogen werden, sowie eine feste Anzahl von Iterationen des GJK-Algorithmus durchgeführt wird, zuerst für die Paare von Bremszonen, bei denen die berechnete Distanz den Wert 0 aufweist, danach reihum, und wenn danach immer noch die Distanz eines Paares den Wert 0 aufweist, zumindest ein Teilbereich der Anlage angehalten oder verlangsamt wird.
  20. Verfahren nach Anspruch 19, dadurch gekennzeichnet, dass als pauschaler Änderungsradius
    Figure 00500001
    verwendet wird, wobei V(r, (pi)n i=1) die Darstellung der Bremszone j im letzten Takt und V(r', (pi')n i=1) die Darstellung der Bremszone j im aktuellen Takt ist.
  21. Verfahren nach einem der Ansprüche 4 bis 20, dadurch gekennzeichnet, dass die Positionsgeber Linear- oder Winkelgeber sind.
  22. Verfahren nach einem der vorangehenden Ansprüche, dadurch gekennzeichnet, dass aus mindestens einer für einen Körper berechneten Bremszone ein Schutzfeld für einen an besagtem oder einem anderen Körper angebrachten Laserscanner berechnet wird.
  23. Verfahren nach Anspruch 21, dadurch gekennzeichnet, dass zur Berechnung des Schutzfeldes das 3D-Volumen der Bremszone in eine Ebene transformiert oder projiziert wird.
  24. Verfahren nach einem der vorangehenden Ansprüche, dadurch gekennzeichnet, dass in Schritt a) ein zusätzlicher Aufschlag auf die Grenzen erfolgt.
  25. Verfahren nach einem der vorangehenden Ansprüche, dadurch gekennzeichnet, dass vorher festgelegte Paare von Körpern von der Bestimmung der Distanz in c) und der Überprüfung in d) ausgenommen sind.
DE102009006256.4A 2009-01-27 2009-01-27 Verfahren zur Vermeidung von Kollisionen gesteuert beweglicher Teile einer Anlage Expired - Fee Related DE102009006256B4 (de)

Priority Applications (2)

Application Number Priority Date Filing Date Title
DE102009006256.4A DE102009006256B4 (de) 2009-01-27 2009-01-27 Verfahren zur Vermeidung von Kollisionen gesteuert beweglicher Teile einer Anlage
PCT/DE2010/000090 WO2010085944A1 (de) 2009-01-27 2010-01-26 Verfahren zur vermeidung von kollisionen gesteuert beweglicher teile einer anlage

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
DE102009006256.4A DE102009006256B4 (de) 2009-01-27 2009-01-27 Verfahren zur Vermeidung von Kollisionen gesteuert beweglicher Teile einer Anlage

Publications (2)

Publication Number Publication Date
DE102009006256A1 true DE102009006256A1 (de) 2010-07-29
DE102009006256B4 DE102009006256B4 (de) 2019-01-03

Family

ID=42154615

Family Applications (1)

Application Number Title Priority Date Filing Date
DE102009006256.4A Expired - Fee Related DE102009006256B4 (de) 2009-01-27 2009-01-27 Verfahren zur Vermeidung von Kollisionen gesteuert beweglicher Teile einer Anlage

Country Status (2)

Country Link
DE (1) DE102009006256B4 (de)
WO (1) WO2010085944A1 (de)

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP2428862A1 (de) 2010-09-13 2012-03-14 Sick Ag Vorrichtung und Verfahren zur Sicherheitssteuerung eines Fahrzeuges
DE102013019368A1 (de) * 2013-11-18 2015-05-21 Grenzebach Maschinenbau Gmbh Verfahren und Vorrichtung zur weitgehend maschinellen Zusammenstellung von Warenlieferungen in Lagerhallen
DE102012007254B4 (de) * 2011-04-18 2015-10-15 Fanuc Corporation Verfahren und Vorrichtung zum Vorausberechnen einer Behinderung zwischen einem Zielteil eines Roboters und einem peripheren Objekt
DE102014115774B3 (de) * 2014-10-17 2015-10-22 GM Global Technology Operations LLC (n. d. Ges. d. Staates Delaware) Robotersystem und Verfahren zum Vermeiden eines Kontakts zwischen einem Greiforgan des Robotersystems und einem dynamischen Hindernis in der Umgebung
DE102015009815A1 (de) * 2015-07-28 2017-02-02 Kuka Roboter Gmbh Verfahren zum Steuern eines mobilen redundanten Roboters
DE102016211129A1 (de) * 2016-06-22 2017-12-28 Kuka Roboter Gmbh Verfahren zum Überprüfen einer Kollision zwischen zwei fahrerlosen Transportfahrzeugen, fahrerloses Transportfahrzeug und System mit mehreren fahrerlosen Transportfahrzeugen
DE102020213127B3 (de) 2020-10-19 2022-01-20 Kuka Deutschland Gmbh Verfahren und System zum Betreiben eines Roboters
DE102022121539A1 (de) 2022-08-25 2024-03-07 Bayerische Motoren Werke Aktiengesellschaft Fahrerloses Transportsystem

Families Citing this family (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2015157883A1 (en) 2014-04-17 2015-10-22 SZ DJI Technology Co., Ltd. Flight control for flight-restricted regions
CN118011935A (zh) 2015-03-31 2024-05-10 深圳市大疆创新科技有限公司 可移动物体的控制方法和装置
EP3421189B1 (de) 2017-06-28 2019-05-22 Sick AG Verfahren zum überwachen einer maschine
DE102021200600A1 (de) 2021-01-22 2022-07-28 Kuka Deutschland Gmbh Planen eines Pfads eines fahrerlosen mobilen Roboters
CN113858213B (zh) * 2021-11-09 2023-07-25 南京埃斯顿机器人工程有限公司 一种用于目标同步的机器人动态轨迹规划方法

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5056031A (en) 1988-11-12 1991-10-08 Kabushiki Kaisha Toyota Chuo Kenyusho Apparatus for detecting the collision of moving objects
US6099573A (en) * 1998-04-17 2000-08-08 Sandia Corporation Method and apparatus for modeling interactions
DE10226140A1 (de) * 2002-06-13 2004-01-08 Kuka Roboter Gmbh Verfahren und Vorrichtung zum Vermeiden von Kollisionen zwischen Industrierobotern und anderen Objekten
US6678582B2 (en) 2002-05-30 2004-01-13 Kuka Roboter Gmbh Method and control device for avoiding collisions between cooperating robots
DE102004027944A1 (de) * 2004-06-08 2005-12-29 Kuka Roboter Gmbh Verfahren und Vorrichtung zum Schützen eines Roboters gegen Kollisionen

Family Cites Families (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
SE456048B (sv) * 1982-02-24 1988-08-29 Philips Norden Ab Sett och anordning for att bestemma kollisionsrisken for tva inbordes rorliga kroppar
JP2826138B2 (ja) * 1988-11-12 1998-11-18 株式会社豊田中央研究所 移動体の干渉チェック装置
AUPR257001A0 (en) * 2001-01-17 2001-02-08 Bhp Innovation Pty Ltd Anti-collision protection system
DE10361132B4 (de) 2003-06-18 2013-02-28 Elan Schaltelemente Gmbh & Co. Kg Verfahren zur Überwachung der Bewegung eines sich in mehreren Freiheitsgraden bewegenden Gefahr bringenden Objektes eines Handhabungsgerätes, wie Handhabungsmasse und/oder bewegliche Masse
ES2316012T3 (es) 2006-09-14 2009-04-01 Abb Research Ltd. Un metodo y dispositivo para evitar colisiones entre un robot industrial y un objeto.
DE602006012485D1 (de) 2006-09-14 2010-04-08 Abb Research Ltd Verfahren und Vorrichtung zur Vermeidung von Kollisionen zwischen einem Industrieroboter und einem Objekt

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5056031A (en) 1988-11-12 1991-10-08 Kabushiki Kaisha Toyota Chuo Kenyusho Apparatus for detecting the collision of moving objects
US6099573A (en) * 1998-04-17 2000-08-08 Sandia Corporation Method and apparatus for modeling interactions
US6678582B2 (en) 2002-05-30 2004-01-13 Kuka Roboter Gmbh Method and control device for avoiding collisions between cooperating robots
DE10226140A1 (de) * 2002-06-13 2004-01-08 Kuka Roboter Gmbh Verfahren und Vorrichtung zum Vermeiden von Kollisionen zwischen Industrierobotern und anderen Objekten
DE102004027944A1 (de) * 2004-06-08 2005-12-29 Kuka Roboter Gmbh Verfahren und Vorrichtung zum Schützen eines Roboters gegen Kollisionen

Non-Patent Citations (12)

* Cited by examiner, † Cited by third party
Title
"A mathematical introduction into robotic manipulation", R. Murray, Z. Li and S. Sastry, CRC, 1. Auflage, 22. März 1994, 2006
2004 in "The Gilbert-Johnson-Keerthi (GJK) Algorithm" in SICGRAPH Conference Plimary Talk, von C. Ericson
A. Fuhrmann und E. Schömer, "A general method for computing the regional space of mechanisms", Proceedings of the ASME Design Engineering Technical Conference 2001
BERNABE,E.J., TORNERO,J.: "Hough Transform for Distance Computation and Collision Avoidance", In: IEEE Transaction on Robotics and Automation, Vol.18, No.3, June 2002, S.393-398 *
BERNABE,E.J., TORNERO,J.: "Hough Transform for Distance Computation and Collision Avoidance", In: IEEE Transaction on Robotics and Automation, Vol.18, No.3, June 2002, S.393-398 HU,H., BRADY,M., PROBERT,P.: "Navigation and Control of Mobile Robot among Moving Obstacles", In: Proceedings of the 30th IEEE International Conference on Decision and Control, Dec. 1991, S.698-703 BERNABEU,E.J., TORNERO,J.: Hough Transform for Robot Motion Planning in Industrial Applications", IN: Proceedings of the 7th IEEE International Conference on Emerging Technologies and Factory Automation, Vol.2, 18-21 Oct. 1999, S.987-994 BERNABEU,E.J., TORNERO,J., TOMIZUKA,M.: "Collision Predition an Avoidance Amidst Moving Objects for Trajectory Planning Applications", In: Proceedings of the 2001 IEEE International Conference on Robotics and Automation, Vol.4, 21-26 May 2001, S.3801-3806
BERNABEU,E.J., TORNERO,J., TOMIZUKA,M.: "Collision Predition an Avoidance Amidst Moving Objects for Trajectory Planning Applications", In: Proceedings of the 2001 IEEE International Conference on Robotics and Automation, Vol.4, 21-26 May 2001, S.3801-3806 *
BERNABEU,E.J., TORNERO,J.: Hough Transform for Robot Motion Planning in Industrial Applications", IN: Proceedings of the 7th IEEE International Conference on Emerging Technologies and Factory Automation, Vol.2, 18-21 Oct. 1999, S.987-994 *
C. Ericson, "The Gilbert-Johnson-Keerthi (GJK) algorithm", in Sicgraph Conference Plenary Talk, 2004
E. Gilbert, D. Johnson, S. Keerthi, "A fast procedure for computing the distance between complex objects in 3D space", IEEE Journal an Robotics and automation, Band 4, Nr. 2, 1988
Gilbert et al.
HU,H., BRADY,M., PROBERT,P.: "Navigation and Control of Mobile Robot among Moving Obstacles", In: Proceedings of the 30th IEEE International Conference on Decision and Control, Dec. 1991, S.698-703 *
Kapitel 3 von "A mathematical introduction into robotic manipulation", R. Murray, Z. Li und S. Sastry, CRC, 1. Auflage, 22. März 1994, 2006

Cited By (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP2428862A1 (de) 2010-09-13 2012-03-14 Sick Ag Vorrichtung und Verfahren zur Sicherheitssteuerung eines Fahrzeuges
DE102012007254B4 (de) * 2011-04-18 2015-10-15 Fanuc Corporation Verfahren und Vorrichtung zum Vorausberechnen einer Behinderung zwischen einem Zielteil eines Roboters und einem peripheren Objekt
DE102013019368A1 (de) * 2013-11-18 2015-05-21 Grenzebach Maschinenbau Gmbh Verfahren und Vorrichtung zur weitgehend maschinellen Zusammenstellung von Warenlieferungen in Lagerhallen
DE102014115774B3 (de) * 2014-10-17 2015-10-22 GM Global Technology Operations LLC (n. d. Ges. d. Staates Delaware) Robotersystem und Verfahren zum Vermeiden eines Kontakts zwischen einem Greiforgan des Robotersystems und einem dynamischen Hindernis in der Umgebung
US9403275B2 (en) 2014-10-17 2016-08-02 GM Global Technology Operations LLC Dynamic obstacle avoidance in a robotic system
DE102015009815A1 (de) * 2015-07-28 2017-02-02 Kuka Roboter Gmbh Verfahren zum Steuern eines mobilen redundanten Roboters
DE102016211129A1 (de) * 2016-06-22 2017-12-28 Kuka Roboter Gmbh Verfahren zum Überprüfen einer Kollision zwischen zwei fahrerlosen Transportfahrzeugen, fahrerloses Transportfahrzeug und System mit mehreren fahrerlosen Transportfahrzeugen
DE102020213127B3 (de) 2020-10-19 2022-01-20 Kuka Deutschland Gmbh Verfahren und System zum Betreiben eines Roboters
DE102022121539A1 (de) 2022-08-25 2024-03-07 Bayerische Motoren Werke Aktiengesellschaft Fahrerloses Transportsystem

Also Published As

Publication number Publication date
WO2010085944A1 (de) 2010-08-05
DE102009006256B4 (de) 2019-01-03

Similar Documents

Publication Publication Date Title
DE102009006256B4 (de) Verfahren zur Vermeidung von Kollisionen gesteuert beweglicher Teile einer Anlage
EP1366867B1 (de) Verfahren und Vorrichtung zum Vermeiden von Kollisionen zwischen Industrierobotern und anderen Objekten
EP2550227B1 (de) Verfahren zum betreiben eines autonomen flurförderfahrzeugs
DE102013109876A1 (de) Verfahren zur Steuerung eines redundanten Roboters
DE102007059480B4 (de) Verfahren und Vorrichtung zur Posenüberwachung eines Manipulators
DE112017002498T5 (de) Robotervorgang-auswertungseinrichtung, robotervorgang-auswertungsverfahren und robotersystem
DE102008046348B4 (de) Verfahren, Gerät und ein entsprechendes Computerprogrammprodukt zur rechnergestützten Bahnplanung eines bewegbaren Geräts, insbesondere eines medizinischen Geräts
WO2008113636A1 (de) Verfahren zur berechnung einer kollisionsvermeidenden trajektorie für ein fahrmanöver eines fahrzeugs
DE10226140A1 (de) Verfahren und Vorrichtung zum Vermeiden von Kollisionen zwischen Industrierobotern und anderen Objekten
DE102010046327A1 (de) Überwachung eines mobilen Manipulators
DE102008057142A1 (de) Verfahren zur rechnergestützten Bewegungsplanung eines Roboters
DE112011105397B4 (de) Beweglicher Körper vom Typ inverses Pendel mit Geschwindigkeitsplanungsvorrichtung
EP3439834B1 (de) Kartesische steuerung einer mastspitze eines grossmanipulators, insbesondere betonpumpe
DE4425924A1 (de) Autonome mobile Einheit mit raumsparendem Manipulator und zugehöriges Steuerungsverfahren
DE102015223258A1 (de) Verfahren zum Bearbeiten der Oberfläche eines dreidimensionalen Objekts
EP3705662B1 (de) Gelenkarm-steuerung einer betonpumpe
EP3556521A1 (de) Bremswegüberwachung einer kinematik
EP3225366B1 (de) Positionsüberwachung einer kinematik
DE102012206952A1 (de) Verfahren und Vorrichtung zur Steuerung der Bewegung einer beweglichen Einheit im Raum
DE102012022190B4 (de) Inverse Kinematik
EP3569367B1 (de) Rechnergestütztes ermitteln einer bewegung einer vorrichtung
WO2018060060A1 (de) Verfahren zum betreiben von sich autonom bewegenden plattformen und hindernisschutzsensor
DE102018133472B3 (de) Bewegungsüberwachung eines Robotermanipulators
EP0907604A1 (de) Verfahren und anordnung zur vermeidung vom lastschwingungen bei einem drehbewegungen ausführenden hängelastbewegungsgerät
WO2019201488A1 (de) Mehrgliedrige aktuierte kinematik, vorzugsweise roboter, besonders vorzugsweise knickarmroboter

Legal Events

Date Code Title Description
OP8 Request for examination as to paragraph 44 patent law
R016 Response to examination communication
R016 Response to examination communication
R018 Grant decision by examination section/examining division
R119 Application deemed withdrawn, or ip right lapsed, due to non-payment of renewal fee