Update (Dec 17 2023): Migrated the code to tensorflow 2
ReDMark is a watermarking framework that uses Convolutional Neural Networks (CNNs) in watermark embedding and extraction. Both embedding and extraction networks are trained together in an end-to-end pipeline; Therefore, the trained embedding and extraction networks interact better in the real situations.
Also, we simulate some attacks so that the networks embed the data more robustly. We implemented multiple different attacks as network layers. The most interesting attack is Jpeg attack that is written fully by network structures. Another useful attack that helped our networks to propagate the watermark data more, is grid-crop attack. The networks can be trained by multiple attacks at the same time and the results would be robust against all of them.
To share the watermark data between more image regions, we developed the novel circular convolutional layer. This layer, instead of zero-padding its input tensor, performs a circular convolution on it.
- The watermark data is fully random, i.e. is a random binary vector.
- In every training iteration, the random watermark and cover images are changed.
- Some attacks are not differentiable and cannot be implemented exactly as they are. In this cases we used their approximations. The experiments showed us that the resulting networks are robust to not only the real attack but also to a wider family of attacks.
- The embedding network's structure is residual. This means that the watermark data is embedded into the residual part of the pipeline and then added to the original image. This helps the transparency of the watermarked images.
First download pascal dataset from here and place the extracted JPEGImages
folder in images/pascal folder. Then run the file prepare_pascal.py.
wget http://host.robots.ox.ac.uk/pascal/VOC/voc2012/VOCtrainval_11-May-2012.tar
tar xf images/pascal/VOCtrainval_11-May-2012.tar
mv VOCdevkit/VOC2012/JPEGImages/ images/pascal/
Download the 49 test images from here and place them in the folder images/512x512.
wget https://ccia.ugr.es/cvg/CG/images/base/{1..49}.gif -P images/512x512
To train the networks run the train.py
file. This file creates the network weights according to its settings. The embedding and extraction weights are saved a single .h5 file in the logs folder.
By running test.py
, they will be split into two separate networks. In this file, the trained networks are tested against various real attacks and their results are saved in logs/{name-of-experiment}/Analysis.
Prior to run the codes you need the packages mentioned in the file requirements.txt. You can create a virtual environment and install the dependencies by pip install -r requirements.txt
Please cite our paper ReDMark: Framework for residual diffusion watermarking based on deep networks.
BibTeX
@article{Redmark,
title={ReDMark: Framework for Residual Diffusion Watermarking based on Deep Networks},
author={Ahmadi, Mahdi and Norouzi, Alireza and Karimi, Nader and Samavi, Shadrokh and Emami, Ali},
journal={Expert Systems with Applications},
pages={113157},
year={2019},
publisher={Elsevier}
}