User Tools

Site Tools


projects:farmrobot:realcode_g-code

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
projects:farmrobot:realcode_g-code [2021/03/08 21:57]
roman-heinrich
projects:farmrobot:realcode_g-code [2021/03/11 21:20] (current)
roman-heinrich [Pumpe]
Line 1: Line 1:
 ====== Realtime G-code ====== ====== Realtime G-code ======
 +===== Code =====
 +
 +<WRAP download>
 +G-Code Sender mit Beispielen: https://gitlab.com/Romanizer/gcode-py/-/tree/master/gcode\\
 +</WRAP>
 +Die Datei ''GCodeSender.py'' ist wie eine normale Library geschrieben.\\
 +Zuerst muss man sie importieren und ein Objekt instanziieren (Achtung: Es wird mit dem Roboterarm verbunden und eine Nullpunktfahrt ausgeführt!).\\
 +Um ''GCodeSender.py'' zu importieren :
 +<file python>
 +from gcodesender import *
 +gcsender = GCodeSender('COMX') # oder '/dev/ttyUSBX'  -> X = Port der Roboterarmes
 +</file>
 +
 +Es gibt folgende Funktionen:
 +^ Funktion ^ Erklärung ^  Parameter ^ Rückgabewert ^
 +| gcsender.send(x,y,z,f) | sendet den Arm an die gegebene Position | x,y,z: absolute Position, f: feedrate | Zeit in Sekunden bis der Move abgeschlossen ist | 
 +| gcsender.enablePump()  | sendet ''M106 S255'' und die Pumpe geht an | - | - |
 +| gcsender.disablePump() | sendet ''M106 S0'' und die Pumpe geht aus | - | - |
 +| gcsender.cleanup()     | schliesst die serielle Verbindung zum Arm | - | - | 
 +
 +Die Zeit in Sekunden bis der Arm von Punkt A nach Punkt B fährt ergibt sich wie folgt:\\
 +<file python>
 +rel_x = x - self.last_x  # calc relative change in position from last position
 +rel_y = y - self.last_y
 +rel_z = z - self.last_z
 +t = math.sqrt(rel_x * rel_x + rel_y * rel_y + rel_z * rel_z) * (60 / f) * 0.9  # 3D Pythagoras of x,y,z * feedrate in sec/mm * calibration
 +self.last_x = x  # update last position to current position
 +self.last_y = y
 +self.last_z = z
 +</file>
 +Der Code behält immer die letzte Position des Armes im Speicher, um die Zeit auszurechnen.\\
 +Indem gewartet wird bis der Arm den aktuellen Move abgeschlossen hat, und erst dann ein neuer Move gesendet wird, wird verhindert, dass sich der serielle Buffer im Arduino füllt.
 +So wird immer erst ein Move gesendet, wenn der Arm diesen direkt ausführen kann. Der aktuelle Move basiert so immer auf den aller neusten Daten aus der Object-Recognition mit YOLOv5.
 +
 +==== Pumpe ====
 +Zum Sprühen des Herbizids wird eine Pumpe verwendet.
 +
 +Das Kommando ''M106'' wird zur Steuerung der Herbizidpumpe verwendet. Mit diesem G-Code wird normalerweise der Ausgang des Lüfters ein- oder ausgeschaltet. Die ''enablePump()'' Funktion schaltet den 12V Ausgang "D9" ein. ''S0'' bzw. ''S255'' bedeutet Geschwindigkeit, und die von uns angegebene ''255'' ist die maximale Geschwindigkeit. Die Funktion ''disablePump()'' schaltet den Ausgang ab.
 +
 +<file python>
 +def enablePump(self):
 +    # turn the pump on (D9 on Ramps PCB)
 +    # set the pump to 100% power. 255 is full speed (12V)
 +    self.ser.write(b'M106 S255 \r\n')
 +    self.ser.flush()
 +
 +def disablePump(self):
 +    # turn off pump completely. 0 is no speed
 +    self.ser.write(b'M106 S0 \r\n')
 +    self.ser.flush()
 +</file>
 +
 ===== Tests ===== ===== Tests =====
 === Allgemeine Informationen === === Allgemeine Informationen ===
Line 14: Line 66:
 Der Kommando G1 wird verwendet, um die Koordinaten für die lineare Bewegung zu senden. Der Kommando G1 wird verwendet, um die Koordinaten für die lineare Bewegung zu senden.
  
-^ Parameter         Erläuterung +^ Parameter ^ Bereich ^ Erklärung 
-| X        bra     +| X      -100, +100 |  Links und Rechts 
-| Y        bra     +| Y      -100, +100 |  Vorne und Hinten 
-| Z        bra     +| Z      0, +245    |  Höhe (+ is up) 
-| F        bra     |+| F      <4200  (firmware limit)     |  Feedrate in mm/min |
  
 === Bilder === === Bilder ===
- +1. Ein grünes Objekt\\  
-{{:projects:farmrobot:testwithopencv-1.jpg?400|}} +{{:projects:farmrobot:testwithopencv-2.jpg?400|}}\\  
-{{:projects:farmrobot:testwithopencv-2.jpg?400|}}+2. Erkennung eines Objekts. Die Konsole zeigt die für den Vorgang benötigte Zeit an.\\  
 +{{:projects:farmrobot:testwithopencv-1.jpg?400|}}\\  
 +3. Oben ist das Bild des erkannten Objekts mit dem Begrenzungsrahmen und dem Mittelpunkt des Objekts nach der Erfassung der Koordinaten dargestellt. Das Bild unten zeigt das erkannte Objekt nach der Entrauschung. Um das erkannte Objekt zu analysieren, wurde es in ein Schwarz-Weiß-Bild umgewandelt.\\ 
 {{:projects:farmrobot:testwithopencv-3.jpg?400|}} {{:projects:farmrobot:testwithopencv-3.jpg?400|}}
  
 === Code block === === Code block ===
-<color #ed1c24>noch mal kurze Erklärung +opencv wird verwendet, um ein bestimmtes Objekt (in diesem Fall ein grünes Objekt) aus dem Video zu erkennen und die Koordinaten des Objekts zu erhalten. Um ein bewegtes Objekt zu erkennen, verwenden wir das Video anstelle des Bildes. Um den Delta-Arm in die Mitte des Objekts zu bewegen, verwenden wir eine Bounding-Box, um die Koordinaten des erkannten Objekts zu erhalten, und rufen gcsender auf, um den Gcode zu senden. 
-</color><file python>+ 
 +<file python>
 import cv2 import cv2
 import serial import serial
Line 46: Line 101:
 camera = cv2.VideoCapture(0) camera = cv2.VideoCapture(0)
  
-gcsender = GCodeSender('COM7')+gcsender = GCodeSender('COM7'# choose your own port
  
 while True: while True:
projects/farmrobot/realcode_g-code.1615240631.txt.gz · Last modified: 2021/03/08 21:57 by roman-heinrich