Skip to content

Latest commit

 

History

History
88 lines (51 loc) · 4.68 KB

README.md

File metadata and controls

88 lines (51 loc) · 4.68 KB

DarkShotLearning + DarkTNN

One Shot Learning with Siamese Neural Networks on Dark Web Images -Triplet Siamese Neural Networks with Triplet Loss

Overview

In this project the Label-Agnostic Siamese and Triplet Siamese Neural Networks are used for One-Shot and Few-Shot experiments.

Siamese Neural Networks

The Siamese Neural Networks are (two) identical neural networks that are trained in parallel. The neural networks produce embeddings (128,256,..,etc) from the input images which are then used to identify the similarities of the two outputs. The similarity of the two embeddings is calculated by measuring the Euclidean distance between them, and the contrastive loss function is used to penalize the calculation of the embedding distances accordingly.

Triplet-Siamese Neural Networks

Similar to the Siamese Neural Networks the Triplet-Siamese Networks are making use of three identical embedding neural networks (CNNs) in this case. The embedding similarities are compared with the Triplet Loss function. In the case of Triplet-Siamese the loss is calculated instead of the overall accuracy*. To visualize how well the Triplet-Siamese Network has separated the embeddings we can use the TSNE library and visualize the manifolds of the generated embeddings (see Figures folder).

Note: The Triplet-Siamese Neural Network generally require a lot of hours of training, esepecially compared to the Siamese Neural Networks that are quite lightweight.

*With a simple transfer learning script we can calculate the accuracy of the prediction.

The models were tested on images of various sizes that (mainly) depict illegal drugs.

The datasets used for the experiments are consisted by 3500 images scraped from the Dark Web

  • There are 11 main categories

An example of the data can be found in the data folder

The data folder contains 3 datasets that were generated from the same initial images (3500)

 - Junior_Dealer (Sample Included)   (25 categories) : By shape        -->  All powders together, all pills together, etc
 
 - Senior_Dealer (Not Included)      (67 categories) : By_type         -->  Benzos/Attivan, Benzos/Valium
 
 - Druglord (Sample Included)        (100 categories): By_type & shape -->  Benzos/Xanax Pills, Benzos/Xanax Powder, 
                                                            Benzos/Xanax Boxes, etc
 
 
Note:
 From top to bottom the difficulty/hours of labelling the datasets increased
 Most of the changes are in the drug categories
 Each dataset has different results for the models

Code Explanation:

  • PrepSteps:

    • ReSize.py -- Prints information regarding the characteristics of the images and rescales the images (see README in folder)
    • OneShotAugment.py -- Calculates the threshold for maximizing the given dataset with 6 augmentation steps -> augments the data
    • PrepareData.py -- Combines the above processes in one and creates the training and testing datasets
  • LoadModels:

    • CategoricalNets.py -- 2 categorical convolutional neural networks (CNN)
    • SiameseNet.py -- The Siamese Neural Network with Absolute Distance calculation and Binary Cross-entropy Loss
    • SiameseNet_Contrastive.py -- The Siamese Neural Network using the Eucledian Distance and Contrastive Loss
  • DataLoad:

    • PairGen.py -- Creates balanced N-shot pairs for the Siamese Neural Networks
    • DataPrep.py -- Creates random N-shot pairs for the Siamese Neural Networks - The positive and negative representation is completely unbalanced
    • TripletGen.py -- Creates balanced N-shot triplets fro the Triplet Siamese Network
  • TripletSiamese:

    • Triplet_Loss.py -- Calculates the Triplet Loss for the Siamese Neural Network
    • TripletNet.py -- The Triplet Siamese Neural Network
  • Visuals:

    • TSNE.py -- Creates the scatter-plot for the TSNE manifolds

  • TO RUN THE MODELS

Create a new virtual environment and pip install the requirements.txt

  • Test_Triplet.ipynb -- Jupyter Notebook with the Training and Testing of the Tiplet Siamese Neural Network

  • Test_Siamese.ipynb -- Jupyter Notebook with the Training and Testing of the Siamese Neural Network

  • Test_Baseline.ipynb -- Jupyter Notebook with the baseline comparison models (CNN + KNN + NAIVE-statistical)

  • Figures

    • Includes the TSNE manifolds from the 10-way and 8-way datasets

      alt text