Skip to content

Commit

Permalink
chat: implement get-location-plus-offset
Browse files Browse the repository at this point in the history
  • Loading branch information
rmackay9 authored and peterbarker committed Dec 15, 2023
1 parent 18a4e6b commit 3e10e1d
Showing 1 changed file with 45 additions and 0 deletions.
45 changes: 45 additions & 0 deletions MAVProxy/modules/mavproxy_chat/chat_openai.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
import time
from datetime import datetime
import json
import math

try:
from openai import OpenAI
Expand Down Expand Up @@ -183,6 +184,20 @@ def handle_function_call(self, run):
recognised_function = True
output = json.dumps(self.get_vehicle_location_and_yaw())

# get_location_plus_offset
if tool_call.function.name == "get_location_plus_offset":
recognised_function = True
try:
arguments = json.loads(tool_call.function.arguments)
except:
print("chat::handle_function_call: get_location_plus_offset: failed to parse arguments")
output = "get_location_plus_offset: failed to parse arguments"
try:
output = json.dumps(self.get_location_plus_offset(arguments))
except:
print("chat::handle_function_call: get_location_plus_offset: failed to calc location")
output = "get_location_plus_offset: failed to get location"

# send mavlink command_int
if tool_call.function.name == "send_mavlink_command_int":
recognised_function = True
Expand Down Expand Up @@ -294,6 +309,20 @@ def get_vehicle_location_and_yaw(self):
}
return location

# Calculate the latitude and longitude given distances (in meters) North and East
def get_location_plus_offset(self, arguments):
lat = arguments.get("latitude", 0)
lon = arguments.get("longitude", 0)
dist_north = arguments.get("distance_north", 0)
dist_east = arguments.get("distance_east", 0)
lat_lon_to_meters_scaling = 89.8320495336892 * 1e-7
lat_diff = dist_north * lat_lon_to_meters_scaling
lon_diff = dist_east * lat_lon_to_meters_scaling / max(0.01, math.cos(math.radians((lat+lat_diff)/2)))
return {
"latitude": self.wrap_latitude(lat + lat_diff),
"longitude": self.wrap_longitude(lon + lon_diff)
}

# send a mavlink command_int message to the vehicle
def send_mavlink_command_int(self, arguments):
target_system = arguments.get("target_system", 1)
Expand Down Expand Up @@ -336,3 +365,19 @@ def send_mavlink_set_position_target_global_int(self, arguments):
yaw_rate = arguments.get("yaw_rate", 0)
self.mpstate.master().mav.set_position_target_global_int_send(time_boot_ms, target_system, target_component, coordinate_frame, type_mask, lat_int, lon_int, alt, vx, vy, vz, afx, afy, afz, yaw, yaw_rate)
return "set_position_target_global_int sent"

# wrap latitude to range -90 to 90
def wrap_latitude(self, latitude_deg):
if latitude_deg > 90:
return 180 - latitude_deg
if latitude_deg < -90:
return -(180 + latitude_deg)
return latitude_deg

# wrap longitude to range -180 to 180
def wrap_longitude(self, longitude_deg):
if longitude_deg > 180:
return longitude_deg - 360
if longitude_deg < -180:
return longitude_deg + 360
return longitude_deg

0 comments on commit 3e10e1d

Please sign in to comment.