Skip to content

Core code for simulations used for most of my publications

Notifications You must be signed in to change notification settings

NEGU93/CVNN-PolSAR

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

CVNN-PolSAR

This code performs real or complex-valued neural networks semantic segmentation or pixel-wise classification on Polarimetric Synthetic Aperture Radar (PolSAR) images (to be downloaded by the user).

Plots of the results achieved are displayed online here. With exception of the Bretigny dataset which was not published due to confidenciality reasons.

Core code for simulations used for the following publications:

Publications

  • Barrachina, J. A., Ren, C., Morisseau, C., Vieillard, G., and Ovarlez, J.-P. (2022). "Comparison Between Equivalent Architectures of Complex-Valued and Real-Valued Neural Networks - Application on Polarimetric SAR Image Segmentation". Journal of Signal Processing Systems, pages 1–10. link.
  • Barrachina, J. A., Ren, C., Vieillard, G., Morisseau, C., and Ovarlez, J.-P. (2022). "Real- and Complex-Valued Neural Networks for SAR image segmentation through different polarimetric representations". IEEE International Conference on Image Processing (ICIP).
  • Barrachina, J. A., Ren, C., Morisseau, Vieillard, G., C., and Ovarlez, J.-P. (2022c). "Merits of Complex-Valued Neural Networks for PolSAR image segmentation". GRETSI XXVIIIème Colloque Francophone de Traitement du Signal et des Images. link.
  • 3MT finalist. Barrachina, J. A., Ren, C., Morisseau, Vieillard, G., C., and Ovarlez, J.-P. (2022a). "Complex-Valued Neural Networks for Polarimetric SAR segmentation using Pauli representation". IEEE International Geoscience and Remote Sensing Symposium (IGARSS). link.
  • Ranked top 15% reviewer score. Barrachina, J. A., Ren, C., Vieillard, G., Morisseau, C., and Ovarlez, J.-P. (2021c). "About the Equivalence Between Complex-Valued and Real-Valued Fully Connected Neural Networks - Application to PolInSAR Images". IEEE 31st International Workshop on Machine Learning for Signal Processing (MLSP), pages 1–6. link.
  • Pre-print. Barrachina, J. A., Ren, C., Morisseau, C., Vieillard, G., & Ovarlez, J. (2022). "Impact of PolSAR pre-processing and balancing methods on complex-valued neural networks segmentation tasks". arXiv. link.
  • Workshop presentation and publication. Barrachina, J. A., Ren, C., Morisseau, Vieillard, G., C., and Ovarlez, J.-P. (2022b). "Complex-Valued Neural Networks for Polarimetric SAR segmentation using Pauli representation". 5th SONDRA Workshop. link.

Single simulations usage:

Each run will be saved into log/<year>/<month>/<day>/run-<time>/. Inside each iteration, the following information will be saved by default:

  • tensorboard/: Tensorboard.
  • checkpoints/: Saved best performant model (lower validation loss).
  • evaluate.csv: Loss and metrics performance per dataset (train, val and test).
  • history_dict.csv: loss and metric per epoch for both train and validation sets (as can be seen in Tensorboard).
  • model_summary.txt: Parameters used for the simulation and model summary.
  • prediction.png: Predicted image.
  • <set>_connfusion_matrix: Confusion matrix.
usage: principal_simulation.py [-h] [--dataset_method DATASET_METHOD] [--equiv_technique EQUIV_TECHNIQUE] [--tensorflow] [--epochs EPOCHS]
                               [--learning_rate LEARNING_RATE] [--model MODEL] [--early_stop [EARLY_STOP]] [--balance BALANCE] [--model_index MODEL_INDEX]
                               [--depth DEPTH] [--real_mode [REAL_MODE]] [--dropout DROPOUT DROPOUT DROPOUT] [--coherency [COHERENCY]] [--dataset DATASET]

optional arguments:
  -h, --help            show this help message and exit
  --dataset_method DATASET_METHOD
                        One of:
                        	- random (default): randomly select the train and val set
                        	- separate: split first the image into sections and select the sets from there
                        	- single_separated_image: as separate, but do not apply the slinding window operation 
                        		(no batches, only one image per set). 
                        		Only possible with segmentation models
  --equiv_technique EQUIV_TECHNIQUE
                        Available options:
                        	- none
                        	- np
                        	- alternate_tp
                        	- ratio_tp
  --tensorflow          Use tensorflow library
  --epochs EPOCHS       (int) epochs to be done
  --learning_rate LEARNING_RATE
                        (float) optimizer learning rate
  --model MODEL         deep model to be used. Options:
                        	- cao [1]
                        	- own
                        	- small-unet
                        	- zhang [2]
                        	- cnn
                        	- expanded-cnn
                        	- haensch [3]
                        	- mlp
                        	- expanded-mlp
                        	- tan [4]
  --early_stop [EARLY_STOP]
                        Apply early stopping to training
  --balance BALANCE     Deal with unbalanced dataset by:
                        	- loss: weighted loss
                        	- dataset: balance dataset by randomly remove pixels of predominant classes
                        	- any other string will be considered as not balanced
  --model_index MODEL_INDEX
  --depth DEPTH
  --real_mode [REAL_MODE]
                        run real model instead of complex.
                        If [REAL_MODE] is used it should be one of:
                        	- real_imag
                        	- amplitude_phase
                        	- amplitude_only
                        	- real_only
  --dropout DROPOUT DROPOUT DROPOUT
                        dropout rate to be used on downsampling, bottle neck, upsampling sections (in order). Example: `python main.py --dropout 0.1 None 0.3` will use 10% dropout on the downsampling part and 30% on the upsamlpling part and no dropout on the bottle neck.
  --coherency [COHERENCY]
                        Use coherency matrix instead of s. (Optional) followed by an integer stating the boxcar size used for coherency matrix averaging.
  --dataset DATASET     dataset to be used. Available options:
                        	- SF-AIRSAR
                        	- OBER
                        	- FLEVOLAND
                        	- BRET
                        	- GARON

[1] Cao, Y., Wu, Y., Zhang, P., Liang, W., & Li, M. (2019). "Pixel-Wise PolSAR Image Classification via a Novel Complex-Valued Deep Fully Convolutional Network". arXiv.

[2] Z. Zhang, H. Wang, F. Xu and Y. -Q. Jin, (2017) "Complex-Valued Convolutional Neural Network and Its Application in Polarimetric SAR Image Classification," IEEE Transactions on Geoscience and Remote Sensing, vol. 55, no. 12, pp. 7177-7188.

[3] R. Haensch and O. Hellwich, (2010) "Complex-Valued Convolutional Neural Networks for Object Detection in PolSAR data," 8th European Conference on Synthetic Aperture Radar, pp. 1-4.

[4] X. Tan, M. Li, P. Zhang, Y. Wu and W. Song, (2020) "Complex-Valued 3-D Convolutional Neural Network for PolSAR Image Classification," IEEE Geoscience and Remote Sensing Letters, vol. 17, no. 6, pp. 1022-1026.

MonteCarlo comparissons

To run several simulations, you can use a MonteCarlo simulation. -I is the total iterations per configuration. -CF is a configuration json file with the parameters (model, dataset, etc.). See examples in this folder.

python runner.py -I <number of iteration per config> -CF <json configuration path>

Result viewer

The stat results from the runner can be seen using the qt_app.py script. The app allows the quick visualization of the results predicted image (choosing a random simulation to display), stats results with error, total number of simulations, loss and accuracy evolution per epoch, etc.

ATTENTION: The log file path of the results should be added as a variable root_drive (see line 21). Together with the datasets RGB images in BASE_PATHS and GROUND_TRUTH_PATHS.

qt_app_results

Plot exports

It is possible to export Plotly or seaborn/matplotlib figures using results_reader.py.

Figures generated can be seen in [this online](http://negu93.github.io/cvnn_vs_rvnn_polsar_applications source.

Configure datasets

To use this library, the user must download its own dataset and configure it as the following:

  1. Create a class than inherits from PolsarDatasetHandler. The recommended way is to add it inside the dataset_readers folder. Any of the files within that folder can serve as an example on the implementation. The class must implement:
    • get_image method: Must open the image. It must be:
      • numpy array
      • Data type np.complex
      • Shape (Width, Height, channels), with channels = 3 if self.mode = 'k' or 's' and channels = 6 if self.mode = 't'
      • S format: (s_11, s_12, s_22) or equivalently (HH, HV, VV)
      • K format:
      • T format:
      • :return: The opened numpy image.
    • get_sparse_labels: Must open the labels in sparse mode (last dimension is a number from 0 to num_classes+1).
      • :return: Numpy array with the sparse labels.
    • (Optional): Define a self.azimuth string variable whose value should be either "horizontal" or "vertical" according to the azimuth direction of the used image.
  2. Add the dataset in _get_dataset_handler with a particular name to be recognized.
  3. Add the new dataset assigned name to DATASET_META dictionary with the information of:
    • classes: Number of classes in the labels.
    • azimuth: (Optional)
    • percentage: list of floats with the percentage of the dataset to be used for train, validation, test, etc. Example (.8, .1, .1) will use 80% for train, and 10% for validation and test.

Supported datasets

For the supported datasets, it will suffice to download the data and labels and add the path to the respective variable:

Add model

  1. Create a function that returns a tf.Model. (Must return it compiled).
  2. Add the function into _get_model on line 203. You can use this code for reference of the methos parameters and implementation.
  3. Add model metadata information with:
    • Size, stride and padding of the sliding window operation used for extracting the small image patches.
    • batch size
    • Percentage of the datasets, example (0.8, 0.1, 0.1) for 80% training set and 10% for both validation and test set.
    • Task (segmentation or classification). This parameter will change the labels shape.
      • segmentation: (size, size, classes)
      • classification: (1, 1, classes)

About

Core code for simulations used for most of my publications

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published