A new technique is proposed to classify the defects that could occur on the PCB using neural network paradigm. The algorithms to segment the image into basic primitive patterns, enclosing the primitive patterns, patterns assignment, patterns normalization, and classification have been developed based on binary morphological image processing and Learning Vector Quantization (LVQ) neural network. Thousands of defective patterns have been used for training, and the neural network is tested for evaluating its performance. A defective PCB image is used to ensure the function of the proposed technique.
INTRODUCTION
A printed circuit board (PCB) is a basic component of many electronic devices. The quality of PCBs will have a significant effect on the performance of many electronic products. Conventionally, visual inspection of PCBs is done manually by inspectors. It is known that humans are subject to make mistakes, and they are slow and less consistent, whereas automatic inspection systems remove the subjective aspects and provide fast quantitative dimensional assessments [1] , [2] . When applied at each appropriate step of the assembly process, they can reduce rework costs. All of these mean better quality at a lower cost. Undoubtedly, the automation of visual inspection will increase productivity and improve product quality [3] . The process in PCB inspection (in term of the defects identification) could be separated into two main stages: (1) The defects detection, and (2) The defects classification. In defect detection, it is not important to know the type of defects. But in defect classification, it is desired to know the type of the detected or identified defects. Usually, the defects classification will take place after the defect detection mechanism has been carried out [1] . Presently, there has been a lot of work concentrating on the detection of defects on PCB. In general, one can group the approaches of these defects detection techniques into three major classes: (1) Reference based approaches, (2) Non-reference based approaches, and (3) Hybrid based approaches (combination of the first two groups) [1] , [3] . In a PCB, the defects could be classified as either visual defects or functional defects. Unlike the visual defects, the functional defects could seriously affect the function of a PCB. Based on this reason, it is essential to classify the type of defects that exist on a PCB. Hence the development of algorithms for PCB defects classification is crucial. In addition, this work is also motivated by the fact that there are not many algorithms or systems, which have been developed for PCB defects classification. Many existing or developed algorithms just focus on PCB defects detection [1] , [3] . This work then, is undertaken to develop an algorithm for defects classification in order to identify correctly the detected defects on a PCB. Organization of this paper will be as follows. The design of training set and test set data for neural network is briefly discussed, and followed by neural network design discussion. Next section discusses on segmentation of the PCB image into basic primitive patterns, and the windowing technique to enclose these primitive patterns is briefly described. The patterns assignment is employed to determine the position of the defects relative to the test image and the defect patterns with its position are called then as the candidate patterns, and it is discussed in the next section. After that the discussion is focused on the candidate patterns normalization before they are fed into the neural network. The experimental result of the algorithm is given in the next section. Discussion and summary of the experimentation are presented in the final section.
NEURAL NETWORK DATA DESIGN
Based on a study in [3] and [4] , there are about 14 defects that could occur on the PCB i.e. short, excessive short, missing conductor, conductor too close, missing hole, breakout (c-pattern), wrong size hole, pinhole, open, mousebite, spur, underetch, overetch, and spurious copper. In this work, short and excessive short defect will be treated as the same as short defect. Underetched and overetched will also be treated as the same as the etching problem defect. Hence, there will be only 12 defects that will be classified.
In this approach for the purpose of training and testing the neural network, 11 defective patterns have been designed. The designed pattern is in 8 x 8 pixels size, with binary format. Using this technique, spurious copper defect could be identified during pattern assignment operation (discussed in Section 6.0), therefore training patterns for this type of defect is not needed. Figure 1 shows some of these designed patterns.
NEURAL NETWORK DESIGN
The PCB defects could be formed into three groups: the defects on the foreground only, the defects on the background only, and the defects on both foreground and background (the defect is caused by interaction with other object). Figure 2 shows these defects groupings.
To classify the defects, LVQ neural network has been selected as the classifier. The designed patterns are trained and tested using this neural network. For the neural network implementation, only two groups of defects will be used for training (i.e. the foreground, and the background and foreground). Defects on background only (spurious copper) could be classified directly without any need to pass it to the neural network. 1 1 1 1 1  1 1 1 1 1 1 1 1   1 1 1 1 1 1 1 1  1 1 1 1 1 1 1 1  1 1 1 1 1 1 1 1  1 1 0 1 1 1 1 1  1 1 1 1 1 1 1 1  1 1 1 1 1 1 1 1  1 1 1 1 1 1 1 1  1 1 1 1 1 1 1 1   1 1 1 1 1 1 1 1  1 1 1 1 1 1 1 1  1 1 1 1 1 1 1 0  1 1 1 1 1 1 Figure 2 The defects grouping The foreground only defects consist of two types of defects based on the defects location: the defects on hole pad and the defects on trace only. Hence, there will be three groups of defects: the defects on foreground and background (Group #1), the defects on hole pad only (Group #2), and the defects on trace only (Group #3), which will be the basis for designing the neural network. In the implementation of the neural network, three neural network designs are used for detecting three defects groups. The first network (LVQ #1) is for the foreground and background group which detects the short, missing conductor, and conductor too close. The second network (LVQ #2) is for the hole pad only group which identifies missing hole, wrong size hole, and breakout. Finally, the third network (LVQ #3) is for the pads and line group only (including rectangular pads, square pads, and lines), which classifies pinhole, open, mousebite, spur, and etching problem defects.
SEGMENTATION INTO PRIMITIVE PATTERNS
Segmentation is carried out using binary morphological image processing [5] . To simplify the operation, the primitive patterns are grouped into four main types: hole pad, rectangular pad, square pad, and line. In segmentation operation, morphological operators such as dilation, opening, and closing are used. This segmentation involves a series of image processing operations (morphological image processing based segmentation and subtraction operation). A detailed algorithm for this segmentation could be found in [6] .
PRIMITIVE PATTERNS WINDOWING
After segmenting the PCB image into basic primitive patterns, the next step is to enclose each pattern so that only pixels under this window will be processed. Windowing operation is also employed to the detected defective patterns. Further details could be found in [6] .
PATTERNS ASSIGNMENT
The flowchart for the defect classification based on the neural network is shown in Figure 3 . The segmentation into basic primitive patterns is applied only onto the PCB reference image. The defects detection applied in this work is based on the image subtraction operation [1] . The segmented primitive patterns of the reference image will be enclosed using the windowing technique, and these window coordinates will be mapped onto the test image to generate the same window coordinates for the test image. At the same time, the detected defects from previous subtraction operation will also be enclosed using the same windowing technique. At this stage there will be three windows coordinates or three enclosed patterns: enclosed primitive patterns of the reference image rpat [ tpat [i] dpat [i] tpat [i] dpat [i] tpat [i] dpat [i] tpat [i] dpat [i] tpat [i] dpat [i] tpat [i] dpat [i] tpat [i] dpat [i] tpat [i] dpat [i] dpat[i] tpat [i] Note that in determining these cases, the process is applied to every defective pattern from dpat [1] to dpat [n] , relative to tpat [1] rowEndT, colStartT, colEndT) . In addition, the input image to the neural net, which will be called as the source image, will also be determined based on these two criteria. The other step in this stage is to decide to which neural network design (LVQ #1, #2, or #3), cpat[i] belongs to. The descri ption for these steps (assignment operation) is listed in Table 1 . Note from the table that the outside case is not included. The reason is, any cpat[i] pattern with this case, will be automatically identified as spurious copper 
dpat [i] tpat [i] tpat [i] dpat [i] dpat [i] tpat [i] dpat [i] tpat [i] dpat [i] tpat [i] dpat [i] tpat [i] dpat [i] tpat [i] dpat [i] tpat [i] tpat [j] defect. Hence it does not need further processing. Note that in 
PATTERNS NORMALIZATION
The patterns are normalized into the size of 8 × 8 pixels. At this stage, any test pattern (primitive pattern or defective pattern), which is less than 8 × 8, will be enlarged, while the one that is larger will be reduced into 8 × 8 in size. The scaling algorithm is described below. Suppose that the pattern before the normalization is named as old_pat ij with i and j denote the row and colu mn respectively, where:
If both k and l are less than 8 × 8, the pattern will undergo the enlargement operation. Otherwise, if k and l are greater than 8 × 8, the pattern will undergo the minification operation.
Let the pattern after normalization due to minification or enlargement be represented by new_pat mn and new_pat pq , where:
. Note that is the pattern after minification or enlargement of old_pat ij on the row (column) side only, and is the pattern after minification or enlargement of on the colu mn (or row) side. See Figure 12 for the illustration of old_pat ij relationship with new_pat mn and new_pat pq . 
Minification: Row
Let s a be a row combination factor, i.e. it indicates how many rows from old_pat ij need to be combined in order to be a row in new_pat mn , and a indicates the row in new_pat mn . In this situation, s 1 and s 8 will always equal to 1. In other words, this is to say that the row of new_pat mn is equal to row 1 and row k of old_pat ij . The reason for doing this is to preserve the border area. If for example, s 3 = 2, this means that the 3 rd row of new_pat mn is composed of 2 rows of old_pat ij . In row composition or combination process, a certain rule will be applied and this is discussed in Section 7.3. The following paragraphs discuss rules in determining combination factor s a for a = 2, 3, 4, 5, 6, and 7.
As stated before s 1 will be set to the first row of old_pat ij while s 8 will be set to the last row of old_pat ij . For the 2 nd to the 7 th rows of new_pat mn , they are constructed based on the combination factor s 2 …, 7. Note that in minification of the row, for every old_pat ij pattern, only the index i will be manipulated, the index j will be used in minification of the column, once the minification of the row has been done. Since the first row and the last row of new_pat mn have already been assigned, there are 6 rows more that need to be filled up. Let then restRow = i -2, indicates the remaining row of old_pat ij that need to be processed. Now, for every row in new_pat mn , the combination factor, s a , for a = 2, …, 7, is given in Equation (1). The ROUND operator in the equation is to ensure that the result will always be an integer number.
To ensure whether all i have been used for s 2 …,7, one of the combination factors, for example s 2 will be checked by using the following equation:
There could be three cases for rowCheck. o rowCheck > 0. If rowCheck > 0 then from Equation (1):
To check whether the all-available rows i have been used correctly, the following equation is used:
o rowCheck < 0. There is only one case for rowCheck < 0 in which i = 11. Then the combination factor sa for a = 2…4 is as given in Equation (5a). The combination factor for the next three rows (a = 5…7), is given in Equation (5b):
o rowCheck = 0. For this case, the following equations are applied:
Minification: Column
Minification for the column side is carried out once minification for the rows is already completed. A new-reduced pattern new_patt pq is constructed based on the reduced pattern new_pat mn from the previous step. Basically, the rules are similar to the row minification combination operation rule.
Minification: Pixel Combinatiopn Operation
At this point, it is important to note that normalization process (either minification or enlargement) should preserve the property of the original image. In this project, it has been found that a simple logical AND operator could perform this task. Let p1 and p2 be the pixels in the 1 st row (column) and 2 nd row (column) respectively. Then the result of combining these two rows (columns) p12 can be expressed as: p12 = p1· p2 (7)
Enlargement: Row
Enlargement operation is an opposite process from the minification operation. Enlargement operation will be applied only when i < 8 and j < 8 of old_pat ij . If i < 8, then old_pat ij will be enlarged row-wise to form a new pattern new_pat mn , and if n < 8 then new_pat mn will be enlarged column-wise to form another pattern new_patt pq . Let the enlargement factor be denoted by sb, where b = 1,…, 7 indicates the position of row of new_pat mn . Unlike in the minification operation, enlargement operation uses these enlargement factors sb to expand one row of old_pat ij to become several rows of new_pat mn . Similarly, these factors are used to expand one column of new_pat mn into several columns of new_patt pq . In other words, the enlargement factor is to duplicate the numbers of the original row (column) accordingly.
In the event that old_pat ij has only one row or i = 1 then the enlargement for both in row and column side will be enlarged 8 times as in Equation (8a).
But if i > 2, then Equation (8a) has to be modified as:
where the ROUND operator is to ensure that the result will always be an integer. From Equation (8b), the enlargement factor s b , for i = 1 to 7, will be as follows:
is as in Equation (9).
is as in Equation (10).
o i = 3 = 3 = 3 = 3 = 3. For i = 3, s 1…3 is as given in Equations (11a) and (11b).
To check whether Equation (11a) and (11b) has distributed i correctly, Equation (12) could be used. 
o i = 6. For i = 6, s 1…6 values are given in Equation (15a) and (15b).
o i = 7. For i = 7, s 1…7 values are given in Equation (16a) and (16b).
Enlargement: Column
The enlargement for column wise has the same rule as with the enlargement for the row wise. All equations, Equation (9) to (16b), are employed for enlargement in column wise. After enlargement on the row wise is applied (if i < 8), and if , then the enlargement on column wise is carried out.
EXPERIMENTAL RESULTS
In PCB defects classification, neural network training is an off-line operation. Neural network was trained using LVQ net. There are three LVQ nets for three groups of defects. There are 64 inputs for each LVQ net, 3 outputs for LVQ #1 and #2, and 5 outputs for LVQ #3. Output was represented with [1 2 … n], where n indicates type of n-th defect. Figure 13 shows neural network topology for LVQ #1, #2, and #3. In this approach, the numbers of first layer neurons (hidden layer neurons) for each LVQ net was selected by testing with various numbers of neurons, and by considering the most optimum one. By using the optimum parameters as already described in the previous section, each neural network was trained and tested by using various numbers of data.
There are 500 defective patterns for each type of defect as the training set (or a total of 5500 defective patterns for all defects for the training data set) and 100 defective patterns per set for the test data set for each type of defect. Classification result is shown in Table 2 . The table shows an overall correct classification result as 97.55%. Figure 14(a) shows a synthetic 256 × 256 PCB image as the reference, and Figure  14 (b) shows a defective image, both are in binary format, for an example, to test the developed algorithm. The first step is to segment the reference image into basic primitive patterns, and then to generate the window coordinates for these individual segmented primitive patterns. The next step is to subtract the test image from the reference image in order to detect the defects, and again the same windowing technique is employed to the defective patterns to generate the windows coordinates.
The third step is to define the position of the defective pattern dpat [i] Table 3 is associated to the numbers shown in Figure 15 .
DISCUSSION
As shown in Figure 15 and Table 3 , all defects could be successfully classified. For performance comparison, a pixel-based approach developed by Wu et al. [1] was used. At the time of writing this paper, this was the only algorithm designed for defect classification. The pixel-based approach could classify seven defects (short, missing hole, pinhole, open, mousebite, spur, and etching problem) [1] , but the NN-based Another issue, which is worth addressing, is the processing time in classifying each defect. In this approach there are few stages involved: segmentation, windowing (reference image and detected defects), defects detection, pattern assignment, normalization, and classification. For the neural network training part, since this process is done off-line, it does not affect the overall processing time. Among these five stages, the windowing task is the most time consuming operation (see Table 4 ), due to the operation working at pixel level, meaning that every individual pixel is analysed. In addition, the results of the windowing operation, i.e. window coordinates are saved into the hard disk, which adds more processing time. Table 4 shows overall processing time for the sample image. The first two stages could be done separately and only once. By including segmentation and windowing of the reference image operation processing time, it takes 16.39s to classify all 18 defects on Pentium III 800 MHz with 256 MB RAM, while by excluding the segmentation and reference image windowing as in real implementation, it takes about 3.97s to classify all defects. The processing time for the classification stage is only 0.82s for 18 defects, or approximately 0.046s to classify each defects. For the pixel-based approach reported in [1] , the processing time is 15.68s. It takes 5.26s for the defect detection and an average of 1.49s for classifying each defect. 
CONCLUSION
This paper proposes a new technique for PCB defects classification. It has been demonstrated that the proposed algorithm could classify correctly all possible type of defects that could occur on the PCB. It also has been shown that the defects classification technique based on neural network is better than pixel-based defects classification technique in term of numbers of classified defects and processing time.
