Last active
July 24, 2020 21:04
-
-
Save shantanusingh16/5a9b88e045fca80f7c6ea656d7519a6a to your computer and use it in GitHub Desktop.
Turtlebot gibson-ros
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#!/usr/bin/python | |
from gibson.envs.mobile_robots_env import TurtlebotNavigateEnv | |
import argparse | |
import os | |
import rospy | |
from std_msgs.msg import Float32, Int64 | |
from geometry_msgs.msg import Twist | |
from sensor_msgs.msg import Image, CameraInfo | |
from nav_msgs.msg import Odometry | |
import rospkg | |
import numpy as np | |
from cv_bridge import CvBridge | |
import tf | |
rospack = rospkg.RosPack() | |
path = rospack.get_path('gibson-ros') | |
config_file = os.path.join(path, 'turtlebot_rgbd.yaml') | |
print(config_file) | |
cmdx = 0.0 | |
cmdy = 0.0 | |
depth_pub = rospy.Publisher("/gibson_ros/camera/depth/image",Image, queue_size=10) | |
depth_raw_pub = rospy.Publisher("/gibson_ros/camera/depth/image_raw",Image, queue_size=10) | |
odom_pub = rospy.Publisher("/odom", Odometry, queue_size=10) | |
camera_info_pub = rospy.Publisher("/gibson_ros/camera/depth/camera_info", CameraInfo, queue_size=10) | |
bridge = CvBridge() | |
br = tf.TransformBroadcaster() | |
def callback(data): | |
global cmdx, cmdy | |
cmdx = data.linear.x/10.0 - data.angular.z / 50.0 | |
cmdy = data.linear.x/10.0 + data.angular.z / 50.0 | |
def callback_step(data): | |
global cmdx, cmdy, bridge | |
obs, _, _, _ = env.step([cmdx, cmdy]) | |
depth = obs["depth"].astype(np.float32) | |
depth[depth > 10] = np.nan | |
depth[depth < 0.45] = np.nan | |
depth_raw_image = (obs["depth"] * 1000).astype(np.uint16) | |
depth_raw_message = bridge.cv2_to_imgmsg(depth_raw_image, encoding="passthrough") | |
depth_message = bridge.cv2_to_imgmsg(depth, encoding="passthrough") | |
now = rospy.Time.now() | |
depth_message.header.stamp = now | |
depth_raw_message.header.stamp = now | |
depth_message.header.frame_id="camera_depth_optical_frame" | |
depth_raw_message.header.frame_id="camera_depth_optical_frame" | |
depth_pub.publish(depth_message) | |
depth_raw_pub.publish(depth_raw_message) | |
msg = CameraInfo(height=256, width=256, distortion_model="plumb_bob", D=[0.0, 0.0, 0.0, 0.0, 0.0], | |
K=[128, 0.0, 128.5, 0.0, 128, 128.5, 0.0, 0.0, 1.0], | |
R=[1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 1.0], | |
P=[128, 0.0, 128.5, -0.0, 0.0, 128, 128.5, 0.0, 0.0, 0.0, 1.0, 0.0]) | |
msg.header.stamp = now | |
msg.header.frame_id="camera_depth_optical_frame" | |
camera_info_pub.publish(msg) | |
# odometry | |
odom = env.get_odom() | |
br.sendTransform((odom[0][0], odom[0][1], 0), | |
tf.transformations.quaternion_from_euler(0, 0, odom[-1][-1]), | |
rospy.Time.now(), | |
'base_footprint', | |
"odom") | |
odom_msg = Odometry() | |
odom_msg.header.stamp = now | |
odom_msg.header.frame_id = 'odom' | |
odom_msg.child_frame_id = 'base_footprint' | |
odom_msg.pose.pose.position.x = odom[0][0] | |
odom_msg.pose.pose.position.y = odom[0][1] | |
odom_msg.pose.pose.orientation.x, odom_msg.pose.pose.orientation.y, odom_msg.pose.pose.orientation.z, \ | |
odom_msg.pose.pose.orientation.w = tf.transformations.quaternion_from_euler(0, 0, odom[-1][-1]) | |
odom_msg.twist.twist.linear.x = (cmdx + cmdy) * 5 | |
odom_msg.twist.twist.angular.z = (cmdy - cmdx) * 25 | |
odom_pub.publish(odom_msg) | |
# camera tf | |
eye_pos, eye_orn = env.get_eye_pos_orientation() | |
br.sendTransform(eye_pos, (eye_orn[1], eye_orn[2], eye_orn[3], eye_orn[0]), now, | |
'camera_depth_optical_frame', "world") | |
parser = argparse.ArgumentParser() | |
parser.add_argument('--config', type=str, default=config_file) | |
args, unknown = parser.parse_known_args() | |
rospy.init_node('gibson-sim') | |
env = TurtlebotNavigateEnv(config = args.config) | |
print(env.config) | |
obs = env.reset() | |
stamp = rospy.Time.now() | |
br.sendTransform((0, 0, 0), | |
tf.transformations.quaternion_from_euler(0, 0, 0), | |
stamp, | |
'base_footprint', | |
"odom") | |
eye_pos, eye_orn = env.get_eye_pos_orientation() | |
br.sendTransform(eye_pos, eye_orn, stamp, 'camera_depth_optical_frame', "world") | |
rospy.Subscriber("/mobile_base/commands/velocity", Twist, callback) | |
rospy.Subscriber("/gibson_ros/sim_clock", Int64, callback_step) | |
rospy.spin() |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment