Information
-
Patent Application
-
20040017944
-
Publication Number
20040017944
-
Date Filed
May 23, 200321 years ago
-
Date Published
January 29, 200420 years ago
-
CPC
-
US Classifications
-
International Classifications
Abstract
In a method for character recognition based on Gabor filter group the Gabor filter's joint spatial/spatial-frequency localization and capability to efficiently extract characters' local structural features are employed to extract, from the character image, information of the stroke direction of characters as the recognition information of characters, so as to improve the capability to resist the noises, backgrounds, brightness variances in images and the deformation of characters. Using this information, a simple and effective parameter design method is put forward to. optimally design the Gabor filter, ensuring a preferable recognition performance; a corrected Sigmoid function is used to non-linearly adaptively process the stroke direction information output from the Gabor filter group. When extracting the feature from blocks, Gaussian filter array is used to process the positive and negative values output from Gabor filter group to. enhance the discrimination ability of the extracted features.
Description
FIELD OF THE INVENTION
[0001] The present invention relates to a method for character recognition. More particularly, the present invention relates to a method for character recognition based on Gabor filters.
BACKGROUND OF THE INVENTION
[0002] Traditional methods for character recognition carry out recognition based on binary character images. When recognizing various low-quality images, for example, the low-resolution image, the image of an identification card, an automobile license plate and a image of natural scenery, because their binarized images are extremely low quality, traditional methods for character recognition present a poor performance in recognizing characters regarding above-mentioned images.
[0003] Because of the disadvantages of traditional methods for character recognition, many prior arts does not carry out recognition based on binarization, but directly extract recognition features from a gray character image.
[0004] To directly extract recognition features from a gray character image, two specific methods are as follows:
[0005] One method extracts topographical and gradient features, etc. by means of analyzing the gradient distribution of a gray character image. Because the distribution of image's brightness needs to meet with some specific rules, the method owns a poor capability to resist noises.
[0006] The other method extracts recognition features by means of simple orthogonal transformation, for example, FFT or DCT Because the transformations reflect only global information of a character image, the method cannot extract local stroke direction and structural information of the character image, resulting in a poor capability to resist to the change in image's brightness and the deformation of the character.
[0007] Gabor filter possesses excellent joint spatial/spatial-frequency localization and capability to efficiently extract local structural features, thus, the method emerges at present to employ Gabor filters to extract the recognition features of handwritten digital images. However, current methods have following disadvantages:
[0008] When designing the Gabor filters, because the method selects different parameter values on the basis of different recognition ratios, the procedure of the method is tedious and the amount of calculation is tremendous, resulting in a poor capability to recognize.
[0009] The method does not apply Gabor filter to gray character image of low quality to carry out the recognition procedure, but apply Gabor filter only to binary image to recognize the characters. Therefore, when the method is applied to gray character image of low quality, the capability to discriminate the strokes off backgrounds of character images is poor.
[0010] Upon the above, though Gabor filter is used for character recognition, the method does not make full use of Gabor filter's excellent joint spatial/spatial-frequency localization and capability to efficiently extract local structural features.
SUMMARY OF THE INVENTION
[0011] One objective of the invention is to provide a method for character recognition based on Gabor filters. With the method, Gabor filter's excellent joint spatial/spatial-frequency localization and capability to efficiently extract characters' local structural features are employed to extract, from the character image, the most important and most stable information—the information of the stroke direction of characters—as the recognition information of characters so as to improve the capability to resist the change in image's brightness and the deformation of characters.
[0012] Another objective is to provide a method for character recognition based on Gabor filters. With the method, according to the statistic result of the stroke direction information of character image, a simple and effective parameter design method is put forward to optimally design the Gabor filter, ensuring a preferable recognition performance.
[0013] Another objective is to provide a method for character recognition based on Gabor filters. With the method, a corrected Sigmoid function is used to non-linear adaptively process the stroke direction information output from the Gabor filter so that the processed stroke direction information possesses a better restrain on the change in image's brightness, stroke's illegibility and fracture and disturbance from the background, and the robustness of the recognition features is dramatically enhanced.
[0014] Another objective is to provide a method for character recognition based on Gabor filter group. With the method, when extracting the histogram feature from blocks, Gaussian filter array is used to process the positive and negative values output from Gabor filter group to enhance the discrimination ability of the extracted features.
[0015] In order to realize the objectives of the invention, according to one embodiment of the invention, the method comprises steps:
[0016] P1: pre-processing a character image, including receiving, pre-processing the character image to be recognized, and obtaining a binary or gray image with N×N pixels for each character to be recognized, wherein said the binary or gray image for each character to be recognized is represented by a matrix, [A(i, j)]N×N;
[0017] P2: processing the matrix [A(i, j)]N×N for the image of each character to be recognized obtained in the step of pre-processing, including the following steps:
[0018] extracting stroke direction information of characters, including employing a Gabor filter group composed of K two-dimension Gabor filters to extract stroke information in K different directions from the matrix [A(i, j)]N×N for the character image to be recognized, and obtaining K matrixes [Gm(i, j)]M×M for the character image to be recognized, m=1 . . . K, each of said matrixes possessing M×M pixels and representing the stroke information of one direction;
[0019] extracting histogram features from blocks, including extracting features from blocks in said K matrixes of the character image to be recognized, i.e., [Gm(i, j)]M×M, m=1 . . . K, obtained in the step of extracting stroke direction information of characters, and obtaining a initial recognition feature vector V with a high dimension for the character image to be recognized;
[0020] compressing the features, including compressing the initial recognition feature vector V, and obtaining a recognition feature vector Vc with a low dimension for the character image to be recognized;
[0021] recognizing characters, including employing a specific classifier to calculate the distance between the recognition feature vector Vc for the image of each character to be recognized and the category center vector of each of the character categories, and selecting a nearest distance from the distances and the character category corresponding to the nearest distance, then calculating the character code for each character to be recognized according to national standard code or ASCII code of the character category.
[0022] P3: repeating step P2, until the character code for the image of each character to be recognized is obtained.
BRIEF DESCRIPTION OF THE DRAWINGS
[0023]
FIG. 1 is a flow chart of a method for character recognition based on Gabor filter group.
[0024]
FIG. 2 is a flow chart of optimizing parameters of Gabor filter group.
[0025]
FIG. 3 is a diagram of measuring the width and direction of a character's strokes.
[0026]
FIG. 4 is a diagram showing the result of the gray character image which is pre-processed, consecutively processed by Gabor filter group and finally adaptively processed, wherein, (a) is a diagram showing a character image with a low-resolution and a size of 20 pixel×20 pixel; (b) is a diagram showing the result of pre-processing; (c1)˜(f1) are diagrams showing the output results after processed by Gabor filter group (the degrees of φ are respectively −90°, −45°, 0° and 45°), wherein white color represents positive values and black color represents negative values; (c2)˜(f2) are respectively the diagrams showing the results of adaptively processing the images of (c1)˜(f1).
[0027]
FIG. 5 is a diagram of Sigmoid function and corrected Sigmoid function, wherein, (a) is the diagram of Sigmoid function and (b) is the diagram of corrected Sigmoid function.
[0028]
FIG. 6 is a flow chart of adaptively processing.
[0029]
FIG. 7 is a flow chart of extracting histogram features from blocks.
[0030]
FIG. 8 is a diagram of dividing blocks when extracting histogram features from blocks.
[0031]
FIG. 9 is a flow chart of calculating a matrix of compressed features.
[0032]
FIG. 10 is a flow chart of generating a recognition library.
[0033]
FIG. 11 is a flow chart of character recognition.
[0034]
FIG. 12 is a diagram showing the statistic result of the width and direction of a Chinese character's strokes, wherein, (a) is the diagram showing the statistic result of the width of a Chinese character's strokes and (b) is the diagram showing the statistic result of the direction of a Chinese character's strokes.
[0035]
FIG. 13 is a table showing the difference of recognition ratio for recognizing character images with different resolutions between an embodiment of the invention and DH method which extracts directional edge histogram features from the binary character images.
[0036]
FIG. 14 is a table showing the difference of recognition ratio for recognizing the images added with noises between an embodiment of the invention and DH method.
[0037]
FIG. 15 is a table showing the difference of recognition ratio for recognizing the samples of offline, handwritten Chinese characters between an embodiment of the invention and DH method.
[0038]
FIG. 16 is a diagram showing the structure of a typical character recognition system.
[0039]
FIG. 17 is a diagram showing the structure of identification card recognition system based on the method for character recognition of present invention.
[0040]
FIG. 18 is a diagram showing the result of identification card recognition in identification card recognition system.
DETAILED DESCRIPTION OF THE DRAWINGS
[0041] As stated above, due to Gabor filter's excellent optimum joint spatial/spatial-frequency localization and capability to efficiently extract character's local structural features, and since the main features of a character image is the structure of the character's strokes, the basic ideas of the present invention is to employ Gabor filter to extract the information of strokes in different direction of a character to be recognized so as to form recognition features highly robust to the disturbance of the image and the deformation of the strokes, then employ classifier to get the character label (or code) for the character to be recognized based on obtained recognition features.
[0042] As shown in FIG. 1, a method for character recognition based on Gabor filter group of the present invention comprises steps as follows:
[0043] pre-processing a character image,. wherein receiving, pre-processing the character image to be recognized, thus, obtaining a binary or gray image with N×N pixels for each character to be recognized, said the binary or gray image for each character to be recognized represented by a matrix [A(i, j)]N×N;
[0044] extracting stroke direction information of characters, wherein employing a Gabor filter group composed of K two-dimension Gabor filters to extract stroke information in K different directions from the matrix [A(i, j)]N×N for the image of each character to be recognized, thus, obtaining K matrixes [Gm(i, j)]M×M for the image of each character to be recognized, m=1 . . . K, each of said matrix possessing M×M pixels and representing the stroke information of one direction;
[0045] adaptively processing, wherein employing corrected Sigmoid function to adaptively process the K matrixes [Gm(i, j)]M×M, m=1 . . . K , obtained in the step of extracting stroke direction information of characters, each of said matrixes representing the stroke information of one direction, thereby, obtaining K matrixes [Fm(i, j)]M×M for the image of each character to be recognized;
[0046] extracting features from blocks, wherein extracting features from blocks of said K matrixes of the image of each character to be recognized, i.e., [Fm(i, i)]M×M obtained in the step of adaptively processing, thus, obtaining a initial recognition feature vector V with a high dimension for the image of each character to be recognized;
[0047] compressing the features, wherein compressing the initial recognition feature vector V, thereby, obtaining a recognition feature vector Vc with a low dimension for the image of each character to be recognized;
[0048] recognizing characters, wherein employing a specific classifier to calculate the distance between the recognition feature vector Vc for the image of each character to be recognized and the category center vector of each of the character categories, and selecting a nearest distance from the distances and the character category corresponding to the nearest distance, then calculating the character code for each character to be recognized according to national standard code or ASCII code of the character category.
[0049] For a more complete understanding of the detailed steps of the method of the present invention, reference is made to the following descriptions taken in conjunction with the accompanying drawings.
[0050] I. Step of Pre-Processing the Character Image
[0051] The step of pre-processing the character image comprises three steps as follows:
[0052] cutting the character image, wherein employing the row/column projection algorithm or character block orientation algorithm to cut the image of each character to be recognized from the whole image;
[0053] reversing the brightness of the image, wherein turning the color of each image obtained from cutting step into white and the color of the background into black, i.e., the brightness value of the pixels of the strokes of the image higher than that of the background;
[0054] normalizing the size of the image, wherein normalizing the images with different sizes into images with the same size so as to be convenient for the consecutive step of features extracting and achieve a stable capability to recognize the variance in size and the slight deformation of characters during the course of recognition, and generally employing well-known algorithms, i.e., gravity-center to shape-center normalization algorithm or line density equalization algorithm, to normalize the size of images.
[0055] After the step of pre-processing, each of obtained images are all gray or binary images with the unified size, and characters in white and the background in black, i.e., the brightness value of the pixels of the strokes of the image higher than that of the background. Assuming the size of the gray or binary image for each of character to be recognized is N×N pixels, the image can be represented by a matrix [A(i, j)]N×N, wherein A(i, j) represents the value of the pixel on ith row and jth column in the image.
[0056] Step of Extracting the Stroke Information of a Character
[0057] Said step mainly includes employing the Gabor filter group to extract the information of the strokes in K different directions from [A(i, j)]N×N for the image of each character to be recognized, thereby, obtaining K matrixes [Gm(i, j)]M×M, m=1 . . . K, each of said matrix possessing M×M pixels and representing the stroke information of one direction.
[0058] It is necessary to optimize the parameter of the Gabor filter group before its usage. The objective of optimizing the parameter is to reduce the similarity among output matrixes {[Gm(i, j)]M×M}, (1<=m<=K) by means of setting the optimal parameters for the Gabor filter group.
[0059] The optimization of Gabor filter group's parameters involves the following points: statistic of the width and direction of strokes in images of characters, realization of Gabor filter group, determination of initial parameters of Gabor filter group and optimization of the parameters of Gabor filter group by means of principle of information entropy.
[0060] Now the key points in optimization procedure are illustrated as follows.
[0061] Statistic of the Width and Direction of Strokes in Images of Characters
[0062] When determining the initial parameters of Gabor filter group, the average width and direction of strokes of the character image is used. Therefore, it is necessary to obtain the statistic of the average width and direction of strokes in images of characters in advance.
[0063] As shown in FIG. 3, for each simple stroke in the image (the complex stroke can be split into several simple strokes, i.e., horizontal stroke, perpendicular stroke, left-falling stroke and right-falling stroke), near the center of the stroke, assuming the width wi (i=1, 2, 3, . . . ) perpendicular to the direction of the stroke; estimating the direction of the stroke θi(i=1, 2, 3, . . . ) based on the horizontal direction. For some strokes, if the left-falling and right-falling strokes are not straight lines, least square estimation is used to obtain an optimal fitting straight line, the included angle between the fitting straight line and the horizontal direction is defined as the direction of the stroke. “W” represents the average width of strokes and {θm} (1<=m<=K) represents the typical direction of strokes.
[0064] Realization of Gabor Filter Group
[0065] Gabor filter group is generally composed of a plurality of two-dimension Gabor filters, the number of which is dependent on the actual requirement. Usually the impulse response function of two-dimension filter takes the following form:
1
[0066] Therefore, the parameters of Gabor filter group composed of K Gabor filters, whose impulse response function is abbreviated as hm(x,y) are {λm, φm, σxm, σym, D}(1≦m≦K), wherein D is the extracting spacing in the space of the Gabor filter group.
[0067] After pre-processing, the image [A(i, j)]N×N is processed by a Gabor filter group composed of K Gabor filters, thereby, obtaining K matrixes, each of whom is represented by {[Gm(i, j)]M×M}, (1<=m<=K), wherein, M=N/D.
[0068] [Gm(i, j)]M×M can be obtained by following convolution calculation:
2
[0069] Wherein the space range of the impulse response function hm(x,y) can be defined as—C<=x<=C, —C<=y<=C, because hm(X,Y) is a function which attenuates very quickly, when its absolute value is less than a certain threshold value, for example, 10−3, hm(x,y) imposes slight influence on the result and it is unnecessary to take it into consideration during the course of calculation, wherein C=N/4.
[0070] Determination of the Initial Parameters of Gabor Filter Group
[0071] According to the statistic result of average width W and typical direction θm of strokes of the image, the parameters {λm, φm, σxm, σym, D} (1≦m≦K) of the Gabor filter group composed of K Gabor filters are determined as follows:
λm=2W,φm=θm−90°,σxm=σym=,a≦σ≦b, D≦σ/{square root}{square root over (2)}, 1≦m≦K
[0072] wherein:
3
[0073] Wherein, as for a, only a range is defined and the specific value will be defined in the procedure of parameter optimization.
[0074] Optimizing the parameters of Gabor filter group by means of information entropy principle.
[0075] During the procedure of parameter optimization, in order to determine the degree of similarity among {[Gm(i, j)]M×M} (1<=m<=K) output from Gabor filters under the condition that parameter a takes different values, entropy correlation coefficient is employed.
[0076] Entropy correlation coefficient is a method for describing the matching similarity degree between two images by means of mutual information. For two images A and B with the same sizes, assuming their entropies are respectively H(A) and H(B), combinative entropy is H(A,B), mutual information is I(A,B)=H(A)+H(B)−H(A,B), the entropy correlation coefficient ECC is defined as:
ECC
(A,B)=2*I(A,B)/(H(A)+H(B))
[0077] wherein, entropy H(A) and H(B) are respectively calculated by means of the brightness histogram of images A and B.
[0078] Assuming the distribution of the brightness histogram of image A is Hist(i), 0<=i<=255 and the total number of the pixels in the image is PN, the entropy
4
[0079] For image B, H(B) can be calculated in the same way.
[0080] For combinative entropy H(A,B), firstly it is needed to calculate the statistic of the combinative histogram distribution Hist2(i,j) of images A and B, wherein Hist2(i,j) is defined as, in the same position, the total number of the pixels whose brightness are i or j in the images A and B. After obtaining Hist2(i,j), the combinative H(A, B) of images A and B is calculated as follows:
5
[0081] Upon the above, ECC is only dependent on the statistic of the brightness distribution of the pixels corresponding to two images, while ECC has no relationship with the specific difference of brightness. Therefore, a preferable capability to match images is obtained.
[0082] According to above-mentioned calculation of entropy correlation coefficient, a method for calculating the average entropy correlation coefficient of {[Gm(i,j)]M×M} (1<=m<=K) is illustrated as follows.
[0083] The {[Gm(i, j)]M×M} (1<=m<=K) resulting from processing character image
[0084] [A(i, j)]N×N by a Gabor filter group is firstly homogeneously quantified as {[G*m(i,j)]M×M}(1≦m≦K ) taking the values of integer 0˜255:
6
[0085] wherein, └ ┘ is for round-off.
[0086] Then, calculating the average entropy correlation coefficient Ecc of matrixes {[[G*m(i,j)]M×M] (1≦m≦K ):
7
[0087] Seen from above equation, average entropy correlation coefficient {overscore (ECC)} is actually the average of the sum of similarity of each two matrixes among the matrixes {[Gm(i, j)]M×M} (1<=m<=K) output from Gabor filter group after processing character image. If the similarity among the matrixes {[Gm(i, j)]M×M} (1<=m<=K) is small, the {overscore (ECC)} is small; otherwise, the {overscore (ECC)} is large.
[0088] When the parameter σ of Gabor filter group takes different values within a predetermined range, after the Gabor filter group processes the same character image, different matrixes are obtained, then, calculating average entropy correlation coefficient {overscore (ECC)}s of the matrixes, output from Gabor filter group, corresponding to every value of σ, and selecting the smallest {overscore (ECC)} which corresponds to the optimal value of σ. According to the optimal value of σ, suitable value of D is determined, thereby, achieving the objective of parameter optimization.
[0089] For a deep understanding of the procedure of parameter optimization, reference is now made to the following descriptions taken in conjunction with FIG. 2.
[0090] Initiating
[0091] Characters' images, which are typical and whose total number is SNUM, are selected from training sample character image database (step 10), then pre-processing the selected images and obtaining the statistic of the average width and direction of the strokes (step 20); according to the statistic, determining initiating parametersλ,φi (i=1,2 . . . K) for the Gabor filter group, the value range [a, b] of σ and the step length Δ of σ:Δ=(b−a)/N, for every step length Δ within the range [a, b], determining a series values for σi(i=1,2,3, . . . N+1) (step 30).
[0092] Calculating the average entropy correlation coefficient {overscore (ECC)} corresponding to each of values of σi.
[0093] Firstly to set parameter σ of the Gabor filter group as σ1, i.e., σ=a (step 40); then, employing the Gabor filter group to calculate, in sequence, the average entropy correlation coefficient {overscore (ECC)} for each image of the total images, the number of which is SNUM, and accumulating the {overscore (ECC)}s (step 50, 60 and 70); finally, averaging the accumulating value of the {overscore (ECC)}s, thereby, obtaining the average entropy correlation coefficient {overscore (ECC)} of all images corresponding to , (step 80) then storing it (step 90). Accordingly, respectively calculating and storing the average entropy correlation coefficient {overscore (ECC)} of all images corresponding to σ2, to σ3, . . . to σN+1(step 100).
[0094] Acquiring the Optimal Value of σ
[0095] The smallest average entropy correlation coefficient {overscore (ECC)} is selected from the average entropy correlation coefficient {overscore (ECC)}s of all images respectively corresponding to σ2, to σ3, . . . to σN+1 and the smallest one is the optimal value of σ (σ*) (step 110), then calculating D*=σ/{square root}{square root over (2)} (step 120). Thus, optimization of parameters of Gabor filter group is realized.
[0096] In FIG. 4, (c1), (d1), (e1) and (f1) show the output of a Chinese character processed by the optimized Gabor filter group. Seen from FIG. 4, optimized Gabor filter group performs well in separating the strokes in different directions inside the character image.
[0097] III. Adaptively Processing
[0098] Within the step, employing corrected Sigmoid function to non-linear adaptively process the K matrixes [Gm(i, j)]M×M, (1<=m<=K), obtained in the step of extracting stroke direction information of characters, each of said matrixes representing the stroke information of one direction, thereby, obtaining K matrixes [Fm(i, j)]M×M, (1<=m<=K), for the image of each character to be recognized.
[0099] For binary image, after processed by optimized Gabor filter group, recognition features can be directly extracted from obtained matrixes representing information of strokes in different direction. However, for gray character image under an adverse circumstance, recognition features cannot be directly extracted from the results after processed by optimized Gabor filter group, because the gray character images acquired under different illumination circumstances or during different taken courses have different brightness and contrast; even within a image, due to un-uniform illumination, the brightness of every stroke may vary. Even though Gabor filter has the capability to resist disturbance, after processed by Gabor filter group, the disturbance in the gray character image under the adverse circumstance has not been completely eliminated, because the disturbance line with low brightness, the disturbance lines with the width much less than that of stroke and the change in brightness with the width much-greater than that of stroke will generate output with a very small argument.
[0100] In order to restrain the influence of the change in brightness of image on the capability to recognize characters (abbreviated as invariability of brightness), it is necessary to further process the output from the Gabor filter group so as to restrain the output resulted from the disturbance.
[0101] Therefore, in the invention, corrected Sigmoid function ψm (t) (1≦m≦K) is employed to respectively carry out non-linear adaptive process on each of {[Gm(i,j)]M×M} (1≦m≦K) output from the Gabor filter group in order to restrain the disturbance, wherein, function ψm(t) (1≦m≦K) is the translation result of the Sigmoid function φ(t), as shown in FIG. 5.
[0102] Sigmoid function φ(t) will saturate the large input, which can compensate the difference in brightness of each part of the image and the slight change in the width of strokes. After correction, corrected Sigmoid function ψm(t) (1≦m≦K) not only retain the saturation feature for large inputs, but also put up a restrain feature for weak inputs, thus, avoiding function φ(t)'s amplifying action on weak input and achieving restrain on output of noises and backgrounds.
[0103] Sigmoid function φ(t) is:
φ(t) tanh(αt)=(e2αt−1)/(e2αt+1)
[0104] Corrected Sigmoid function ψm(t) is:
ψm(t) tanh(αm(t−χm))+βm, 1≦m≦K
[0105] Differentiating the corrected Sigmoid function ψm(t)
8
[0106] Upon the above, when t<vm, the gradient of ψm(t)<1, putting up a restrain feature on weak input; when t>χm+(χm−νm), the gradient of ψm(t)<1, i.e., putting up a strong saturation feature on large input.
[0107] In order to employ function χm(t), the parameters χm, αm and βm inside the function need to be determined. In the invention, defining χm, αm as follows: 0.1<χm<0.5, 2<αm<10, the specific value of χm and αm will be selected dependent on different recognition capabilities. The value of βm is determined dependent on different qualifications.
[0108] Reference is made in conjunction with FIG. 6 to describe how to employ corrected Sigmoid function ψm(t) to non-linear adaptively process each of matrixes [Gm(i, j)]M×M, (1<=m<=K), output from Gabor filter group.
[0109] 1. Normalizing Matrixes (Step 120)
[0110] Before each of the matrixes {[Gm(i, j)]M×M} (1<=m<=K) output from Gabor filter group is non-linear adaptively processed, they shall be normalized in a simple way, thus, obtaining {[G′m(i,j)]M×M} (1≦m≦K ). The normalization is carried out based on following equation:
G′
m
(i,j)=Gm(i,j)/MAXm
[0111] wherein, MAXm=max(|Gm(i,j)|)
[0112] 2. Determining Values of Parameters of Corrected Sigmoid Function ψm(t) (Step 130)
[0113] Within the range of 0.1<χm<0.5, 2<αm<10, the values of χm and αm are determined upon the requirements of recognition capability and experiences. The value of βm is determined upon experiences.
[0114] 3. Adaptively Processing by Means of Corrected Sigmoid Function (Step 140)
[0115] First to, turn the corrected Sigmoid function ψm(t) with parameters determined to odd symmetry, thus, the corrected Sigmoid function ψm(t) can also, process the negative values in the matrixes {[G′m(i,j)]M×M} (1≦m≦K ), that is:
9
[0116] Then to process {[G′m(i,j)]M×M} (1≦m≦K ), thus, obtaining output after processing, Fm(i,j)]M×M(1≦m≦K):
10
[0117] In this way, both the positive values and negative values in {[Gm(i,j)]M×M} (1≦m≦K) output from Gabor filter group are simultaneously processed, and achieved the result {[Fm(i,j)]M×M} (1≦m≦K).
[0118] IV. Extracting Histogram Features from Blocks
[0119] Within the step, extracting histogram features from blocks of said K matrixes of the image of each character to be recognized, i.e., [Fm(i, j)]M×M, m=1 . . . K, obtained in the step of adaptively processing, thus, obtaining a initial recognition feature vector V with a high dimension for the image of each character to be recognized;
[0120] The following is detailed description of the procedure of extracting features from blocks in conjunction with FIG. 7.
[0121] 1. Evenly Dividing (Step 160)
[0122] For each of matrixes {[Fm(i,j)]M×M} (1≦m≦K), evenly dividing into P×P rectangular areas overlapped with each other and the length of side of each rectangular are L. FIG. 8 is a diagram showing the mode of dividing the rectangular into blocks.
[0123] 2. Calculating Feature Vector Sm+ and Sm− for Each Matrix (Step 170)
[0124] At the center r(x, y) of each rectangular area, respectively calculating the weighted sum of positive values and weighted sum of negative values for each area; then, based on the weighted sum of positive values and weighted sum of negative values of each rectangular area of each matrix, summing by Gaussian weighting, thereby, obtained the feature vector Sm+ of positive values and the feature vector Sm− of negative values, wherein the dimensions of Sm+ and Sm− are both P2. The equations for calculating Sm+ and Sm− are as follows:
11
[0125] wherein, G(x,y)=exp{−(x2+y2)/2}/(2π) is Gaussian weighting function.
[0126] 3. Calculating Initial Recognition Feature Vector V (Step 180)
[0127] The feature vector Sm+ of positive values and the feature vector Sm− of negative values for each matrix are orderly merged as a feature vector, whose dimension is 2 KP2, thus, obtaining initial recognition feature vector V:
V=[S
1
+
S
1
−
S
2
+
S
2
−
. . . S
K
+
S
K
−
].
[0128] V. Compressing Features
[0129] With in the step, compressing the initial recognition feature vector V, thereby, obtaining a recognition feature vector Vc with a lower dimension for the image of each character to be recognized.
[0130] The objective of the step is to further compress the initial recognition feature vector V so as to improve the distribution of features and after-mentioned capability of character recognition. Usually, compressing feature step carries out by means of LDA method.
[0131] The feature compression is realized by multiplying the initial recognition feature vector V by transformation matrix Φ. The dimension of the transformation matrix Φ is 2KP2×n, wherein n≦2KP2 . The matrix Φ is calculated by means of LDA method.
[0132] Following reference is made to describe the procedure of calculating transformation matrix Φ in conjunction with FIG. 9.
[0133] 1. Calculating Feature Vector Sequence for each Character Category (Step 210)
[0134] Assuming the total number of character categories is C01, above-mentioned the steps of pre-processing, extracting information of strokes' direction of characters, adaptively processing and extracting from blocks are carries out for images of all training sample characters of each character category, thereby, obtaining feature vector sequence {Vi1, Vi2, . . . ViQi} for each character category i, wherein, Qi the number of total images of training sample characters of character category i.
[0135] 2. Calculating Category Center μi of each character category i and category center μ of all character categories
[0136] According to feature vector sequence {Vi1, Vi2, . . . ViQi} of each character category i, calculating category center μi of each character category i (step 220):
12
[0137] According to the category center μi of each character category i, calculating category center μ of all character categories (step 230):
13
[0138] 3. Calculating Between-Class Scatter Matrix Σb and Within-Class Scatter Matrix Σw
[0139] According to the category center μi of each character category i and the category center μ of all character categories, calculating inter-category discrete degree matrix Σb (step 240):
14
[0140] According to the category center μi of each character category i, calculating inner-category discrete degree matrix Σw (step 250):
15
[0141] 4. Calculating the Transformation Matrix φ used for Feature Compression.
[0142] The transformation matrix is found when the matrix maximize the value of |φτΣbφ|/|φτΣwφ|. By means of matrix calculating tool, first n largest non-zero eigenvalues of matrix Σ−1wΣb are achieved, and first n eigenvectors corresponding to first n largest non-zero eigenvalues are arranged column by column to form the transformation matrix φ (step 260, 270).
[0143] After achieving the transformation matrix φ, the compression on the initial recognition feature vector V can be carried out according to the following equation:
Vc=ΦTV
[0144] Wherein: VC represents the compressed recognition feature vector.
[0145] The compressed recognition feature vector VC accords with the hypothesis of Gaussian distribution better in statistics, thus, the capability of classifiers improves and meanwhile, the complexity and the amount of calculation of classifiers are reduced.
[0146] Acquiring recognition feature vector VC means that the step of extracting features from the character image to be recognized is finished. The following step is to recognize by means of put the recognition feature vector VC into classifiers.
[0147] VI. Character Recognition
[0148] In the step, the classifiers used are the statistical classifiers based on Bayes decision theory, for example, Gaussian distance classifiers.
[0149] During the procedure of character recognition, category center vector and its national standard code of each character category shall be acquired in advance.
[0150] Following reference is made to describe how to acquire category center vector and its national standard code of each character category in conjunction with FIG. 10.
[0151] 1. Calculating Compressed Feature Vector Sequence of each Character Category
[0152] Assuming the total number of character categories is Co, above-mentioned steps of pre-processing, extracting information of stroke's direction of characters, adaptively processing, extracting from blocks and compressing feature are carries out for images of all training sample characters of each character category, thereby, obtaining compressed feature vector sequence {Vic1, Vic2, . . . VicQi} for each character category i (step S50), wherein, Qi is the number of total images of training sample characters of character category i.
[0153] 2. Calculating Category Center of each Character Category
[0154] According to the compressed feature vector sequence {Vic1, Vic2, . . . VicQi} for each character category i, calculating n-dimension category center μ*i of each character category i (step S60):
16
[0155] 3. Storing National Standard Code and Category Center Vector of each Character Category
[0156] According to a certain sequence, the national standard code GB(i) and n-dimension category center vector μ*i of each character category i are stored in the documents of recognition library (step S70).
[0157] Reference is now made to describe the procedure of character recognition by means of Euclidean distance classifier in conjunction with FIG. 11.
[0158] 1. Reading the National Standard Code and Category Center Vector of each Character Category
[0159] Category center vector {μ*i}l≦i≦C and national standard code GB(i) of each character category are read out from the recognition library (step S10).
[0160] 2. Calculating the Distance Between the Recognition Feature Vector VC and Category Center Vector of each Category
[0161] The recognition feature vector VC of the character image to be recognized acquired in the step of compressing features is input, then the Euclidean distance {DISTi}l≦i≦C between the recognition vector VC and category center vector {μ*i}1≦i≦C is calculated as follows (step S20):
17
[0162] 3. Calculating the Character Code for each Character to be Recognized
[0163] According to the Euclidean distance {DISTi}1≦i≦C between the recognition vector VC and the category center vector of each character category, the smallest distance and the character category the smallest distance corresponds to are determined. According to the character category found out, the character code “CODE” of the image of each the character to be recognized is calculated (step S30, S40).
18
[0164] CODE=GB(p).
[0165] The code “CODE” is the recognition result of the character to be recognized, which can be output to the database of computers, the text files or directly displayed on the screen of computers.
[0166] Upon the above, the method for character recognition based on Gabor filter group can be divided into two states: training stage and character recognition stage.
[0167] During the course of the training: 1. According to the properties of image sample of characters, a method for extracting features is optimally designed, i.e., firstly, Gabor filter group is constructed and the parameters thereof are optimized; secondly, according to the requirements of recognition capabilities, the values of the parameters of corrected Sigmoid function ψm(t) used in the step of adaptively processing are set; thirdly, the number of blocks each matrix is divided into in the step of extracting features from blocks is determined; the transformation matrix used in the step of compressing features is calculated; 2. Suitable classifier is selected; 3. Optimal method for extracting features is used, i.e., firstly, recognition features sequences of all character categories are obtained by extracting features from character's sample image of all character categories; secondly, all recognition features sequences are processed by selected classifier, and category center vectors of all character categories are obtained; finally, the category center vectors and the national standard codes of all character categories are stored in the recognition library.
[0168] During the course of recognizing characters, firstly, the character image is processed by means of the optimal method of extracting features obtained in the stage of training, and the recognition features vector is obtained; furthermore, the classifier calculates the distance between the recognition feature vector of the image of characters to be recognized and the category center vector of each category; moreover, according to the distances, the smallest distance and the character category which the smallest distance corresponds to are determined; finally, according to the national standard code of the character category found out, the character code “CODE” of the character image to be recognized is calculated.
[0169] Generally, the training stage of the present invention is carried out in the units developing the technique, while the character recognition stage is carried out at the user terminals.
[0170] The following description relates to an embodiment of a method for recognizing the images of Chinese characters based on Gabor filter group.
[0171] During the Course of Training:
[0172] 1. Statistic of the Width and Direction of Strokes
[0173] A plurality of typical images of characters are selected from Chinese character training samples and these images are normalized as images of [A(i,j)]N×N of 64×64 pixels and the statistic of the average width and direction of the strokes of these typical images is obtained. The statistic result is shown in FIG. 12. Seen from the statistic result, the average width of strokes W is 5 pixels and the direction of strokes distributes near four directions of {0°,45°, 90°, 135°}.
[0174] 2. Constructing Gabor filter group and optimizing the parameters
[0175] In the embodiment, the Gabor filter group comprises four Gabor filters, i.e., K=4. According to the statistic result of the average width and direction of the strokes, the parameters of the Gabor filter group are optimized, the optimized parameters are as follows:
λ=10, {φk}k=1,2,3,4={−90°,−45°,0°,45°}, σ=5.6, D=4.
[0176] 3. Setting the Parameters of Corrected Sigmoid Function ψm(t)
[0177] In the embodiment, all matrixes output from the Gabor filter group are processed by a same corrected Sigmoid function ψm(t) . According to the requirements of recognition capability, the setting are as follows: α=7,χ=0.59, β=1.00.
[0178] 4. Determining the Number of Blocks Divided in the Step of Extracting Features from Blocks
[0179] In the embodiment, the number of blocks of each matrix is 8×8=64 and the length of side of each block is L=8. Thus, the initial recognition feature vector of the image of each character to be recognized is 512-dimension.
[0180] 5. Determining the Transformation Matrix φ used in the Step of Compressing Features
[0181] In the embodiment, the 512-dimension initial recognition feature vector of the character image to be recognized can be compressed into 120-dimension recognition feature vector by the transformation matrix φ by means of LDA transformation.
[0182] 6. Determining Classifier
[0183] In the embodiment, Euclidean distance classifier is selected.
[0184] 7. Generating a Recognition Library of Chinese Characters The 3755 Chinese characters contained in the first class of national standard code are processed to obtain the category center vectors of 3755 Chinese characters, and the vectors and the national standard codes of these characters are stored in the documents of the recognition library.
[0185] During the course of recognizing characters:
[0186] 1. Pre-Processing
[0187] Firstly, the image of characters to be recognized is cut and the images of single characters are obtained; secondly, normalization process on each image of single character is carried out and the images [A(i,j)]N×N obtained are all 64×64 pixels and in the images the color of the characters is white and that of background is black.
[0188] 2. Extracting Direction Information of Strokes
[0189] Each of the images [A(i,j)]N×N of Chinese characters obtained in the step of pre-process is processed the Gabor filter group {λm, φm, σxm, σym, D} (1≦m≦4) obtained during the course of training processes and the output in four directions {[Gm(i,j)]M×M} (1≦m≦4) are obtained.
[0190] 3. Non-Linear Processing
[0191] The output {[Gm(i,j)]M×M}(1≦m≦4) of the image of each Chinese character to be recognized from the Gabor filter group is non-linear adaptively processed and matrix {[Fm(i,j)]M×M} (1≦m≦4) of each Chinese character to be recognized is obtained.
[0192] 4. Extracting Histogram Features from Blocks
[0193] According to the flow chart shown in FIG. 7, the dividing mode shown in FIG. 8 and the number of blocks each matrix is divided into in the embodiment, for the positive values and negative values of matrixes {[Fm(i,j)]M×M}(1≦m≦4) of the image of each Chinese character to be recognized, features of blocks are respectively calculated. And finally 512-dimension initial recognition feature vector of the image of
[0194] 7. Generating a Recognition Library of Chinese Characters
[0195] The 3755 Chinese characters contained in the first class of national standard code are processed to obtain the category center vectors of 3755 Chinese characters, and the vectors and the national standard codes of these characters are stored in the documents of the recognition library.
[0196] During the course of recognizing characters:
[0197] 1. Pre-Processing
[0198] Firstly, the image of characters to be recognized is cut and the images of single characters are obtained; secondly, normalization process on each image of single character is carried out and the images [A(i,j)]N×N obtained are all 64×64 pixels and in the images the color of the characters is white and that of background is black.
[0199] 2. Extracting Direction Information of Strokes
[0200] Each of the images [A(i,j)]N×N of Chinese characters obtained in the step of pre-process is processed the Gabor filter group {λm,φm,σxm,σym, D} (1≦m≦4) obtained during the course of training processes and the output in four directions {[Gm(i,j)]M×M} (1≦m≦4) are obtained.
[0201] 3. Non-Linear Processing
[0202] The output {[Gm(i,j)]M×M}(1≦m≦4) of the image of each Chinese character to be recognized from the Gabor filter group is non-linear adaptively processed and matrix {[Fm(i,j)]M×M} (1≦m≦4) of each Chinese character to be recognized is obtained.
[0203] 4. Extracting Histogram Features from Blocks
[0204] According to the flow chart shown in FIG. 7, the dividing mode shown in FIG. 8 and the number of blocks each matrix is divided into in the embodiment, for the positive values and negative values of matrixes {[Fm(i,j)]M×M}(1≦m≦4) of the image of each Chinese character to be recognized, features of blocks are respectively calculated. And finally 512-dimension initial recognition feature vector of the image of
[0205]
FIG. 16 shows a system for character recognition based on the method for character recognition of the present invention. The system comprises two parts: image input device 300 and universal computer 310. The image input device 300 usually takes the form of scanner, digital camera, etc. to acquire the digital image of texts so as to facilitate the process by computers. Universal computer 310 is used to run the method for character recognition of present invention.
[0206]
FIG. 17 shows a system for recognizing identification card based on the method of present invention, wherein the system comprises: photoelectric take-in device 400 (special digital camera), computer 410 (comprising the character recognition system and database).. The photoelectric take-in device 400 is used to transform the identification card into digital image and input it into computer 410; computer 410 recognizes the input digital image invoking character recognition system, and the result is sent to database or compared with the data in the database to authenticate the identification card.
[0207] At a Custom Administration Office, images of 41 identification cards with different qualities are collected by means of the system of identification card. And the names and numbers on the cards are recognized. Seen from the result shown in FIG. 18, the whole recognition ratio of recognizing identification cards is up to 90%, which meets the practical demand.
[0208] Advantageous Effects
[0209] In sum, seen from the comparison between an embodiment of the present invention and the best recognition method, at present, of extracting directional edge histogram features from the binary images, when recognizing high-quality images of print Chinese characters, the recognition capability of the method disclosed in present invention is same as that of the best method; when recognizing low-quality images which are in low resolution and with disturbance, the recognition capability of the invention is far better than that of the best method at present; when recognizing the images of handwritten characters, it can be seen that the method of the present invention possesses a strong resistance to the change in handwritten characters and obtains the highest recognition ratio at present,
Claims
- 1. A method for character recognition based on a Gabor filter group, said method comprising:
(a) pre-processing a character image, said pre-processing including receiving, pre-processing the character image of a character to be recognized, and obtaining a binary or gray image with N×N pixels for each character to be recognized, wherein said binary or gray image for each character to be recognized is represented by a matrix [A(i, j)]N×N; (b) processing the matrix [A(i, j)]N×N for the character image of each character to be recognized obtained in the step (a), said processing including:
extracting stroke direction information of the character to be recognized, said extracting including employing the Gabor filter group which is composed of K two-dimension Gabor filters to extract stroke information in K different directions from the matrix [A(i, j)]N×N of the character image of the character to be recognized, and obtaining K matrixes [Gm(i, j)]M×M, m=1 . . . K, of the character image of the character to be recognized, wherein each of said matrixes [Gm(i, j)]M×M, m=1 . . . K, possesses M×M pixels and represents the stroke information of one of the K directions; extracting features from blocks, including extracting features from the blocks in said K matrixes [Gm(i, j)]M×M, m=1 . . . K, of the image of the character to be recognized, and obtaining an initial recognition feature vector V with a high dimension of the character image of the character to be recognized; compressing the features, including compressing the initial recognition feature vector V and obtaining a recognition feature vector Vc with a low dimension of the character image of the character to be recognized; recognizing the character, including employing a specific classifier to calculate a distance between the recognition feature vector Vc and a category center vector of each character category, selecting a nearest distance from distances and the character category corresponding to the nearest distance, and calculating a character code of the character to be recognized according to a national standard code of the character category; and (c) repeating step (b) to obtain each character code of each character image.
- 2. The method of claim 1, wherein processing the matrix further includes a step of optimizing parameters, said optimizing parameters including:
(1) selecting some typical character images from a training sample character image database, pre-processing the selected character images and obtaining a statistic of an average width and direction of the strokes of pre-processed images; (2) determining an initial value of each parameter in impulse response function of the Gabor filter group according to the statistic, and determining a plurality of values of a parameter a in impulse response function for every step length within a certain value range; (3) selecting one value from the plurality of values of a, combining said value with other determined parameters to construct the Gabor filter group, extracting the direction information of strokes from the pre-processed image of the character by the constructed Gabor filter group, and calculating a first average entropy correlation coefficient {overscore (ECC)} of the character image according to the information; (4) repeating step (3) to obtain each first average entropy correlation coefficient {overscore (ECC)} of the image of each character corresponding to selected value of σ, calculating an average value of all first average entropy correlation coefficients {overscore (ECC)}S of the image of each character to obtain a second average entropy correlation coefficient {overscore (ECC)} corresponding to the selected value of σ; (5) repeating step (4) to obtain each second average entropy correlation coefficient {overscore (ECC)} corresponding to each value of σ; and (6) selecting the smallest one from second average entropy correlation coefficients {overscore (ECCS)}, using the value of a corresponding to the smallest second average entropy correlation coefficient {overscore (ECC)} and other said determined parameters to optimally construct the Gabor filter group.
- 3. The method of claim 1, further comprising a step of adaptively processing, said adaptively processing including employing corrected Sigmoid function to adaptively process the K matrixes [Gm(i, j)]M×M, 1<=m<=K, wherein each of said matrixes represents the stroke information of one of the K directions to obtain K matrixes [Fm(i,j)]M×M, 1<=m<=K, for the character image of each character to be recognized.
- 4. The method of claim 2, further comprising a step of adaptively processing, said adaptively processing including employing corrected Sigmoid function to adaptively process the K matrixes [Gm(i, j)]M×M, 1<=m<=K, wherein each of said matrixes represents the stroke information of one of the K directions to obtain K matrixes [Fm(i,j)]M×M, 1<=m<=K, for the character image of each character to be recognized.
- 5. The method of claim 3, wherein the step of adaptively processing further comprises:
(1) normalizing said K matrixes [Gm(i, j)]M×M, 1<=m<=K, to obtain K matrixes {[G′m(i,j)]M×M}, 1≦m≦K; (2) determining values of parameters of corrected Sigmoid function ψm(t) according to the requirements of recognition capacity and experiences; and (3) non-linear adaptively processing said K matrixes {[G′m(i,j)]M×M}, 1≦m≦K, using the determined corrected Sigmoid function ψm(t) to obtain K matrixes [Fm(i,j)]M×M.
- 6. The method of claim 4, wherein the step of adaptively processing further comprises:
(1) normalizing said K matrixes [Gm(i, j)]M×M, 1<=m<=K, to obtain K matrixes {[G′m(i,j)]M×M}, 1≦m≦K ; (2) determining values of parameters of corrected Sigmoid function ψm(t) according to the requirements of recognition capacity and experiences; and (3) non-linear adaptively processing said K matrixes {[G′m(i,j)]M×M}, 1≦m≦K, using the determined corrected Sigmoid function ψm(t) to obtain K matrixes [Fm(i,j)]M×M, 1≦m≦K.
- 7. The method of any of claims 1-6, wherein the step of extracting features from blocks further including:
(1) evenly dividing, each of said K matrixes [Gm(i, j)]M×M or each of said K matrixes {[Fm(i,j)]M×M} into P×P rectangular areas which are overlapped with each other and have a length L for each side of each rectangular; (2) respectively calculating a first weighted sum of positive values and a second weighted sum of negative values of all pixels within the area, at the center of each rectangular area; (3) forming a first feature vector Sm+ of positive values and a second feature vector Sm− of negative values according to the first weighted sum and the second weighted sum of each rectangular area of each matrix, wherein the dimensions of Sm+ and Sm− are both P2; and (4) merging the first feature vector Sm+ and the second feature vector Sm− for each [Gm(i, j)]M×M or each {[Fm(i,j)]M×M} as an initial recognition feature vector V=[S+1 S−1 S+2 S−2 . . . S+K S−K] with a dimension of 2KP2.
- 8. The method of any of claims 1-6, wherein said step of compressing features further includes:
(1) calculating a transformation matrix φ used in the step of compressing features; and (2) transposing the transformation matrix φ, multiplying the transposed transformation matrix φ by the initial recognition feature vector V of the character image of the character to be recognized thus compressing said initial recognition feature vector V and obtaining the recognition feature vector Vc with a low dimension for the character image of the character to be recognized.
- 9. The method of claim 7, wherein said step of compressing features further includes:
(1) calculating a transformation matrix φ used in the step of compressing features; and (2) transposing the transformation matrix φ, multiplying the transposed transformation matrix φ by the initial recognition feature vector V of the character image of the character to be recognized thus compressing said initial recognition feature vector V and obtaining the recognition feature vector Vc with a low dimension for the character image of the character to be recognized.
- 10. The method of claim 8, wherein said calculating a transformation matrix φ includes:
(1) pre-processing the character image, extracting information of stroke's direction of the character, adaptively processing the images and extracting features from blocks regarding all training sample characters of each character category, and obtaining a recognition feature vector sequence for each character category; (2) calculating a first category center of each character category according to each recognition feature vector sequence of each character category; (3) calculating a second category center of all character categories, according to each first category center of each character category; (4) calculating a between-class scatter matrix Σb according to each first category center and the second category center; (5) calculating a within-class scatter matrix Σw according to each first category center; and (6) calculating first n largest, non-zero eigenvalues of matrix Σ−1wΣb, and arranging first n eigenvectors corresponding to said first n largest non-zero eigenvalues column by column to form the transformation matrixφ.
- 11. The method of claim 9, wherein said calculating a transformation matrix φ includes:
(1) pre-processing the character image, extracting information of stroke's direction of the character, adaptively processing the images and extracting features from blocks regarding all training sample characters of each character category, and obtaining a recognition feature vector sequence for each character category; (2) calculating a first category center of each character category according to each recognition feature vector sequence of each character category; (3) calculating a second category center of all character categories, according to each first category center of each character category; (4) calculating a between-class scatter matrix Σb according to each first category center and the second category center; (5) calculating a within-class scatter matrix Σw according to each first category center; and (6) calculating first n largest, non-zero eigenvalues of matrix Σ−1wΣb, and arranging first n eigenvectors corresponding to said first n largest non-zero eigenvalues column by column to form the transformation matrix φ.
Priority Claims (1)
Number |
Date |
Country |
Kind |
02117865.8 |
May 2002 |
CN |
|