16. Weitere Schnittstellen
16.1. SSH öffentlichen Schlüssel abrufen
Prototyp |
|
|---|---|
Beschreibung |
SSH öffentlichen Schlüssel abrufen |
Erforderliche Parameter |
Keine |
Standardparameter |
Keine |
Rückgabewert |
|
16.2. SCP-Befehl senden
Neu in Version Python: SDK-v2.1.3
Prototyp |
|
|---|---|
Beschreibung |
SCP-Befehl senden |
Erforderliche Parameter |
|
Standardparameter |
Keine |
Rückgabewert |
Fehlercode: 0 = Erfolg, sonst Fehlercode |
16.3. MD5-Wert einer Datei unter einem bestimmten Pfad berechnen
Prototyp |
|
|---|---|
Beschreibung |
MD5-Wert einer Datei unter einem bestimmten Pfad berechnen |
Erforderliche Parameter |
|
Standardparameter |
Keine |
Rückgabewert |
|
16.4. Codebeispiel für SSH- und MD5-Befehle des Roboters
1from fairino import Robot
2import time
3import threading
4# Verbindung zur Robotersteuerung herstellen, bei Erfolg wird ein Roboterobjekt zurückgegeben
5robot = Robot.RPC('192.168.58.2')
6file_path = "/fruser/airlab.lua"
7md5 = ""
8emerg_state = 0
9si0_state = 0
10si1_state = 0
11sdk_com_state = 0
12ssh_keygen = ""
13retval,ssh_keygen = robot.GetSSHKeygen()
14print(f"GetSSHKeygen retval is: {retval}")
15print(f"ssh key is: {ssh_keygen}")
16ssh_name = "fr"
17ssh_ip = "192.168.58.45"
18ssh_route = "/home/fr"
19ssh_robot_url = "/root/robot/dhpara.config"
20retval = robot.SetSSHScpCmd(1, ssh_name, ssh_ip, ssh_route, ssh_robot_url)
21print(f"SetSSHScpCmd retval is: {retval}")
22print(f"robot url is: {ssh_robot_url}")
23error, md5 = robot.ComputeFileMD5(file_path)
24print(f"md5 is: {md5}")
25robot.CloseRPC()
16.5. Rückmeldezyklus für den Roboter-Port 20004 einstellen
Neu in Version Python: SDK-v2.0.5
Prototyp |
|
|---|---|
Beschreibung |
Rückmeldezyklus für den Roboter-Port 20004 einstellen |
Erforderliche Parameter |
|
Standardparameter |
Keine |
Rückgabewert |
Fehlercode: 0 = Erfolg, sonst Fehlercode |
16.6. Rückmeldezyklus für den Roboter-Port 20004 abrufen
Neu in Version Python: SDK-v2.0.5
Prototyp |
|
|---|---|
Beschreibung |
Rückmeldezyklus für den Roboter-Port 20004 abrufen |
Erforderliche Parameter |
Keine |
Standardparameter |
Keine |
Rückgabewert |
|
16.7. Codebeispiel für die Konfiguration des Statusrückmeldezyklus (Port 20004)
1from fairino import Robot
2import time
3import threading
4# Verbindung zur Robotersteuerung herstellen, bei Erfolg wird ein Roboterobjekt zurückgegeben
5robot = Robot.RPC('192.168.58.2')
6robot.SetRobotRealtimeStateSamplePeriod(10)
7error,getPeriod = robot.GetRobotRealtimeStateSamplePeriod()
8print(f"period is {getPeriod}")
9time.sleep(1)
10robot.CloseRPC()
16.8. Roboter-Software-Upgrade
Neu in Version Python: SDK-v2.0.5
Prototyp |
|
|---|---|
Beschreibung |
Roboter-Software-Upgrade |
Erforderliche Parameter |
|
Standardparameter |
Keine |
Rückgabewert |
Fehlercode: 0 = Erfolg, sonst Fehlercode |
16.9. Status des Roboter-Software-Upgrades abrufen
Neu in Version Python: SDK-v2.0.5
Prototyp |
|
|---|---|
Beschreibung |
Status des Roboter-Software-Upgrades abrufen |
Erforderliche Parameter |
Keine |
Standardparameter |
Keine |
Rückgabewert |
|
16.10. Codebeispiel für Roboter-Software-Upgrade
1from fairino import Robot
2import time
3import threading
4# Verbindung zur Robotersteuerung herstellen, bei Erfolg wird ein Roboterobjekt zurückgegeben
5robot = Robot.RPC('192.168.58.2')
6error = robot.SoftwareUpgrade("D://zUP/QNX382/software.tar.gz", False)
7print(f"SoftwareUpgrade error is {error}")
8while True:
9 curState = robot.GetSoftwareUpgradeState()
10 print(f"upgrade state is {curState}")
11 time.sleep(3)
12robot.CloseRPC()
16.11. Punktetabellen-Datenbank herunterladen
Neu in Version Python: SDK-v2.0.1
Prototyp |
|
|---|---|
Beschreibung |
Punktetabellen-Datenbank herunterladen |
Erforderliche Parameter |
|
Standardparameter |
Keine |
Rückgabewert |
Fehlercode: 0 = Erfolg, sonst Fehlercode |
16.12. Punktetabellen-Datenbank hochladen
Neu in Version Python: SDK-v2.0.1
Prototyp |
|
|---|---|
Beschreibung |
Punktetabellen-Datenbank hochladen |
Erforderliche Parameter |
|
Standardparameter |
Keine |
Rückgabewert |
Fehlercode: 0 = Erfolg, sonst Fehlercode |
16.13. Lua-Datei mit Punktetabelle aktualisieren
Neu in Version Python: SDK-v2.0.1
Prototyp |
|
|---|---|
Beschreibung |
Lua-Datei mit Punktetabelle aktualisieren |
Erforderliche Parameter |
|
Standardparameter |
Keine |
Rückgabewert |
Fehlercode: 0 = Erfolg, sonst Fehlercode |
16.14. Codebeispiel für Roboter-Punktetabellen-Operationen
1from fairino import Robot
2# Verbindung zur Robotersteuerung herstellen, bei Erfolg wird ein Roboterobjekt zurückgegeben
3robot = Robot.RPC('192.168.58.2')
4save_path = "D://zDOWN/"
5point_table_name = "point_table_FR5.db"
6rtn = robot.PointTableDownLoad(point_table_name, save_path)
7print(f"download : {point_table_name} fail: {rtn}")
8upload_path = "D://zDOWN/point_table_FR5.db"
9rtn = robot.PointTableUpLoad(upload_path)
10print(f"retval is: {rtn}")
11point_tablename = "point_table_FR5.db"
12lua_name = "test0610.lua"
13rtn,error = robot.PointTableUpdateLua(point_tablename, lua_name)
14print(f"retval is: {rtn}")
15robot.CloseRPC()
16.15. Controller-Protokolle herunterladen
Neu in Version Python: SDK-v2.1.1
Prototyp |
|
|---|---|
Beschreibung |
Controller-Protokolle herunterladen |
Erforderliche Parameter |
|
Standardparameter |
Keine |
Rückgabewert |
Fehlercode: 0 = Erfolg, sonst Fehlercode |
16.16. Alle Datenquellen herunterladen
Neu in Version Python: SDK-v2.1.1
Prototyp |
|
|---|---|
Beschreibung |
Alle Datenquellen herunterladen |
Erforderliche Parameter |
|
Standardparameter |
Keine |
Rückgabewert |
Fehlercode: 0 = Erfolg, sonst Fehlercode |
16.17. Daten-Backup-Paket herunterladen
Neu in Version Python: SDK-v2.1.1
Prototyp |
|
|---|---|
Beschreibung |
Daten-Backup-Paket herunterladen |
Erforderliche Parameter |
|
Standardparameter |
Keine |
Rückgabewert |
Fehlercode: 0 = Erfolg, sonst Fehlercode |
16.18. Codebeispiel zum Herunterladen von Controller-Daten
1from fairino import Robot
2import time
3import threading
4# Verbindung zur Robotersteuerung herstellen, bei Erfolg wird ein Roboterobjekt zurückgegeben
5robot = Robot.RPC('192.168.58.2')
6rtn = robot.RbLogDownload("D://zDOWN/")
7print(f"RbLogDownload rtn is {rtn}")
8rtn = robot.AllDataSourceDownload("D://zDOWN/")
9print(f"AllDataSourceDownload rtn is {rtn}")
10rtn = robot.DataPackageDownload("D://zDOWN/")
11print(f"DataPackageDownload rtn is {rtn}")
12robot.CloseRPC()
16.19. Encoder-Upgrade einstellen
Neu in Version Python: SDK-v2.1.4
Prototyp |
|
|---|---|
Beschreibung |
Encoder-Upgrade einstellen |
Erforderliche Parameter |
|
Standardparameter |
Keine |
Rückgabewert |
Fehlercode: 0 = Erfolg, sonst Fehlercode |
16.20. Gelenk-Firmware-Upgrade einstellen
Neu in Version Python: SDK-v2.1.4
Prototyp |
|
|---|---|
Beschreibung |
Gelenk-Firmware-Upgrade einstellen |
Erforderliche Parameter |
|
Standardparameter |
Keine |
Rückgabewert |
Fehlercode: 0 = Erfolg, sonst Fehlercode |
16.21. Steuerkasten-Firmware-Upgrade einstellen
Neu in Version Python: SDK-v2.1.4
Prototyp |
|
|---|---|
Beschreibung |
Steuerkasten-Firmware-Upgrade einstellen |
Erforderliche Parameter |
|
Standardparameter |
Keine |
Rückgabewert |
Fehlercode: 0 = Erfolg, sonst Fehlercode |
16.22. Endeffektor-Firmware-Upgrade einstellen
Neu in Version Python: SDK-v2.1.4
Prototyp |
|
|---|---|
Beschreibung |
Endeffektor-Firmware-Upgrade einstellen |
Erforderliche Parameter |
|
Standardparameter |
Keine |
Rückgabewert |
Fehlercode: 0 = Erfolg, sonst Fehlercode |
16.23. Upgrade der vollständigen Gelenkparameter-Konfigurationsdatei
Neu in Version Python: SDK-v2.1.4
Prototyp |
|
|---|---|
Beschreibung |
Upgrade der vollständigen Gelenkparameter-Konfigurationsdatei |
Erforderliche Parameter |
|
Standardparameter |
Keine |
Rückgabewert |
Fehlercode: 0 = Erfolg, sonst Fehlercode |
16.24. Codebeispiel für Roboter-Slave-Firmware-Upgrade
1from fairino import Robot
2import time
3import threading
4# Verbindung zur Robotersteuerung herstellen, bei Erfolg wird ein Roboterobjekt zurückgegeben
5robot = Robot.RPC('192.168.58.2')
6robot.RobotEnable(0)
7time.sleep(0.2)
8rtn = robot.JointAllParamUpgrade("D://zUP/MT/joint0603/jointallparameters.db")
9print(f"robot JointAllParamUpgrade rtn is {rtn}")
10rtn = robot.SetCtrlFirmwareUpgrade(2, "D://zUP/MT/FAIR_Cobot_Cbd_Asix_V2.0.bin")
11print(f"robot SetCtrlFirmwareUpgrade rtn is {rtn}")
12rtn = robot.SetEndFirmwareUpgrade(2, "D://zUP/MT/FAIR_Cobot_Axle_Asix_V2.4.bin")
13print(f"robot SetEndFirmwareUpgrade rtn is {rtn}")
14robot.SetSysServoBootMode()
15time.sleep(0.2)
16rtn = robot.SetCtrlFirmwareUpgrade(1, "D://zUP/MT/FR_CTRL_PRIMCU_FV201412_MAIN_U4_T01_20250630(MT).bin")
17print(f"robot SetCtrlFirmwareUpgrade rtn is {rtn}")
18rtn = robot.SetEndFirmwareUpgrade(1, "D://zUP/MT/FR_END_FV2010010_MAIN_U1_T01_20250603.bin")
19print(f"robot SetEndFirmwareUpgrade rtn is {rtn}")
20rtn = robot.SetJointFirmwareUpgrade(1, "D://zUP/MT/FR_SERVO_FV504215_MAIN_U7_T07_20250603.bin")
21print(f"robot SetJointFirmwareUpgrade rtn is {rtn}")
22robot.CloseRPC()
16.25. Upgrade des Roboter-Betriebssystems (LA-Steuerkasten)
Neu in Version Python: SDK-v2.1.6
Prototyp |
|
|---|---|
Beschreibung |
Upgrade des Roboter-Betriebssystems (LA-Steuerkasten) |
Erforderliche Parameter |
|
Standardparameter |
Keine |
Rückgabewert |
Fehlercode: 0 = Erfolg, sonst Fehlercode |
16.26. Ergebnis des Roboter-Betriebssystem-Upgrades abrufen (LA-Steuerkasten)
Neu in Version Python: SDK-v2.1.6
Prototyp |
|
|---|---|
Beschreibung |
Ergebnis des Roboter-Betriebssystem-Upgrades abrufen (LA-Steuerkasten) |
Erforderliche Parameter |
Keine |
Standardparameter |
Keine |
Rückgabewert |
Fehlercode: 0 = Erfolg, sonst Fehlercode |
16.27. Roboter-MCU-Protokoll generieren
Neu in Version Python: SDK-v2.1.7
Prototyp |
|
|---|---|
Beschreibung |
Roboter-MCU-Protokoll generieren |
Erforderliche Parameter |
Keine |
Standardparameter |
Keine |
Rückgabewert |
Fehlercode: 0 = Erfolg, sonst Fehlercode |
16.28. Roboter bei getrennter Port-Kommunikation stoppen
Prototyp |
|
|---|---|
Beschreibung |
Roboter bei getrennter Port-Kommunikation stoppen |
Erforderliche Parameter |
|
Standardparameter |
Keine |
Rückgabewert |
Fehlercode Erfolg-0 Fehler-errcode |
16.29. Parameter für Roboterstopp bei Kommunikationsunterbrechung abrufen
Prototyp |
|
|---|---|
Beschreibung |
Parameter für Roboterstopp bei Kommunikationsunterbrechung abrufen |
Erforderliche Parameter |
|
Standardparameter |
Keine |
Rückgabewert |
Fehlercode Erfolg-0 Fehler-errcode |
16.30. Codebeispiel für Parameter Roboterstopp bei Kommunikationsunterbrechung
1from time import sleep
2import time
3from fairino import Robot
4# Verbindung mit der Robotersteuerung herstellen
5robot = Robot.RPC('192.168.58.2')
6
7def test_robot_stop_on_com_disc(self):
8 # Parameter initialisieren
9 enable = False
10 confirm_time = 0
11
12 # Roboterstopp bei Kommunikationsunterbrechung einstellen
13 rtn = robot.SetRobotStopOnComDisc(0, True, 330)
14 print(f"SetRobotStopOnComDisc index0: {rtn}")
15
16 rtn = robot.SetRobotStopOnComDisc(1, True, 550)
17 print(f"SetRobotStopOnComDisc index1: {rtn}")
18
19 rtn = robot.SetRobotStopOnComDisc(2, True, 110)
20 print(f"SetRobotStopOnComDisc index2: {rtn}")
21
22 rtn = robot.SetRobotStopOnComDisc(3, True, 220)
23 print(f"SetRobotStopOnComDisc index3: {rtn}")
24
25 # Roboterstopp bei Kommunikationsunterbrechung abrufen
26 rtn, enable, confirm_time = robot.GetRobotStopOnComDisc(0)
27 print(f"GetRobotStopOnComDisc 8080 rtn {rtn}; enable is {enable}; confirm time is {confirm_time}")
28
29 rtn, enable, confirm_time = robot.GetRobotStopOnComDisc(1)
30 print(f"GetRobotStopOnComDisc 80803 rtn {rtn}; enable is {enable}; confirm time is {confirm_time}")
31
32 rtn, enable, confirm_time = robot.GetRobotStopOnComDisc(2)
33 print(f"GetRobotStopOnComDisc 20002 rtn {rtn}; enable is {enable}; confirm time is {confirm_time}")
34
35 rtn, enable, confirm_time = robot.GetRobotStopOnComDisc(3)
36 print(f"GetRobotStopOnComDisc 20004 rtn {rtn}; enable is {enable}; confirm time is {confirm_time}")
37
38 # RPC-Verbindung schließen
39 robot.CloseRPC()
40 return 0
41
42test_robot_stop_on_com_disc(robot)
16.31. UDP-Befehlframe senden
Prototyp |
|
|---|---|
Beschreibung |
UDP-Befehlframe senden |
Erforderliche Parameter |
|
Standardparameter |
Keine |
Rückgabewert |
Fehlercode Erfolg-0 Fehler-errcode |
16.32. SDK-Codebeispiel für UDP-Kommunikation
1from time import sleep
2import time
3from fairino import Robot
4
5# Verbindung mit der Robotersteuerung herstellen
6robot = Robot.RPC('192.168.58.2')
7
8def TestSendUDPFrame(self):
9 # Callback einstellen
10 def callback(src_type, count, cmd_id, data_len, content):
11 print("Antwort erhalten: cmd_id={} count={} data_len={} content={}".format(cmd_id, count, data_len, content))
12 return 0
13 robot.SetUDPCmdRpyCallback(callback)
14
15 rtn = robot.SendUDPFrame("/f/bIII20III303III7IIIMode(0)III/b/f")
16 print(f"SendUDPFrame Mode(0) rtn is {rtn}")
17 time.sleep(1)
18
19 rtn = robot.SendUDPFrame("/f/bIII21III303III7IIIMode(1)III/b/f")
20 print(f"SendUDPFrame Mode(1) rtn is {rtn}")
21 time.sleep(1)
22
23 rtn = robot.SendUDPFrame(
24 "/f/bIII49III201III184IIIMoveJ(-15.625, -82.680, 101.654, -110.950, -88.290, 0.017, -383.012, -2.325, 242.655, -178.024, 1.710, 74.416, 0, 0, 100, 100, 100, 0.000, 0.000, 0.000, 0.000, -1, 0, 0, 0, 0, 0, 0, 0)III/b/f")
25 print(f"SendUDPFrame MoveJ(-15.625) rtn is {rtn}")
26 time.sleep(1)
27
28 rtn = robot.SendUDPFrame(
29 "/f/bIII48III203III199IIIMoveL(-75.622, -82.680, 101.654, -110.950, -88.290, 0.017, -193.537, 330.525, 242.657, -178.024, 1.710, 14.420, 0, 0, 100, 100, 100, -1, 0, 0.000, 0.000, 0.000, 0.000, 0, 0, 0, 0, 0, 0, 0, 0, 100, 0)III/b/f")
30 print(f"SendUDPFrame MoveL(-75.622) rtn is {rtn}")
31 time.sleep(1)
32
33 rtn = robot.SendUDPFrame("/f/bIII4III905III20IIIGetSoftwareVersion()III/b/f")
34 print(f"SendUDPFrame GetSoftwareVersion() rtn is {rtn}")
35
36 time.sleep(1)
37
38 # UDP-Frame-Datenvalidierungstest
39 rtn = robot.SendUDPFrame("/f/bIII20III303III7IIIMode(0)III/b/f")
40 print(f"SendUDPFrame rtn is {rtn}")
41
42 rtn = robot.SendUDPFrame("III20III303III7IIIMode(0)III/b/f")
43 print(f"SendUDPFrame rtn is {rtn}")
44
45 rtn = robot.SendUDPFrame("/f/bIII20III303III7IIIMode(0)")
46 print(f"SendUDPFrame rtn is {rtn}")
47
48 rtn = robot.SendUDPFrame("/f/bIII20III303III6IIIMode(0)III/b/f")
49 print(f"SendUDPFrame rtn is {rtn}")
50
51 rtn = robot.SendUDPFrame("/f/b|||20|||303|||7|||Mode(0)|||/b/f")
52 print(f"SendUDPFrame rtn is {rtn}")
53
54 rtn = robot.SendUDPFrame("/f/bII20II303II7IIMode(0)II/b/f")
55 print(f"SendUDPFrame rtn is {rtn}")
56
57 robot.CloseRPC()
58 time.sleep(1)
59
60TestSendUDPFrame(robot)
16.33. Benutzerdefinierte LED-Farbe des Roboterendeffektors einstellen
Prototyp |
|
|---|---|
Beschreibung |
Benutzerdefinierte LED-Farbe des Roboterendeffektors einstellen |
Erforderliche Parameter |
|
Standardparameter |
Keine |
Rückgabewert |
Fehlercode Erfolg-0 Fehler-errcode |
16.34. SDK-Codebeispiel zum Einstellen der benutzerdefinierten LED-Farbe des Roboterendeffektors
1from time import sleep
2import time
3from fairino import Robot
4
5# Verbindung mit der Robotersteuerung herstellen
6robot = Robot.RPC('192.168.58.2')
7
8
9def testled(self):
10 # Benutzerdefinierte LED-Farbe einstellen
11 # Parameterreihenfolge: R, G, B (Rot, Grün, Blau)
12
13 # Weiß (alle Lichter an)
14 robot.SetUserLEDColor(True, True, True)
15 time.sleep(1)
16
17 # Alle Lichter ausschalten
18 robot.SetUserLEDColor(False, False, False)
19 time.sleep(1)
20
21 # Rot (nur rotes Licht)
22 robot.SetUserLEDColor(True, False, False)
23 time.sleep(1)
24
25 # Grün (nur grünes Licht)
26 robot.SetUserLEDColor(False, True, False)
27 time.sleep(1)
28
29 # Blau (nur blaues Licht)
30 robot.SetUserLEDColor(False, False, True)
31
32 # Verbindung schließen
33 robot.CloseRPC()
34
35testled(robot)