Skip to content

Latest commit

 

History

History
33 lines (23 loc) · 1.48 KB

README.md

File metadata and controls

33 lines (23 loc) · 1.48 KB

mj_pc

Class for rendering depth images and generating point clouds in MuJoCo

PointCloudGenerator is a Python class that can, given a mujoco_py.cymj.MjSim, render depth images from all available cameras, convert them to an Open3D point cloud, and return the cloud with its estimated normals.

Dependencies

This Python3 package depends on MuJoCo, Open3D, and PIL for image saving. See the official MuJoCo documentation for installation instructions, and install the pip packages pip3 install Pillow and pip3 install open3d.

Usage

Define any number of cameras in your MuJoCo environment with:

<body name="cam_body_name" pos="`x` `y` `z`" euler="`ax` `ay` `az`">
    <camera name="cam_name" pos="0.0 0 0" fovy="`fov`"></camera>
</body>

And replacing x, y, z, ax, ay, az, and fov with your values.

In your Python script:

from mujoco_py import cymj
from mujoco_py import load_model_from_path, MjSim
from mj_pc.mj_point_clouds import PointCloudGenerator
import open3d as o3d

model = load_model_from_path("path_to_your_model_with_cameras")
sim = MjSim(model)
# Bounds can optionally be provided to crop points outside the workspace
pc_gen = PointCloudGenerator(sim, min_bound=(-1., -1., -1.), max_bound=(1., 1., 1.))
cloud_with_normals = pc_gen.generateCroppedPointCloud()

world_origin_axes = o3d.geometry.TriangleMesh.create_coordinate_frame()
o3d.visualization.draw_geometries([cloud_with_normals, world_origin_axes])