# CAD Model Rendering scripts
In this part show how to render CAD model to images and corresponding poses for later Gaussian-Splats. use the format of [NeRF Synthetic Dataset](https://github.com/bmild/nerf). adapt the code from work [work](https://github.com/bmild/nerf) and the code from [work](https://github.com/Xharlie/ShapenetRender_more_variation) for the rendering.

## Installation
use blender to render CAD model to images. Following blender install [instruction](https://www.blender.org/download/lts/3-6/), use blender 3.6.13. You can install by
```sh
mkdir ./blender_install && cd ./blender_install # or change to your prefer location
wget https://www.blender.org/download/release/Blender3.6/blender-3.6.13-linux-x64.tar.xz

tar -xvf blender-3.6.13-linux-x64.tar.xz
```
After unpacking Blender, can use it for rendering through the Python interface.

## Environment:
need package **trimesh** and **PIL** for processing
```
pip install trimesh
pip install Pillow
```


## Datasets
Prepare the CAD Dataset for usage. Get the ShapeNet from [ShapeNet website](https://shapenet.org/). Place the installed ShapeNet to **./ShapeNet**. support both ShapeNetv1 and ShapeNetv2 rendering.
Similarily, get the ModelNet from [ModelNet website](https://modelnet.cs.princeton.edu/#) and place it in **./ModelNet40**. Also you can download it from [Kaggle](https://www.kaggle.com/datasets/balraj98/modelnet40-princeton-3d-object-dataset/data).
Note that unlike other point cloud data processing like [Point-MAE](https://github.com/Pang-Yatian/Point-MAE/blob/main/DATASET.md) and [Point-Bert](https://github.com/Julie-tang00/Point-BERT/blob/49e2c7407d351ce8fe65764bbddd5d9c0e0a4c52/DATASET.md), download the CAD model files instead of processed point cloud.

While using these excellent datasets, please remember to cite the original ShapeNet and ModelNet datasets.


## Rendering
After preparing the blender and dataset, can start rendering CAD Models to images. use **start_idx** and **end_idx** to divide the whole dataset which is easier for submit multiple jobs to multiple gpus. save the first object in ShapeNetv2 and ModelNet for example.

```
# for ShapeNetv2

python3 render_shapenet.py --start_idx=0 --end_idx=1 --model_root_dir=./ShapeNet --render_root_dir=./ShapeNet/render --blender_location=./blender_install/blender-3.6.13-linux-x64/blender --shapenetversion=v2

# for ModelNet40
python3 render_modelnet.py --start_idx=0 --end_idx=1 --model_root_dir=./ModelNet40 --render_root_dir=./ModelNet40/render/ --blender_location=./blender_install/blender-3.6.13-linux-x64/blender


```

The render output format will be :
```
├──object/
│   ├──image.zip
│   ├──depth.zip
│   ├──normal.zip
│   ├──point_cloud.obj
│   ├──transforms_train.json
│   ├──transforms_test.json
│   ├──transforms_val.json
│   ├──.......
├──.......
```

Note that the train use 72 views and validation and test is seleced for last 4 views from train views. You can adjust the sampling views in by modifying variable *vertical_list* in render_blender.py and the data split.

Unlike other methods that process NeRF synthetic data by using random initialization for the Gaussian, saved the **point_cloud.obj** file from CAD and used it for initialization. This approach ensures faster convergence and higher accuracy in Gaussian rasterization.

In order to use such initialization, you only need to simply replace the dataset_readers.py in most gs-splat object with the one provide here. The difference is add another function **fetchObj** and read images from .zip files .

With render output and modified dataset_readers.py you can start training the ShapeNet and ModelNet or other CAD models efficiently.



```

## Acknowledgements

