This is a tensorflow implementation of GAN to generate RS Images.
Remote sensing is the acquisition of information about an object or phenomenon without making physical contact with the object and thus in contrast to on-site observation, especially the Earth. Scene classification of remote sensing images plays a role in many remote sensing image applications. Training a good classifier needs a large number of training samples. The labeled samples are often scarce and difficult to obtain. Thus, I implemented Generative Adversarial Networks (GANs) to generate remote sensing images. The network is capable of generating 128x128 RGB images .
A random noise vector of size 100 is given to the generator. The generater has 4 transpose convolution layers, each layer is followed by batch normalisation and leaky_relu non-liearity. The output of the 4th layer is again convolved to obtain an image vector of shape 128x128x3. The generated image is then passed to the discriminator network, composed of five convolution layers, each of which is also followed by batch normalisation and leaky_relu non-linearity. The output of the 5th layer is flattened and compressed into a single probability value. Based on this value the model is optimised.
- tensorflow__ 1.14
- matplotlib__ 3.0.3
- PIL_________ 4.3.0
- numpy_______ 1.16
- glob2_______ 0.7
- os
- time
- tqdm
- urllib
- Model architecture: 'Unsupervised Representation Learning with Deep Convolutional Generative Adversarial Networks' by Alec Radford, Luke Metz, Soumith Chintala
- Dataset: RSI-CB (A Large Scale Remote Sensing Image Classification Benchmark via Crowdsource Data)
- www.tensorflow.org/api_docs/python/tf/layers
- www.towardsdatascience.com