导读:
摘要图像识别是目前很热门的研究领域,涉及的知识很广,包括信息论、模式识别、模糊数学、图像编码、内容分类等等。本文仅对使用Java实现了一个简单的图像文本二值处理,关于识别并未实现。
步骤
建立文本字符模板二值矩阵
对测试字符进行二值矩阵化处理
代码
/*
* @(#)StdModelRepository.java
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Library General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
package cn.edu.ynu.sei.recognition.util;import java.awt.Image;import java.awt.image.BufferedImage;import java.io.File;import java.io.IOException;import java.util.ArrayList;import java.util.List;import java.util.logging.Level;import java.util.logging.Logger;import javax.imageio.ImageIO;/** * Hold character charImgs as standard model repository.
* @author 88250
* @version 1.0.0.0, Mar 20, 2008
*/
public class StdModelRepository {
/** * hold character images
*/ List charImgs = new ArrayList ();
/** * default width of a character
*/ static int width = 16 /** * default height of a character
*/ static int height = 28 /** * standard character model matrix
*/ public int[][][] stdCharMatrix = new int[27][width][height];
/** * Default constructor.
*/ public StdModelRepository() {
BufferedImage lowercase = null try {
lowercase = ImageIO.read(new File("lowercase.png"));
} catch (IOException ex) {
Logger.getLogger(StdModelRepository.class.getName()).
log(Level.SEVERE, null, ex);
}
for (int i = 0 i < 26 i++) {
charImgs.add(lowercase.getSubimage(i * width,
0,
width,
height));
}
for (int i = 0 i < charImgs.size(); i++) {
Image image = charImgs.get(i);
int[] pixels = ImageUtils.getPixels(image,
image.getWidth(null),
image.getHeight(null));
stdCharMatrix[i] = ImageUtils.getSymbolMatrix(pixels, 0).clone();
ImageUtils.displayMatrix(stdCharMatrix[i]);
}
}
}
/*
* @(#)ImageUtils.java
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Library General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
package cn.edu.ynu.sei.recognition.util;import java.awt.Image;import java.awt.image.PixelGrabber;import java.util.logging.Level;import java.util.logging.Logger;/** * Mainipulation of image data.
* @author 88250
* @version 1.0.0.3, Mar 20, 2008
*/
public class ImageUtils {
/** * Return all of the pixel values of sepecified
.> * @param image the sepecified image
* @param width width of the
* @param height height of the
* @return */ public static int[] getPixels(Image image, int width, int height) {
int[] pixels = new int[width * height];
try {
new PixelGrabber(image, 0, 0, width, height, pixels, 0, width).grabPixels();
} catch (InterruptedException ex) {
Logger.getLogger(ImageUtils.class.getName()).
log(Level.SEVERE, null, ex);
}
return pixels;
}
/** * Get a matrix that described the
*
* 0000000000000000
* 0000000000000000
* 0001111111110000
* 0011111111111000
* 0011111111111100
* 0011000000011100
* 0000000000011100
* 0000111111111100
* 0011111111111100
* 0011111110011100
* 0111100000011100
* 0111100000011100
* 0111100000111100
* 0111100001111110
* 0011111111111100
* 0011111111111100
* 0001111111111100
* 0000000000000000
* 0000000000000000
*
* it describes the alphbet 'a'.
*
* @param pixels the pixel array
* @param sparseFactor sparse factor
* @return a matrix that describes a alphbet
*/ public static int[][] getSymbolMatrix(int[] pixels, int sparseFactor) {
final int width = StdModelRepository.width;
final int height = StdModelRepository.height;
int[][] ret = new int[width][height];
for (int i = 0 i < height; i++) {
for (int j = 0 j < width; j++) {
if (pixels[i * width + j] == -1) {
ret[j][i] = 0 } else {
ret[j][i] = 1 }
}
}
return ret;
}
/** * Print the
> * @param matrix the sepecified matrix data
*/ public static void displayMatrix(int[][] matrix) {
System.out.println("");
for (int i = 0 i < matrix[0].length; i++) {
for (int j = 0 j < matrix.length; j++) {
if (matrix[j][i] != 0) {
System.out.print("*");
} else {
System.out.print(" ");
}
}
System.out.println();
}
}
}
/*
* @(#)ImageTextRecognitor.java
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Library General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
package cn.edu.ynu.sei.recognition;import cn.edu.ynu.sei.recognition.util.StdModelRepository;import cn.edu.ynu.sei.recognition.util.ImageUtils;import java.awt.Image;import java.awt.image.BufferedImage;import java.io.File;import java.io.IOException;import java.util.logging.Level;import java.util.logging.Logger;import javax.imageio.ImageIO;/** * Demonstrate recognition characters from a image.
* @author 88250
* @version 1.0.0.2, Mar 20, 2008
*/
public class ImageTextRecognitor {
private final static long serialVersionUID = 1L private StdModelRepository smr = new StdModelRepository();
private BufferedImage bufferedImage;
/** * Default constructor.
*/ public ImageTextRecognitor() {
try {
bufferedImage = ImageIO.read(new File("a_yahei12.png"));
} catch (IOException ex) {
Logger.getLogger(StdModelRepository.class.getName()).
log(Level.SEVERE, null, ex);
}
}
/** * Return the matched character with sepecified image.
* @param symbolMatrix the matrix of sepecified image
* @return the character
*/ // TODO: the core algorithm
public char getMatchResult(int[][] symbolMatrix) {
char result = 0 int tmpEvaluation = 100 int evaluation = 0 return result;
}
/** * Main program entry.
* @param args should be
> */ public static void main(String[] args) {
ImageTextRecognitor irt = new ImageTextRecognitor();
BufferedImage bi = irt.bufferedImage;
Image img = bi.getScaledInstance(16, 28, BufferedImage.SCALE_FAST);
int[] testImgPixels = ImageUtils.getPixels(img, img.getWidth(null),
img.getHeight(null));
ImageUtils.displayMatrix(ImageUtils.getSymbolMatrix(testImgPixels, 2));
// irt.getMatchResult(ImageUtils.getPixels(bi,
// bi.getWidth(),
// bi.getHeight()));
}
}
测试
标准字符图像
测试字符图像
测试输出init:
deps-jar:
Compiling 2 source files to /home/daniel/Work/Sources/Java/ImageTextRecognition/build/classes
compile:
run:
*********
***********
************
** ***
***
**********
************
******* ***
**** ***
**** ***
**** ****
**** *****
************
************
***********
***
***
***
***
***
*** ******
************
************
***** *****
**** ****
**** ****
**** ***
*** ***
**** ***
**** ****
**** ****
***** *****
************
************
*** *******
*********
**********
***********
**** *
****
****
****
****
****
****
****
**** *
***********
**********
*********
***
***
***
***
***
**********
***********
************
**** ****
**** ****
**** ***
**** ***
**** ***
**** ***
**** ***
**** ****
**** ****
************
***********
**********
********
***********
************
**** ****
*** ****
**** ***
**************
**************
****
****
****
**** **
*************
************
**********
********
*********
*****
****
***
*************
*************
***
***
***
***
***
***
***
***
***
***
***
***
***
**********
***********
************
**** ****
**** ****
**** ***
**** ***
**** ***
**** ***
**** ***
**** ****
**** ****
************
***********
**********
***
****
* ****
**** *****
**********
*********
***
***
***
***
***
*** *******
***********
************
***** ****
**** ***
**** ***
**** ***
*** ***
*** ***
*** ***
*** ***
*** ***
*** ***
*** ***
*** ***
***
***
***
***
*******
*******
***
***
***
***
***
***
***
***
***
***
***
*************
*************
****
****
****
****
********
********
****
****
****
****
****
****
****
****
****
****
****
****
****
****
****
****
********
********
*******
***
***
***
***
***
*** ****
*** ****
*** ****
*** *****
********
*******
********
********
**** ****
*** *****
*** ****
*** ****
*** *****
*** *****
*** ****
*******
*******
***
***
***
***
***
***
***
***
***
***
***
***
***
***
***
********
********
*******
*************
**************
**************
*** **** ***
*** *** ***
*** *** ***
*** *** ***
*** *** ***
*** *** ***
*** *** ***
*** *** ***
*** *** ***
*** *** ***
*** *** ***
*** *** ***
*** *******
***********
************
***** ****
**** ***
**** ***
**** ***
*** ***
*** ***
*** ***
*** ***
*** ***
*** ***
*** ***
*** ***
********
**********
************
**** ****
*** ****
**** ****
**** ****
**** ****
**** ****
**** ****
*** ****
**** ****
************
**********
********
*** ******
***********
************
***** *****
**** ****
**** ****
*** ***
*** ***
*** ***
**** ****
**** ****
***** *****
************
************
*** ******
***
***
***
***
***
***
**********
***********
************
**** ****
*** ****
**** ***
**** ***
**** ***
**** ***
**** ***
*** ****
**** ****
************
***********
**********
***
***
***
***
***
***
***********
***********
***********
****** *
*****
****
****
****
****
****
****
****
****
****
****
* *********
* **********
* **********
* **** *
****
*****
*********
*********
********
****
***
** ****
************
***********
**********
****
****
****
****
*************
*************
****
****
****
****
****
****
****
****
****
****
*****
********
*******
*** ***
*** ***
*** ***
*** ***
*** ***
*** ***
*** ***
*** ***
*** ***
**** ***
**** ****
**** ****
***********
***********
**********
**** ***
**** ****
*** ****
**** ***
**** ****
*** ****
**** ***
**** ****
*** ****
**** ***
********
*******
******
******
****
*** **
*** **
*** **
**** **
**** **** ***
*** **** ***
*** **** ***
**** ***** ***
**************
*************
****** *****
***** *****
***** *****
**** *****
**** ***
****** ****
* **** ****
* **** *****
* ***** ****
* ********
* ******
*****
****
******
********
*********
**** ****
**** ****
***** ****
**** ****
**** ***
**** ****
*** ****
**** ****
**** ****
**** ****
**** ***
*** ****
**** ****
**** ***
*******
*******
******
*****
* ****
****
****
****
*****
******
******
* ***********
***********
****
*****
*****
****
****
****
*****
*****
****
****
****
************
************
*******
*******
********
* ***
* ***
*******
********
********
***** **
*** ***
*** ***
*********
********
********
BUILD SUCCESSFUL (total time: 1 second)
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=2202367
本文转自
http://blog.csdn.net/DL88250/archive/2008/03/21/2202367.aspx
摘要图像识别是目前很热门的研究领域,涉及的知识很广,包括信息论、模式识别、模糊数学、图像编码、内容分类等等。本文仅对使用Java实现了一个简单的图像文本二值处理,关于识别并未实现。
步骤
建立文本字符模板二值矩阵
对测试字符进行二值矩阵化处理
代码
/*
* @(#)StdModelRepository.java
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Library General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
package cn.edu.ynu.sei.recognition.util;import java.awt.Image;import java.awt.image.BufferedImage;import java.io.File;import java.io.IOException;import java.util.ArrayList;import java.util.List;import java.util.logging.Level;import java.util.logging.Logger;import javax.imageio.ImageIO;/** * Hold character charImgs as standard model repository.
* @author 88250
* @version 1.0.0.0, Mar 20, 2008
*/
public class StdModelRepository {
/** * hold character images
*/ List charImgs = new ArrayList ();
/** * default width of a character
*/ static int width = 16 /** * default height of a character
*/ static int height = 28 /** * standard character model matrix
*/ public int[][][] stdCharMatrix = new int[27][width][height];
/** * Default constructor.
*/ public StdModelRepository() {
BufferedImage lowercase = null try {
lowercase = ImageIO.read(new File("lowercase.png"));
} catch (IOException ex) {
Logger.getLogger(StdModelRepository.class.getName()).
log(Level.SEVERE, null, ex);
}
for (int i = 0 i < 26 i++) {
charImgs.add(lowercase.getSubimage(i * width,
0,
width,
height));
}
for (int i = 0 i < charImgs.size(); i++) {
Image image = charImgs.get(i);
int[] pixels = ImageUtils.getPixels(image,
image.getWidth(null),
image.getHeight(null));
stdCharMatrix[i] = ImageUtils.getSymbolMatrix(pixels, 0).clone();
ImageUtils.displayMatrix(stdCharMatrix[i]);
}
}
}
/*
* @(#)ImageUtils.java
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Library General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
package cn.edu.ynu.sei.recognition.util;import java.awt.Image;import java.awt.image.PixelGrabber;import java.util.logging.Level;import java.util.logging.Logger;/** * Mainipulation of image data.
* @author 88250
* @version 1.0.0.3, Mar 20, 2008
*/
public class ImageUtils {
/** * Return all of the pixel values of sepecified
.> * @param image the sepecified image
* @param width width of the
image
* @param height height of the
image
* @return */ public static int[] getPixels(Image image, int width, int height) {
int[] pixels = new int[width * height];
try {
new PixelGrabber(image, 0, 0, width, height, pixels, 0, width).grabPixels();
} catch (InterruptedException ex) {
Logger.getLogger(ImageUtils.class.getName()).
log(Level.SEVERE, null, ex);
}
return pixels;
}
/** * Get a matrix that described the
pixels
.
*
* For example, the result of the matrix like this:
*
* 0000000000000000
* 0000000000000000
* 0001111111110000
* 0011111111111000
* 0011111111111100
* 0011000000011100
* 0000000000011100
* 0000111111111100
* 0011111111111100
* 0011111110011100
* 0111100000011100
* 0111100000011100
* 0111100000111100
* 0111100001111110
* 0011111111111100
* 0011111111111100
* 0001111111111100
* 0000000000000000
* 0000000000000000
*
* it describes the alphbet 'a'.
*
* @param pixels the pixel array
* @param sparseFactor sparse factor
* @return a matrix that describes a alphbet
*/ public static int[][] getSymbolMatrix(int[] pixels, int sparseFactor) {
final int width = StdModelRepository.width;
final int height = StdModelRepository.height;
int[][] ret = new int[width][height];
for (int i = 0 i < height; i++) {
for (int j = 0 j < width; j++) {
if (pixels[i * width + j] == -1) {
ret[j][i] = 0 } else {
ret[j][i] = 1 }
}
}
return ret;
}
/** * Print the
> * @param matrix the sepecified matrix data
*/ public static void displayMatrix(int[][] matrix) {
System.out.println("");
for (int i = 0 i < matrix[0].length; i++) {
for (int j = 0 j < matrix.length; j++) {
if (matrix[j][i] != 0) {
System.out.print("*");
} else {
System.out.print(" ");
}
}
System.out.println();
}
}
}
/*
* @(#)ImageTextRecognitor.java
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Library General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
package cn.edu.ynu.sei.recognition;import cn.edu.ynu.sei.recognition.util.StdModelRepository;import cn.edu.ynu.sei.recognition.util.ImageUtils;import java.awt.Image;import java.awt.image.BufferedImage;import java.io.File;import java.io.IOException;import java.util.logging.Level;import java.util.logging.Logger;import javax.imageio.ImageIO;/** * Demonstrate recognition characters from a image.
* @author 88250
* @version 1.0.0.2, Mar 20, 2008
*/
public class ImageTextRecognitor {
private final static long serialVersionUID = 1L private StdModelRepository smr = new StdModelRepository();
private BufferedImage bufferedImage;
/** * Default constructor.
*/ public ImageTextRecognitor() {
try {
bufferedImage = ImageIO.read(new File("a_yahei12.png"));
} catch (IOException ex) {
Logger.getLogger(StdModelRepository.class.getName()).
log(Level.SEVERE, null, ex);
}
}
/** * Return the matched character with sepecified image.
* @param symbolMatrix the matrix of sepecified image
* @return the character
*/ // TODO: the core algorithm
public char getMatchResult(int[][] symbolMatrix) {
char result = 0 int tmpEvaluation = 100 int evaluation = 0 return result;
}
/** * Main program entry.
* @param args should be
> */ public static void main(String[] args) {
ImageTextRecognitor irt = new ImageTextRecognitor();
BufferedImage bi = irt.bufferedImage;
Image img = bi.getScaledInstance(16, 28, BufferedImage.SCALE_FAST);
int[] testImgPixels = ImageUtils.getPixels(img, img.getWidth(null),
img.getHeight(null));
ImageUtils.displayMatrix(ImageUtils.getSymbolMatrix(testImgPixels, 2));
// irt.getMatchResult(ImageUtils.getPixels(bi,
// bi.getWidth(),
// bi.getHeight()));
}
}
测试
标准字符图像
测试字符图像
测试输出init:
deps-jar:
Compiling 2 source files to /home/daniel/Work/Sources/Java/ImageTextRecognition/build/classes
compile:
run:
*********
***********
************
** ***
***
**********
************
******* ***
**** ***
**** ***
**** ****
**** *****
************
************
***********
***
***
***
***
***
*** ******
************
************
***** *****
**** ****
**** ****
**** ***
*** ***
**** ***
**** ****
**** ****
***** *****
************
************
*** *******
*********
**********
***********
**** *
****
****
****
****
****
****
****
**** *
***********
**********
*********
***
***
***
***
***
**********
***********
************
**** ****
**** ****
**** ***
**** ***
**** ***
**** ***
**** ***
**** ****
**** ****
************
***********
**********
********
***********
************
**** ****
*** ****
**** ***
**************
**************
****
****
****
**** **
*************
************
**********
********
*********
*****
****
***
*************
*************
***
***
***
***
***
***
***
***
***
***
***
***
***
**********
***********
************
**** ****
**** ****
**** ***
**** ***
**** ***
**** ***
**** ***
**** ****
**** ****
************
***********
**********
***
****
* ****
**** *****
**********
*********
***
***
***
***
***
*** *******
***********
************
***** ****
**** ***
**** ***
**** ***
*** ***
*** ***
*** ***
*** ***
*** ***
*** ***
*** ***
*** ***
***
***
***
***
*******
*******
***
***
***
***
***
***
***
***
***
***
***
*************
*************
****
****
****
****
********
********
****
****
****
****
****
****
****
****
****
****
****
****
****
****
****
****
********
********
*******
***
***
***
***
***
*** ****
*** ****
*** ****
*** *****
********
*******
********
********
**** ****
*** *****
*** ****
*** ****
*** *****
*** *****
*** ****
*******
*******
***
***
***
***
***
***
***
***
***
***
***
***
***
***
***
********
********
*******
*************
**************
**************
*** **** ***
*** *** ***
*** *** ***
*** *** ***
*** *** ***
*** *** ***
*** *** ***
*** *** ***
*** *** ***
*** *** ***
*** *** ***
*** *** ***
*** *******
***********
************
***** ****
**** ***
**** ***
**** ***
*** ***
*** ***
*** ***
*** ***
*** ***
*** ***
*** ***
*** ***
********
**********
************
**** ****
*** ****
**** ****
**** ****
**** ****
**** ****
**** ****
*** ****
**** ****
************
**********
********
*** ******
***********
************
***** *****
**** ****
**** ****
*** ***
*** ***
*** ***
**** ****
**** ****
***** *****
************
************
*** ******
***
***
***
***
***
***
**********
***********
************
**** ****
*** ****
**** ***
**** ***
**** ***
**** ***
**** ***
*** ****
**** ****
************
***********
**********
***
***
***
***
***
***
***********
***********
***********
****** *
*****
****
****
****
****
****
****
****
****
****
****
* *********
* **********
* **********
* **** *
****
*****
*********
*********
********
****
***
** ****
************
***********
**********
****
****
****
****
*************
*************
****
****
****
****
****
****
****
****
****
****
*****
********
*******
*** ***
*** ***
*** ***
*** ***
*** ***
*** ***
*** ***
*** ***
*** ***
**** ***
**** ****
**** ****
***********
***********
**********
**** ***
**** ****
*** ****
**** ***
**** ****
*** ****
**** ***
**** ****
*** ****
**** ***
********
*******
******
******
****
*** **
*** **
*** **
**** **
**** **** ***
*** **** ***
*** **** ***
**** ***** ***
**************
*************
****** *****
***** *****
***** *****
**** *****
**** ***
****** ****
* **** ****
* **** *****
* ***** ****
* ********
* ******
*****
****
******
********
*********
**** ****
**** ****
***** ****
**** ****
**** ***
**** ****
*** ****
**** ****
**** ****
**** ****
**** ***
*** ****
**** ****
**** ***
*******
*******
******
*****
* ****
****
****
****
*****
******
******
* ***********
***********
****
*****
*****
****
****
****
*****
*****
****
****
****
************
************
*******
*******
********
* ***
* ***
*******
********
********
***** **
*** ***
*** ***
*********
********
********
BUILD SUCCESSFUL (total time: 1 second)
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=2202367
本文转自
http://blog.csdn.net/DL88250/archive/2008/03/21/2202367.aspx