2024.8.14
🚀 OBSD has been selected as the ACL 2024 Best Paper.2024.7.15
🚀 OBSD has been selected as the ACL 2024 Oral.2024.5.16
🚀 OBSD is accepted by ACL 2024 Main.2024.2.15
🚀 Sourced code for OBSD is released.
In data/modern_kanji.zip, we also provide images of modern Chinese characters corresponding to Oracle Bone Script, and you can run the data/process.py to process the data if you wish to use your own data.
You can arbitrarily divide the training and test sets from the dataset and place them in the following format. The image names in the input folder and the target folder need to correspond one to one. The input folder stores OBS images, and the target folder stores modern Chinese character images.
Your_dataroot/
├── train/ (training set)
│ ├── input/
│ │ ├── train_安_1.png (OBS image)
│ │ ├── train_安_2.png
│ │ ├── train_北_1.png
│ │ └── train_北_2.png
│ └── target/
│ ├── train_安_1.png (Modern Chinese Character image)
│ ├── train_安_2.png
│ ├── train_北_1.png
│ └── train_北_2.png
│
└── test/ (test set)
├── input/
│ ├── test_1.png (OBS image)
│ └── test_2.png
└── target/
├── test_1.png (Modern Chinese Character image)
└── test_2.png
data:
train_data_dir: '/Your_dataroot/train/' # path to directory of train data
test_data_dir: '/Your_dataroot/test/' # path to directory of test data
test_save_dir: 'Your_project_path/OBS_Diffusion/result' # path to directory of test output
val_save_dir: 'Your_project_path/OBS_Diffusion/validation/' # path to directory of validation during training
tensorboard: 'Your_project_path/OBS_Diffusion/logs' # path to directory of training information
training:
resume: '/Your_save_root/diffusion_model' # path to pretrained model
git clone https://github.com/guanhaisu/OBSD.git
cd OBS_Diffusion
conda create -n OBSD python=3.9
conda activate OBSD
conda install pytorch torchvision torchaudio pytorch-cuda=12.1 -c pytorch -c nvidia
pip install -r requirements.txt
CUDA_VISIBLE_DEVICES=0,1,2,3,4,5,6,7 python -m torch.distributed.run --nproc_per_node=8 --nnodes=1 --node_rank=0 --master_addr=localhost --master_port=1234 train_diffusion.py
tensorboard --logdir ./logs
CUDA_VISIBLE_DEVICES=0,1,2,3,4,5,6,7 python -m torch.distributed.run --nproc_per_node=8 --nnodes=1 --node_rank=0 --master_addr=localhost --master_port=1234 eval_diffusion.py
If you want to refine the generated character results, you can run the following script. Also be careful to change your file paths.
CUDA_VISIBLE_DEVICES=0 python refine.py
You can find the FontDiffuser weights here, GoogleDrive.