-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathaltiholdsim.py
108 lines (84 loc) · 3.4 KB
/
altiholdsim.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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
from dronekit import connect, VehicleMode, LocationGlobalRelative
from pymavlink import mavutil
import time
import argparse
_land = False
#kp=0.3,ki=0.01,kd=0.2
def arm_and_takeoff(aTargetAltitude):
global _land
# print kp
"""
Arms vehicle and fly to aTargetAltitude.
"""
print "Basic pre-arm checks"
# Don't try to arm until autopilot is ready
'''while not vehicle.is_armable:
print " Waiting for vehicle to initialise..."
time.sleep(1)'''
print "Arming motors"
# Copter should arm in GUIDED mode
vehicle.mode = VehicleMode("ALT_HOLD")
vehicle.armed=True
# Confirm vehicle armed before attempting to take off
while not vehicle.armed:
print " Waiting for arming..."
time.sleep(1)
print "Taking off!"
# vehicle.mode = VehicleMode("STABILIZE")
#vehicle.simple_takeoff(aTargetAltitude) # Take off to target altitude
# Wait until the vehicle reaches a safe height before processing the goto (otherwise the command
# after Vehicle.simple_takeoff will execute immediately).
while True:
try:
if _land==False:
setz = aTargetAltitude
currentz = vehicle.location.global_relative_frame.alt
PID = 0
sum_error = 0
prev_error = 0
errorz = setz - currentz
vehicle.armed=True
#Break and return from function just below target altitude.
if abs(errorz)>setz*0.1:
if errorz<0 :
vehicle.channels.overrides['3'] = 1340
elif errorz>0 :
vehicle.channels.overrides['3'] = 1660
else:
vehicle.channels.overrides['3'] = 1500
print "Reached target altitude"
print " Altitude: ", currentz , "errorz:", errorz,"setz",setz
print "throttle",vehicle.channels['3']
time.sleep(1)
else:
print "Setting throttle zero"
vehicle.channels.overrides['3']=0
exit()
except KeyboardInterrupt:
vehicle.channels.overrides['3']=0
# vehicle.mode = VehicleMode("LAND")
# if _land:
# vehicle.channels.overrides['3']=1000
# exit()
_land = True
#Set up option parsing to get connection string
parser = argparse.ArgumentParser(description='Commands vehicle using vehicle.simple_goto.')
parser.add_argument('--connect',
help="Vehicle connection target string. If not specified, SITL automatically started and used.")
args = parser.parse_args()
connection_string = args.connect
sitl = None
#connection_string = '/dev/serial/by-id/usb-Arduino__www.arduino.cc__Arduino_Mega_2560_740313032373515082D1-if00' #for serial
connection_string = 'udp:127.0.0.1:14549'
# Connect to the Vehicle
print 'Connecting to vehicle on: %s' % connection_string
vehicle = connect(connection_string, wait_ready=True) #for udp
#vehicle = connect(connection_string, baud=115200, wait_ready=True) #for serial
print _land
arm_and_takeoff(1.5)
#Close vehicle object before exiting script
print "Close vehicle object"
vehicle.close()
# Shut down simulator if it was started.
if sitl is not None:
sitl.stop()