Legosortiermaschine gesamte Anlage

Aus HSHL Mechatronik
Zur Navigation springen Zur Suche springen

Dies ist ein Unterartikel von der Legoteil_Zählmaschine, welcher die Zusammenführung der einzelnen Teile zu einer Einheit beschrieben. Es werden die Schwierigkeiten und Hürden von der Kooperation der Anlagenteile dargestellt.


Anforderungen

Spezifikations-ID Anforderungs-ID Anforderungstitel Beschreibung der Spezifikation Link
0010 REQ10.2000 Eigenständige Funktionsweise der Sortiermaschine Der Zähl- und Sortiervorgang erfolgt ohne menschlichen oder weiteren maschinellen Eingriff Link
0020 REQ10.2010 Antriebe Die Sortiermaschine wird elektrisch angetrieben Link
0030 REQ10.2020 Energieversorgung Die Sortieranlage wird mit 230 Volt AC Schukostecker versorgt Link
0040 REQ10.2030 Abmessung Für die Abmessung der Sortieranlage werden folgende Kriterien eingehalten: Länge: 2,5m, Breite 1,0m, Höhe: 1,5m Link
0045 REQ10.2030 Abmessung Die Maschiene steht auf einer Grundplatte von 2,0m x 0,8m Link
0046 REQ10.2030 Abmessung Die Höhe vom Förderband und den Bildverarbeitungen überschreitet nicht mehr als 1,2m Link
0070 REQ10.2060 Verarbeitungszeit Die Anlage kann 60 Legoteile innerhalb von 10 Minuten autonom sortieren Link
0160 REQ10.3100 Hardware Als Hardware wird ein PC mit Matlab eingesetzt Link
0190 REQ10.3210 Versionsverwaltung Alle in dem Projekt anfallenden Dateien werden in dem Versionsverwaltungssystem "Subversion" abgelegt Link
0200 REQ10.3220 Dokumentation Für die Ablage von Dateien im Versionsverwaltungssystem ist eine geeignete Ablagestruktur definiert Link
0250 REQ10.3260 Tool der Softwareentwicklung Er werden Matlab und Atmel Studio für die Softwarentwicklung eingesetzt Link
0310 REQ10.3295 Codezusammenführung Separierung und Bildverarbeitung laufen im gleichen Programm Link


Schnittstellen

Die Legosortiermaschiene ist in drei Arbeitsbereiche eingeteilt. Dies hat den Vorteil, dass aus dem gesamten Team kleine Gruppen gebildet werden können, welche für ihren Maschinenteil verantwortlich sind. Dadurch wird vermieden, dass Aufgaben doppelt oder gar nicht erledigt werden. Es bringt allerdings den Nachteil mit sich, dass es Schnittstellen zwischen den Gruppen gibt. Diese müssen genau definiert werden, damit eine reibungslose Zusammenarbeit gewährleistet ist.


Separierung - Bildverarbeitung

Die Separierung vereinzelt die Legoteile, damit die Bildverarbeitung diese verarbeiten kann. Dafür sind folgende Vereinbarungen getroffen worden:

Hardware

  • Es darf immer nur ein Teil von der Separierung an die Bildverarbeitung übergeben werden
  • Das Förderband und der Eingang der Bildverarbeitungsbox liegen auf einer Höhe, damit kein Teil vom Förderband fällt. Damit alle Teile in die Box fallen, ist diese schräg angebracht.
  • Die Anlage wird über einen Schaltschrank gesteuert. Dort werden die Komponenten der Separierung und der Bildverarbeitung gesteuert. Informationen hierzu gibt es hier

Software

  • Beide Anlagenteile können nicht gleichzeitig durch zwei getrennt Programme gesteuert werden. Deshalb muss eine Hauptfunktion die Laufzeiten steuern. Nötige Vereinbarungen:
    • Sobald ein Teil in der Bildbox erkannt wird, bleibt die Separierung stehen
    • Kalibrierungen der Kameras wird in der Hauptfunktion durchgeführt
    • Die Teilprogramme dürfen keine Dauerschleifen haben
    • Die graphische Ausgabe für beide Funktionen ist in einer Figur

Die Realisierung der Softwareschnittstelle ist hier zu lesen.

Bildverarbeitung - Sortierung

Das Teil aus der Bildverarbeitung muss in die Sortierung gelangen, damit es richtig einsortiert wird. Dafür sind folgende Vereinbarungen getroffen worden:

Hardware

  • Die Bildverarbeitung hat den Ausgang zur Seite
  • Das Teil wird mit einer Luftdüse herausgeschossen
  • Die Anlage wird über einen Schaltschrank gesteuert. Informationen dazu gibt es hier.

Software

  • Hat die Bildverarbeitung ein Teil erkannt, so steuert sie die Klappen der Sortierung. Dazu ist in der Bildverarbeitung hinterlegt, welche Klappen bei jedem Teil angesteuert werden müssen.

[1]

Hardwareumsetzung

Entwicklung einer Steuerplatine

Abbildung 1: Steuerplatine

Zur Inbetriebnahme der umgebauten Anlage war es notwendig, die Funktionen der Schaltplatine zu erweitern. Die eingebaute Steuerplatine war auf den Arduino aufgesattelt und bezog Steuersignale sowie die 5 V Versorgungsspannung direkt über die eingesteckten Pins. Mit dieser Platine ist es möglich, drei Motoren mit Strom zu versorgen bzw. durch ein PWM Signal zu steuern. Zusätzlich konnten noch zwei Servomotoren und zwei Infrarotsensoren betrieben werden. Durch die Konzeptänderung der Separierung und der Bildverarbeitung wurde es notwendig, weitere Schaltfunktionen hinzuzufügen. Die Bildverarbeitung benötigte durch Software schaltbares Licht, um zwischen Durch- und Drauflicht in der Bildverarbeitungsbox umschalten zu können. Ebenso wie bei den Motoren sollte die Ansteuerung des Lichts über den Arduino erfolgen. Die Spannungsversorgung der Bildverarbeitungsbox war in der Vergangenheit mit einem eigenen Netzteil erfolgt, welches direkt in eine Steckdose eingesteckt wurde.

Neben der Einrichtung von schaltbaren Licht, wurde die Schaltung der Pneumatik hinzugefügt. Auch diese sollte über den Arduino gesteuert werden. Die Ventilinsel wird mit 24 V Signalen angesteuert.

Die Motoransteuerung musste auch bei der neuen Steuerplatine wieder per MOSFETs umgesetzt werden, da die Geschwindigkeit hier per PWM Signal gesteuert wird. Die Lichtansteuerung der LED Streifen in den Bildverarbeitungsboxen sollte ebenfalls per MOSFET geschehen, da die Schaltfrequenz gegebenfalls recht hoch werden kann und mechanische Relais nicht für höhere Schaltfrequenzen ausgelegt sind. Außerdem benötigen diese eine 12 V Versorgungsspannung. Die Option auf ein weiteres Netzteil, um aus 230 V Netzspannung die 12 V Spannung für die LEDs herzustellen, wurde aufgrund des hohen Kaufpreises für das Netzteil sowie des hohen Aufwandes für den Umbau abgelehnt. Als Alternative wurde sich für die Verwendung von Linearspannungsreglern auf der Steuerplatine entschieden, die aus der vorhandenen Spannung von 24 V, die zur Versorgung der Motoren benötigt werden, 12 V erzeugen sollen.

Bei der Ansteuerung der Ventilinsel gab es ebenfalls zwei Optionen. Die erste Möglichkeit war die Nutzung von Relais, wie z.B. Solid State Relais, durch die Arduino-Ausgänge weniger belastet werden. Die zweite Option war die Nutzung derselben MOSFETs, die schon bei der Ansteuerung der Motoren und des Lichts verwendet wurden. Hier wurde sich auf Grund von bereits vorhandenen Komponenten und der damit verbundenen Einheitlichkeit für die zweite Variante entschieden.

Der Schaltplan der Platine wurde in Multisim erstellt, der Leiterplattenentwurf in Ultiboard. Die Platine wurde anschließend in der Hochschule gefräst und bestückt(siehe Abbildung 1). Zum Anschluss an den Arduino wurde die Platine mit Schraubklemmen versehen. Der Arduino wurde eine Platine aus dem Zubehör erweitert, welche jeden Anschluss als Schraubklemme zur Verfügung stellt, um Platine und Arduino zu verbinden.

Während der Tests der Platine sind 2 MOSFETs aus unbekannten Gründen zerstört worden. Die Platine ist weiterhin für die aktuellen Funktionen einsatzfähig, für die Hinzunahme weiterer Funktionen, wie beispielsweise der Einbindung einer weiteren Druckluft-Düse, müssen die Bauteile jedoch ausgetauscht werden.

Umbau des Schaltschranks

Abbildung 2: Schaltschrank der Anlage

Der Schaltschrank wird über 230 Volt Wechselspannung versorgt. Für die jeweiligen Anforderungen sind ein 5 Volt DC und ein 24 Volt DC Netzteil eingebaut. Die Spannungsausgänge sind auf Verteilerklemmen gelegt, um von dort eine ordentliche Verteilung dieser zu garantieren.

Aufgrund des Einsatzes der neuen Steuerplatine war es notwendig, den Schaltschrank umzubauen (siehe Abbildung 2). Hierzu wurde die alte Steuerplatine entfernt und an ihrer Stelle die neue Sattelplatine mit Schraubklemmen auf dem Arduino installiert. Auch wurde der Arduino auf einer Hutschienenhalterung installiert. Ebenso wurde die neue Steuerplatine auf einer solchen Halterung installiert. Die Anschlüsse untereinander wurden verbunden, die Anschlüsse zu den Geräten außerhalb des Schranks wurden auf Reihenklemmen gelegt.

Im Wintersemester 17/18 ist der Gekodrive und andere Komponenten für den Linearläufer aus dem Schaltschrank entfernt worden. Anstelle dessen, ist die Ansteuerung für die neue Sortierbox hinzugefügt worden. Für die ist eine Versorgungleitung auf die 5 Volt Spannungsklemmen gelegt worden. Die Steuerleitung ist an 6 Klemmen angeschlossen. Diese sind mit den jeweiligen Ausgängen an dem Ardiuno verbunden. Die Steuerleitung ist nicht direkt auf den Ardiuno gelegt worden, damit bei einer Änderung im Schaltschrank flexibel reagiert werden kann.

Hier ist der aktuelle Schaltplan in dem Schaltschrank zu finden.

Kabelkanal

Seit dem Sommersemester 2016 sind die verlegten Leitungen fest verlegt werden. Hierzu wurde ein Kabelkanal zur ordentlichen Verlegung der Leitungen an den Förderbändern montiert. Er dient dem Schutz und der mechanischen Entlastung der Leitung. Es wurde ein geschlitzter Kabelkanal gewählt, da an vielen unterschiedlichen Stellen Leitungen z.B. zu den Motoren abgehen. So war es nicht nötig, einen geschlossenen Kabelkanal zu modifizieren, um die Leitungsabgänge möglich zu machen.

Im Wintersemester 2017 wurd ein Kabelkanal von den Kameras zu dem Laptop hinzugefügt. Dadurch sind die Kameraleitungen und die serieelle Schnitstelle vor Beschädigung geschützt.

Elektrische Sicherheit

Die elektrische Sicherheit des Schaltschrankes wurde im Zuge der Umbauarbeiten sichergestellt, indem alle Leitungen gegen spannungsfestere Leitungen vom Typ H07 bzw. H05 ausgetauscht wurden. So werden nun auch die Anforderungen nach VDE 0100-600 erfüllt. Eine Anlagenprüfung wurde im August 2016 vorgenommen.

Abmessung der Maschine

Die Maschiene steht auf einer Platte von 2,2 x 0,8 Meter. Diese Platte ist flexibel verstellbar. Die Maschine ist am höchsten Punkt ungefähr 1,2 Meter hoch. Der Computer zur Steuerung kann beliebig neben oder unter der Maschine platziert werden. In der aktuellen Anforderung steht dieser unterhalb der Bildverarbeitungsbox. Die Bildschirme für die Visualisierung befinden sich neben der Platte auf einem extra Tisch.


[2] [1] [3] [4]

Softwareumsetzung

Implementierung einer Hauptfunktion

Abbildung 3: Entwurf des Programmablaufes
Abbildung 4: Entwurf der Sortierhauptfunktion

Bis zum Sommersemster 2017 wurden die Legosortiermaschine durch zwei Programme in Matlab gesteuert. Ein Programm, welches die Separierung steuert, und ein Programm, welches die Bildverarbeitung und Sortierung steuert. Da immer nur ein Programm in Matlab ausgeführt werden kann, werden beide Programme so geändert, dass eine Hauptfunktion die Laufzeiten dieser steuert. Probleme bei der Zusammenführung waren:

  • Die Kameras sollen nur ein mal kalibriert werden
→ Die Kalibrierungen werden am Anfang des Hauptprogramms durchgeführt und nicht mehr in den Unterfunktionen.
  • Die Schnittstelle zum Arduino kann nur ein mal erzeugt werden
→ Die Schnittstelle wird in der Hauptfunktion erzeugt. Da die Unterfunktionen die Schnittstelle brauchen, um Befehle an den Arduino zu senden, muss diese beim Funktionsaufruf übergeben werden.
  • Es soll eine Auswahl zwischen Teach-In und Sortierung geben
→ Die Gui, über welche diese Abfrage läuft, wird als erstes aufgerufen. Bei Auswahl von Teach-In wird in dieses Unterprogramm gesprungen.
  • Wann ist welcher Programmteil dran, damit keine Teile übersehen werden?
→ Die Separierung und Bildverarbeitung laufen immer abwechselnd. Zunächst erzeugt sich die Bildverarbeitung ein Bild. Erkennt sie kein Teil, so wird die Funktion beendet und die Separierung erzeugt sich ein Bild. Diese ermittelt die Anzahl der Teile auf dem Band und pustet diese nach Bedarf auseinander. Danach ermittelt die Bildverarbeitung erneut, ob ein Teil in der Box liegt. Dieser Ablauf wiederholt sich immer wieder.
Um dies umzusetzten, wird in der Separierung die Dauerschleife entfernt und in der Bildverarbeitung wird ein break implementiert, um aus der Schleife zu springen.
  • Was passiert wenn ein Teil in der Bildbox liegt?
→ Erkennt die Bildverarbeitung ein Teil in der Box, so wird das Förderband gestoppt. Die Funktion der Bildverarbeitung wird weiter ausgeführt und das Teil wird mit Hilfe der Merkmale erkannt. Dann wird die Sortierung angesteuert und das Teil wird aus der Box gepustet. Erst jetzt wird die Separierung wieder ausgeführt.
  • Durch das Abwechseln der Funktionen überlagern sich die graphischen Ausgaben der Kamerabilder
→ Die Bilder werden in einer Figur über Subplots angezeigt.
  • Das Programm muss beendbar sein, egal in welchem Programmteil es sich befindet
→ Wird die ESC-Taste gedrückt, so wird dies von dem durchgeführten Programmteil erkannt. Die globale Variabel abbruch wird auf eins gesetzt und der Programmteil wird verlassen. Die Variabel verhindert nun, dass der andere Programmteil ausgeführt wird und beendet die Schleife um die Unterfunktionen. Wird die ESC-Taste gedrückt, während die Bildverarbeitung ein Teil erkennt, so wird das Programm bis zur Einsortierung weiter durchlaufen. So wird gewährleistet, dass kein Teil in der Bildbox liegen bleibt.
  • Die Datenbank speichert die leere Box bei jedem Programmaufruf als ein Teil
→ Der Wert des erzeugten Teils, wird nach Beendigung des Programms gelöscht
  • Die benötigten Daten sind in vielen verschiedenen Ordnern angeordnet und teilweise schwer zu finden. Außerdem sind dort viele alte nicht verwendete Funktionen
→ Nur die verwendeten Dateien werden in einen neuen Ordner in SVN unter ./SRC/Matlab angeordnet. Dort wird eine neue übersichtliche Ordnerstruktur erzeugt


In Abbildung 3 und 4 sieht man den Programmablauf der Hauptfunktion.


[1]


Arduino-Kommunikation

Zum Ansteuern der Aktoren mithilfe des Arduino Mega, wurde ein Kommunikationsprogramm geschrieben. Dieses ermöglicht dem Nutzer über den PC einen seriellen Befehl an den Arduino zu schicken, der daraufhin den Befehl ausführt. Zu den Befehlen gehören:

  • Ansteuern der LED's in den Kameraboxen für die Erkennung bzw. Separierung
  • Ventilsteuerung für die Druckluftdüsen für die Erkennung bzw. Separierung
  • Einstellung der Servomotoren für die Sortierung
  • Ansteuern der Förderbandmotoren

Für die Botschaften wurde ein einheitliches Framework herausgearbeitet. So besitzt jede serielle Botschaft folgende kodierte Inhalte:

  • Am Anfang jeder Botschaft steht ein B
  • Eine 1-stellige ID, welche die oben aufgeführten Aufgaben repräsentiert
  • Eine 2-stellige Nummer (NR), welche einen bestimmten Aktor beinhaltet
  • Eine 3-stellige Zusatzzahl, welche z.B. den Motoren eine relative Geschwindigkeit vorgibt, den LEDs bzw. Ventilen an/auf und aus/zu vorgibt
  • Die Botschaft wird mit einem E beendet

Eine detalierte Beschreibung der Kommunikation findet sich in folgender Tabelle:

Beschreibung ID NR ZUSATZ Gesamtstring Beispielstring
(ohne Leerzeichen)
Servoansteuerung der Fächer F 00 - 18: für die Fachnummern Z: 000 B ID NR Z E B F 01 055 E (Servo 1 auf 55°)
LED's L 00: Erkennung oben
1: Erkennung unten
2: Sortierung
Z: Status (0=aus; 1 = an) B ID NR Z E B L 01 001 E (Erkennung unten an)
Förderbandmotoren M 00: Bunker
01: Förderband
Z: Power in % B ID NR Z E B M 01 080 E (Förderband mit 80%)
Initalisierungsstellung der Servomotoren I 00 Z: 0 (kein Zusatz) B ID NR Z E B I 00 000 E (alle Servomotoren auf Initalstellung)
Ventile V 00: Erkennung pusten
01: nicht belegt
02: Vereinzelung pusten (1)
03: Vereinzelung pusten (2)
Z: Status (0=aus; 1 = an) B ID NR Z E B V 00 001 E (Erkennung pusten)


Das Programm auf dem Arduino beobachtet dauerhaft den seriellen Eingang und reagiert bei einem Eintreffen einer Botschaft mit einem jeweiligen Ansteuern der digitalen Ausgänge. Das Programm befindet sich im folgenden Ordner: Serielle_Kommunikation_Arduino_Matlab.

[1] [2]

Tests

Test der Verarbeitungszeit

Um die Dauer der Verarbeitungszeit der Maschine aus Spezifikation 0070 zu überprüfen, wird eine Auswahl von Legoteilen in die Maschine eingeworfen. Am Ende wird entschieden, ob die Teile erkannt wurden oder nicht. Die Sortierung wird nicht getestet.

Anzahl Teile Dauer erkannte Teile Bemerkung Erkenntnis
60 5:34 Minuten 21 Eingelernte Teile werden nicht erkannt Teile müssen erneut eingelernt werden
60 8:56 Minuten 39 zwei lange Teile blockieren sich gegenseitig in der Vereinzelung der Druck für die Luftdüsen in der Vereinzelung muss erhöht werden
60 6:20 Minuten 45 Fehler durch: zusammenliegende Teile, nicht erkannte Teile Farberkennung in der Vereinzellung wird angepasst, Teile werden neu eingelernt
100 10:36 Minuten 73 Vereinzellung und Bildverarbeitung machen kleine Fehler Beide Funktionsteile müssen im nächsten Semester verbessert werden

Ohne die Sortierung ist das Requirement 10.2060 erfüllt. [1] [2]

Zusammenfassung

Umgesetze Punkte:

  • Hardwarezusammenführung der einzelnen Komponenten
    • Schaltschrank
    • Steuerplatine
    • elektrischer Anschluss
  • Softwarezusammenführung
    • Ein Hauptprogramm
    • Unterprogramme für Systemteile
    • Kommunikation zwische Arduino und Matlab
  • Gesamtanlagentest

Autoren

  1. 1,0 1,1 1,2 1,3 1,4 Autor Nils Busemann
  2. 2,0 2,1 2,2 Autor Maik Schmotz
  3. in Anlehnung an Autor Adam Fankhauser
  4. in Anlehnung an Autor Niklas Lingenauber

Dies ist ein Unterartikel von der Legoteil_Zählmaschine, welcher die Zusammenführung der einzelnen Teile zu einer Einheit beschrieben.