forked from MTS-AUV-ZHCET/ROVC2.0
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy paththruster4.py
94 lines (83 loc) · 3.13 KB
/
thruster4.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
#import RPi.GPIO
#import RPi.GPIO
import pigpio
import numpy as np
from pysticks import get_controller
con = get_controller()
thruster_1 = 9 #Enter the PIN Number to Which Thrsuter 1 is coonected
thruster_2 = 11 #Enter the PIN Number to Which Thrsuter 2 is coonected
thruster_3 = 16 #Enter the PIN Number to Which Thrsuter 3 is coonected
thruster_4 = 8
thruster_pins = [thruster_1,thruster_2,thruster_3,thruster_4]
thvalue = [1500,1500,1500,1500]
pi = pigpio.pi()
for item in thruster_pins:
pi.set_servo_pulsewidth(item,1500)
# def ip():
# con.update()
# print('Throttle: %+2.2f Roll: %+2.2f Pitch: %+2.2f Yaw: %+2.2f Aux: %+2.2f' %(con.getThrottle(), con.getRoll(), con.getPitch(), con.getYaw(), con.getAux()))
# nonlocal pwm = con.getThrottle()
def map_values(value):
if value < -1 or value > 1:
return None
elif value == 0:
return 1500
else:
return int(1500 + (value * 300))
def sig(value):
if value < -1 or value > 1:
return None
elif value == 0:
return 1500
else:
return int((np.sign(value) * (27**(abs(value)) - 1) / (27**(1) - 1)) * 300 + 1500)
def forward():
con.update()
up=map_values(con.getThrottle())
move=map_values(con.getPitch())
turn=sig(con.getYaw())
toggle = con.getAux()
while(1):
up=map_values(con.getThrottle())
move=map_values(con.getPitch())
turn=sig(con.getYaw())
toggle = con.getAux()
prev=1
curr=toggle
if(prev==toggle):
pi.set_servo_pulsewidth(thruster_1, 1500)
pi.set_servo_pulsewidth(thruster_2, 1500)
pi.set_servo_pulsewidth(thruster_3, 1500)
pi.set_servo_pulsewidth(thruster_4, 1500)
print("thruster off")
break
else:
if turn == 1500 and move == 1500 and up==1500 :
pi.set_servo_pulsewidth(thruster_1, 1500)
pi.set_servo_pulsewidth(thruster_2, 1500)
pi.set_servo_pulsewidth(thruster_3, 1500)
pi.set_servo_pulsewidth(thruster_4, 1500)
print("thruster stop")
print(move)
elif turn!=1500:
pi.set_servo_pulsewidth(thruster_2, turn+50)
#pi.set_servo_pulsewidth(thruster_1, up)
#pi.set_servo_pulsewidth(thruster_1, turn+50)
pi.set_servo_pulsewidth(thruster_3, turn-50)
print("Thruster 1: ", turn+50)
print("Thruster 2: ", turn-50)
elif move!=1500:
pi.set_servo_pulsewidth(thruster_2, move)
#pi.set_servo_pulsewidth(thruster_1, up)
#pi.set_servo_pulsewidth(thruster_1, move)
pi.set_servo_pulsewidth(thruster_3, move)
print("forward thrust: ", move)
elif up!=1500:
pi.set_servo_pulsewidth(thruster_1, up)
pi.set_servo_pulsewidth(thruster_4, up)
#pi.set_servo_pulsewidth(thruster_1, up)
#pi.set_servo_pulsewidth(thruster_1, move)
print("up thrust: ", up)
break
while(1):
forward()