# Dataset Constuction Pipeline

This README provides step-by-step instructions for generating a 3D mesh from images using the Hunyuan3D model, estimating camera poses, and rendering the mesh under new camera poses. Follow the sections in order.

## 1. Image to Mesh Generation

### Step 1: Set Up the Hunyuan3D Repository and Environment
- Clone the Hunyuan3D repository from GitHub.
- Download the Hunyuan3D checkpoint (refer to the repository's instructions for the download link and placement).
- Set up the environment as described in the repository's documentation (e.g., create a virtual environment and install dependencies).

```bash
git clone git@github.com:Tencent-Hunyuan/Hunyuan3D-2.git
```

### Step 2: Prepare the Images Dataset
Prepare your dataset of images for mesh generation. Ensure the images are in the appropriate format and directory structure as required by the script.

### Step 3: Run Image to Mesh Generation
Execute the bash script to process the images and generate the mesh.

```bash
bash image2mesh.sh
```

## 2. Camera Pose Estimation

### Step 1: Prepare the Environment
Install the required Python packages from the `requirements.txt` file. It's recommended to use a virtual environment for this.

```bash
pip install -r requirements.txt
```

### Step 2: Prepare the Mask-Mesh Paired Dataset
Prepare a dataset that pairs object masks with corresponding meshes. Ensure the data is organized in the expected directory structure.

### Step 3: Run Camera Pose Estimation
Execute the Python script to estimate camera poses using Kaolin.

```python
python kaolin_pose_estimation.py
```

## 3. Render the Mesh Under New Camera Poses

Once the camera poses are estimated, render the generated mesh from new viewpoints.

```python
python kaolin_new_pose_rendering.py
```