-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhoffmantest3.py
130 lines (102 loc) · 3.76 KB
/
hoffmantest3.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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
"""
Main driver code for moving drone to each waypoint
"""
import asyncio
from mavsdk import System
import mavsdk as sdk
import logging
import math
import typing
from typing import Dict,List
async def move_to(drone: System, latitude: float, longitude: float, altitude: float) -> None:
"""
This function takes in a latitude, longitude and altitude and autonomously
moves the drone to that waypoint. This function will also auto convert the altitude
from feet to meters.
Parameters
----------
drone: System
a drone object that has all offboard data needed for computation
latitude: float
a float containing the requested latittude to move to
longitude: float
a float containing the requested longitude to move to
altitude: float
a float contatining the requested altitude to go to (in feet)
Returns
-------
None
"""
#converts feet into meters
altitude = altitude * .3048
#get current altitude
async for terrain_info in drone.telemetry.home():
absolute_altitude: float = terrain_info.absolute_altitude_m
break
await drone.action.goto_location(latitude,longitude, altitude+absolute_altitude, 0)
location_reached: bool=False
#Loops until the waypoint is reached
while(not location_reached):
print("Going to waypoint")
async for position in drone.telemetry.position():
#continuously checks current latitude, longitude and altitude of the drone
drone_lat: float=position.latitude_deg
drone_long: float=position.longitude_deg
drone_alt: float=position.relative_altitude_m
#checks if location is reached and moves on if so
if ((round(drone_lat,4)==round(latitude,4)) and
(round(drone_long,4)==round(longitude,4)) and
(round(drone_alt,1)==round(altitude,1))):
location_reached=True
print("arrived")
break
await asyncio.sleep(1)
return
async def run() -> None:
"""
This function is just a driver to test the goto function.
Parameters
----------
None
Returns
-------
None
"""
#Put all latitudes, longitudes and altitudes into seperate arrays
lats: List[float]=[37.900304,37.900276,37.899893,37.899563,37.899557,37.899910,37.900155]
longs: List[float]=[-91.663359,-91.663780,-91.663887,-91.663668,-91.663142,-91.662930,-91.663088]
altitudes: List[float]=[50,100,150,100,50,100,80]
#create a drone object
drone: System = System()
await drone.connect(system_address="udp://:14540")
#connect to the drone
logging.info("Waiting for drone to connect...")
async for state in drone.core.connection_state():
if state.is_connected:
logging.info("Drone discovered!")
break
logging.info("Waiting for drone to have a global position estimate...")
async for health in drone.telemetry.health():
if health.is_global_position_ok:
logging.info("Global position estimate ok")
break
logging.info("-- Arming")
await drone.action.arm()
logging.info("-- Taking off")
await drone.action.takeoff()
#wait for drone to take off
await asyncio.sleep(20)
#move to each waypoint in mission
for point in range(len(lats)):
await move_to(drone,lats[point],longs[point],altitudes[point])
#return home
print("Last waypoint reached")
print("Returning to home")
await drone.action.return_to_launch()
print("Staying connected, press Ctrl-C to exit")
#infinite loop till forced disconnect
while True:
await asyncio.sleep(1)
if __name__ == "__main__":
loop = asyncio.get_event_loop()
loop.run_until_complete(run())