7. Ustawienia bezpieczeństwa robota

7.1. Ustawianie poziomu kolizji

1/**
2* @brief Ustawianie poziomu kolizji
3* @param  [in]  mode  0-poziom, 1-procent
4* @param  [in]  level Próg kolizji, poziom odpowiada zakresowi [1 - 10 dla poziomów 1-10, 100-wyłączone], procent odpowiada zakresowi [0~10 dla 0% - 100%]
5* @param  [in]  config 0-nie aktualizuj pliku konfiguracyjnego, 1-aktualizuj plik konfiguracyjny
6* @return  Kod błędu
7*/
8int SetAnticollision(int mode, Object[] level, int config);

7.2. Ustawianie strategii po kolizji

1/**
2* @brief  Ustawianie strategii po kolizji
3* @param  [in] strategy  0-zatrzymaj z błędem, 1-kontynuuj działanie
4* @param  [in] safeTime  Czas bezpiecznego zatrzymania [1000 - 2000] ms
5* @param  [in] safeDistance  Bezpieczna odległość zatrzymania [1-150] mm
6* @param  [in] safetyMargin  Współczynniki bezpieczeństwa dla j1-j6 [1-10]
7* @return  Kod błędu
8*/
9int SetCollisionStrategy(int strategy, int safeTime, int safeDistance, int safetyMargin[]);

7.3. Rozpoczęcie funkcji niestandardowego progu detekcji kolizji

Nowe w wersji Java: SDK-v1.0.3-3.8.0

1/**
2* @brief  Rozpoczęcie funkcji niestandardowego progu detekcji kolizji, ustawienie progów detekcji kolizji dla strony przegubów i strony TCP
3* @param  [in] flag 1-tylko detekcja przegubów włączona; 2-tylko detekcja TCP włączona; 3-detekcja przegubów i TCP włączone jednocześnie
4* @param  [in] jointDetectionThreshould Próg detekcji kolizji przegubów j1-j6
5* @param  [in] tcpDetectionThreshould  Próg detekcji kolizji TCP, xyzabc
6* @param  [in] block 0-nieblokujący; 1-blokujący
7* @return  Kod błędu
8*/
9public int CustomCollisionDetectionStart(int flag, double[] jointDetectionThreshould, double[] tcpDetectionThreshould, int block);

7.4. Zakończenie funkcji niestandardowego progu detekcji kolizji

Nowe w wersji Java: SDK-v1.0.3-3.8.0

1/**
2* @brief  Zakończenie funkcji niestandardowego progu detekcji kolizji
3* @return  Kod błędu
4*/
5public int CustomCollisionDetectionEnd();

7.5. Przykład kodu ustawiania poziomu kolizji robota

 1public static int TestCollision(Robot robot)
 2{
 3    int mode = 0;
 4    int config = 1;
 5    Object[] level1 = new Object[]{ 1.0,2.0,3.0,4.0,5.0,6.0 };
 6    Object[] level2 = new Object[]{ 50.0,20.0,30.0,40.0,50.0,60.0 };
 7
 8    int rtn = robot.SetAnticollision(mode, level1, config);
 9    System.out.println("SetAnticollision mode 0 rtn is: "+ rtn);
10    mode = 1;
11    rtn = robot.SetAnticollision(mode, level2, config);
12    System.out.println("SetAnticollision mode 1 rtn is :"+ rtn);
13
14    JointPos p1Joint=new JointPos(-11.904, -99.669, 117.473, -108.616, -91.726, 74.256);
15    JointPos p2Joint=new JointPos(-45.615, -106.172, 124.296, -107.151, -91.282, 74.255);
16
17    DescPose p1Desc=new DescPose(-419.524, -13.000, 351.569, -178.118, 0.314, 3.833);
18    DescPose p2Desc=new DescPose(-321.222, 185.189, 335.520, -179.030, -1.284, -29.869);
19
20    ExaxisPos exaxisPos=new ExaxisPos(0.0, 0.0, 0.0, 0.0);
21    DescPose offdese=new DescPose(0.0, 0.0, 0.0, 0.0, 0.0, 0.0);
22    robot.MoveL(p2Joint, p2Desc, 0, 0, 100, 100, 100, 2,0, exaxisPos, 0, 0, offdese,0,10);
23    robot.ResetAllError();
24    int[] safety = new int[]{ 5,5,5,5,5,5 };
25    rtn = robot.SetCollisionStrategy(3, 1000, 150, 250, safety);
26    System.out.println("SetCollisionStrategy rtn is:"+ rtn);
27
28    double[] jointDetectionThreshould = new double[]{ 0.1, 0.1, 0.1, 0.1, 0.1, 0.1 };
29    double[] tcpDetectionThreshould =new double[] { 60,60,60,60,60,60 };
30    rtn = robot.CustomCollisionDetectionStart(3, jointDetectionThreshould, tcpDetectionThreshould, 0);
31    System.out.println("CustomCollisionDetectionStart rtn is :"+ rtn);
32
33    robot.MoveL(p1Joint, p1Desc, 0, 0, 100, 100, 100, -1,0, exaxisPos, 0, 0, offdese,0,10);
34    robot.MoveL(p2Joint, p2Desc, 0, 0, 100, 100, 100, -1,0, exaxisPos, 0, 0, offdese,0,10);
35    rtn = robot.CustomCollisionDetectionEnd();
36    System.out.println("CustomCollisionDetectionEnd rtn is: "+ rtn);
37    return 0;
38}

7.6. Ustawianie dodatniego ograniczenia

1/**
2* @brief  Ustawianie dodatniego ograniczenia
3* @param  [in] limit Pozycje sześciu przegubów, jednostka deg
4* @return  Kod błędu
5*/
6int SetLimitPositive(Object[] limit);

7.7. Ustawianie ujemnego ograniczenia

1/**
2* @brief  Ustawianie ujemnego ograniczenia
3* @param  [in] limit Pozycje sześciu przegubów, jednostka deg
4* @return  Kod błędu
5*/
6int SetLimitNegative(Object[] limit);

7.8. Pobieranie kątów miękkiego ograniczenia przegubów

1/**
2* @brief  Pobieranie kątów miękkiego ograniczenia przegubów
3* @param  [in] flag 0-blokujący, 1-nieblokujący
4* @param  [out] negative  Kąt ujemnego ograniczenia, jednostka deg
5* @param  [out] positive  Kąt dodatniego ograniczenia, jednostka deg
6* @return  Kod błędu
7*/
8int GetJointSoftLimitDeg(int flag, Object[] negative, Object[] positive);

7.9. Przykład kodu ustawiania ograniczeń robota

 1public static int TestLimit(Robot robot)
 2{
 3    Object[] plimit =new Object[] { 170.0,80.0,150.0,80.0,170.0,160.0 };
 4    robot.SetLimitPositive(plimit);
 5    Object[] nlimit =new Object[] { -170.0,-260.0,-150.0,-260.0,-170.0,-160.0 };
 6    robot.SetLimitNegative(nlimit);
 7
 8    Object[] neg_deg =new Object[] {0, 0 , 0, 0, 0, 0}, pos_deg = new Object[]{0, 0 , 0, 0, 0, 0};
 9    robot.GetJointSoftLimitDeg(1,  neg_deg,  pos_deg);
10    System.out.println("neg limit deg:"+ neg_deg[0]+","+ neg_deg[1]+","+ neg_deg[2]+","+ neg_deg[3]+","+ neg_deg[4]+","+ neg_deg[5]);
11    System.out.println("pos limit deg:"+pos_deg[0]+","+ pos_deg[1]+","+ pos_deg[2]+","+ pos_deg[3]+","+ pos_deg[4]+","+pos_deg[5]);
12    return 0;
13}

7.10. Ustawianie metody detekcji kolizji robota

Zmienione w wersji Java: SDK-v1.0.5-3.8.2

1/**
2* @brief Ustawianie metody detekcji kolizji robota
3* @param [in] method Metoda detekcji kolizji: 0-tryb prądowy; 1-podwójny enkoder; 2-tryb prądowy i podwójny enkoder włączone jednocześnie
4* @param [in] thresholdMode Sposób progu poziomu kolizji; 0-stały próg poziomu kolizji; 1-niestandardowy próg detekcji kolizji
5* @return Kod błędu
6*/
7int SetCollisionDetectionMethod(int method,int thresholdMode)

7.11. Włączanie/wyłączanie detekcji kolizji w stanie statycznym

1/**
2* @brief Włączanie/wyłączanie detekcji kolizji w stanie statycznym
3* @param  [in] status 0-wyłączone; 1-włączone
4* @return  Kod błędu
5*/
6public int SetStaticCollisionOnOff(int status)

7.12. Przykład kodu ustawiania metody detekcji kolizji robota

 1public static int TestCollisionMethod(Robot robot)
 2{
 3    int rtn = robot.SetCollisionDetectionMethod(0);
 4
 5    rtn = robot.SetStaticCollisionOnOff(1);
 6    System.out.println("SetStaticCollisionOnOff On rtn is:"+ rtn);
 7    robot.Sleep(5000);
 8    rtn = robot.SetStaticCollisionOnOff(0);
 9    System.out.println("SetStaticCollisionOnOff Off rtn is:"+ rtn);
10
11    robot.CloseRPC();
12    return 0;
13}

7.13. Detekcja momentu obrotowego i mocy przegubów

1/**
2* @brief Detekcja momentu obrotowego i mocy przegubów
3* @param  [in] status 0-wyłączone; 1-włączone
4* @param  [in] power Ustawiona maksymalna moc (W)
5* @return  Kod błędu
6*/
7public int SetPowerLimit(int status, double power)

7.14. Przykład kodu detekcji momentu obrotowego i mocy przegubów

 1public static int TestPowerLimit(Robot robot)
 2{
 3    robot.DragTeachSwitch(1);
 4    robot.SetPowerLimit(1, 200);
 5    List<Number> joint_toq=new ArrayList<>();
 6    joint_toq=robot.GetJointTorques(1);
 7
 8    int count = 100;
 9    robot.ServoJTStart(); //   #servoJT开始
10    int error = 0;
11    while (count > 0)
12    {
13        count = count - 1;
14        robot.Sleep(1);
15    }
16    error = robot.ServoJTEnd();
17    robot.DragTeachSwitch(0);
18
19    robot.CloseRPC();
20    return 0;
21}

7.15. Ustawianie parametrów bezpiecznej prędkości

1/**
2* @brief Ustawianie parametrów bezpiecznej prędkości
3* @param enable 0-wył.; 1-włączone w trybie ręcznym; 2-włączone we wszystkich trybach (automatyczne ograniczanie prędkości nie jest obsługiwane)
4* @param maxTCPVel Ograniczenie maksymalnej prędkości TCP; [0-1000] mm/s
5* @param strategy Strategia po przekroczeniu prędkości; 0-zatrzymaj i alarmuj; 1-automatyczne ograniczanie prędkości; 2-zatrzymaj, alarmuj i dezaktywuj
6* @return Kod błędu
7*/
8public int SetVelReducePara(int enable, double maxTCPVel, int strategy)

7.16. Przykład kodu SDK ustawiania parametrów bezpiecznej prędkości

 1public static int TestSetVelReducePara(Robot robot) {
 2    int rtn = 0;
 3
 4    JointPos j1 = new JointPos(0, -90, 90, 0, 0, 0);
 5    JointPos j2 = new JointPos(90, -90, 90, 0, 0, 0);
 6    ExaxisPos epos = new ExaxisPos(0, 0, 0, 0);
 7    DescPose offset_pos = new DescPose(0, 0, 0, 0, 0, 0);
 8
 9    robot.SetSpeed(80);
10    rtn = robot.SetVelReducePara(2, 30, 1);
11    System.out.printf("SetVelReducePara param error rtn is %d\n", rtn);
12
13    rtn = robot.SetVelReducePara(0, 30, 1);
14    System.out.printf("SetVelReducePara disable reduce vel rtn is %d\n", rtn);
15    robot.MoveJ(j1, 0, 0, 100, 100, 100.0, epos, -1.0, 0, offset_pos);
16    robot.MoveJ(j2, 0, 0, 100, 100, 100.0, epos, -1.0, 0, offset_pos);
17
18    rtn = robot.SetVelReducePara(1, 30, 1);
19    System.out.printf("SetVelReducePara reduce vel rtn is %d\n", rtn);
20    robot.MoveJ(j1, 0, 0, 100, 100, 100.0, epos, -1.0, 0, offset_pos);
21    robot.MoveJ(j2, 0, 0, 100, 100, 100.0, epos, -1.0, 0, offset_pos);
22
23    rtn = robot.SetVelReducePara(2, 30, 2);
24    System.out.printf("SetVelReducePara disable robot rtn is %d\n", rtn);
25    robot.MoveJ(j1, 0, 0, 100, 100, 100.0, epos, -1.0, 0, offset_pos);
26    robot.MoveJ(j2, 0, 0, 100, 100, 100.0, epos, -1.0, 0, offset_pos);
27
28    robot.Sleep(2000);
29    robot.ResetAllError();
30    robot.RobotEnable(1);
31    robot.Sleep(1000);
32
33    rtn = robot.SetVelReducePara(2, 30, 0);
34    System.out.printf("SetVelReducePara report error rtn is %d\n", rtn);
35    robot.MoveJ(j1, 0, 0, 100, 100, 100.0, epos, -1.0, 0, offset_pos);
36    robot.MoveJ(j2, 0, 0, 100, 100, 100.0, epos, -1.0, 0, offset_pos);
37
38    robot.Sleep(1000);
39    return 0;
40}