Unsupervised Defect Segmentation: PCB Solder Joint Inspection
data:image/s3,"s3://crabby-images/559c2/559c2d70a8f9bc651aa9f6d5cba6381ca32d3f1b" alt="../_images/handian.png"
In this project, we need to inspect the solder joints on PCB boards to determine if they are correctly applied. Additionally, we need to analyze the presence of two types of anomalies:
Based on the previous example Unsupervised Defect Segmentation: PCB Component Damage/Missing we can exclude the use of anomaly detection models. This is because the images contain numerous interference points, making anomaly detection models less suitable for this task.
Additionally, we can exclude object detection models because anomalies in solder joints often appear as irregular regions, which are not well-suited for traditional object detection methods.
So the question is, is a semantic segmentation model the only option?
Using a semantic segmentation model can effectively distinguish whether anomalies are present and can also accurately identify the types of anomalies when they occur.
data:image/s3,"s3://crabby-images/056ac/056ac4f7413c815de9d4b25817cc1a03203098ca" alt="../_images/semantic_seg_training_handian.png"
The semantic segmentation model includes a preprocessing step for resizing images, but no data augmentation was applied. A total of 75 images were used, with 52 images allocated for the training set.
The test results are as follows:
data:image/s3,"s3://crabby-images/04488/04488e7dcd7036d55884a09060f0cc71194dc4f6" alt="../_images/semantic_seg_handian_result.png"
The results from the semantic segmentation model are quite good. However, we could explore if there are better model options, such as instance segmentation models. We can label different types of anomalies as separate categories of segmentation regions and use an instance segmentation model to identify them.
data:image/s3,"s3://crabby-images/76656/7665697576b102a6f9e6daf7d23ebae5df969e38" alt="../_images/instance_seg_training_handian.png"
The instance segmentation model includes a preprocessing step for resizing images, but no data augmentation was applied. A total of 32 images were used, with 22 images allocated for the training set.
The test results are as follows:
data:image/s3,"s3://crabby-images/8a63c/8a63c01e617345296284bf1684663bfd76641229" alt="../_images/instance_seg_handian_result.png"
The instance segmentation model also performs quite well. Compared to the semantic segmentation model, it achieved similar results with less data. Since semantic segmentation models require more non-anomalous data for pixel-level detection, the instance segmentation model has an advantage in this scenario.