This page includes the program and software toolkits for our paper SVDTree (Accepted by CVPR 2024).
This project was led by two co-first authors, each responsible for different parts seperately:
🐶 Zhihao Liu: mainly handles Shape-guided 3D Tree Modeling
(3D Graphics part), which takes voxels (point clouds) as input and produces the final realistic 3D tree models.
• [Code (C++)] [Demo Video] [EXE Program]. Please refer to Sec.1 for detailed introduction.
🐶 Yuan Li: mainly handles the Voxel Diffusion Network
(CNN part), which is trained to generate rough semantic voxels.
• [Code (Python)] Please refer to Sec.2 for detailed introduction.
In this section, we released a more adaptable version of our code, that is capable of reconstructing 3D tree structures from both voxels
or dense point clouds
. Typically, handling point clouds poses greater challenges compared to voxels, which is our default input setting. We hope this version could be helpful if you need to process such complex data format.
Should you have any questions on this part, please feel free to reach out to Zhihao Liu.
📺 (1) Demo Video:
We strongly recommend watching this [Demo Video] to quickly know about the basic usage of the software.
🟥 (2) Software Download:
We have released a compiled exe software that can be directly used without any configuration on Windows PCs. Please download the entire [this Folder] to access the software. Once downloaded, you can easily run the program by simply double-clicking the TreeFromPoint.exe
.
📁 (3) Source Code:
Please check this [Folder] to download the source code.
🟦 (4) Test Data of a 3D Point Cloud:
You can download this example 3D point cloud file [xyz file] to quickly have a try with our software. If you would like to generate trees using your own point data, please prepare the file with reference to this format.
The code for Shape-driven Tree modeling is entirely developed by C++, so you'll need to install the necessary IDE if you want to compile it from scratch.
📁 IDE:
The IDE I used for programming is Qt (qt-opensource-windows-x86-mingw530-5.8.0.exe).
I highly recommend you to use it as well, since I have successfully compiled my code with it, which can help you avoid many unexpected compilation errors. Certainly, other IDEs like Visual Studio, are also alternatives.
📁 Compile:
You can directly compile in Qt by pressing CTRL+R
after opening the project,
or simply run the following script in the command line:
cd ./TreeFromPoints_codes
qmake TreeFromPoints.pro
Then, you can find the newly-compiled exe program under path ./release/
. and you can activate it easily by clicking it.
In this section, we released the neural network that is designed for semantic voxel inference.
Should you have any questions on this part, please feel free to reach out to Yuan Li.
• Download:
Please download the code for this part from this [Folder].
• Dependencies:
conda create -n DiffTreeVxl
conda activate DiffTreeVxl
conda install pytorch=1.9.0 torchvision=0.10.0 cudatoolkit=10.2 -c pytorch -c nvidia
pip install tqdm fire einops pyrender pyrr trimesh ocnn timm scikit-image==0.18.2 scikit-learn==0.24.2 pytorch-lightning==1.6.1
• Data Preparation:
We prepare the dataset of diverse 3D tree models using a software that was developed by Zhihao Liu. Please refer to this [GitHub page] for more details and to download the generation tool.
Notebly, our tool enables automatic generation of realistic 3D trees with diverse species, and has been used for generating dataset by many external labs in their projects, including several SIGGRAPH/CHI/CVPR papers (e.g., TreePartNet).
• Training:
python train.py --config ./config/config.yaml
You can freely change the training settings by customizing the yaml file.
• Test:
python predict.py
In predict.py, You can set the paths to ckpt and yaml files by changing the Line 9 and Line 12, respectively.