Commit 0f61d212 authored by Larkin Heintzman's avatar Larkin Heintzman

qualisys further changes

parent 7b08a026
...@@ -71,6 +71,7 @@ typedef struct ServiceAck ...@@ -71,6 +71,7 @@ typedef struct ServiceAck
float eucDistance(std::vector<float> a, std::vector<float> b); float eucDistance(std::vector<float> a, std::vector<float> b);
float normalizeAngle(float angle);
std::vector<std::vector<float>> rotateAxisAngle(std::vector<float> u, float angleRad); std::vector<std::vector<float>> rotateAxisAngle(std::vector<float> u, float angleRad);
float dotProduct(std::vector<float> vect_A, std::vector<float> vect_B); float dotProduct(std::vector<float> vect_A, std::vector<float> vect_B);
std::vector<float> crossProduct(std::vector<float> vect_A, std::vector<float> vect_B); std::vector<float> crossProduct(std::vector<float> vect_A, std::vector<float> vect_B);
......
...@@ -11,18 +11,27 @@ ...@@ -11,18 +11,27 @@
<param name="enc_key" type="string" value="e180b993ca8365653437fbafe7211ba040386d77c3c87627882857a11bd8efbd"/> <param name="enc_key" type="string" value="e180b993ca8365653437fbafe7211ba040386d77c3c87627882857a11bd8efbd"/>
<param name="use_broadcast" type="bool" value="false"/> <param name="use_broadcast" type="bool" value="false"/>
</node> </node>
<!-- <param name="min_yaw_speed" type="double" value="0.0"/>
<param name="max_yaw_speed" type="double" value="15.0"/> -->
<param name="base_speed" type="double" value="0.5"/> <param name="base_speed" type="double" value="0.5"/>
<param name="min_speed" type="double" value="0.1"/> <param name="min_speed" type="double" value="0.1"/>
<param name="speed_scalar" type="double" value="0.01"/> <param name="speed_scalar" type="double" value="0.01"/>
<!-- max yaw rate in deg/s -->
<param name="max_yaw_speed" type="double" value="30.0"/>
<param name="position_playback" type="bool" value="false"/>
<param name="drone_id" type="int" value="0"/> <param name="drone_id" type="int" value="0"/>
<param name="camera_type" type="int" value="1"/> <param name="camera_type" type="int" value="1"/>
<!-- <param name="angle_offset" type="double" value="-33"/> --> <!-- <param name="angle_offset" type="double" value="-33"/> -->
<node pkg="dji_osdk_ros" type="bus_driver" name="bus_driver" output="screen"/> <node pkg="dji_osdk_ros" type="bus_driver" name="bus_driver" output="screen"/>
<node pkg="dji_osdk_ros" type="poseFeedbackConversion.py" name="poseFeedbackConversion" output="screen"> <!-- <node pkg="dji_osdk_ros" type="poseFeedbackConversion.py" name="poseFeedbackConversion" output="screen">
<rosparam command="load" param="angleOffset"> <rosparam command="load" param="angleOffset">
-33.0 0.0
</rosparam> </rosparam>
</node> -->
<node pkg="dji_osdk_ros" type="qualisysFeedback.py" name="qualisysFeedback" output="screen">
<param name="trackName" type="string" value="M100_CarbonFiber"/>
</node> </node>
<node name="waypointGenerator" type="waypointGeneratorRemote.py" pkg="dji_osdk_ros"> <node name="waypointGenerator" type="waypointGeneratorRemote.py" pkg="dji_osdk_ros">
......
...@@ -3,6 +3,7 @@ ...@@ -3,6 +3,7 @@
import rospy import rospy
import numpy as np import numpy as np
from sensor_msgs.msg import NavSatFix from sensor_msgs.msg import NavSatFix
from sensor_msgs.msg import Imu
from geometry_msgs.msg import PointStamped from geometry_msgs.msg import PointStamped
from geometry_msgs.msg import QuaternionStamped from geometry_msgs.msg import QuaternionStamped
from dji_osdk_ros.msg import VOPosition from dji_osdk_ros.msg import VOPosition
...@@ -34,7 +35,9 @@ def point_rotation(origin, pt, ang): ...@@ -34,7 +35,9 @@ def point_rotation(origin, pt, ang):
def rotCallback(data): def rotCallback(data):
global quat global quat
quat = data.quaternion quat = data.orientation;
# # FINE ill DO it MYself all ALONE
def posCallback(data): def posCallback(data):
global homeSetFlag global homeSetFlag
...@@ -51,21 +54,16 @@ def posCallback(data): ...@@ -51,21 +54,16 @@ def posCallback(data):
rotation = Quaternion() rotation = Quaternion()
# rotate the xy plane by angle # rotate the xy plane by angle
# dataPointSpun = point_rotation([0, 0], [data.x, data.y], angleOffset)
homePointMeters = lat_lon2meters([homePoint.latitude, homePoint.longitude]) homePointMeters = lat_lon2meters([homePoint.latitude, homePoint.longitude])
currentPointMeters = lat_lon2meters([data.latitude, data.longitude]) currentPointMeters = lat_lon2meters([data.latitude, data.longitude])
currentOffset = [currentPointMeters[0] - homePointMeters[0], currentPointMeters[1] - homePointMeters[1]] currentOffset = [currentPointMeters[0] - homePointMeters[0], currentPointMeters[1] - homePointMeters[1]]
# angleOffset = -33.0
# rospy.loginfo(angleOffset)
# rospy.loginfo(currentOffset)
angleOffset = rospy.get_param("~angleOffset") angleOffset = rospy.get_param("~angleOffset")
currentRotatedOffset = point_rotation([0,0], currentOffset, angleOffset) currentRotatedOffset = point_rotation([0,0], currentOffset, angleOffset)
# rospy.loginfo(currentRotatedOffset)
# performing dark magics
translation.x = currentRotatedOffset[1] translation.x = currentRotatedOffset[1]
translation.y = currentRotatedOffset[0] translation.y = currentRotatedOffset[0]
translation.z = data.altitude - homePoint.altitude translation.z = data.altitude - homePoint.altitude
...@@ -73,19 +71,11 @@ def posCallback(data): ...@@ -73,19 +71,11 @@ def posCallback(data):
transform.translation = translation transform.translation = translation
transform.rotation = quat transform.rotation = quat
# rot = Rotation.from_euler('xyz', [0, 0, 0], degrees = True) # be not rotated pls
# zeroQuaternion = rot.as_quat()
# rotation.x = zeroQuaternion[0]
# rotation.y = zeroQuaternion[1]
# rotation.z = zeroQuaternion[2]
# rotation.w = zeroQuaternion[3]
def main(): def main():
global transform global transform
rospy.init_node("poseFeedbackConversion") rospy.init_node("poseFeedbackConversion")
rospy.Subscriber("dji_osdk_ros/gps_position", NavSatFix, posCallback, queue_size = 1) rospy.Subscriber("dji_osdk_ros/gps_position", NavSatFix, posCallback, queue_size = 1)
rospy.Subscriber("dji_osdk_ros/attitude", QuaternionStamped, rotCallback, queue_size = 1) rospy.Subscriber("dji_osdk_ros/imu", Imu, rotCallback, queue_size = 1)
posePublisher = rospy.Publisher("pose_feedback", Transform, queue_size = 1) posePublisher = rospy.Publisher("pose_feedback", Transform, queue_size = 1)
while not rospy.is_shutdown(): while not rospy.is_shutdown():
posePublisher.publish(transform) posePublisher.publish(transform)
......
#!/usr/bin/python3
import rospy
import numpy as np
from geometry_msgs.msg import PoseStamped
from geometry_msgs.msg import Transform
transform = Transform()
def callback(data):
# save the pose date in transform
transform.rotation = data.pose.orientation
# we must remapp
# transform.translation = data.pose.position
transform.translation.x = data.pose.position.z
transform.translation.z = data.pose.position.y
transform.translation.y = data.pose.position.x
def main():
global transform
rospy.init_node("qualisysFeedback")
name = rospy.get_param("~trackName")
rospy.loginfo("looking for track of name " + str(name) + " ...")
rospy.Subscriber("/qualisys/" + name + "/pose", PoseStamped, callback, queue_size = 1)
pub = rospy.Publisher("pose_feedback", Transform, queue_size = 1)
while not rospy.is_shutdown():
pub.publish(transform)
if __name__ == '__main__':
main()
...@@ -12,3 +12,10 @@ def lat_lon2meters(latlon_point): ...@@ -12,3 +12,10 @@ def lat_lon2meters(latlon_point):
transformer = Transformer.from_crs(4326, 3857) transformer = Transformer.from_crs(4326, 3857)
meters_point = transformer.transform(latlon_point[0], latlon_point[1]) meters_point = transformer.transform(latlon_point[0], latlon_point[1])
return meters_point return meters_point
def normalizeAngle(angle):
newAngle = angle%360
newAngle = (newAngle + 360)%360
if(newAngle >= 180):
newAngle -= 360
return newAngle
...@@ -58,7 +58,7 @@ def generateWaypoints(): ...@@ -58,7 +58,7 @@ def generateWaypoints():
for i, offset in enumerate(waypointOffsets): for i, offset in enumerate(waypointOffsets):
waypointLatLon = meters2lat_lon([apMeters[0] + offset[0], apMeters[1] + offset[1]]) waypointLatLon = meters2lat_lon([apMeters[0] + offset[0], apMeters[1] + offset[1]])
waypointLatLonRev = meters2lat_lon([apMeters[0] - offset[0], apMeters[1] - offset[1]]) waypointLatLonRev = meters2lat_lon([apMeters[0] - offset[0], apMeters[1] - offset[1]])
waypointHeading = normalizeAngle(45*i) waypointHeading = (45.0*i)%360.0
# waypoints # waypoints
waypointDict["robot_{}".format(d)]["waypoints"].update({"waypoint_{}".format(i) : [i, waypointLatLon[0], waypointLatLon[1], baseWaypointAltitude + d*waypointAltitudeIncrement, waypointHeading]}) waypointDict["robot_{}".format(d)]["waypoints"].update({"waypoint_{}".format(i) : [i, waypointLatLon[0], waypointLatLon[1], baseWaypointAltitude + d*waypointAltitudeIncrement, waypointHeading]})
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment