RGB2IR Image Translation with Generative Adversarial Network
This project aims to create partially novel generative adversarial network model that can translate RGB image to the IR image.
Motivation and Rationale
IR imaging is used in many crucial applications such as, surveillance, UAVs, search and rescue operations etcetera. To improve their abilities, most of these systems depend on deep learning models. Due to the nature of deep learning, they need a huge amount of data for training. However, IR images are hard to obtain due to the high cost of IR cameras. Moreover, even with a camera, obtaining images for specific scenarios could be very time-consuming. Thus, we want to create a model that can translate any RGB image to IR image with high quality such that it can be used as data augmentation method.
According to Stefan-Boltzmann Law, every object above the temperature of absolute zero degree emits electromagnetic radiation due to its internal energy, and the amount of this radiated energy is proportional to the emissivity of the material and also proportional to the fourth power of its absolute temperature. This thermal radiation can be detected partially through infrared cameras. Especially objects at room temperature almost only emits infrared light. As a result, we can conclude that material type gives important information about the amount of radiation since emissivity directly, and temperature of an object indirectly depends on the material type. Thus, if the model can learn the material types, it can also translate them to the IR image. To this end, to improve the result, we also obtained the semantic segmented version of the dataset, and concatenated it to the input.
The Dataset
We used FLIR Thermal Dataset. All the images in the dataset were resized to have same size 640x512.
Note that semantic segmantation was done by the means of PSPNET pretrained on cityscapes dataset which is a similar to FLIR thermal dataset in terms of objects they contained.
Unfortunately, image pairs in the dataset has slight alignment problem which was solved emprically. Alternatively, a homography matrix could have also been used to align.
The Generator Model
As a generator network, a modified version of the image stylization network proposed by Johnson et al. was preferred. This was also a part of Pix2PixHD model. However, to avoid checkboard effects early in the training, the direct convolutional layer was preferred instead of the transposed convolution. Also, the number of residual blocks was decreased considering the resolution of the dataset. Each block in the following figure contains a convolution layer, leaky rectified linear activation function, and instance normalization.
Above figure illustrates the generator network. Downsampling and upsampling blocks are represented with the blue blocks. Between these, there are 6 residual blocks to refine the feature maps over and over again.
The Multi-Scale Discriminator Model
I designed generic discrimination network except that it yields a matrix of values, so it works like a PatchGAN. Each value in the matrix focuses on the 80 by 80 pixel in the input image i.e. effective receptive field is 80.
To implement a multi-scale discriminator, 2 different discriminators were used. The first one processed the original images, and the second one processed the images that were resized by the ratio of 1/2.
The Loss Function
To optimize the parameters of generator and discriminator, the least-square loss was preferred. To improve its performances, additionally, feature matching loss and perceptual loss were used. As a result, the overall loss function turned out to be following form for the generator:
And for the multi-scale discriminator:
Training Details
I trained the model for a 100 epochs with and without segmented input. I used Adam optimizer with learning rate of 0.0002 and 0.00004 for generator and discriminator respectively. Due to the limited resources, I resized the input image with a factor of 2.
For training, Google Colab Pro Notebook environment was prefered.
Results
1st row: predicted IR, Ground truth IR, and 2nd row: RGB, segmented RGB.
As can be seen, two types of distortion in the images can be noticed — ghosting and a kind of fixed-pattern noise. Also, the image segmentation network did not work perfectly, so it affected the performance of the model.
Possible Improvements
To improve the results, there are many hyper-parameters to tune. Also, loss function can be changed to Wasserstein loss or another loss in the literature.
Additionally, it was observed that loss of the generator dropped imidiately even after the adjustment of the learning rate. This is probably because ADAM optimizer has adaptive learning rate ability, and controlling the learning rate did not result in as expected, so other optimization functions could be used.
Another issue is to understand the importance of each component of the loss function by doing an ablation study. For instance, the results of the two models trained with and without the perceptual loss can be compared.
Lastly, the dataset at the hand was not very comprehensive. Training with different datasets may improve the results.