Method for retrieval of arabic historical manuscripts

Information

  • Patent Grant
  • 9075846
  • Patent Number
    9,075,846
  • Date Filed
    Wednesday, December 12, 2012
    11 years ago
  • Date Issued
    Tuesday, July 7, 2015
    9 years ago
Abstract
The method for retrieval of Arabic historical manuscripts using Latent Semantic Indexing approaches the problem of manuscripts indexing and retrieval by automatic indexing of Arabic historical manuscripts through word spotting, using “Text Image” similarity of keywords. The similarity is computed using Latent Semantic Indexing (LSI). The method involves a manuscript page preprocessing step, a segmentation step, and a feature extraction step. Feature extraction utilizes a circular polar grid feature set. Once the salient features have been extracted, indexing of historical Arabic manuscripts using LSI is performed in support of content-based image retrieval (CBIR).
Description
BACKGROUND OF THE INVENTION

1. Field of the Invention


The present invention relates to content search and retrieval methods, and particularly to a method for retrieval of Arabic historical manuscripts that uses Latent Semantic Indexing.


2. Description of the Related Art


Typically, a Latent Semantic Indexing method (LSI) uses statistical techniques to model the way in which words are used in an overall collection of documents. In the resulting semantic space, a query can be similar to a document, even if they have no words in common. LSI is, thus, not dependent on any single word and might handle recognition errors robustly.


Large archives of historical Arabic manuscripts cannot be manually searched because of the difficulty of manual index construction, and also cannot be automatically searched, since they were stored in their original image forms. Optical character recognition (OCR) techniques are available, but due to the characteristics of the historical Arabic manuscripts and some content features, such as figures and drawings of manuscripts, OCR techniques may not yield satisfactory results due to feasibility issues. An alternative to OCR techniques involving a Contents-Based Image Retrieval (CBIR) system utilizing angular line feature extraction, concentric circle feature extraction, and similarity matching based on a variety of distance measures, as disclosed in S. A. Shahab et al., “Computer Aided Indexing of Historical Manuscripts”, Proceedings of the International Conference on Computer Graphics, Imaging and Visualisation (July 2006), which is hereby incorporated by reference in its entirety. However, there remains room for improvement in such a system.


Thus, a method for retrieval of Arabic historical manuscripts solving the aforementioned problems is desired.


SUMMARY OF THE INVENTION

The method for retrieval of Arabic historical manuscripts is an electronic method of retrieving manuscripts that approaches the problem of manuscript indexing and retrieval by automatic indexing of Arabic historical manuscripts through word spotting, using “Text Image” similarity of keywords. The similarity is computed using Latent Semantic Indexing.


These and other features of the present invention will become readily apparent upon further review of the following specification and drawings.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a flowchart of a content-based retrieval method used in a method for retrieval of Arabic historical manuscripts according to the present invention.



FIG. 2 is a diagram showing the component matrices of the SVD (singular value decomposition) of the content-based retrieval method of FIG. 1.



FIG. 3A is a diagram showing the term-by-document matrix of the content-based retrieval method of FIG. 1.



FIG. 3B is a plot showing normalized values of rectangular region features used in the content-based retrieval method of FIG. 1.



FIG. 3C is a bar graph showing the results of applying the values in FIG. 3B to rectangular region features in the content-based retrieval method of FIG. 1.



FIG. 4 is a diagram showing the steps in converting RGB (color) images to binary (black and white) representations of the images in the content-based retrieval method of FIG. 1.



FIG. 5 is a diagram showing the RGB to grayscale conversion step in the content-based retrieval method of FIG. 1.



FIG. 6 is a diagram showing the grayscale to binary conversion step in the content-based retrieval method of FIG. 1.



FIG. 7 is a diagram of a grid showing the current pixel and nearest neighbors used in the content-based retrieval method of FIG. 1.



FIG. 8 is a diagram showing the results of the smoothing and noise removal steps in the content-based retrieval method of FIG. 1.



FIG. 9 is a diagram showing the baseline detection of manuscript rows in the content-based retrieval method of FIG. 1.



FIG. 10 is a diagram showing the 4-connected components of an exemplary word processed by the content-based retrieval method of FIG. 1.



FIG. 11 is a diagram showing an exemplary 8-connected pixel used by the content-based retrieval method of FIG. 1.



FIG. 12 is a diagram showing an exemplary pixel and 4 neighbors according to the content-based retrieval method of FIG. 1.



FIG. 13 is a diagram showing an exemplary pixel and diagonal neighbors according to the content-based retrieval method of FIG. 1.



FIG. 14 is a diagram showing an exemplary pixel and 8-connected neighbors according to the content-based retrieval method of FIG. 1.



FIG. 15 is a diagram showing 8-connected foreground pixels according to the content-based retrieval method of FIG. 1.



FIG. 16 is a diagram showing 4 concentric circles drawn around a text symbol according the content-based retrieval method of FIG. 1.



FIG. 17 is a diagram showing 8 angular line features of a text symbol according to the content-based retrieval method of FIG. 1.



FIG. 18 is a diagram showing 9 rectangular regions over a text symbol according to the content-based retrieval method of FIG. 1.



FIG. 19 is a diagram showing 32 circular polar grid features of a text symbol according to the content-based retrieval method of FIG. 1.



FIG. 20 is a diagram showing experimental results of a query search for a particular Arabic word using circular polar grid features of a text symbol according to the content-based retrieval method of FIG. 1.



FIG. 21 is a diagram showing discarded words from the query of FIG. 20 using circular polar grid features for the text symbol according to the content-based retrieval method of FIG. 1.



FIG. 22 is a diagram showing experimental results of another query search for a particular Arabic word using circular polar grid features of a text symbol according to the content-based retrieval method of FIG. 1.



FIG. 23 is a diagram showing discarded words from the query of FIG. 22 using circular polar grid features for the text symbol according to the content-based retrieval method of FIG. 1.



FIG. 24 is a diagram showing experimental results of a third query search for a particular Arabic word using circular polar grid features of a text symbol according to the content-based retrieval method of FIG. 1.



FIG. 25 is a diagram showing discarded words from the query of FIG. 24 using circular polar grid features for the text symbol according to the content-based retrieval method of FIG. 1.



FIG. 26 is a diagram showing experimental results of a fourth query search for a particular Arabic word using circular polar grid features of a text symbol according to the content-based retrieval method of FIG. 1.



FIG. 27 is a diagram showing discarded words from the query of FIG. 26 using circular polar grid features for the text symbol according to the content-based retrieval method of FIG. 1.



FIG. 28A is a diagram showing Circular Polar grid features for a fifth query search for a particular Arabic word using circular polar grid features of a text symbol according to the content-based retrieval method of FIG. 1.



FIG. 28B is a diagram showing concentric circle features for the fifth query search of FIG. 28A.



FIG. 28C is a diagram showing angular line features for the fifth query search of FIG. 28A.



FIG. 28D is a diagram showing rectangular region features for the fifth query search of FIG. 28A.



FIG. 29A is a diagram showing Circular Polar grid features for a sixth query search for a particular Arabic word using circular polar grid features of a text symbol according to the content-based retrieval method of FIG. 1.



FIG. 29B is a diagram showing concentric circle features for the sixth query search of FIG. 29A.



FIG. 29C is a diagram showing angular line features for the sixth query search of FIG. 29A.



FIG. 29D is a diagram showing rectangular region features for the sixth query search of FIG. 29A.



FIG. 30A is an average precision plot of normalized feature values for one-connected components according to the content-based retrieval method of FIG. 1.



FIG. 30B is an average precision plot of normalized feature values for 2-connected components according to the content-based retrieval method of FIG. 1.



FIG. 30C is an average precision plot of normalized feature values for 3-connected components according to the content-based retrieval method of FIG. 1.



FIG. 30D is an average precision plot of normalized feature values for 4-connected components according to the content-based retrieval method of FIG. 1.



FIG. 31A is an average precision plot of feature occurrence values for one-connected components according to the content-based retrieval method of FIG. 1.



FIG. 31B is an average precision plot of feature occurrence values for 2-connected components according to the content-based retrieval method of FIG. 1.



FIG. 31C is an average precision plot of feature occurrence values for 3-connected components according to the content-based retrieval method of FIG. 1.



FIG. 31D is an average precision plot of feature occurrence values for 4-connected components according to the content-based retrieval method of FIG. 1.



FIG. 32A is an average precision plot of term weighing feature values for one-connected components according to the content-based retrieval method of FIG. 1.



FIG. 32B is an average precision plot of term weighing feature values for 2-connected components according to the content-based retrieval method of FIG. 1.



FIG. 32C is an average precision plot of term weighing feature values for 3-connected components according to the content-based retrieval method of FIG. 1.



FIG. 32D is an average precision plot of term weighing feature values for 4-connected components according to the content-based retrieval method of FIG. 1.



FIG. 33A is an average precision plot of different feature types of circular polar grid features for one-connected components according to the content-based retrieval method of FIG. 1.



FIG. 33B is an average precision plot of different feature types of circular polar grid features for 2-connected components according to the content-based retrieval method of FIG. 1.



FIG. 33C is an average precision plot of different feature types of circular polar grid features for 3-connected components according to the content-based retrieval method of FIG. 1.



FIG. 33D is an average precision plot of different feature types of circular polar grid features for 4-connected components according to the content-based retrieval method of FIG. 1.



FIG. 34 is a diagram showing experimental results of a query search for a particular Arabic word using circular polar grid features of a text symbol according to the content-based retrieval method of FIG. 1.



FIG. 35 is a diagram showing discarded words from the query of FIG. 34 using circular polar grid features for the text symbol according to the content-based retrieval method of FIG. 1.



FIG. 36 shows a comparison plot of the content-based retrieval method of FIG. 1 vs. a method of the prior art.





Similar reference characters denote corresponding features consistently throughout the attached drawings.


DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS

As shown in FIG. 1, the method for retrieval of Arabic historical manuscripts using Latent Semantic Indexing 100 includes an off-line process 115a and an on-line process 115b. Latent Semantic Indexing (LSI) is used as a vector space, and the map from term space to concept space is obtained via singular value decomposition (SVD) by retaining the largest singular values. The LSI method is a main process, which is used as a mathematical model for word and subword recognition. The present method performs LSI on documents and terms that are handwritten images. The indexing method 100 approaches the problem of manuscript indexing and retrieval by automatic indexing of Arabic historical manuscripts through word spotting, using “Text Image” similarity of keywords. The similarity is computed using Latent Semantic Indexing (LSI). The method involves a manuscript's pages preprocessing step, a segmentation step, and a feature extraction step. Feature extraction utilizes a novel circular polar grid feature set. Once the salient features have been extracted, indexing of historical Arabic manuscripts using LSI is performed in support of content-based image retrieval (CBIR). CBIR is preferred over OCR because character-by-character word recognition usually fails in this instance due to faded ink, stained and lacerated paper, perforated paper and scribbles. CBIR uses low-level features (e.g. color, shape and texture) to index and retrieve images from databases without regard to accompanying textual information.


At the outset, it should be understood by one of ordinary skill in the art that embodiments of the present method can comprise software or firmware code executing on a computer, a microcontroller, a microprocessor, or a DSP processor; state machines implemented in application specific or programmable logic; or numerous other forms without departing from the spirit and scope of the invention. The present method can be provided as a computer program, which includes a non-transitory machine-readable medium having stored thereon instructions that can be used to program a computer (or other electronic devices) to perform a process according to the method. The machine-readable medium can include, but is not limited to, floppy diskettes, optical disks, CD-ROMs, and magneto-optical disks, ROMs, RAMs, EPROMs, EEPROMs, magnetic or optical cards, flash memory, or other type of media or machine-readable medium suitable for storing electronic instructions.


The main reason for employing Latent Semantic Indexing (LSI) is its ability to carry out similarity matches using thresholds that are largely independent from the underlying features used. This is important in Arabic manuscripts due to the complexity of the script. For example, the Arabic language has 28 letters, and more than half of them can assume four different shapes depending on their position (i.e. initial, medial, final, or isolated) within the word. For example, the letter “seen” (custom character) (the name of the letter does not transliterate literally into English; it is translated phonetically, and is also known as siin and sīn takes the following forms: (custom character) at the beginning of the word, (custom character) in the middle of the word, (custom character) at the end of the word and (custom character) as an isolated letter. Moreover, a word may consist of one or more subwords. This adds another difficulty to the recognition process. For example, the word (custom character) which means university, consists of two parts (custom character) and (custom character). Some letters have the same bodies with different dot positions, as in “ba” (custom character) “ta” (custom character) and “tha” (custom character). Combinations of some letters may form a new shape, which is a vertical stacking of two or more characters. For example, the word (custom character) consists of the letter (custom character) and the letter (custom character), which are very difficult to separate. Writers prolong letters for decorative reasons or for justifying text. These prolongings can cause vertical overlaps with neighboring letters. Some of the resulting difficulties are: two different words have been written in such a way, i.e., by prolonging letters, as to be impossible to segment; overlapping of two letters; combinations of some characters form new shapes that are vertical stockings of two letters; different letters with the same shapes, but the use of dots in relation to the letters distinguish them; two different shapes that depend on the position of the letter within a word; and last, a word consisting of three subwords.


In Arabic literature and books, including Arabic manuscripts, there are distinct words and phrases called keywords, which can be used to make a specialized search on a topic or a specific paragraph. What distinguishes these keywords is that they are frequently repeated in the pages of a book, and a particular topic may be searched or inferred through these keywords. For example, in the books of prophetic tradition (custom character), a tradition text may be searched using a few words, including the names of the narrators of the tradition, such as Abu Huraira (custom character), or the names of the collectors of these traditions, such as Al-Bukhaari (custom character) and Muslim (custom character). Moreover, most of the texts of the traditions begin with the words: The Messenger of Allah peace be upon him, said (custom charactercustom character), and ends with the name of the narrator. Hence, the beginnings of the tradition texts and their endings can be searched. In the field of Arabic literature and poetry, specific verses by Al-Mutannabi (custom character) (an Arab poet) can be searched just by searching the word (custom character). Moreover, praise (custom character), satire (custom character), or pride (custom character) poetry can be searched using expressions related to them. As for Arabic Grammar books, there are words, such as verb (custom character), subject (custom character), noun (custom character), and adjective (custom character), that show the function and the structure of the Arabic sentence. As for the books of jurisprudence and legal transactions, we find such words as duties (custom character) provisions (custom character), hated) (custom character), and desirable (custom character), which can be used to search terms and provisions of a particular topic. For example, some terms and conditions of prayer may be searched by searching the word prayer (custom character), or to be more specific, by searching for such words as provisions of prayer (custom character) On the other hand, ablution subject and its terms can be searched through the expression purity chapter (custom character).


The Latent Semantic Indexing (LSI) model is used to exploit geometric relationships between document and term vectors in order to explain both similarities and differences. LSI attempts to project very high dimensional document and query vectors into a low dimensional space. This uses a singular value decomposition (SVD) of the term-by-document matrix.


The singular value decomposition (SVD) of any matrix Am×n of rank r≦q min(m,n), denoted by SVD(A), is defined as:

A=UΣVT  (1)

where Um×m and Vn×n are orthogonal matrices, and Σm×n is a diagonal matrix.


The first r columns of U and V are called the left and right singular vectors, respectively. The elements σi of Σ are the nonnegative square roots of the n eigenvalues of AAT or VAT.


In other words, U is the m×m orthogonal matrix whose columns define the left singular vectors of A, V is the n×n orthogonal matrix whose columns define the right singular vectors of A, and Σ is the m×n diagonal matrix containing the singular values σ1≧σ2≧ . . . ≧σmin(m,n) of A in order along its diagonal. The SVD component matrices 200 are illustrated in FIG. 2. The following theorem is used to construct an approximation of A and estimate its quality. Let the SVD of A be given by the definition characterized by equation (1) with σ12> . . . >σr+1= . . . σq=0, and define the truncated SVD approximation Ak of A as:











A
k

=





i
=
1

k




u
i

·

σ
i

·

v
i
T



=


U
k





k



V
k
T










then




(
2
)








rank


(
B
)


min

=


k





A
-
B



F
2


=




A
-

A
k




=




i
=

k
+
1


q



σ
i
2








(
3
)







Thus, the best rank k approximation of A with respect to the Frobenius norm is as defined by equation (2).


In text retrieval (TR), a document collection comprised of n documents that are indexed by m terms can be represented as an m×n term-by-document matrix A, where n columns represent the n documents and m rows represent the m terms. Thus, the matrix element is a weighted frequency at which term i occurs in document j. In the present method, all subword images and their feature values are used as a document collection. Thus, n columns represent the images, and m rows represent the feature values.


With respect to LSI in image retrieval, two challenges have emerged: (1) what are the documents, and (2) what are the terms. In the instant method, the documents and the terms that are used in TR are replaced by subword images and feature values, respectively. Thus, the columns of the term-by-document matrix will represent subword images and the rows represent feature values. FIG. 3A shows how an 8×3 term-by-document matrix 300a is constructed from a small collection of subwords of the image of the word “prophet” (custom character). Angular line features and subword images were chosen as terms and columns, respectively, for indexing purposes. Another problem arose related to the feature value itself. In applying LSI to TR, the occurrence of the terms is easy to imagine and compute. In contrast, the notion of occurrence is even harder to imagine for image features that have numeric values, i.e., counter of black pixels within an area. To address this problem, the concept of feature occurrences is applied. Different combinations of feature sets are tested in order to determine the suitable number of features that make LSI perform with satisfactory results.


Feature normalization techniques aim at normalized extracted features in such a way that the normalized features are better suited for classification. For example, normalized features are suitable for a word written in different sizes. A simple technique used to carry out the features normalization includes counting the number of black pixels within a given area and dividing the area black pixel count by the count of all black pixels within the word image. We apply these steps for all regions within a given word image. Table 1 depicts these normalized features.









TABLE 1







Normalized Features











Feature types
f1
f2
f3
f4





Features Counter
237    
902    
795    
556    


Normalized
0.0949
0.3609
0.3179
0.2234


Features









The major problem of applying LSI to image retrieval is that terms must be replaced by image features. In image feature values, there is no existence of occurrence, thus, we have to convert these feature values into feature occurrences. In order to do that, we apply the following algorithm, shown in Table 2.









TABLE 2







Feature Value Conversion Algorithm








STEP
ACTION





1
Pick a comprehensive training set of a document for each feature.


2
Compute the mean μf and the standard deviation σf of the features



f 's value across the training set.


3
For each image in the collection define the “occurrence count” Ofj



of feature f as:














Ofj={valfj-μfσfifvalfj>μf0otherwise

(4)










In Table 2, valfj is the value, of the feature f in image j. Table 3 includes these feature occurrence values of the rectangular region features for a given word. Plot 300b of FIG. 3B and bar graph 300c of FIG. 3C illustrate this idea.









TABLE 3







Feature Occurrences of the Normalized


Rectangular Region Features















f1
f2
f3
f4
f5
f6
f7
f8
f9





0
0
2
0
2
1
2
0
0









The goal of term weighting is to condition the data in order to improve retrieval performance. Conditioning data will describe the relative frequency (i.e., the importance) of a term i in a document j, which is called local weighting lij, and within the entire collection of documents, which is called global weighting gi. Recall that a collection of n documents indexed by m terms can be represented as term-by-document matrix A=[ais], where each element is defined as:

aij=lijgt  (5)


There are many local functions and global functions that can be used to compute term weighting. Many empirical studies report that Log Entropy weighting works well with many data sets. Thus, each entry aij of A is computed as:

aij=gi log(fij+1)  (6)

where fij is the frequency that term i appears in document j, while gi can be computed as:











g
i

=

1
+



j





p
ij



log


(

p
ij

)




log





n










where




(
7
)







p
ij

=


f
ij




j



f
ij







(
8
)







Query matching in the vector space model can be viewed as a search in the column space of the matrix A or can be formulated using the component matrices of the SVD. Suppose we have a query vector q and n columns of the reduced-rank matrix Ak. The trigonometric function cos θ can be used as a distance measure to retrieve a relevant document. Computations of this measure are as follows:










cos






θ
j


=





(


A
k



e
j


)

T


q







A
k



e
j




2





q


2



=




(


U
k





k




V
k
T



e
j




)

T


q







U
k





k




V
k
T



e
j






2





q


2








(
9
)








for j=1, 2, . . . , n.


For the scaled document vector sjkVkTej, the formula in equation (9) can be simplified to:











cos






θ
j


=



s
j
T



(


U
k
T


q

)







s
j



2





q


2




,


for





j

=
1

,
2
,





,

n
.





(
10
)







In the present method, a user can specify a query word, and the system will search and retrieve occurrences of the query word found in the database. All of the retrieved words will be presented to the user to select the relevant words. Moreover, the searching process will have several options (e.g. controlling threshold values, selecting feature types, and selecting the feature set). The present method utilizes five main modules, which include an image pre-processing module, an image segmentation module, a feature extraction module, an LSI index construction module, and a query matching module. Each one of these modules includes several tasks, detailed in the flowchart 100 shown in FIG. 1.


In the preprocessing stage 115a, necessary operations carried out on manuscript images in order to represent them in a way that can be measured for enhancing the efficiency of the developed system include binarization, noise removal and smoothing. These processes increase the efficiency of later processes, such as segmentation and retrieval. Since processes for converting color images to binary (or black and white) images and for noise removal and smoothing are conventional, this step may be viewed as optional, so that the method operates on manuscript images that have already been converted to black and white images and processed for noise removal and smoothing.


Most features used in the developed system depend entirely on the count of black pixels within an area. Thus, binary images (i.e., black and white images) as a source of features are a suitable choice in the present method. Many Arabic manuscripts that were stored as images are colored images. Converting these colored images into binary images, i.e., binarization, is done by converting RGB color space to a gray-scale image, and then converting a gray-scale image to a binary image. As shown in FIG. 4, an RGB image 402 undergoes RGB-to-grayscale conversion 403, producing a grayscale image 404, which undergoes grayscale-to-binary conversion 405 to produce a binary image 406. The aim of these conversions is to simplify the amount of information in the colored images. Although a binary image contains less information than a colored image, the majority of important, feature-related information is maintained, such as regions, black and white pixels, connected parts, and so on.


An image can be converted from RGB color space to a grayscale image using a simple transformation by eliminating the hue and saturation information related to a pixel, while retaining the luminance of a pixel. This conversion is implemented by using the following transformation:











I
grayscale



(

n
,
m

)


=


α







I
color



(

n
,
m
,
R

)



+

β







I
color



(

n
,
m
,
G

)



+

γ







I
color



(

n
,
m
,
B

)








(
11
)








where Igrayscale is a gray-scale image, Icolor is a RGB color image, (n,m) are the coordinates of an individual pixel within a grayscale image or a color image. The symbols R, G, and B are color channels for red, green and blue colors respectively. In other words, the gray-scale image is a weighted sum of the red, green and blue color channels. While α=0.2989, β=0.5870 and y=0.1140 represent the weighting coefficients, the intensity level of the image pixels ranges from 0 to 255, where 0 value represents a black pixel and 255 represents a white pixel. FIG. 5 shows a gold RGB image 502a, and the conversion resulting in a gray-scale image 502b.


The binarization process replaces all pixels in the input image, i.e., the gray-scale image, with luminance greater than an intensity threshold with the value 1 (white pixels) and replaces all other pixels with the value 0 (black pixel). The following equation can be applied in order to create a binary image from a gray-scale image.











I
binary



(

n
,
m

)


=

{



1




if







I
grayscale



(

n
,
m

)



>
T





0


otherwise








(
12
)








where T is the intensity threshold, Igrayscale is a grayscale image, Ibinary is a binary image, and (n,m) are the coordinates of an individual pixel within a gray-scale image and a binary image.



FIG. 6 depicts a grayscale image 502b and its subsequent conversion to a binary image 602. The intensity threshold of the grayscale image must be computed. This threshold is computed automatically, which is suitable for the present method because many processing tasks require full automation. The common method to compute it automatically is from a gray level histogram, as is known by artisans having ordinary skill. This method selects the threshold that results in the tightest clustering of the two groups represented by the foreground and background pixels.


The smoothing module is used for blurring and noise reduction. These two operations are used in removal of small objects that are not part of the text or are irrelevant areas of images. In order to remove these irrelevant pixels and fill the gap between connected components, a commonly known smoothing algorithm based on a statistical decision criterion is employed. Given a binary image of an Arabic subword, the algorithm modifies each pixel according to its initial value and those of its neighbors. The rules are stated as follows:


If P0=0, then:










0

=

{




0




if









i
=
1

8



P
i



>
T





1


otherwise








else






(
13
)







0

=

{



1






if






p
i


+

p

i
+
1



=


2





for





at





least





one





i

=
1


,
2
,





,
8





0


otherwise








(
14
)








where P0 is the current pixel value, P0 the new pixel value, and T is the threshold. According to the prior art, an experimentally determined threshold of 5 yields acceptable results. The current pixel and its neighbors 700 are shown in FIG. 7, while FIG. 8 shows a noisy image 800a and the smoothed and noise removed image 800b.


The objective of the segmentation process is to segment all of the manuscript pages, i.e. images, into connected components (i.e. words/subwords). In order to achieve this objective, a first module segments the whole text within a page into lines, and a second module segments the lines of the first module into connected components.


To segment a manuscript image into line images, we depend on a well-defined method that enables us to detect a baseline of the Arabic scripts. Arabic baseline is very important in our developed system because it is used to estimate the location of peaks and to indicate the number of lines within a page in order to segment the whole page to lines. There are several methods, such as horizontal projection, word skeleton, and word counter representation, used in detecting baseline. The present method implements a process that is based on horizontal projection.


The horizontal projection method to detect the Arabic baseline works by reducing the two dimensional (2D) of data to one dimension (1D) based on the pixels of the subword image, and the longest link that will implement in a straight line will be the Arabic text baseline. FIG. 9 visualizes the horizontal projection method for detecting the Arabic baseline. An Arabic manuscript binary image 902 is processed to provide a horizontal projection 904 of the image 90, which includes the first line's baseline 906. We compute the horizontal projection profile by using the following equation:

Pi=ΣImg(i,j)  (15)

where P(i,j) is the horizontal projection of the image for row i, and Img(i,j) is the pixel value at (i,j).


In the Segmentation of Line Images to Subword Images procedure, a line image is segmented to connected-component images by applying a known connected component algorithm. Additionally, each subword is tagged with specific information, such as page number and line number for storage and retrieval purposes.


Concepts of connected component labeling are used to detect connected regions, i.e., connected parts of the subword images within a segmented line. A connected region consists of any group of connected pixels. For example, as shown in FIG. 10, the Arabic word (custom character), which means prophet, has four connected parts: (c1) 1010a, (c2) 1010b, (c3) 1010c, and (c4) 1010d. The 4-connection and 8-connection are commonly used definitions of connection between pixels. Here, we are interested in 8-connection, which is defined as: if a given foreground pixel has at least one neighboring foreground pixel to the north, south, east, west, north-east, north-west, south-east or south-west of itself, then this neighboring foreground pixel can be considered as part of the same object. These simple concepts are illustrated in pixel drawing 1100 of FIG. 11.


Prior art researchers have defined mathematical representation of the concepts of connection components as follows:


A pixel p at coordinates (x,y) has two horizontal and two vertical neighbors, whose coordinates are (x+1, y), (x−1, y), (x,y+1) and (x,y−1). This set of 4-neighbors 1200 of p, denoted N4(p), is shown in FIG. 12. The four diagonal neighbors of p have coordinates (x+1, y+1) (x+1, y−1), (x−1, y+1) and (x−1, y−1). FIG. 13 shows these neighbors 1300, which are denoted ND(p). The union 1400 of N4(p) and ND(p), shown in FIG. 14, results in the 8-neighbors of p, denoted N8(p). Two pixels p and q are said to be 8-adjacent if qεN8(p). FIG. 15 shows a small region 1500 that is extracted from a binary line image.


With respect to feature extraction, the objective is to extract the essential attributes that describe each word/subword resulting from the segmentation process. Generally, feature extraction is considered as a difficult problem in pattern recognition systems. This difficulty lies in what are the proper features to be extracted. The present method uses four sets of low-level features, including: (1) Concentric circle features, (2) angular line features, (3) rectangular region features, and (4) circular polar grid features. These features are represented as numerical values in order to construct LSI indexing and to carry out efficient searching and retrieval.


Four concentric circle features are computed by counting the number of black pixels contained between concentric circles centered at the centroid with radius 1×r, 2×r, . . . , (n−1)×r, n×r, where n is the number of concentric circles. Then, the values are normalized by dividing the count of black pixels within each region by the count of black pixels within the subword image. In practice, these features are computed using the following steps.


The first step computes the centroid of the image according to the image centroid computation algorithm outlined in Table 4.









TABLE 4





Image Centroid Computation (Algorithm 1)


ACTION

















Input: Image



Output: Centroid of an image ( )









Read Image I



for r←0 to I.allRows−1



 for c←0 to I.allCols−1



  if I(r,c)=BlackPixel



   xCtr.row ← xctr.row + (I.allRows−1) − r



   yCtr.col ← yctr.col + c



   area ← area + 1



  end if



 end for



end for



xCtr← xCtr / area



yCtr← yCtr / area



Ctr(xCtr,yCtr)










Second, the distance between the centroid and the original pixel Org(0,0) is computed using the following equation:

Dis=√{square root over (xCtr2+yCtr2)}  (16)


Third, the radius of the concentric circles is calculated using the equation:










r
i

=


Dis
n

×
i





(
17
)








where i=1, 2, . . . , n and n is the number of concentric circles.


Fourth, the black pixel count computation within concentric circles algorithm is performed as outlined in Table 5.









TABLE 5





Concentric Circles Black Pixel Count Computation (Algorithm 2)


ACTION















  Input: Ctr(xCtr,yCtr), r[1: n], n


  Output: Count of black pixels, count[1:4], within concentric circles


count[1:4] ← 0


for each pixel p(x,y) in image I


 if {square root over ((x − xCtr)2 + (y − yCtr)2 < r1)}{square root over ((x − xCtr)2 + (y − yCtr)2 < r1)}


  count(1) ← count(1) + 1


 end if


 for i←1 to n−1


  if ri ≦ {square root over ((x − xCtr)2 + (y − yCtr)2 < ri+1)}{square root over ((x − xCtr)2 + (y − yCtr)2 < ri+1)}


   count(i+1) ← count(i+1) + 1


  end if


 end for


end for









Fifth, the normalized values of the concentric circle features are computed using the following equation:









NorConC
=


count
i




i
n



count
i







(
18
)








where i=1, 2, . . . n and n is the number of concentric circles.









TABLE 6







Concentric Feature Values












f1
f2
f3
f4







0.0949
0.3609
0.3179
0.2234











FIG. 16 depicts the concentric circle features 1600 while Table 6 includes these normalized features.


Angular line features are computed by counting the number of black pixels in degree slices centered at the centroid of the subword image with respect to the horizontal axis. As a result of this slicing, there are eight features. Then, these values are normalized by the total number of black pixels of the image. FIG. 17 depicts these angular line features 1700 of a given word, while Table 7 includes the eight feature values of that word.









TABLE 7







Angular Line Feature Values














f1
f2
f3
f4
f5
f6
f7
f8





0.36688
0.001843
0.00553
0.11225
0.344551
0.006452
0.00443
0.160012









The following steps are used to extract a feature set that belongs to the region f1.


First, the centroid, Ctr(xCtr,yCtr), of the image is computed by the present method, which uses algorithm 1.


Second, the present method computes the slope of two lines, m, at θ=0°, 45°, respectively, and centered at centroid, Ctr(x,y), using the following equation:

m=tan(θ)  (19)


Third, the following equation is used for a given line:

y=mx+b  (20)

Thus, there are two equations that result from plugging the two different slopes in the above equation:

y1=m1x+b1  (21)
y2=m2x+b2  (22)


Fourth, the present method uses the fact that each line passes through the centroid (xCtr,yCtr) to compute the Y-intercept by using the following equation:










b
i

=


xCtr
-
yCtr


m
i






(
23
)







where i is the line number.


Finally, the present method performs a computation that finds yi and y2 by plugging the X-coordinate of each black pixel in the equation of lines defined in equation (21). If y1<y≦y2 then, this pixel belongs to the region 1. Practically, the present method computes the count of black pixels within the two angular lines with slope 0 and slope 1 by applying the developed Algorithm 3 detailed in Table 8.









TABLE 8





Computing the Number of Black Pixels Within


the Two Angular Lines (Algorithm 3)


ACTION

















Input: Image I, Ctr(xCtr,yCtr)



Output: Count of black pixels



m1← tan(0)



m2← tan(45)











b
1

=


xCtr
-
yCtr


m
1

















b
2

=


xCtr
-
yCtr


m
2












for each pixel p(x,y) in image I



 y1 = m1x + b1



 y2 = m2x + b2



 if y1 < y ≦ y2



  count(1) ← count(1) + 1



 end if



end for









The rectangular region features are nine feature values that result from dividing the image area into nine rectangular regions. The count of black pixels is then computed for each region. These values are normalized by the count of all black pixels of the image. Practically, the present method applies the following steps in order to compute these feature values.


First, the present method computes the dimensions, i.e., the height and the width for the rectangular areas:









RecRegW
=


Img
·
Width

3





(
24
)






RecRegH
=


Img
·
Height

3





(
25
)







Second, the sum of black pixels within each area is calculated using the following equation:

RecRegCntiip(x,y)  (26)

where i=1, 2, . . . n, n=9 is the number of rectangular regions, and p(x,y) is a black pixel.


Third, these feature values are normalized by dividing each rectangular region counter by the subword total black pixel count. FIG. 18 depicts these features 1800 while Table 9 shows the normalized values. For instance, to find the count of black pixels contained in the second rectangular region, the following algorithm detailed in Table 10 is applied.









TABLE 9







Rectangular Region Feature Values















f1
f2
f3
f4
f5
f6
f7
f8
f9





0
0
0.2005
0.0510
0.2682
0.2119
0.2392
0.0290
0
















TABLE 10





Computing the Number of Black Pixels


Within Rectangular Regions (Algorithm 4)


ACTION

















Input: Image I



Output: Count of black pixels, count[1:4]










RecRegW



Img
.




Width

3















RecRegH



Img
.




Width

3











count[1:4]←0



for each black pixel p(x,y) in image I



 if 1 ≦ x < RecRegH and RecRegW + 1 ≦ y < RecRegW × 2



  count(2) = count(2) + 1



 end if



end for









Circular polar grid features are thirty two values that are calculated by drawing four angular lines with equally-spaced angles i.e., 0°, 45°, 90°, and 135° with respect to the horizontal axis and four concentric circles with radius 1×r, 2×r, . . . , n×r, where n is the number of concentric circles centered at the image centroid. Then the count of black pixels within each region resulting from the intersection of the angular lines and the concentric circles is calculated. Finally, the normalized values of these features are computed by dividing each region's value counter by the total number of black pixels in the subword. In practice, algorithm 5 detailed in Table 11, is applied to calculate the total sum of black pixels within a region resulting from the intersection between the first and the second concentric circles and the two lines with slopes 0 and 1. FIG. 19 depicts these thirty two circular polar grid features 1900, while the normalized values of these features are shown in Table 12.









TABLE 11





Computing the Number of Black Pixels Within the First Sector


of Circular Polar Grids (Algorithm 5)


ACTION

















Input: Image I, Ctr(xCtr,yCtr), and r[1:2]



Output: Count of black pixels



m1← tan(0)



m2← tan(45)











b
1

=


xCtr
-
yCtr


m
1

















b
2

=


xCtr
-
yCtr


m
2












for each black pixel p(x,y) in image I



 y1 = m1x + b1



 y2 = m2x + b2



 if y1 < y ≦ y2



  if r2 ≦ {square root over ((x − xCtr)2 + (y − yCtr)2 < r2)}{square root over ((x − xCtr)2 + (y − yCtr)2 < r2)}



   count(1) ← count(1) + 1



  end if



 end if



end for
















TABLE 12







Some Circular Polar Grid Feature Values















f1
f2
f3
f4
f13
f14
f16
f31
f32





0.0754
0.1271
0.1356
0.1524
0.0823
0.1304
0.0687
0
0









In order to support several processes, such as the query matching process, the present method extracts or creates pieces of information about each subword/word. This information includes the width and the height of the subword image, the centroid, the location of the subword within the line, the page, the manuscript, and the BMP image.


Some of these features, e.g., centroids and dimensions, are used in the feature extraction process. Such information as dimensions, locations and BMP images is used for advanced purposes, such as clustering and displaying retrieved images as thumbnails.


The present Arabic historical manuscripts retrieval method is implemented in the MATLAB 2009b environment and provides a GUI-based, easy to use application. Users can perform several tasks, such as preprocessing steps, segmentation and feature extraction steps, and searching steps. Furthermore, Microsoft Excel is used for storage purposes.


Experimental work using the present method involved the use of two pre-scanned historical Arabic manuscripts. The title of the first one is “Sahih Al-Bukhari” (custom charactercustom character). We used 34 pages from the section of “Mawaqeet Al-Haj wa Al-Umra” (custom charactercustom character) of this manuscript. These pages were pre-processed, segmented into lines and words (i.e. connected component), and then the word features were extracted. The overall number of extracted words is about 5,500. The second manuscript is an old Arabic handwritten manuscript that was used in the above cited article by Shahab et al. This manuscript was used for comparison purposes.


We choose 20 words as query words. Some of these words, such as custom character, meaning pilgrimage, may be considered as keywords in order to search particular topics. Names of places and names of people are also selected to be query words. Moreover, phrases such as “peace be upon him” (custom character) and “be pleased with him” (custom character) are selected to issue queries in order to search prophetic traditions. On the other hand, all of these words consist of one-connected components, two-connected components, three-connected components or four-connected components.


The standard way to evaluate the performance of a system is to compute recall and precision. Recall is measured as the ratio of the number of relevant documents retrieved to the total number of relevant documents that exist in the collection. In other words, recall is a measure of the accuracy of the retrieval. In contrast, precision is measured as the ratio of the number of relevant documents retrieved to the total number of documents retrieved. This is a measure of the completeness of the retrieval. Computations of these measures are as follows.









Recall
=


Relevant





Images





Retrieved


Total





Relevant





Images





Present






(
27
)






Precision
=


Relevant





Images





Retrieved


Total





Images





Retrieved






(
28
)







Each one of the four different features used has three different calculated values. The first value is the normalized features, the second value is feature occurrence values, and the third value is term weighting features. Also, we group our query words depending on the number of connected components. Thus, we have 12 feature sets that should be tested on each query word. The goal of the tests is to indicate which feature sets and feature value types will be most useful in indexing and retrieval of manuscripts. The main results from these tests are shown in Table 13, while FIG. 20 results 2000, FIG. 22 results 2200, FIG. 24 results 2400 and FIG. 26 results 2600 show some of these tests using circular polar grid features. In these figures, the cells marked with true symbol correspond to relevant words, while the cells marked with false symbol correspond to non-relevant words. The discarded words are shown in FIG. 21 word 2100, FIG. 23 word 2300, FIG. 25 word 2500, and FIG. 27 word 2700. Some of the reasons that the system discards retrieval of these words are (i) some of these words are concatenating with other words, and (ii) the prolonging of some letters for decorative reasons. FIGS. 28A-28D (2800a-2800d, respectively) and 29A-29D (2900a-2900d, respectively) visualize the experiment results for some selected query words using all feature sets that were used in testing. It is clear that circular polar grid feature sets are the best features over the other feature sets.









TABLE 13





Recall Results of Different Feature Sets







One-Connected Components












Feature



Feature Sets
Normalized
Occurrences
Term Weighting





Concentric Circles
47.5%
56.5%
56.2%


Angular Lines
53.7%
60%  
60%  


Rectangular Regions
53.7%
60%  
56.7%


Circular Polar Grids
58.7%
61.2%
63.7%






Normalized
Feature



Feature Sets
Features
Occurrences
Term Weighting










Two-Connected Components










Concentric Circles
55%  
57.5%
63.7%


Angular Lines
58.7%
62.5%
65%  


Rectangular Regions
60%  
62.5%
66.2%


Circular Polar Grids
65%  
70%  
70%  







Three-Connected Components










Concentric Circles
61.2%
60%  
62.2%


Angular Lines
62.5%
70%  
75%  


Rectangular Regions
65%  
67.5%
73.7%


Circular Polar Grids
68.7%
73.6%
77.5%







Four-Connected Components










Concentric Circles
61.2%
61.2%
63.7%


Angular Lines
65%  
71.2%
75%  


Rectangular Regions
63.7%
72.5%
75%  


Circular Polar Grids
70%  
77.5%
78.7 









The main evident observations from Table 13 are that the term weighting of the circular polar grid feature set, with recall equal to 78.8%, performs better than other feature sets, while the normalized concentric circle feature set is the worst, with recall equal to 47.5%.


Moreover, there is a steadily increasing relationship between the number of connected components and the recall.


We computed average precision over sets of query words in order to represent the performance of the system. Each set contains words that have the same number of connected components. Furthermore, the exact recall points for which we computed the average precision were 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9 and 1.0. FIGS. 30A-30D show plots 3000a-3000d, FIGS. 31A-31D show plots 3100a-3100d, and FIGS. 32A-32D show plots 3200a-3200d, which represent the performance of the system, while FIGS. 33A-33D show plots 3300a-3300d, which represent the performance of the system using circular polar grid features.


From the above figures (i.e. FIGS. 30A-30D, 31A-31D and 32A-32D), we can observe the line slope of each figure downwards from left to right, enforcing the notion that as more relevant words are retrieved (recall increase), the more non-relevant words are retrieved (precision decreases). Moreover, the circular polar grid features set performs better than other feature sets, while the concentric circle features set is the worst.


Additionally, the angular line feature set and the rectangular feature set perform next best. These two feature sets do not differ significantly from each other. As evident from FIGS. 33A-33D, which related to the best feature sets, i.e., circular polar grid features, the average precision for all of feature types, viz., normalized features, feature occurrences, and term-weighting features, increases steadily with the number of connected components.


The similarity in the present method depends on the choice of the threshold value specified by how far the query word(s) is from the stored word(s) in the database. Therefore, when there is an exact match, i.e., the angle between the two is equal to zero, the cosine value is equal to 1. Since it is unlikely that an exact match occurs, we need to choose a suitable threshold that will be used to retrieve candidate words. In order to determine the value of that suitable threshold, we tested the present method with three threshold values, viz., 0.6, 0.7 and 0.8. We used these values such that if the cosine of the angle between a query and a word is greater than or equal to that threshold value, the word is retrieved. We carried out this experiment with nine queries. Table 14 shows the query words along with the precision and recall results associated with each query for the three different threshold values. In order to determine the most suitable threshold, Table 15 shows the number of retrieved results for different precision recall pairs. In this table, with the exception of precision recall pair values equal to (0.8,0.8) and threshold value equal to 0.8, we found that the threshold value equal to 0.7 along with recall precision pairs is suitable threshold for retrieving relevant results more than the other two threshold values.









TABLE 14







Recall and Precision Results Using Different Threshold Values














Query

Thresh-







Words
Total
old
Total
Relevant
Non-
Precision
Recall


















custom character

24
0.6
59
22
37
0.37
0.91




0.7
44
19
25
0.43
0.79




0.8
34
15
19
0.44
0.62



custom character

75
0.6
107
68
39
0.63
0.9




0.7
98
65
33
0.66
0.86




0.8
72
55
17
0.76
0.73



custom character

12
0.6
51
11
40
0.21
0.91




0.7
17
10
7
0.58
0.83




0.8
10
9
1
0.9
0.75



custom character

10
0.6
54
9
45
0.16
0.9




0.7
35
9
26
0.25
0.9




0.8
29
9
20
0.31
0.9



custom character

12
0.6
29
10
19
0.34
0.83




0.7
16
10
6
0.62
0.83




0.8
6
6
0
1
0.5



custom character

29
0.6
33
22
11
0.66
0.75




0.7
24
19
5
0.79
0.65




0.8
13
13
0
1
0.44



custom character

8
0.6
15
8
7
0.53
1




0.7
11
8
3
0.72
1




0.8
7
7
0
1
0.87



custom character

64
0.6
86
55
31
0.63
0.85




0.7
63
45
18
0.71
0.70




0.8
35
30
5
0.85
0.46



custom character

8
0.6
22
6
16
0.27
0.75




0.7
19
6
13
0.31
0.75




0.8
7
5
2
0.71
0.62



custom character

28
0.6
35
24
11
0.68
0.85




0.7
27
22
5
0.81
0.78




0.8
21
19
2
0.90
0.67
















TABLE 15







Number of Results Where the Precision/Recall Pair for Some Queries Is


At Least As Specified in Each Column for Different Threshold Values












(Precision,
(0.9,






Recall)
0.9)
(0.8, 0.8)
(0.7, 0.7)
(0.6, 0.6)
(0.5, 0.5)





Threshold = 0.6
0
0
0
4
5


Threshold = 0.7
0
0
3
6
7


Threshold = 0.8
0
1
3
5
6









Testing of the present method used the same manuscript and the same query words that were used in the above cited journal article by Shahab et al, The recognition rate of the present method was compared with other work. The recognition rate of the other work is about 76%, while the recognition rate of the present method for the same manuscript is 78.7%. Table 16 shows the experimental results of our system for the same query words, while the retrieval results for the query word Al-Muhtasib (custom character) are shown in the diagram 3400 of FIG. 34. In this figure, the cells marked with true symbol correspond to relevant words, while the cells marked with false symbol correspond to non-relevant words. The discarded words are shown in diagram 3500 of FIG. 35. The reason that the system discards retrieval of this word is that this word is concatenating with other words. One of the reasons that our work yields a better performance compared to the results reported by the other is that the precision here is better than the other. For example, the number of all retrieved words for the Al-Muhatsib word in the related art system is 68 words, while in the present method the number is 23. Plot 3600 of FIG. 36 shows the average precision of the present method vs. the related art retrieval system disclosed in the journal article “Computer Aided Indexing of Historical Manuscripts”. We observe that overall the average precision of the present method is better than the related art work.









TABLE 16







Comparison to Shahab et al. for the Same Query Words











Total of Relevant


Query word
Total words Present
Retrieved Words






custom character

10
 5



custom character

17
14



custom character

18
17



custom character

16
13



custom character

 5
 3









An indexing and searching system for Arabic historical manuscript is developed and implemented. There are several modules, such as preprocessing module, segmentation module, and features extraction module, which are applied before constructing the term-by-document matrix. Such features as concentric circular, angular lines, rectangular regions, and circular polar grids are extracted from the word images. Latent Semantic Indexing (LSI) is employed to represent subword images and their corresponding features as a term-by-document matrix. Query-matching mechanisms are applied in order to retrieve candidate words. Additionally, setting a threshold for similarity matching using LSI is less dependent on the underlying features. The performance evaluation is measured using recall and precision. Our system shows encouraging results and is able to retrieve relevant words. Additionally, the newly proposed circular polar grid of the present method performs better than previously used feature sets for automatic indexing of Arabic handwritten manuscripts.


It is to be understood that the present invention is not limited to the embodiments described above, but encompasses any and all embodiments within the scope of the following claims.

Claims
  • 1. A computer-implemented method for retrieval of Arabic historical manuscripts, comprising the steps of: entering Arabic historical manuscript images into a computer for processing;extracting circular polar grid features from the Arabic historical manuscript images stored in the computer, wherein the step of extracting circular polar grid features comprises: building a circular polar grid from a multiline-axis including an intersection of a 0° line, a 45° line, a 90° line and a 135° line;overlaying concentric circles centered about the intersection point of said multiline-axis, the concentric circles having radial values of r, 2r, 3r, . . . nr; andcentering said circular polar grid at a centroid of an image term to be indexed;constructing a Latent Semantic Index based on the extracted circular polar grid features, the Latent Semantic Index having a reduced dimension m×n Term-by-Document matrix obtained from a Singular Value Decomposition of a higher dimensional Term-by-Document matrix constructed by the computer from the extracted circular polar grid features, wherein m rows represent the features and n columns represent the images;accepting a user query against the stored Arabic historical manuscript images, the computer forming the user query as a query vector derived from features extraction of a query image supplied by the user;performing query matching based on comparison between the query vector and the Term-by-Document matrix;weighing each term of said Term-by-Document matrix by a value representing an occurrence frequency of a feature of said term in said document, wherein the step of weighing each term of said Term-by-Document matrix comprises: picking a comprehensive training set of said document for each said feature;calculating a mean μf and a standard deviation σf of the features f's value across the training set; andfor each image in the collection, defining an occurrence count Ofj of feature f according to the relation:
  • 2. The computer-implemented method according to claim 1, wherein said number of concentric circles is four, thereby defining 32 regions of intersection between said multilines and said concentric circles.
  • 3. The computer-implemented method according to claim 1, further comprising the step of, for each of said regions, normalizing said count.
  • 4. The computer-implemented method according to claim 1, further comprising the step of calculating said predetermined distance measurement as a cosine between said query vector, and said Term-by Document matrix.
  • 5. The computer-implemented method according to claim 1, further comprising preprocessing steps adapted for enhancing efficiency of said circular polar grid features extraction step.
  • 6. The computer-implemented method according to claim 5, wherein said preprocessing steps include an RGB conversion procedure comprising the steps of: converting said Arabic historical manuscript images from an RGB color space to gray-scale images;converting said gray-scale images to binary images by performing calculations characterized by the relation:
  • 7. The computer-implemented method according to claim 5, wherein said preprocessing steps include a smoothing and noise removal procedure comprising the steps of: accepting as input binary versions of said Arabic historical manuscript images;providing as output said binary versions of said Arabic historical manuscript images processed according to rules characterized by the relation if P0=0 then:
  • 8. The computer-implemented method according to claim 5, wherein said preprocessing steps include a segmentation procedure comprising the steps of: determining a baseline of text of said Arabic historical manuscripts images by calculating a horizontal projection profile, said horizontal projection profile calculation being characterized by the relation: Pi=ΣImg(i,j)
  • 9. The computer-implemented method according to claim 8, wherein said returned document images display step further comprises displaying image thumbnails of said image subwords matched according to said query matching process.
  • 10. A computer software product embedded in a non-transitory storage medium readable by a processor, the non-transitory storage medium having stored thereon a set of instructions which, when executed by the processor, causes a computer to perform retrieval of Arabic historical manuscripts using Latent Semantic Indexing, comprising: (a) a first sequence of instructions which, when executed by the processor, causes said processor to accept in main memory storage Arabic historical manuscript images for processing;(b) a second sequence of instructions which, when executed by the processor, causes said processor to extract circular polar grid features from said Arabic historical manuscript images stored in said main memory storage;(c) a third sequence of instructions which, when executed by the processor, causes said processor to construct a Latent Semantic Index based on said extracted circular polar grid features, said Latent Semantic Index being comprised of a reduced dimension m×n Term-by-Document matrix obtained from a Singular Value Decomposition of a higher dimensional Term-by-Document matrix constructed by said computer from said extracted circular polar grid features, wherein m rows represent said features and n columns represent said images;(d) a fourth sequence of instructions which, when executed by the processor, causes said processor to accept a user query against said stored Arabic historical manuscript images, and to form said user query as a query vector derived from features extraction of a query image supplied by said user;(e) a fifth sequence of instructions which, when executed by the processor, causes said processor to perform query matching based on comparison between said query vector and said Term-by-Document matrix;(f) a sixth sequence of instructions which, when executed by the processor, causes said processor to display Arabic historical document images returned by said query matching process, said returned document images being ranked by similarity to said user query according to a predetermined distance measurement between said query vector and said Term-by-Document matrix;(g) a seventh sequence of instructions which, when executed by the processor, causes said processor to build said circular polar grid from a multiline-axis comprised of the intersection of a 0° line, a 45° line, a 90° line and a 135° line;(h) an eighth sequence of instructions which, when executed by the processor, causes said processor to overlay concentric circles centered about the intersection point of said multiline-axis, said concentric circles having radial values of r; 2r, 3r, . . . nr; and(i) a ninth sequence of instructions which, when executed by the processor, causes said processor to center said circular polar grid at a centroid of an image term to be indexed by said retrieval process;(j) a tenth sequence of instructions which, when executed by the processor, causes said processor to determine a plurality of image features defined by a count of black image pixels found in regions of intersection between said multilines and said concentric circles;(k) an eleventh sequence of instructions which, when executed by the processor, causes said processor to weigh each term of said Term-by-Document matrix by a value representing an occurrence frequency of a feature of said term in said document;(l) a twelfth sequence of instructions which, when executed by the processor, causes said processor to pick a comprehensive training set of said document for each said feature;(m) a thirteenth sequence of instructions which, when executed by the processor, causes said processor to calculate the mean μf and the standard deviation σf of the features f's value across the training set and, for each image in the collection, causes said processor to define the occurrence count Ofj of feature f according to the relation
  • 11. The computer software product according to claim 10, further comprising a twentieth sequence of instructions which, when executed by the processor, causes said processor to use four concentric circles thereby defining 32 said regions of intersection between said multilines and said concentric circles.
  • 12. The computer software product according to claim 10, further comprising a twenty-first sequence of instructions which, when executed by the processor, causes said processor to normalize said count for each of said regions.
  • 13. The computer software product according to claim 10, further comprising a twenty-second sequence of instructions which, when executed by the processor, causes said processor to calculate said predetermined distance measurement as a cosine between said query vector, and said Term-by Document matrix.
US Referenced Citations (19)
Number Name Date Kind
4602163 Pryor Jul 1986 A
4839853 Deerwester et al. Jun 1989 A
5083378 Juday Jan 1992 A
7024400 Tokuda et al. Apr 2006 B2
7113943 Bradford et al. Sep 2006 B2
7533094 Zhang et al. May 2009 B2
7630992 Martin et al. Dec 2009 B2
7720792 Price May 2010 B2
8040824 Liu et al. Oct 2011 B2
8239334 Yan et al. Aug 2012 B2
20020174120 Zhang et al. Nov 2002 A1
20040170327 Kim et al. Sep 2004 A1
20050004448 Gurr et al. Jan 2005 A1
20050201405 Liu et al. Sep 2005 A1
20050228778 Perrone Oct 2005 A1
20090157601 Lee et al. Jun 2009 A1
20090268733 Liu et al. Oct 2009 A1
20100161596 Yan et al. Jun 2010 A1
20120191632 Chen et al. Jul 2012 A1
Foreign Referenced Citations (2)
Number Date Country
WO 2007064375 Jun 2007 WO
WO 2008069791 Jun 2008 WO
Non-Patent Literature Citations (8)
Entry
Arabic Phonetic Dictionaries for Speech Recognition, Mohamed Ali et al., 2009.
Improving the Arabic Pronunciation Dictionary for Phone and Word Recognition with Linguistically-Based Pronunciation Rules, Fadi Biadsy et al., Jun. 2009.
Natural Speaker-Independent Arabic Speech Recognition System Based on Hidden Markov Models Using Sphinx Tools, Mohammad A, et al., May 2010.
Morphological Decomposition for Arabic Broadcast News Transcription, Bing Xiang et al., IEEE, 2006.
Sami Brandt; Jorma Laaksonen and Erkki Oja, “Statistical Shape Features in Content-Based Image Retrieval”, Proceedings of ICPR2000, Barcelona, Spain, Sep. 2000.
Yang Mingqiang, Kpalma Kidiyo and Ronsin Joseph, “A Survey of Shape Feature Extraction Techniques”, Pattern Recognition Techniques, Technology and Applications Nov. 2008.
Sameer Antani, Rangachar Kasturi, Ramesh Jain, “A survey on the use of pattern recognition methods for abstraction, indexing and retrieval of images and video”, Pattern Recognition (2002) pp. 945-965.
S.A. Shahab, Wasfi G. Al-Khatib, Sabri A. Mahmoud, “Computer Aided Indexing of Historical Manuscripts”, Proceedings of the International Conference on Computer Graphics, Imaging and Visualisation (CGIV'06) (2006).
Related Publications (1)
Number Date Country
20140164370 A1 Jun 2014 US