kingnobro / IconShop

(Siggraph Asia 2023) Code of "IconShop: Text-Guided Vector Icon Synthesis with Autoregressive Transformers"
32 stars 8 forks source link
icon svg svg-generation text-to-svg vector-graphics vector-graphics-generation

IconShop: Text-Guided Vector Icon Synthesis with Autoregressive Transformers

Setup

git clone https://github.com/kingnobro/IconShop.git
cd IconShop

Environment

To set up our environment, please run:

conda env create -f environment.yml
conda activate iconshop

Please refer to cairosvg's documentation for additional requirements of CairoSVG. For example:

Dataset

We have cleaned up the FIGR-8-SVG by command simplification, removing the black bounding box, and resizing the icons.

Download the labels and SVG files from Google Drive and place them in the ./dataset folder. You need to unzip the FIGR-SVG-svgo.zip.

The resulting file structure should be:

./dataset
├── FIGR-SVG-train.csv
├── FIGR-SVG-valid.csv
├── FIGR-SVG-test.csv
└── FIGR-SVG-svgo
    ├── 100000-200.svg
    ├── 1000003-200.svg
    └── ...

There are some other useful files in the Google Drive link. Please check the Readme.md and download them as needed.

Training

I use 8 RTX 3090 (or 2 A100) to train the model.

Feel free to adjust the batch size, number of epochs, and learning rate. The training will take several days, so I did not spend a lot of time optimizing these parameters.

bash scripts/train.sh

Use the following command to check the loss curve:

bash scripts/log.sh

Sample

bash scripts/sample.sh

Download our pretrained models and unzip it under proj_log/FIGR_SVG. This model is trained with 100 epochs.

Please note that the results presented in the paper may differ from those of this pretrained model (e.g., the same prompt will create different outputs). Due to copyright issues, access to the model described in the paper is available upon request for research purposes only.

Miscellaneous