Verification and Validation for AI: Learning process verification
data:image/s3,"s3://crabby-images/4a417/4a417d584d1982851781a59b5c2eb1216b6129a4" alt="Steps in W-shaped development process with highlighted the step of Learning Process Verification"
Testing and Understanding Model Performance
The model was trained using fast gradient sign method (FGSM) adversarial training, which is a method for training networks so that they are robust to adversarial examples. After training the model, particularly following adversarial training, it is crucial to assess its accuracy using an independent test set. The model we developed achieved an accuracy exceeding 90%, which not only meets our predefined requirement but also surpasses the benchmarks reported in the foundational research for comparable neural networks. To gain a more nuanced understanding of the model’s performance, we examine the confusion matrix, which sheds light on the types of errors the model makes.data:image/s3,"s3://crabby-images/b1487/b1487513e95588b82c4971f0faf76e59b86a552c" alt="Confusion chart for adversarially-trained model showing accuracy of 90.71%, and true and predicted classes"
data:image/s3,"s3://crabby-images/a53c1/a53c17b12dfb236ff3fb38376c8679289b12ce3b" alt="Two images of lungs with pneumonia. The left image is showing the ground truth and the right image is showing the prediction with Grad-CAM."
Verify Robustness of Deep Learning Models
Adversarial Examples
Robustness of the AI model is one of the main concerns when deploying neural networks in safety-critical situations. It has been shown that neural networks can misclassify inputs due to small imperceptible changes. Consider the case of an X-ray image that a model correctly identifies as indicative of pneumonia. When a subtle perturbation is applied to this image (that is, a small change is applied to each pixel of the image), the model’s output shifts, erroneously classifying the X-ray as normal.data:image/s3,"s3://crabby-images/ce95a/ce95ab4766e474a80910de65d017d5e939a573e5" alt="Effect of input perturbation to lung image with pneumonia. The classifier misclassifies the image as normal."
L-infinity norm
To understand and quantify these perturbations, we turn to the concept of the l-infinity norm. Imagine you have a chest X-ray image. A perturbation with an l-infinity norm of, say, 5 means adding or subtracting any number from 0 to 5 to any number of pixels. In one scenario, you might add 5 to every pixel within a specific image region. Alternatively, you could adjust various pixels by different values within the range of -5 to 5 or alter just a single pixel.data:image/s3,"s3://crabby-images/b8de0/b8de0277c7df055642e4a65c29503aeb78bc2e5e" alt="Examples of input perturbations of a pixel of a lung image."
Formal verification
Given one of the images in the test set, we can choose a perturbation that defines a collection of perturbed images for this specific image. It is important to note that this collection of images is extremely large (the images depicted in the volume in Figure 5 are just a representative sample), and it is not practical to test each perturbed image individually. Deep Learning Toolbox Verification Library allows you to verify and test robustness of deep learning networks using formal verification methods, such as abstract interpretation. The library enables you to verify whether the network you have trained is adversarially robust with respect to the class label provided an input perturbation.data:image/s3,"s3://crabby-images/28670/28670465f072874fa135e5d12e5c5baf749705ac" alt="Abstract interpretation applied to a lung image. The classification results can be interpreted as verified, unproven, or violated."
- Verified - The output label remains consistent.
- Violated - The output label changes.
- Unproven - Further verification efforts or model improvement is needed.
perturbation = 0.01; XLower = XTest - perturbation; XUpper = XTest + perturbation; XLower = dlarray(XLower,"SSCB"); XUpper = dlarray(XUpper,"SSCB");We are now ready to use the verifyNetworkRobustness function. We specify the trained network, the lower and upper bounds, and the ground truth labels for the images.
result = verifyNetworkRobustness(net,XLower,XUpper,TTest); summary(result)
verified 402
violated 13
unproven 209
The outcome reveals over 400 images verified, 13 violations, and more than 200 unproven results. We’ll have to go back to those images where the robustness test returned violated or unproven results and see if there is anything we can learn. But for over 400 images, we were able to formally prove that no adversarial example within a 1% perturbation range alters the network’s output—and that’s a significant assurance of robustness. Another question that we can answer with formal verification is if adversarial training contributed to network robustness. In the second post of the series, we began with a reference model and investigated various training techniques, ultimately adopting an adversarially trained model. Had we used the original network, we would have faced unproven results for nearly all images. And in a safety-critical context, you’ll likely need to treat the unproven results as violations. While data augmentation contributed to verification success, adversarial training enabled the verification of substantially more images, leading to a superiorly robust network that satisfies our robustness requirements.data:image/s3,"s3://crabby-images/c20a3/c20a361afd6a6514260a989dbab07fe94030cc24" alt="Bar graph showing number of observations for each verification result (verified, violated, and unproven) for original network, data-augmented network, and robust network."
Out-of-Distribution Detection
A trustworthy AI system should produce accurate predictions in a known context. Still, it should also be able to identify unknown examples to the model and reject them or defer them to a human expert for safe handling. Deep Learning Toolbox Verification Library also includes functionality for out-of-distribution (OOD) detection. Consider a sample image from our test set. To evaluate the model’s ability to handle OOD data, we can derive new test sets by applying meaningful transformations to the original images, as shown in the following figure.data:image/s3,"s3://crabby-images/52aa3/52aa3c44e2349e794298d5d776039784f5fb8bdc" alt="Deriving datasets by adding speckle noise, FlipLR transformation, and contrast transformation to a lung image."
data:image/s3,"s3://crabby-images/3e5b9/3e5b929bcd02d6422131f1fbba6d22652a6a6aee" alt="Bar graph of relative percentage versus distribution confidence scores for training data, speckle noise, FlipLR, and contrast."
What’s Next?
Stay tuned for our fourth and final blog post, where we will navigate the right-hand side of the W-diagram, focusing on deploying and integrating our robust pneumonia detection model into its operational environment. We will show how to bridge the gap between a well-trained model and a fully functional AI system that can be trusted in a clinical setting.- Category:
- AI verification,
- Blog Series,
- Deep Learning
Comments
To leave a comment, please click here to sign in to your MathWorks Account or create a new one.