Skip to content

Latest commit

 

History

History
120 lines (82 loc) · 3.61 KB

README.md

File metadata and controls

120 lines (82 loc) · 3.61 KB

Unity-Python RGBD Simulator

This package provide the ability to capture Unity's PerceptionCamera RGB and depth image, and publish it to a Python endpoint via UDP for image processing.

⚠️ Please read the setup instructions carefully!

Updates

Camera intrinsic can be extracted via the following sample code snippet.

using Unity.Mathematics;
using UnityEngine;

public class CameraIntrinsics : MonoBehaviour 
{
    public Camera Target;

    void Start()
    {
        Debug.Log(GetIntrinsic(Target));
    }   

    void Update()
    {
    } 

    public float3x3 GetIntrinsic(Camera cam)
    {
        float pixel_aspect_ratio = (float)cam.pixelWidth / (float)cam.pixelHeight;

        float alpha_u = cam.focalLength * ((float)cam.pixelWidth / cam.sensorSize.x);
        float alpha_v = cam.focalLength * pixel_aspect_ratio * ((float)cam.pixelHeight / cam.sensorSize.y);

        float u_0 = (float)cam.pixelWidth / 2;
        float v_0 = (float)cam.pixelHeight / 2;

        //IntrinsicMatrix in row major
        float3x3 camIntriMatrix = new float3x3(alpha_u,      0f, u_0,
                                                    0f, alpha_v, v_0,
                                                    0f,      0f,  1f);
        return camIntriMatrix;
    }
}

Setup Instructions

1. Install Unity High Definition Render Pipeline (HDRP)

Pick one of the following options:

Option 1: Importing Unity HDRP to existing projects

Option 2: Creating new project with HDRP preinstalled

2. Convert render materials to HDRP materials

This is necessary for PerceptionCamera to be able to see GameObjects. If there is any Fix All option, select it. All checkmarks should be green on this window.

Converting all project materials to HDRP compliant

3. (Optional) Create and assign new materials as necessary

If your robots and objects does not render correctly i.e., it looks purple, it means the shader for that material is wrong. The correct shader material needs to be HDRP/Lit.

Creating new material and assign correct shader

4. Install Unity Perception package

Add package via Unity package naming convention i.e., com.unity.perception

Importing Unity Perception via Package Manager

5. Import Unity-Python RGBD Capture Package

In this repository, the file CameraStreamer.unitypackage contains all the necessary code and prefabs necessary to complete assignments. To import, go to Assets -> Import Package -> Custom Packages..., which will open a file selection dialog. Navigate to where you download the .unitypackage and select it.

6. Add RGBD camera into scene

The RGBDCamera prefab has all the necessary scripts pre-attached to it and can simply be put into the scene. You can now move and rotate it as you would any other GameObject in the scene to adjust your camera POV.

7. Verify Python communication

At this point, the camera will begin capture and send data to Python, while also listening in for message from Python. You may uncomment:

  1. line 53-54 of the script to view the RGB image
  2. line 90-91 to view the depth image

If everything is done correctly, you should see Unity console display "test message".

You are to modify the code after line 120 in opencv_receiver.py.

Additionally, you may chose to disable the debug prints in PythonSocketCommunicator.cs, it is only there for testing purposes.