Image Analysis
The MNIST Dataset
In this example, we used the MNIST dataset (handwritten digits) to train a convolutional neural network (CNN) for image classification, and reached a validation accuracy of ~0.98 on our trained model.
For more information on using Tensorleap with the MNIST dataset, see MNIST Guide.
Population Exploration
Below is a population exploration plot. It represents a samples' similarity map based on the model's latent space, built using the extracted features of the trained model.
Training Set:
The samples shown below were taken from the training set and are colored based on their ground truth class. The dot's size represents the model's error loss for that specific sample. We can see that there is a clear separation of the samples based on their classes.
Validation Set:
The plot below is a similarity map within the validation set and we can see that there is still a nice separation, but there are quite a few samples with higher error loss (larger dot size). Interestingly, those false predictions are located within clusters of classes different from their ground truth class.
Similar Classes
In the visualization below we can see that the samples from class 7 (peach-colored) and class 1 (light-blue) are relatively close to each other. This makes sense since the digit 7 is visually similar to the digit 1.
Error Analysis
The dot's size in the visualization below represents the sample's loss. The selected sample is a challenging one, and we can also see that it has a relatively high loss. The sample's metadata shown on the right panel shows a distance of 6.83 to class 6
and 7.71 to the ground truth - class 5,
and indeed prediction was class 6
.
Sample Analysis
The Tensorleap platform provides a way to further explore the model's response to specific data samples. For example, from the results below, we can see that the model's prediction was 9 while the ground truth is 8. Additionally, we can use the heat map to see which features of the data contributed to each of the output classes.
Fetch Similars
As explained, Tensorleap tracks how each learned feature responds to each sample. This allows finding samples that the model considers similar, as they activate similar learned features.
This functionality also allows to automatically find candidates for labeling, detect ambiguities in the data and mislabeled samples.
Fetch Similars to a Sample - Example
Example - Investigating the "Closed" 4 Digit
Separate the 4 class into two classes - open and closed digits.
Enrich the data with additional samples of closed digits.
Remove the closed digits from the dataset and support only the open form.
Metrics Analysis
The Tensorleap Dashboard allows users to visualize the training progress and performance metrics of their models. Additionally, users can explore correlations and trends between various metadata to gain insights into their data.
Average Euclidean Distance Metadata vs Average Loss
For each class, its mean image is calculated (28x28) by averaging each pixel. For each sample, its Euclidean distance from the mean image of its class is calculated and set as its metadata.
The Dashboard allows us to visualize and investigate each metadata interactively. The visualization below shows the average error loss per class, vs the Euclidean distance.
This plot reveals a strong correlation between the Euclidean distance and the average loss - as the Euclidean distance increases, the loss increases with it. This is expected, as the model is less capable of generalizing samples with high irregularities.
Loss and Accuracy Visualizations
During training, metrics are collected and presented in the Dashboard. For example, a visualization of the model's Loss (left) and Accuracy(right) vs batches:
As we can see, the model convergences well and achieves an accuracy of ~0.98 on the validation set.
Summary
The Tensorleap platform provides powerful tools for analyzing and understanding deep learning models. In this example, we presented only a few examples of the types of insights that can be gained using the platform.
For more information, please refer to our additional Examples and Guides.
Last updated