Skip to content

Code for the Bioinformatics project of 7.5 ECTS, 'Understanding a CNN in Keras to predict Adaptive Introgression'. Developed in the Racimo group, GLOBE Institute, University of Copenhagen.

License

Notifications You must be signed in to change notification settings

RacimoLab/CNN-vis

 
 

Repository files navigation

CNN-vis

CNN-vis was developed to visualize and understand how a Convolutional Neural Network (CNN) which performs binary classification between two classes works under the hood. The program is optimized to run on genotype matrices from population data. At the moment, four main visualizations are supported: Convolutional Kernel visualization, Activation Maximization technique, Saliency maps and Gradient Class Activation Maps (Grad-CAM), from the Keras-vis library of Github user Raghakot, along with other small utilities.

This software was developed for my Bioinformatics project of 7.5 ECTS with Fernando Racimo's group, at the Univeristy of Copenhagen, with title 'Understanding a CNN to predict Adaptive Introgression'.

Manual to run CNN-vis from the console:

Operation Flag Comments Required Type
Function function Visualization technique or utility to perform. Choices are: activation-max, saliency, average-saliency, grad-cam, average-gradcam, filter-weights, model-summary, or get-labels Yes String
ConvNet model model Path to model file, stored as a .h5 Python format Yes String
Data -d or --data Path to data containing image matrices X and labels y as a pickle package in .pkl format No String
Layer -l or --layer Name of the desired Conv layer in the ConvNet model to visualize No String
Image indeces -im or --images Indeces to the selected images for saliency and grad-CAM visualization No List of integers
Backpropagation modifier -bm or --backprop Modifier for the backpropagation step. Choices are: None (vanilla), guided, rectified, deconv, or relu. Guided backpropagation is recommended and selected by default No String

Functions

  • activation-max: Convolutional filter visualization via Activation Maximization technique (Dumitru Erhan et al.). This method is used to get an insight into what input motifs activate a particular filter. When applied in the final Dense layer, it's possible to visualize which is the input image that the ConvNet expects in order to maximize a certain output class.

  • saliency: Saliency map is an attention visualization technique with discriminative behavior based on estimating the gradient of an output category with respect to the input image. (Karen Simonyan et al.). These attention maps help to visualize which regions of the input image draw the most attention from the ConvNet model.

  • average-saliency: Plot the average saliency map over all input data for both classes separately, as well as a map of the saliency difference between the two average maps.

  • grad-cam Gradient Class Activation map or Grad-CAM is an attention visualization technique with discriminative behavior based on estimating the gradient of an output category with respect to the input image. (Ramprasaath R. Selvaraju et al.). It differs with the saliency maps in the sense that it uses the output of the previous Conv layer before the specified one.

  • average-gradcam: Plot the average gradCAM map over all input data for both classes separately.

  • filter-weights: Visualization of the learned weights from all the filters in the provided Conv layer.

  • model-summary: Prints the information of the provided CNN architecture to the user.

  • filter-weights: Prints the label and the index of the input images provided as data.

Library requirements:

Tensorflow 2.0.*

Keras-vis 0.4.1

Example of terminal command to run the code:

python3 cnn-vis.py saliency my_model.h5 --data my_image_data.pkl --layer output --images 0 3 5 10

About

Code for the Bioinformatics project of 7.5 ECTS, 'Understanding a CNN in Keras to predict Adaptive Introgression'. Developed in the Racimo group, GLOBE Institute, University of Copenhagen.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%