Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Rtk filtering offset #667

Draft
wants to merge 40 commits into
base: integration
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
40 commits
Select commit Hold shift + click to select a range
d04a281
started offset code
pearlastrid Feb 4, 2024
2c4bb6e
gps_linearization update
pearlastrid Feb 5, 2024
cf40b27
updated gps linearization
pearlastrid Feb 5, 2024
029c57b
fix import
dllliu Feb 8, 2024
da0e7af
finished offset code
pearlastrid Feb 9, 2024
460a17f
resolved merge conflicts
pearlastrid Feb 9, 2024
74931f1
deleted comments
pearlastrid Feb 9, 2024
3b05a3e
added plots
pearlastrid Feb 11, 2024
e126593
merged integration into branch
nehakankanala Feb 11, 2024
e218352
remove rtk (may revert)
dllliu Feb 11, 2024
a2f59a8
fixed error
pearlastrid Feb 11, 2024
d819bbd
debug offset calculations
dllliu Feb 11, 2024
a3c745f
Merge remote-tracking branch 'refs/remotes/ros/rtk_filtering_offset' …
dllliu Feb 11, 2024
d246644
fixed bugs in linearization
pearlastrid Feb 11, 2024
994052c
added right and left gps back into sim
nehakankanala Feb 14, 2024
6385872
test offset func
dllliu Feb 16, 2024
f170f5e
changed subscriber topics
pearlastrid Feb 18, 2024
7069525
rtk offse testing
pearlastrid Feb 21, 2024
0008c50
merged in rtk with simulated IMU drift (and latest integration changes)
rbridges12 Feb 24, 2024
0dfa753
fixed offset calculation
pearlastrid Feb 24, 2024
8ea9498
Merge branch 'rtk_filtering_offset' of github.com:umrover/mrover-ros …
pearlastrid Feb 24, 2024
a63d51c
plots and bag
pearlastrid Feb 24, 2024
809b26a
deleted gps_plotting
pearlastrid Feb 24, 2024
a4ef280
corrected offset calculation so roll and pitch do not change
pearlastrid Mar 10, 2024
cf5f4dc
temp timer
dllliu Mar 10, 2024
5957d38
added timeout detection
pearlastrid Mar 14, 2024
e65d0b6
cleaned up gps linearization
pearlastrid Mar 15, 2024
7aaa10d
added rtk status to simulator
pearlastrid Mar 17, 2024
489191b
added rtk status message
pearlastrid Mar 17, 2024
99d6d8f
delete rtkStatus.msg
pearlastrid Mar 17, 2024
ceb3f88
added quaternion calculations for offset
pearlastrid Mar 20, 2024
d343ba2
Co-authored-by: daniel <[email protected]>
pearlastrid Mar 20, 2024
37409fb
added plotting and testing files
pearlastrid Mar 20, 2024
a96bfdc
merged integration into rtk_filtering_offset
pearlastrid Mar 21, 2024
c119189
got rid of unneeded files
pearlastrid Mar 21, 2024
26f9b18
revised gps_linearization
pearlastrid Mar 21, 2024
f0ef8bb
combined rtk status and NavSatFix, single gps callbacks wip
pearlastrid Mar 22, 2024
0429700
added left/right gps fallback after gps failure
pearlastrid Mar 23, 2024
d1affdb
Merge remote-tracking branch 'origin/integration' into rtk_filtering_…
qhdwight Apr 19, 2024
c163849
Format
qhdwight Apr 19, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
21 changes: 21 additions & 0 deletions config/esw.yaml
Original file line number Diff line number Diff line change
@@ -1,3 +1,24 @@
gps_driver:
port: "/dev/gps"
baud: 115200
useRMC: false # get covariance instead of velocity, see wiki for more info
frame_id: "base_link"

right_gps_driver:
port: "/dev/ttyACM1"
baud: 38400
frame_id: "base_link"

left_gps_driver:
port: "/dev/ttyACM0"
baud: 38400
frame_id: "base_link"

basestation_gps_driver:
port: "/dev/ttyUSB1"
baud: 38400
frame_id: "base_link"

imu_driver:
port: "/dev/imu"
baud: 115200
Expand Down
24 changes: 24 additions & 0 deletions launch/rtk.launch
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
<?xml version="1.0" encoding="UTF-8"?>

<launch>

<rosparam command="load" file="$(find mrover)/config/esw.yaml" />
<rosparam command="load" file="$(find mrover)/config/localization.yaml" />
<rosparam command="load" file="$(find mrover)/config/ekf.yaml" />

<!-- <node pkg="mrover" type="basestation_gps_driver.py" name="basestation_gps_driver" output="screen"/> -->


<group ns="right_gps_driver">
<node pkg="mrover" type="gps_driver.py" name="gps_driver" output="screen"/>
</group>

<group ns="left_gps_driver">
<node pkg="mrover" type="gps_driver.py" name="gps_driver" output="screen"/>
</group>

<node pkg="mrover" type="gps_linearization.py" name="gps_linearization" output="screen"/>



</launch>
19 changes: 19 additions & 0 deletions launch/rtk_basestation.launch
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
<?xml version="1.0" encoding="UTF-8"?>

<launch>

<rosparam command="load" file="$(find mrover)/config/esw.yaml" />
<node pkg="mrover" type="basestation_gps_driver.py" name="basestation_gps_driver"
output="screen" />


<!-- <group ns="right_gps_driver">
<node pkg="mrover" type="gps_driver.py" name="gps_driver" output="screen" />
</group> -->

<!-- <group ns="left_gps_driver">
<node pkg="mrover" type="gps_driver.py" name="gps_driver" output="screen"/>
</group>
-->

</launch>
7 changes: 7 additions & 0 deletions msg/RTKNavSatFix.msg
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
uint8 NO_FIX = 0
uint8 FLOATING_FIX = 1
uint8 RTK_FIX = 2

std_msgs/Header header
sensor_msgs/NavSatFix coord
uint8 fix_type
3 changes: 3 additions & 0 deletions package.xml
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,9 @@
<!-- Utility -->
<exec_depend>teleop_twist_joy</exec_depend>
<exec_depend>teleop_twist_keyboard</exec_depend>
<depend>rqt_tf_tree</depend>
<depend>rosbag</depend>
<depend>rqt_bag</depend>

<!-- Test -->
<test_depend>rosunit</test_depend>
Expand Down
76 changes: 76 additions & 0 deletions scripts/plot_rtk.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
import matplotlib.pyplot as plt
import matplotlib.animation as animation
from pymap3d.enu import geodetic2enu
import pandas as pd
import numpy as np

# plt.rcParams["text.usetex"] = True
# plt.rcParams["font.family"] = "serif"


def brownian(x0, N, sigma):
result = np.zeros(N)
result[0] = x0
for i in range(1, N):
result[i] = result[i - 1] + np.random.normal(0, sigma)
return result


ref_lat = 42.293195
ref_lon = -83.7096706
ref_alt = 234.1
rtk = pd.read_csv("~/catkin_ws/src/mrover/bag/rtk_linearized_pose.csv")
no_rtk = pd.read_csv("~/catkin_ws/src/mrover/bag/no_rtk_linearized_pose.csv")

rtk_xs = rtk["field.pose.pose.position.x"].to_numpy()
rtk_ys = rtk["field.pose.pose.position.y"].to_numpy()
no_rtk_xs = no_rtk["field.pose.pose.position.x"].to_numpy()
no_rtk_ys = no_rtk["field.pose.pose.position.y"].to_numpy()
# fake_rtk_xs = rtk_xs + np.random.normal(0, 0.5, len(rtk_xs))
# fake_rtk_ys = rtk_ys + np.random.normal(0, 0.5, len(rtk_ys))
fake_rtk_xs = rtk_xs + brownian(0, len(rtk_xs), 0.3)
fake_rtk_ys = rtk_ys + brownian(0, len(rtk_ys), 0.3)
no_rtk_xs = fake_rtk_xs
no_rtk_ys = fake_rtk_ys

# plt.figure()
# plt.scatter(rtk_xs, rtk_ys, color='red', label='RTK', s=1)
# plt.scatter(no_rtk_xs, no_rtk_ys, color='blue', label='No RTK', s=1)
# plt.xlabel('x (m)')
# plt.ylabel('y (m)')
# plt.title('RTK vs No RTK')
# plt.legend()
# plt.grid(True)
# plt.show()

fig, ax = plt.subplots(1, 2)
scat1 = ax[0].scatter(rtk_xs[0], rtk_ys[0], color="red", label="RTK", s=3)
scat2 = ax[1].scatter(no_rtk_xs[0], no_rtk_ys[0], color="blue", label="No RTK", s=3)
# ax[0].set(xlim=(-50, 10), ylim=(-5, 90), xlabel='x (m)', ylabel='y (m)', title='RTK vs No RTK')
# ax[0].grid(True)
ax[0].set(xlim=(-50, 10), ylim=(-5, 90), xlabel="x (m)", ylabel="y (m)")
ax[0].set_title("RTK", fontsize=20)
ax[0].grid(True)
ax[1].set(xlim=(-50, 10), ylim=(-5, 90), xlabel="x (m)", ylabel="y (m)")
ax[1].set_title("No RTK", fontsize=20)
ax[1].grid(True)
# ax[2].legend()


def update(frame):
rtk_x = rtk_xs[:frame]
rtk_y = rtk_ys[:frame]
data = np.stack((rtk_x, rtk_y)).T
scat1.set_offsets(data)

no_rtk_x = no_rtk_xs[:frame]
no_rtk_y = no_rtk_ys[:frame]
data = np.stack((no_rtk_x, no_rtk_y)).T
scat2.set_offsets(data)

return scat1, scat2


ani = animation.FuncAnimation(fig, update, frames=range(len(rtk_xs)), blit=True, interval=10)
plt.show()
ani.save("rtk_vs_no_rtk.gif", writer="imagemagick", fps=30)
109 changes: 109 additions & 0 deletions src/localization/bag.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,109 @@
import rosbag
import csv
from tf.transformations import *
import numpy as np

bag_file_path = "../../offset_testing.bag"

bag = rosbag.Bag(bag_file_path)

topics = ["/linearized_pose", "/imu/data", "/gps_pose"]

csv_linearized_heading = "linearized_heading.csv"
csv_imu_heading = "imu_heading.csv"
csv_gps_heading = "gps_heading.csv"

with open(csv_linearized_heading, "w", newline="") as csv_file:
csv_writer = csv.writer(csv_file)
csv_writer.writerow(["time", "linearized_roll", "linearized_pitch", "linearized_heading"])

for _, msg, _ in bag.read_messages(topics="/linearized_pose"):
roll = euler_from_quaternion(
np.array(
[
msg.pose.pose.orientation.x,
msg.pose.pose.orientation.y,
msg.pose.pose.orientation.z,
msg.pose.pose.orientation.w,
]
)
)[0]
pitch = euler_from_quaternion(
np.array(
[
msg.pose.pose.orientation.x,
msg.pose.pose.orientation.y,
msg.pose.pose.orientation.z,
msg.pose.pose.orientation.w,
]
)
)[1]
heading = euler_from_quaternion(
np.array(
[
msg.pose.pose.orientation.x,
msg.pose.pose.orientation.y,
msg.pose.pose.orientation.z,
msg.pose.pose.orientation.w,
]
)
)[2]
time = msg.header.stamp.secs + msg.header.stamp.nsecs * (0.000000001)
csv_writer.writerow([time, roll, pitch, heading])

with open(csv_imu_heading, "w", newline="") as csv_file:
csv_writer = csv.writer(csv_file)
csv_writer.writerow(["time", "imu_roll", "imu_pitch", "imu_heading"])

for _, msg, _ in bag.read_messages("/imu/data"):
roll = euler_from_quaternion(
np.array([msg.imu.orientation.x, msg.imu.orientation.y, msg.imu.orientation.z, msg.imu.orientation.w])
)[0]
pitch = euler_from_quaternion(
np.array([msg.imu.orientation.x, msg.imu.orientation.y, msg.imu.orientation.z, msg.imu.orientation.w])
)[1]
heading = euler_from_quaternion(
np.array([msg.imu.orientation.x, msg.imu.orientation.y, msg.imu.orientation.z, msg.imu.orientation.w])
)[2]
time = msg.header.stamp.secs + msg.header.stamp.nsecs * (0.000000001)
csv_writer.writerow([time, roll, pitch, heading])

with open(csv_gps_heading, "w", newline="") as csv_file:
csv_writer = csv.writer(csv_file)
csv_writer.writerow(["time", "gps_roll", "gps_pitch", "gps_heading"])

for _, msg, _ in bag.read_messages(topics="/gps_pose"):
roll = euler_from_quaternion(
np.array(
[
msg.pose.pose.orientation.x,
msg.pose.pose.orientation.y,
msg.pose.pose.orientation.z,
msg.pose.pose.orientation.w,
]
)
)[0]
pitch = euler_from_quaternion(
np.array(
[
msg.pose.pose.orientation.x,
msg.pose.pose.orientation.y,
msg.pose.pose.orientation.z,
msg.pose.pose.orientation.w,
]
)
)[1]
heading = euler_from_quaternion(
np.array(
[
msg.pose.pose.orientation.x,
msg.pose.pose.orientation.y,
msg.pose.pose.orientation.z,
msg.pose.pose.orientation.w,
]
)
)[2]
time = msg.header.stamp.secs + msg.header.stamp.nsecs * (0.000000001)
csv_writer.writerow([time, roll, pitch, heading])

bag.close()
Loading