12. Sterowanie siłą robota
12.1. Konfiguracja czujnika siły
1/**
2* @brief Konfiguruje czujnik siły
3* @param config company: Producent czujnika siły, 17-Kunwei Technology, 19-Instytut Kosmiczny 11, 20-Czujnik ATI, 21-Zhongke Midian, 22-Weihang Minxin, 23-NBIT, 24-Xinjingcheng (XJC), 26-NSR
4* @param config device: Numer urządzenia, Kunwei (0-KWR75B), Instytut Kosmiczny 11 (0-MCS6A-200-4), ATI (0-AXIA80-M8), Zhongke Midian (0-MST2010), Weihang Minxin (0-WHC6L-YB-10A), NBIT (0-XLH93003ACS), Xinjingcheng XJC (0-XJC-6F-D82), NSR (0-NSR-FTSensorA)
5* @param config softvesion: Numer wersji oprogramowania, tymczasowo nieużywany, domyślnie 0
6* @param config bus: Pozycja magistrali końcowej, na której zamontowane jest urządzenie, tymczasowo nieużywane, domyślnie 0
7* @return Kod błędu
8*/
9int FT_SetConfig(DeviceConfig config);
12.2. Pobieranie konfiguracji czujnika siły
1/**
2* @brief Pobiera konfigurację czujnika siły
3* @param [out] config company: Producent czujnika siły, 17-Kunwei Technology, 19-Instytut Kosmiczny 11, 20-ATI, 21-Zhongke Midian, 22-Weihang Minxin
4* @param [out] config device: Numer urządzenia, Kunwei (0-KWR75B), Instytut Kosmiczny 11 (0-MCS6A-200-4), ATI (0-AXIA80-M8), Zhongke Midian (0-MST2010), Weihang Minxin (0-WHC6L-YB-10A)
5* @param [out] config softvesion: Numer wersji oprogramowania, tymczasowo nieużywany, domyślnie 0
6* @param [out] config bus: Pozycja magistrali końcowej, na której zamontowane jest urządzenie, tymczasowo nieużywane, domyślnie 0
7* @return Kod błędu
8*/
9int FT_GetConfig(DeviceConfig config);
12.3. Aktywacja czujnika siły
1/**
2* @brief Aktywuje czujnik siły
3* @param [in] act 0-reset, 1-aktywacja
4* @return Kod błędu
5*/
6int FT_Activate(int act);
12.4. Zerowanie czujnika siły
1/**
2* @brief Zeruje czujnik siły
3* @param [in] act 0-usuń punkt zerowy, 1-korekcja zera
4* @return Kod błędu
5*/
6int FT_SetZero(int act);
12.5. Ustawianie układu odniesienia czujnika siły
1/**
2* @brief Ustawia układ odniesienia czujnika siły
3* @param [in] type 0-układ współrzędnych narzędzia, 1-układ współrzędnych bazowych, 2-swobodny układ współrzędnych
4* @param [in] coord Wartości swobodnego układu współrzędnych
5* @return Kod błędu
6*/
7int FT_SetRCS(int type, DescPose coord);
12.6. Ustawianie masy obciążenia pod czujnikiem siły
1/**
2* @brief Ustawia masę obciążenia pod czujnikiem siły
3* @param [in] weight Masa obciążenia [kg]
4* @return Kod błędu
5*/
6int SetForceSensorPayLoad(double weight);
12.7. Ustawianie środka ciężkości obciążenia pod czujnikiem siły
1/**
2* @brief Ustawia środek ciężkości obciążenia pod czujnikiem siły
3* @param [in] cog Środek ciężkości obciążenia [mm]
4* @return Kod błędu
5*/
6int SetForceSensorPayLoadCog(DescTran cog);
12.8. Pobieranie masy obciążenia pod czujnikiem siły
1/**
2* @brief Pobiera masę obciążenia pod czujnikiem siły
3* @return List[0]:kod błędu; List[1] : weight masa obciążenia [kg]
4*/
5List<Number> GetForceSensorPayLoad();
12.9. Pobieranie środka ciężkości obciążenia pod czujnikiem siły
1/**
2* @brief Pobiera środek ciężkości obciążenia pod czujnikiem siły
3* @param [out] cog Środek ciężkości obciążenia [mm]
4* @return Kod błędu
5*/
6int GetForceSensorPayLoadCog(DescTran cog);
12.10. Automatyczne zerowanie czujnika siły
1/**
2* @brief Automatyczne zerowanie czujnika siły
3* @param [in] massCenter Masa czujnika (kg) i środek ciężkości (mm)
4* @return Kod błędu
5*/
6int ForceSensorAutoComputeLoad(MassCenter massCenter);
12.11. Pobieranie danych siły/momentu w układzie odniesienia
1/**
2* @brief Pobiera dane siły/momentu w układzie odniesienia
3* @param [in] flag 0-blokujący, 1-nieblokujący
4* @param [out] ft Siła/moment, fx, fy, fz, tx, ty, tz
5* @return Kod błędu
6*/
7int FT_GetForceTorqueRCS(int flag, ForceTorque ft);
12.12. Pobieranie surowych danych siły/momentu z czujnika siły
1/**
2* @brief Pobiera surowe dane siły/momentu z czujnika siły
3* @param [in] flag 0-blokujący, 1-nieblokujący
4* @param [out] ft Siła/moment, fx, fy, fz, tx, ty, tz
5* @return Kod błędu
6*/
7int FT_GetForceTorqueOrigin(int flag, ForceTorque ft);
12.13. Przykład kodu konfiguracji czujnika siły i automatycznego zerowania
1public static int TestFTInit(Robot robot)
2{
3 DescTran tr1=new DescTran(0,0,0);
4 robot.SetForceSensorPayload(0);
5 robot.SetForceSensorPayloadCog(tr1);
6
7 int company = 24;
8 int device = 0;
9 int softversion = 0;
10 int bus = 1;
11 int index = 1;
12
13 DeviceConfig con=new DeviceConfig(company,device,softversion,bus);
14 robot.FT_SetConfig(con);
15 robot.Sleep(1000);
16 robot.FT_GetConfig(con);
17 robot.Sleep(1000);
18
19 robot.FT_Activate(0);
20 robot.Sleep(1000);
21 robot.FT_Activate(1);
22 robot.Sleep(1000);
23
24 robot.Sleep(1000);
25 robot.FT_SetZero(0);
26 robot.Sleep(1000);
27
28 ForceTorque ft=new ForceTorque(0,0,0,0,0,0);
29 robot.FT_GetForceTorqueOrigin(0, ft);
30 robot.FT_SetZero(1);
31 robot.Sleep(1000);
32
33 DescPose ftCoord = new DescPose();
34 robot.FT_SetRCS(0, ftCoord);
35
36 robot.SetForceSensorPayload(0.824);
37
38 DescTran tr=new DescTran(0.778, 2.554, 48.765);
39 robot.SetForceSensorPayloadCog(tr);
40 List<Number> weight = new ArrayList<>();
41 double x = 0, y = 0, z = 0;
42 weight=robot.GetForceSensorPayload();
43 robot.GetForceSensorPayloadCog(tr);
44 tr.x=0;
45 tr.y=0;
46 tr.z=0;
47 robot.SetForceSensorPayload(0);
48 robot.SetForceSensorPayloadCog(tr);
49
50 double computeWeight = 0;
51 DescTran tran = new DescTran();
52 MassCenter mass=new MassCenter();
53 mass.weight=weight.get(1).doubleValue();
54 mass.cog=tran;
55 robot.ForceSensorAutoComputeLoad(mass);
56 return 0;
57}
12.14. Rejestracja identyfikacji masy obciążenia
1/**
2* @brief Rejestracja identyfikacji masy obciążenia
3* @param [in] id Numer układu współrzędnych czujnika, zakres [1~14]
4* @return Kod błędu
5*/
6int FT_PdIdenRecord(int id);
12.15. Obliczanie identyfikacji masy obciążenia
1/**
2* @brief Obliczanie identyfikacji masy obciążenia
3* @return List[0]:kod błędu; List[1] : double weight Masa obciążenia, jednostka kg
4*/
5List<Number> FT_PdIdenCompute();
12.16. Rejestracja identyfikacji środka ciężkości obciążenia
1/**
2* @brief Rejestracja identyfikacji środka ciężkości obciążenia
3* @param [in] id Numer układu współrzędnych czujnika, zakres [1~14]
4* @param [in] index Numer punktu, zakres [1~3]
5* @return Kod błędu
6*/
7int FT_PdCogIdenRecord(int id, int index);
12.17. Obliczanie identyfikacji środka ciężkości obciążenia
1/**
2* @brief Obliczanie identyfikacji środka ciężkości obciążenia
3* @param [out] cog Środek ciężkości obciążenia, jednostka mm
4* @return Kod błędu
5*/
6int FT_PdCogIdenCompute(DescTran cog);
12.18. Przykład kodu identyfikacji obciążenia czujnika siły
1public static int TestFTLoadCompute(Robot robot)
2{
3 DescTran tr1=new DescTran(0,0,0);
4 robot.SetForceSensorPayload(0);
5 robot.SetForceSensorPayloadCog(tr1);
6
7 int company = 24;
8 int device = 0;
9 int softversion = 0;
10 int bus = 1;
11 int index = 1;
12
13 DeviceConfig con=new DeviceConfig(company, device, softversion, bus);
14 robot.FT_SetConfig(con);
15 robot.Sleep(1000);
16 robot.FT_GetConfig(con);
17 robot.Sleep(1000);
18
19 robot.FT_Activate(0);
20 robot.Sleep(1000);
21 robot.FT_Activate(1);
22 robot.Sleep(1000);
23
24 robot.Sleep(1000);
25 robot.FT_SetZero(0);
26 robot.Sleep(1000);
27
28 ForceTorque ft=new ForceTorque(0,0,0,0,0,0);
29 robot.FT_GetForceTorqueOrigin(0, ft);
30 robot.FT_SetZero(1);
31 robot.Sleep(1000);
32
33 DescPose tcoord = new DescPose();
34 tcoord.tran.z = 35.0;
35 robot.SetToolCoord(10, tcoord, 1, 0, 0, 0);
36
37 robot.FT_PdIdenRecord(10);
38 robot.Sleep(1000);
39
40 List<Number> weight =new ArrayList<>();
41 weight=robot.FT_PdIdenCompute();
42
43 DescPose desc_p1=new DescPose(-419.524, -13.000, 351.569, -178.118, 0.314, 3.833);
44 DescPose desc_p2=new DescPose(-321.222, 185.189, 335.520, -179.030, -1.284, -29.869);
45 DescPose desc_p3=new DescPose(-327.622, 402.230, 320.402, -178.067, 2.127, -46.207);
46
47 robot.MoveCart(desc_p1, 0, 0, 100.0, 100.0, 100.0, -1.0, -1);
48 robot.Sleep(1000);
49 robot.FT_PdCogIdenRecord(10, 1);
50 robot.MoveCart(desc_p2, 0, 0, 100.0, 100.0, 100.0, -1.0, -1);
51 robot.Sleep(1000);
52 robot.FT_PdCogIdenRecord(10, 2);
53 robot.MoveCart(desc_p3, 0, 0, 100.0, 100.0, 100.0, -1.0, -1);
54 robot.Sleep(1000);
55 robot.FT_PdCogIdenRecord(10, 3);
56 robot.Sleep(1000);
57 DescTran cog=new DescTran(0,0,0);
58 robot.FT_PdCogIdenCompute(cog);
59
60 robot.CloseRPC();
61 return 0;
62}
12.19. Ochrona przed kolizją
1/**
2* @brief Ochrona przed kolizją
3* @param [in] flag 0-wyłącz ochronę przed kolizją, 1-włącz ochronę przed kolizją
4* @param [in] sensor_id Numer czujnika siły
5* @param [in] select Wybór, czy wykrywać kolizję dla sześciu stopni swobody, 0-nie wykrywaj, 1-wykrywaj
6* @param [in] ft Siła/moment kolizji, fx, fy, fz, tx, ty, tz
7* @param [in] max_threshold Maksymalny próg
8* @param [in] min_threshold Minimalny próg
9* @note Zakres wykrywania siły/momentu: (ft-min_threshold, ft+max_threshold)
10* @return Kod błędu
11*/
12int FT_Guard(int flag, int sensor_id, Object[] select, ForceTorque ft, Object[] max_threshold, Object[] min_threshold);
12.20. Przykład kodu ochrony przed kolizją
1public static void main(String[] args)
2{
3 Robot robot = new Robot();
4 robot.SetReconnectParam(true,20,500);
5 robot.LoggerInit(FrLogType.DIRECT, FrLogLevel.INFO, "D://log", 10, 10);
6 int rtn = robot.RPC("192.168.58.2");
7 if(rtn == 0)
8 {
9 System.out.println("rpc połączenie success");
10 }
11 else
12 {
13 System.out.println("rpc połączenie fail");
14 return ;
15 }
16 byte flag = 1;
17 byte sensor_id = 8;
18 Object[] select = { 1, 0, 0, 0, 0, 0 };
19 Object[] max_threshold = { 5.0, 0.01, 0.01, 0.01, 0.01, 0.01 };
20 Object[] min_threshold = { 3.0, 0.01, 0.01, 0.01, 0.01, 0.01 };
21
22 ForceTorque ft = new ForceTorque(0.0, 0.0, 0.0, 0.0, 0.0, 0.0);
23 DescPose desc_p1, desc_p2, desc_p3;
24 desc_p1 = new DescPose(-14.404,-455.283,319.847,-172.935,25.141,-68.097);
25 desc_p2 = new DescPose(-107.999,-599.174,285.939,153.472,12.686,-71.284);
26 desc_p3 = new DescPose(6.586,-704.897,309.638,178.909,-27.759,-70.479);
27
28 int rtn = robot.FT_Guard(flag, sensor_id, select, ft, max_threshold, min_threshold);
29 System.out.println("FT_Guard start rtn {rtn}");
30 robot.MoveCart(desc_p1, 0, 0, 20, 100.0f, 100.0f, -1.0f, -1);
31 robot.MoveCart(desc_p2, 0, 0, 20, 100.0f, 100.0f, -1.0f, -1);
32 robot.MoveCart(desc_p3, 0, 0, 20, 100.0f, 100.0f, -1.0f, -1);
33}
12.21. Sterowanie stałą siłą
1/**
2* @brief Sterowanie stałą siłą
3* @param flag 0-wyłącz sterowanie stałą siłą, 1-włącz sterowanie stałą siłą
4* @param sensor_id Numer czujnika siły
5* @param select Wybór, czy wykrywać kolizję dla sześciu stopni swobody, 0-nie wykrywaj, 1-wykrywaj
6* @param ft Siła/moment kolizji, fx, fy, fz, tx, ty, tz
7* @param ft_pid Parametry PID siły, parametry PID momentu
8* @param adj_sign Sterowanie uruchamianiem/zatrzymywaniem adaptacyjnym, 0-wyłącz, 1-włącz
9* @param ILC_sign Sterowanie uruchamianiem/zatrzymywaniem ILC, 0-zatrzymaj, 1-trening, 2-praktyka
10* @param max_dis Maksymalna odległość regulacji, jednostka mm
11* @param max_ang Maksymalny kąt regulacji, jednostka deg
12* @param M Parametry masy rx, ry [0.1-10], domyślnie 2
13* @param B Parametry tłumienia rx, ry [0.1-50], domyślnie 8
14* @param threshold Próg uruchomienia rx, ry [0-10], domyślnie 0.2
15* @param adjustCoeff Współczynnik regulacji momentu rx, ry [0-1], domyślnie 1
16* @param polishRadio Promień szlifowania, jednostka mm
17* @param filter_Sign Flaga włączenia filtracji 0-wył.; 1-wł., domyślnie wył.
18* @param posAdapt_sign Flaga włączenia dostosowania postawy 0-wył.; 1-wł., domyślnie wył.
19* @param isNoBlock Flaga blokowania, 0-blokuj; 1-nie blokuj
20* @return Kod błędu
21*/
22public int FT_Control(int flag, int sensor_id, int[] select, ForceTorque ft, double[] ft_pid, int adj_sign, int ILC_sign, double max_dis, double max_ang,double[] M,double[] B, double[] threshold, double[] adjustCoeff, double polishRadio,int filter_Sign, int posAdapt_sign, int isNoBlock)
12.22. Przykład kodu sterowania stałą siłą z tłumieniem
1public static int TestFTControlWithAdjustCoeff(Robot robot)
2{
3 int sensor_id = 10;
4 int[] select = { 0,0,1,0,0,0 };
5 double[] ft_pid = { 0.0008, 0.0, 0.0, 0.0, 0.0, 0.0 };
6 int adj_sign = 0;
7 int ILC_sign = 0;
8 double max_dis = 1000.0;
9 double max_ang = 20;
10 ForceTorque ft = new ForceTorque(0.0,0,0,0,0,0);
11 ExaxisPos epos=new ExaxisPos(0, 0, 0, 0);
12 JointPos j1=new JointPos(80.765, -98.795, 106.548, -97.734, -89.999, 94.842);
13 JointPos j2=new JointPos(43.067, -84.429, 92.620, -98.175, -90.011, 57.144);
14 DescPose desc_p1=new DescPose(5.009, -547.463, 262.053, -179.999, -0.019, 75.923);
15 DescPose desc_p2=new DescPose(-347.966, -547.463, 262.048, -180.000, -0.019, 75.923);
16 DescPose offset_pos=new DescPose(0, 0, 0, 0, 0, 0);
17 double[] M = { 2.0, 2.0 };
18 double[] B = { 15.0, 15.0 };
19 double[] threshold = {1.0, 1.0};
20 double[] adjustCoeff = {1.0, 0.8};
21 double polishRadio = 0.0;
22 int filter_Sign = 0;
23 int posAdapt_sign = 1;
24 int isNoBlock;
25 ft.fz = -10.0;
26 while(true)
27 {
28 int rtn = robot.FT_Control(1, sensor_id, select, ft, ft_pid, adj_sign, ILC_sign, max_dis, max_ang, M, B, threshold, adjustCoeff, 0, 0, 1, 0);
29 System.out.printf("FT_Control start rtn is %d\n", rtn);
30 robot.MoveL(j1, desc_p1, 1, 0, 100.0, 100.0, 100.0, -1.0, 0, epos, 0, 0, offset_pos, 0,0, 0,10);
31 robot.MoveL(j2, desc_p2, 1, 0, 100.0, 100.0, 100.0, -1.0, 0, epos, 0, 0, offset_pos, 0,0, 0,10);
32 rtn = robot.FT_Control(0, sensor_id, select, ft, ft_pid, adj_sign, ILC_sign, max_dis, max_ang, M, B, threshold, adjustCoeff, 0, 0, 1, 0);
33 System.out.printf("FT_Control end rtn is %d\n", rtn);
34 }
35}
12.23. Wstawianie obrotowe
1/**
2* @brief Wstawianie obrotowe
3* @param rcs Układ odniesienia, 0-układ współrzędnych narzędzia, 1-układ współrzędnych bazowych
4* @param angVelRot Prędkość kątowa obrotu, jednostka deg/s
5* @param ft Próg siły/momentu, fx, fy, fz, tx, ty, tz, zakres [0~100]
6* @param max_angle Maksymalny kąt obrotu, jednostka deg
7* @param orn Kierunek siły/momentu, 1-wzdłuż osi Z, 2-wokół osi Z
8* @param max_angAcc Maksymalne przyspieszenie kątowe obrotu, jednostka deg/s^2, tymczasowo nieużywane, domyślnie 0
9* @param rotorn Kierunek obrotu, 1-zgodnie z ruchem wskazówek zegara, 2-przeciwnie do ruchu wskazówek zegara
10* @param strategy Strategia postępowania w przypadku niewykrycia siły/momentu, 0-zgłoś błąd; 1-ostrzeżenie, kontynuuj ruch
11* @return Kod błędu
12*/
13public int FT_RotInsertion(int rcs, double angVelRot, double ft, double max_angle, int orn, double max_angAcc, int rotorn, int strategy)
12.24. Przykład kodu wstawiania obrotowego z czujnikiem siły robota
1public static int TestMove(Robot robot)
2{
3 int rtn=-1;
4 JointPos j1=new JointPos(-11.904, -99.669, 117.473, -108.616, -91.726, 74.256);
5 JointPos j2=new JointPos(-45.615, -106.172, 124.296, -107.151, -91.282, 74.255);
6 JointPos j3=new JointPos(-29.777, -84.536, 109.275, -114.075, -86.655, 74.257);
7 JointPos j4=new JointPos(-31.154, -95.317, 94.276, -88.079, -89.740, 74.256);
8 DescPose desc_pos1=new DescPose(-419.524, -13.000, 351.569, -178.118, 0.314, 3.833);
9 DescPose desc_pos2=new DescPose(-321.222, 185.189, 335.520, -179.030, -1.284, -29.869);
10 DescPose desc_pos3=new DescPose(-487.434, 154.362, 308.576, 176.600, 0.268, -14.061);
11 DescPose desc_pos4=new DescPose(-443.165, 147.881, 480.951, 179.511, -0.775, -15.409);
12 DescPose offset_pos=new DescPose(0, 0, 0, 0, 0, 0);
13 ExaxisPos epos=new ExaxisPos(0, 0, 0, 0);
14 int tool = 0;
15 int user = 0;
16 double vel = 100.0;
17 double acc = 100.0;
18 double ovl = 100.0;
19 double oacc = 100.0;
20 double blendT = 0.0;
21 double blendR = 0.0;
22 int flag = 0;
23 int search = 0;
24 int blendMode = 0;
25 int velAccMode = 0;
26 robot.SetSpeed(20);
27 rtn = robot.MoveJ(j1, desc_pos1, tool, user, vel, acc, ovl, epos, blendT, flag, offset_pos);
28 System.out.printf("movej errcode:%d\n", rtn);
29 rtn = robot.MoveL(j2, desc_pos2, tool, user, vel, acc, ovl, blendR, blendMode, epos, search, flag, offset_pos, oacc, velAccMode,0,10);
30 System.out.printf("movel errcode:%d\n", rtn);
31 rtn = robot.MoveC(j3, desc_pos3, tool, user, vel, acc, epos, flag, offset_pos, j4, desc_pos4, tool, user, vel, acc, epos, flag, offset_pos, ovl, blendR, oacc, velAccMode);
32 System.out.printf("movec errcode:%d\n", rtn);
33 rtn = robot.MoveJ(j2, desc_pos2, tool, user, vel, acc, ovl, epos, blendT, flag, offset_pos);
34 System.out.printf("movej errcode:%d\n", rtn);
35 rtn = robot.Circle(j3, desc_pos3, tool, user, vel, acc, epos, j1, desc_pos1, tool, user, vel, acc, epos, ovl, flag, offset_pos, oacc, -1, velAccMode);
36 System.out.printf("circle errcode:%d\n", rtn);
37 rtn = robot.MoveCart(desc_pos4, tool, user, vel, acc, ovl, blendT, -1);
38 System.out.printf("MoveCart errcode:%d\n", rtn);
39 rtn = robot.MoveJ(j1, tool, user, vel, acc, ovl, epos, blendT, flag, offset_pos);
40 System.out.printf("movej errcode:%d\n", rtn);
41 rtn = robot.MoveL(desc_pos2, tool, user, vel, acc, ovl, blendR, blendMode, epos, search, flag, offset_pos, -1, velAccMode,0,10);
42 System.out.printf("movel errcode:%d\n", rtn);
43 rtn = robot.MoveC(desc_pos3, tool, user, vel, acc, epos, flag, offset_pos, desc_pos4, tool, user, vel, acc, epos, flag, offset_pos, ovl, blendR, -1, velAccMode);
44 System.out.printf("movec errcode:%d\n", rtn);
45 rtn = robot.MoveJ(j2, tool, user, vel, acc, ovl, epos, blendT, flag, offset_pos);
46 System.out.printf("movej errcode:%d\n", rtn);
47 rtn = robot.Circle(desc_pos3, tool, user, vel, acc, epos, desc_pos1, tool, user, vel, acc, epos, ovl, flag, offset_pos, oacc, blendR, -1, velAccMode);
48 System.out.printf("circle errcode:%d\n", rtn);
49 return 0;
50}
12.25. Włączenie sterowania podatnego
1/**
2* @brief Włączenie sterowania podatnego
3* @param [in] p Współczynnik regulacji pozycji lub współczynnik podatności
4* @param [in] force Próg siły włączenia podatności, jednostka N
5* @return Kod błędu
6*/
7int FT_ComplianceStart(double p, double force);
12.26. Wyłączenie sterowania podatnego
1/**
2* @brief Wyłączenie sterowania podatnego
3* @return Kod błędu
4*/
5int FT_ComplianceStop();
12.27. Przykład kodu sterowania podatnego
1public static int TestCompliance(Robot robot)
2{
3 DescTran tr1=new DescTran(0,0,0);
4 robot.SetForceSensorPayload(0);
5 robot.SetForceSensorPayloadCog(tr1);
6
7 int company = 24;
8 int device = 0;
9 int softversion = 0;
10 int bus = 1;
11 int index = 1;
12
13 DeviceConfig con=new DeviceConfig(company, device, softversion, bus);
14 robot.FT_SetConfig(con);
15 robot.Sleep(1000);
16 robot.FT_GetConfig(con);
17
18 robot.Sleep(1000);
19
20 robot.FT_Activate(0);
21 robot.Sleep(1000);
22 robot.FT_Activate(1);
23 robot.Sleep(1000);
24
25 robot.Sleep(1000);
26 robot.FT_SetZero(0);
27 robot.Sleep(1000);
28
29 int flag = 1;
30 int sensor_id = 1;
31 Object[] select =new Object[] { 1,1,1,0,0,0 };
32 Object[] ft_pid =new Object[] { 0.0005,0.0,0.0,0.0,0.0,0.0 };
33 int adj_sign = 0;
34 int ILC_sign = 0;
35 double max_dis = 100.0;
36 double max_ang = 0.0;
37
38 ForceTorque ft=new ForceTorque(0,0,0,0,0,0);
39 DescPose offset_pos=new DescPose(0, 0, 0, 0, 0, 0);
40 ExaxisPos epos=new ExaxisPos(0, 0, 0, 0);
41
42
43 JointPos j1=new JointPos(-11.904, -99.669, 117.473, -108.616, -91.726, 74.256);
44 JointPos j2=new JointPos(-45.615, -106.172, 124.296, -107.151, -91.282, 74.255);
45 DescPose desc_p1=new DescPose(-419.524, -13.000, 351.569, -178.118, 0.314, 3.833);
46 DescPose desc_p2=new DescPose(-321.222, 185.189, 335.520, -179.030, -1.284, -29.869);
47
48 ft.fx = -10.0;
49 ft.fy = -10.0;
50 ft.fz = -10.0;
51 robot.FT_Control(flag, sensor_id, select, ft, ft_pid, adj_sign, ILC_sign, max_dis, max_ang, 0, 0, 0);
52 double p = 0.00005;
53 double force = 30.0;
54 int rtn = robot.FT_ComplianceStart(p, force);
55
56 int count = 15;
57 while (count>0)
58 {
59 robot.MoveL(j1, desc_p1, 0, 0, 100.0, 180.0, 100.0, -1.0,0, epos, 0, 1, offset_pos,0,10);
60 robot.MoveL(j2, desc_p2, 0, 0, 100.0, 180.0, 100.0, -1.0,0, epos, 0, 0, offset_pos,0,10);
61 count -= 1;
62 }
63 robot.FT_ComplianceStop();
64 flag = 0;
65 robot.FT_Control(flag, sensor_id, select, ft, ft_pid, adj_sign, ILC_sign, max_dis, max_ang, 0, 0, 0);
66
67 robot.CloseRPC();
68 return 0;
69}
12.28. Inicjalizacja filtracji dynamicznej identyfikacji obciążenia
1/**
2* @brief Inicjalizacja filtracji dynamicznej identyfikacji obciążenia
3* @return Kod błędu
4*/
5int LoadIdentifyDynFilterInit();
12.29. Inicjalizacja zmiennych dynamicznych identyfikacji obciążenia
1/**
2* @brief Inicjalizacja zmiennych dynamicznych identyfikacji obciążenia
3* @return Kod błędu
4*/
5int LoadIdentifyDynVarInit();
12.30. Program główny identyfikacji obciążenia
1/**
2* @brief Program główny identyfikacji obciążenia
3* @param [in] joint_torque Moment stawów
4* @param [in] joint_pos Pozycja stawów
5* @param [in] t Okres próbkowania
6* @return Kod błędu
7*/
8int LoadIdentifyMain(Object[] joint_torque, Object[] joint_pos, double t);
12.31. Pobieranie wyniku identyfikacji obciążenia
1/**
2* @brief Pobiera wynik identyfikacji obciążenia
3* @param [in] gain
4* @return List[0]:kod błędu; List[1] : double weight masa obciążenia; List[2]: x środek ciężkości obciążenia X mm; List[3] : y środek ciężkości obciążenia Y mm; List[2]: z środek ciężkości obciążenia Z mm
5*/
6List<Number> LoadIdentifyGetResult(Object[] gain);
12.32. Przykład kodu identyfikacji obciążenia robota
1public static int TestIdentify(Robot robot)
2{
3 int retval = 0;
4
5 retval = robot.LoadIdentifyDynFilterInit();
6
7 retval = robot.LoadIdentifyDynVarInit();
8
9 JointPos posJ = new JointPos(0,0,0,0,0,0);
10 DescPose posDec = new DescPose(0,0,0,0,0,0);
11 List<Number> joint_toq=new ArrayList<>();
12 robot.GetActualJointPosDegree( posJ);
13 posJ.J2 = posJ.J2 + 10;
14 joint_toq=robot.GetJointTorques(0);
15
16 Object[] gain =new Object[] { 0,0.05,0,0,0,0,0,0.02,0,0,0,0 };
17 double weight = 0;
18 DescTran load_pos=new DescTran(0,0,0);
19 List<Number> num=new ArrayList<>();
20 num = robot.LoadIdentifyGetResult(gain);
21
22 robot.CloseRPC();
23 return 0;
24
25}
12.33. Wspomaganie przeciągania przez czujnik siły
Zmienione w wersji Java: SDK-v1.0.6-3.8.3
1/**
2* @brief Wspomaganie przeciągania przez czujnik siły
3* @param [in] status Stan sterowania, 0-wyłączone; 1-włączone
4* @param [in] asaptiveFlag Flaga włączenia adaptacji, 0-wyłączona; 1-włączona
5* @param [in] interfereDragFlag Flaga przeciągania w obszarze interferencji, 0-wyłączona; 1-włączona
6* @param [in] ingularityConstraintsFlag Strategia punktów osobliwych, 0-omijanie; 1-przechodzenie
7* @param [in] forceCollisionFlag Flaga wykrywania kolizji robota podczas wspomaganego przeciągania; 0-wyłączona; 1-włączona
8* @param [in] M Współczynnik bezwładności
9* @param [in] B Współczynnik tłumienia
10* @param [in] K Współczynnik sztywności
11* @param [in] F Próg sześcioosiowej siły przeciągania
12* @param [in] Fmax Maksymalne ograniczenie siły przeciągania Nm
13* @param [in] Vmax Maksymalne ograniczenie prędkości stawów °/s
14* @return Kod błędu
15*/
16int EndForceDragControl(int status, int asaptiveFlag, int interfereDragFlag,int ingularityConstraintsFlag, int forceCollisionFlag, Object[] M, Object[] B, Object[] K, Object[] F, double Fmax, double Vmax)
12.34. Pobieranie stanu przełącznika przeciągania dla czujnika siły
1/**
2* @brief Pobiera stan przełącznika przeciągania dla czujnika siły
3* @return List[0]:kod błędu; List[1] : dragState Stan sterowania wspomaganiem przeciągania przez czujnik siły, 0-wyłączone; 1-włączone; List[1] : sixDimensionalDragState Stan sterowania wspomaganiem przeciągania przez siłę sześcioosiową, 0-wyłączone; 1-włączone
4*/
5List<Integer> GetForceAndTorqueDragState();
12.35. Automatyczne włączanie czujnika siły po wyczyszczeniu błędu
1/**
2* @brief Automatyczne włączanie czujnika siły po wyczyszczeniu błędu
3* @param [in] status Stan sterowania, 0-wyłączone; 1-włączone
4* @return Kod błędu
5*/
6int SetForceSensorDragAutoFlag(int status)
12.36. Przykład kodu wspomagania przeciągania przez czujnik siły
1public static int TestEndForceDragCtrl(Robot robot)
2{
3 DescTran tr1=new DescTran(0,0,0);
4 robot.SetForceSensorPayload(0);
5 robot.SetForceSensorPayloadCog(tr1);
6
7 robot.SetForceSensorDragAutoFlag(1);
8
9 Object[] M =new Object[] { 15.0, 15.0, 15.0, 0.5, 0.5, 0.1 };
10 Object[] B =new Object[] { 150.0, 150.0, 150.0, 5.0, 5.0, 1.0 };
11 Object[] K =new Object[] { 0.0, 0.0, 0.0, 0.0, 0.0, 0.0 };
12 Object[] F =new Object[] { 10.0, 10.0, 10.0, 1.0, 1.0, 1.0 };
13 robot.EndForceDragControl(1, 0, 0, 0, M, B, K, F, 50, 100);
14
15 robot.Sleep(10000);
16
17 int dragState = 0;
18 int sixDimensionalDragState = 0;
19 List<Integer> state=new ArrayList<>();
20 state=robot.GetForceAndTorqueDragState();
21
22 robot.EndForceDragControl(0, 0, 0, 0, M, B, K, F, 50, 100);
23 return 0;
24}
12.37. Ustawianie przełącznika i parametrów mieszanego przeciągania z wykorzystaniem siły sześcioosiowej i impedancji stawów
1/**
2* @brief Ustawia przełącznik i parametry mieszanego przeciągania z wykorzystaniem siły sześcioosiowej i impedancji stawów
3* @param [in] status Stan sterowania, 0-wyłączone; 1-włączone
4* @param [in] impedanceFlag Flaga włączenia impedancji, 0-wyłączona; 1-włączona
5* @param [in] lamdeGain Wzmocnienie przeciągania
6* @param [in] KGain Wzmocnienie sztywności
7* @param [in] BGain Wzmocnienie tłumienia
8* @param [in] dragMaxTcpVel Maksymalne ograniczenie prędkości liniowej końcówki podczas przeciągania
9* @param [in] dragMaxTcpOriVel Maksymalne ograniczenie prędkości kątowej końcówki podczas przeciągania
10* @return Kod błędu
11*/
12int ForceAndJointImpedanceStartStop(int status, int impedanceFlag, Object[] lamdeGain, Object[] KGain, Object[] BGain, double dragMaxTcpVel, double dragMaxTcpOriVel);
12.38. Przykład kodu mieszanego przeciągania z wykorzystaniem siły sześcioosiowej i impedancji stawów
1public static int TestForceAndJointImpedance(Robot robot)
2{
3 robot.DragTeachSwitch(1);
4 Object[] lamdeDain =new Object[] { 3.0, 2.0, 2.0, 2.0, 2.0, 3.0 };
5 Object[] KGain = new Object[]{ 0, 0, 0, 0, 0, 0 };
6 Object[] BGain =new Object[] { 150, 150, 150, 5.0, 5.0, 1.0 };
7 int rtn = robot.ForceAndJointImpedanceStartStop(1, 0, lamdeDain, KGain, BGain, 1000.0, 180.0);
8
9 robot.Sleep(10000);
10
11 robot.DragTeachSwitch(0);
12 rtn = robot.ForceAndJointImpedanceStartStop(0, 0, lamdeDain, KGain, BGain, 1000.0, 180.0);
13
14 robot.CloseRPC();
15 return 0;
16}
12.39. Sterowanie uruchamianiem/zatrzymywaniem impedancji
1/**
2* @brief Sterowanie uruchamianiem/zatrzymywaniem impedancji
3* @param [in] status 0: wyłączone; 1: włączone
4* @param [in] workSpace 0-przestrzeń stawów; 1-przestrzeń kartezjańska
5* @param [in] forceThreshold Próg siły wyzwalającej (N)
6* @param [in] m Parametr masy
7* @param [in] b Parametr tłumienia
8* @param [in] k Parametr sztywności
9* @param [in] maxV Maksymalna prędkość liniowa (mm/s)
10* @param [in] maxVA Maksymalne przyspieszenie liniowe (mm/s2)
11* @param [in] maxW Maksymalna prędkość kątowa (°/s)
12* @param [in] maxWA Maksymalne przyspieszenie kątowe (°/s2)
13* @return Kod błędu
14*/
15public int ImpedanceControlStartStop(int status, int workSpace, double[] forceThreshold, double[] m, double[] b, double[] k, double maxV, double maxVA, double maxW, double maxWA)
12.40. Przykład kodu sterowania uruchamianiem/zatrzymywaniem impedancji robota
1public static int TestImpedanceControl(Robot robot)
2{
3 JointPos j1=new JointPos(102.622, -135.990, 120.769, -73.950, -90.848, 35.507);
4 JointPos j2=new JointPos(93.674, -80.062, 82.947, -92.199, -90.967, 26.559);
5 DescPose desc_pos1=new DescPose(136.552, -149.799, 449.532, 179.817, -1.172, 157.123);
6 DescPose desc_pos2=new DescPose(136.540, -561.048, 449.542, 179.819, -1.172, 157.122);
7 DescPose offset_pos=new DescPose(0, 0, 0, 0, 0, 0);
8 ExaxisPos epos=new ExaxisPos(0, 0, 0, 0);
9 int tool = 0;
10 int user = 0;
11 double vel = 100.0;
12 double acc = 200.0;
13 double ovl = 100.0;
14 double blendT = -1.0;
15 double blendR = -1.0;
16 int flag = 0;
17 int search = 0;
18 robot.SetSpeed(20);
19 int company = 17;
20 int device = 0;
21 int softversion = 0;
22 int bus = 1;
23 DeviceConfig con=new DeviceConfig(company, device, softversion, bus);
24 robot.FT_SetConfig(con);
25 robot.Sleep(1000);
26 robot.FT_GetConfig(con);
27 System.out.println("FT config:"+con.company+","+con.device+","+con.softwareVersion+"con"+ con.bus);
28 robot.Sleep(1000);
29 robot.FT_Activate(0);
30 robot.Sleep(1000);
31 robot.FT_Activate(1);
32 robot.Sleep(1000);
33 robot.Sleep(1000);
34 robot.FT_SetZero(0);
35 robot.Sleep(1000);
36 robot.FT_SetZero(1);
37 robot.Sleep(1000);
38 double[] forceThreshold = { 30,30,30,5,5,5 };
39 double[] m= { 0.1,0.1,0.1,0.02,0.02,0.02 };
40 double[] b = { 1,1,1,0.08,0.08,0.08 };
41 double[] k = { 0,0,0,0,0,0 };
42 int rtn = robot.ImpedanceControlStartStop(1, 1, forceThreshold, m, b, k, 1000, 500, 100, 100);
43 System.out.println("ImpedanceControlStartStop errcode:"+ rtn);
44 rtn = robot.MoveL(desc_pos1, tool, user, vel, acc, ovl, blendR, 0, epos, search, flag, offset_pos, -1,0,-1, 1);
45 rtn = robot.MoveL(desc_pos2, tool, user, vel, acc, ovl, blendR, 0, epos, search, flag, offset_pos, -1,0,-1, 1);
46 rtn = robot.MoveL(desc_pos1, tool, user, vel, acc, ovl, blendR, 0, epos, search, flag, offset_pos, -1,0,-1, 1);
47 rtn = robot.MoveL(desc_pos2, tool, user, vel, acc, ovl, blendR, 0, epos, search, flag, offset_pos, -1,0,-1, 1);
48 rtn = robot.MoveL(desc_pos1, tool, user, vel, acc, ovl, blendR, 0, epos, search, flag, offset_pos, -1,0,-1, 1);
49 rtn = robot.MoveL(desc_pos2, tool, user, vel, acc, ovl, blendR, 0, epos, search, flag, offset_pos, -1,0,-1, 1);
50 System.out.println("movel errcode:"+ rtn);
51 robot.ImpedanceControlStartStop(0, 1, forceThreshold, m, b, k, 1000, 500, 100, 100);
52 robot.CloseRPC();
53 return 0;
54}
12.41. Włączanie funkcji kompensacji momentu i współczynnik kompensacji
1/**
2* @brief Włączanie funkcji kompensacji momentu i współczynnik kompensacji
3* @param status Przełącznik, 0-wyłączone; 1-włączone
4* @param torqueCoeff Współczynniki kompensacji momentu dla J1-J6 [0-1]
5* @return Kod błędu
6*/
7public int SerCoderCompenParams(int status, double[] torqueCoeff)