Handwriting recognition training and synthesis

Information

  • Patent Grant
  • 7657094
  • Patent Number
    7,657,094
  • Date Filed
    Thursday, December 29, 2005
    19 years ago
  • Date Issued
    Tuesday, February 2, 2010
    14 years ago
Abstract
Methods and systems for converting text into natural personal handwriting are provided. One aspect relates to the training of a computer to recognize a user's handwriting style. In one embodiment, the computer receives handwriting samples of at least one character written by the user, such as the character being provided as the beginning, middle, or ending character among a plurality of other characters. Further embodiments allow for increased personalization of the handwriting. Another aspect relates to system and methods for displaying a representation of a computer user's handwriting. In one embodiment, the handwriting comprises variant shapes of letters, personalized connection style between letters, and connection parts that look pressure-sensitive. In another embodiment, characters are adjusted, such as cutting portions of the character to create a more realistic recreation and synthesis of the handwriting.
Description
BACKGROUND

Personalization of computing environments has become increasingly popular. In addition to the vast array of software packages with similar functionalities for users to select, users may personalize settings within those software packages. For example, users of Microsoft® Windows® operating system may personalize their wallpaper and audio sounds, among other features of the operating system. While adjusting such features increases the personal experience for the user, allowing a user to recreate their own handwriting within a computing environment may be one of the means that most distinguish and personalize one user from another. Moreover, unlike some private settings, a user may be interested in sharing his/her handwriting if his/her emails or other documents could be written in personalized handwriting.


Generally, two kinds of approaches to generate or mimic handwriting have been attempted: direct handwriting capturing, and personal font design. Direct capturing collects the handwriting in digital form and reconstructs the handwriting on the receiver's computer using the recorded stroke point positions, pressure and brush style, or may simply send the images of the handwriting to the receiver. This approach is often utilized in Tablet PCs. Unfortunately, the user is required to write directly on the screen using a digital pen and tasks requiring large amounts of writing, such as preparing lengthy emails, may be inconvenient and tedious.


Personal font design makes a set of handwritten characters into a system font, for example, a true-type font. However, the personal font does not produce variation in character shapes that handwriting is supposed to have. Moreover, natural cursive handwriting cannot be generated, because the characters in system font are just rendered side by side.


Therefore, there exists a need in the art to allow a computer user to readily and effectively train a computer to recognize his/her handwriting without requiring time-intensive writing exercises, such as those associated with direct capturing. A further need exists for systems and methods to capture more characteristics from a sample than the shape of the individual characters, such as with personal font design systems. These and other needs are met with one or more aspects of the invention.


SUMMARY

Aspects of the invention relate to methods and systems for training a computer to recognize a user's handwriting. In one example, a computer receives handwriting samples of at least one character written by the user. The samples may include the character being provided as the beginning character of a word, the character being provided in the middle of a word, and the character being provided as the ending character of a word. Control points may be extracted from the samples to represent the shape of the character. In still yet further examples, the vertical and horizontal alignment of the characters are determined.


Another aspect relates to system and methods for displaying a representation of a computer user's handwriting. In one example, different variations of the same character, such as those described above, may be used depending one the particular usage of that character. In yet another example, methods may determine whether at least two characters received in the user input should be joined, even if the characters are part of the same word or string of characters. In yet further examples, characters are adjusted, such as cutting portions of the character to create a more realistic recreation and synthesis. In still yet another example, the characters are normalized before being displayed. In one such example, the normalization adjusts the character's aesthetic characteristics.


According to specific examples of the invention, characters are generated that accurately represent the handwriting, including variant shapes of letters, natural, reasonable and personalized connection style between letters, and connection parts that look pressure-sensitive.


These and other advantages will become apparent from the following detailed description when taken in conjunction with the drawings, A more complete understanding of the present invention and the advantages thereof may be acquired by referring to the following description in consideration of the accompanying drawings, in which like reference numbers indicate like features, and wherein:





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 illustrates an exemplary computer system in which embodiments of the invention may be implemented.



FIG. 2 illustrates a functional block diagram of one method for training a computer to recognize a user's handwriting.



FIGS. 3
a and 3b show exemplary user interfaces that may be used to receive a plurality of character samples according to one embodiment of the invention.



FIG. 4 shows an exemplary extraction of control points for a character according to one embodiment of the invention.



FIG. 5 shows an exemplary connection possibilities between a multi-stroke character connected to a single stroke character.



FIG. 6 is a flow diagram of one illustrative method of displaying a representation of a computer user's handwriting.



FIG. 7 shows one illustrative collection of characters being synthesized with a probability table according to one aspect of the invention.



FIG. 8 provides four illustrative characters according to one embodiment of the invention.



FIG. 9 shows illustrative character pairs being joined at a horizontal distance from one another



FIG. 10 shows graphs representing characteristics of the weighting functions according to one embodiment of the invention.





DETAILED DESCRIPTION

Exemplary Operating Environment



FIG. 1 is a functional block diagram of an example of a conventional general-purpose digital computing environment that can be used in connection with the methods and systems of the present invention. In FIG. 1, a computer 100 includes a processing unit 110, a system memory 120, and a system bus 130 that couples various system components including the system memory to the processing unit 110. The system bus 130 may be any of several types of bus structures including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of bus architectures. The system memory 120 includes read only memory (ROM) 140 and random access memory (RAM) 150.


A basic input/output system 160 (BIOS), containing the basic routines that help to transfer information between elements within the computer 100, such as during start-up, is stored in the ROM 140. The computer 100 also includes a hard disk drive 170 for reading from and writing to a hard disk (not shown), a magnetic disk drive 180 for reading from or writing to a removable magnetic disk 190, and an optical disk drive 191 for reading from or writing to a removable optical disk 192 such as a CD ROM or other optical media. The hard disk drive 170, magnetic disk drive 180, and optical disk drive 191 are connected to the system bus 130 by a hard disk drive interface 192, a magnetic disk drive interface 193, and an optical disk drive interface 194, respectively. The drives and their associated computer-readable media provide nonvolatile storage of computer readable instructions, data structures, program modules and other data for the personal computer 100. It will be appreciated by those skilled in the art that other types of computer readable media that can store data that is accessible by a computer, such as magnetic cassettes, flash memory cards, digital video disks, Bernoulli cartridges, random access memories (RAMs), read only memories (ROMs), and the like, may also be used in the example operating environment.


A number of program modules can be stored on the hard disk drive 170, magnetic disk 190, optical disk 192, ROM 140 or RAM 150, including an operating system 195, one or more application programs 196, other program modules 197, and program data 198. A user can enter commands and information into the computer 100 through input devices such as a keyboard 101 and pointing device 102. Other input devices (not shown) may include a microphone, joystick, game pad, satellite dish, scanner or the like. These and other input devices are often connected to the processing unit 110 through a serial port interface 106 that is coupled to the system bus, but may be connected by other interfaces, such as a parallel port, game port or a universal serial bus (USB). The illustrated computer 100 includes an optional PCMCIA interface 103 that may connect at least one embodiment of an input device according to the present invention to the computer 100. Further still, these devices may be coupled directly to the system bus 130 via an appropriate interface (not shown). A monitor 107 or other type of display device is also connected to the system bus 130 via an interface, such as a video adapter 108. An auxiliary display device 199 may also be in communication with computer 100. The auxiliary device may be integrated within the computer (as shown), detachable, or external. The auxiliary display device 199 may optionally be in communication with an auxiliary processor 200, which may be integrated within the auxiliary display or housed within the computer 100. In addition to the monitor, personal computers typically include other peripheral output devices (not shown), such as speakers and printers.


The computer 100 can operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 109. The remote computer 109 can be a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer 100, although only a memory storage device 111 has been illustrated in FIG. 1. The logical connections depicted in FIG. 1 include a local area network (LAN) 112 and a wide area network (WAN) 113. Such networking environments are commonplace in offices, enterprise-wide computer networks, intranets and the Internet.


When used in a LAN networking environment, the computer 100 is connected to the local network 112 through a network interface or adapter 114. When used in a WAN networking environment, the personal computer 100 typically includes a modem 115 or other means for establishing a communications over the wide area network 113, such as the Internet. The modem 115, which may be internal or external, is connected to the system bus 130 via the serial port interface 106. In a networked environment, program modules depicted relative to the personal computer 100, or portions thereof, may be stored in the remote memory storage device.


It will be appreciated that the network connections shown are illustrative and other techniques for establishing a communications link between the computers can be used. The existence of any of various well-known protocols such as TCP/IP, Ethernet, FTP, HTTP, Bluetooth, IEEE 802.11x and the like is presumed, and the system can be operated in a client-server configuration to permit a user to retrieve web pages from a web-based server. Any of various conventional web browsers can be used to display and manipulate data on web pages.


Description of Illustrative Embodiments


FIG. 2 illustrates a functional block diagram of one method of training a computer to recognize a computer user's handwriting. In one embodiment, the computer may be arranged similar to computer 100. In step 205, the computer, such as computer 100, receives handwriting samples of at least one character written by the user. The handwriting samples may be received through any user input device, such as for example, a writing utensil, a heat sensitive surface, a pressure sensitive surface and combinations thereof. In yet another embodiment, the user may “select” a character or representation thereof previously stored on a computer-readable medium to serve as one or more samples. In yet another embodiment, the user may “draw” the character by moving a mouse, trackball, or other user input device over a surface.


As used herein, the term “character” may refer to any letter, number, graphical icon, or alphanumeric representation in any language including spoken, written, or utilized for programming computing devices. Indeed, any shape or design that may be received at a computing device through a user interface is a character within the scope of the invention. The samples comprise at least one sample of a character as being provided as the beginning character among a plurality of other characters, at least one sample of the same character being provided as the character as being written in the middle of a plurality of other of characters, and at least one sample of the same character being provided as written as the ending character among a plurality of characters.



FIGS. 3
a and 3b show one exemplary user interface that may be used to receive the plurality of character samples. As seen in the figures, advantages of at least one aspect of the invention can be appreciated. FIG. 3a shows user interface 302, which may be displayed to a user through a display device, such as monitor 107 and/or auxiliary display device 199. User interface 302 is presented to a user and allows the user to input characters corresponding to the letter “a”. As seen in FIG. 3a, user interface 302 comprises user input fields 304, 306, and 308, having user inputs 310, 312, and 314 respectively.


User input 310, shown in input field 304, is provided to represent the user's handwriting of the letter “a” when the letter is a beginning character among a plurality of other characters. For example, the beginning character may be used to represent the first letter of a word, such as the word “asia”, when the word is written in cursive or a format where it is otherwise connected to another character. The first letter of a word, however, is not the only instance where the “beginning” character may be used. Indeed, it is customary for some individuals to write single words as two or more collection of characters, where some of the characters in the middle of the word are not joined. Moreover, if the user generally does not write in cursive format, the “beginning character” may still be utilized for characters in the middle or end of a word or collection of characters. As shown, user input 310 shows an “a” with a trailing or “tail” section that may be connected with a following character. As one skilled in the art will realize the size, angle, and length of the tail of any of the characters may vary among users' handwriting.


User input 312, shown in input field 306, is provided by the user to represent the letter “a” as being written in the middle of a plurality of other of characters. For example, the user may write input 312 as if the letter was within a word he/she frequently writes. As shown, the letter “a” provided as user input 312 has a trailing section or tail like user input 310, but it also has a “head” or leading portion that partially transects the middle of the character, that the user did not provide in user input 310. In one embodiment, the leading portion may be used for connection with a preceding character. As one skilled in the art will realize, the leading portion may vary in size, shape, angle, and length, Some users may write the letter having a head or leading portion that fully transects the middle of the letter and extends beyond the beginning of the body of the letter.


User input 314, shown in input field 308, is provided by the user to represent the letter “a” as written as the ending character among a plurality of characters. Unlike user inputs 310 and 312, the user did not write an extended tail that connects the character to the following character, however, did write a head or leading portion for connecting with the preceding character.


As seen in each of the input fields, one or more lines, such as guide lines 316a, 316b may optionally be provided within the input fields to aid the user in writing the characters. Such guide lines may be beneficial when writing letters extending beyond the lines, such as the letter “b”. In one embodiment, the guidelines aid the user in writing a normalized size of the characters and retain proper dimensions of different portions of the character. Looking to FIG. 3b, user interface 320, which also may be displayed to a user through a display device, such as monitor 107 and/or auxiliary display device 199 is presented to a user and allows the user to input characters corresponding to the letter “b”. As seen in FIG. 3b, user interface 320 comprises user input fields 322, 324, and 326, having user inputs 328, 330, and 332 respectively.


As can be readily seen in the figure, the stem of the letter b extends above the top guideline 316a, while the body of the letter remains substantially within the parameter defined by the top guideline 316a and bottom guideline 316b. Note, however, that there are some variations among the user input in regards to the body of the letter, wherein the body of the letter provided as user input 330 partially extends below the bottom guideline 316b. Similar to the user inputs supplied for the letter “a”, the user inputs 328, 330, and 332 show the letter “b” as being provided as the beginning character among a plurality of other characters, being provided as the character as being written in the middle of a plurality of other of characters, and being provided as written as the ending character among a plurality of characters. While three input fields are shown in both FIGS. 3a and 3b, one skilled in the art will readily appreciate that any number of fields may be used. For example, in one embodiment, user interface 320 may have a plurality of input fields to receive a user input for connecting the letter “b” with numerous other letters of the alphabet. Indeed, in one embodiment, multi-character words are presented to the user.


In step 210, a plurality of control points are extracted from the character. The number of control points extracted and the location of the control points may depend on a myriad of factors, including but not limited to: the desired preciseness of the final handwriting analysis, the sample provided by the user, or the specific character being entered. The extracted control points are extracted to represent the shape of the character. In one embodiment, the shape of a character may be synthesized based on spline interpolation passing the control points. For example, FIG. 4 shows an exemplary extraction of control points for a character. Looking to the figure, a character, such as character 405 representing the letter “a”, is provided by a user as a single stroke through a user input device, such as through user interface 302. (As one skilled in the art will understand, other variations of “a”, such as “A” or other characters require a plurality of strokes, and will be discussed in more detail later in the Specification).


A plurality of control points 410 are extracted from the character 405. The stroke may first be approximated by a polyline using Sklansky's algorithm, for example, as described in Sklansky J. and Gonzalez V., Fast Polygonal Approximation of Digitized Curves. Pattern Recognition, Vol. 12, pp. 327-331, 1980, incorporated herein by reference in its entirety. Intermediate points on the stroke may then be added back to the polyline if the distance between successive nodes of the polyline is too large or the polyline has a high curvature. Looking to the illustrative embodiment in FIG. 4, it can be seen that that there is a higher density of nodes in high curvature areas when compared to areas having low curvature.


In step 215, the vertical positioning of the character in relation to a baseline, such as one of the guidelines 316a, 316b or other character, is determined. In one embodiment, the calculation of the vertical positioning may include determining the distance from the bottom of the character to one or more baselines, yet in another embodiment, the calculation may include determining the distance from the top of the character to one or more baseline. In still yet another embodiment of the invention, the calculation may include determining the ratio of: (1) the distance from a specific control point or location on the character to (2) the overall height of the character. As one skilled in the art will readily appreciate, there are numerous methods that may determine the vertical positioning of the character.


In step 220, one or more of the samples received from the user for at least one character may be normalized. In one embodiment, all of the samples for a specific character undergo a normalization process. In another embodiment, the normalization process may be dependent of the type of character being normalized, for example, different groups of classes of letters may undergo different normalization processes. In one such embodiment, the characters may be classified by their shapes. For example, specific characters are traditionally written to fit entirely within a parameter or have a segment of the character extend beyond a parameter. For example, looking to the character “b”, the main body of the character is substantially within the parameter defined by the top guideline 316a and the bottom guideline 316b. Moreover, a stem passes through the top guideline 316a. These and other characteristics may be used to define how the character is normalized.


In one embodiment of the invention, letters such as “b” that are ascenders (ascend above the top guideline 316a) may be grouped together. Exemplary ascenders may include: b, d, h, i, k, l, and t. One skilled in the art will understand there are additional alphanumeric and other characters that may be included within this classification. In one embodiment of the invention, the average height of the characters classified as an ascender is utilized to normalize the character samples. However, as explained in more detail below, variation of the height of the individual characters may be undertaken at another step to further increase personalization.


Another possible classification may include those characters which are written with the entire character substantially within the parameter defined by the top guideline 316a and bottom guideline 316b (referred to as “middle zone characters”). Such middle zone characters may include the letters: a, c, e, m, n, o, r, s, u, v, w, and x. However, any character which is substantially within the guidelines may be classified as a middle zone character. In one embodiment of the invention, the average height of the middle zone characters may be utilized in normalizing the character samples. In one embodiment, the average heights of middle zone and ascender characters are applied to the original heights for normalization. One such equation may be:

scale=AverageHeighti/Heightj,Wj=scale*Wj,Hj=scale*Hj, where i=1,2; j=a,c,e,m,n,o,r,s,u,v,w,x,b,d,h,i,k,l,t


Regarding classification, those characters which have a stem or segment that substantially crosses a bottom guideline, such as 316b, (hereafter referred to as “descenders”) may be grouped together. Such descenders may include, but are not limited to: g and y. Characters that have at least one stem or segment that crosses both guidelines (hereinafter referred to as “multi-zone characters”) may also be grouped together. As one skilled in the art will readily understand, there are certain characters that may be classified according to different classifications when written by different users. For example, the letter z may be written as a middle zone character or a descender. According one embodiment, computer-executable instructions may determine how the character should be classified depending on a user input. In yet another embodiment, such letters may be grouped in an entirely different category.


While some groups of characters may be optimized by utilizing the average height of the characters, other groupings, such as multi-zone characters, whose shapes are not very certain, may have the character optimized with an optimal algorithm. According to one possible algorithm, the scaling factors may be about 1, so that the height and width of the characters are substantially equal. In one such embodiment, the characters may be optimally scaled with si so that their widths are approximately Wnormalize and their heights are close to each other (We need to normalize the size of letters, but normalizing according to either width or height is not optimal. we introduce Wnormalize because the letter size may not be close to each other). The method is to minimize:








g


(
s
)


=



1
2






i
=
1

N




(



s
i



w
i


-
W

)

2



+


1
2






i
=
1

N




(



s
i



h
i


-


1
N






j
=
1

N




s
j



h
j





)

2





,





where siwi and sihi are the width and height after scaling, and N is the number of sample letters. The optimal s makes:









g




s
k



=




(


w
k
2

+

h
k
2


)



s
k


-


1
N



h
k






j
=
1

N




h
j



s
j




-

Ww
k


=
0.






Therefore it satisfies the following equation:









(

Λ
-

hh
T


)


s

=


W


(




w
1







w
N




)


T


,






where





Λ

=


diag


(



h





1






2


+

w





1






2



,





,


h





N






2


+

w





N






2




)







and








h
=





(




h
1







h
N




)

T

/

N


·
The






inverse





of






(

Λ
-

hh
T


)






is


:








A
=



(

Λ
-

hh
T


)


-
1


=


Λ

-
1


+




Λ

-
1




hh
T



Λ

-
1




1
-


h
T



Λ

-
1



h



.








The optimal Wnormalize should make the scaling factors as close to 1 as possible, i.e., it should minimize:










ϕ


(
W
)


=




1
2






i
=
1

N




(


s
i

-
1

)

2









=




1
2




(

s
-
e

)

T



(

s
-
e

)









=




1
2




(

WAw
-
e

)

T



(

WAw
-
e

)



,








where


e=(1 . . . 1)T and w=(w1 . . . wN)T. Then the optimal Wnormalize is:







W
opt

=




e
T


Aw



w
T



A
T


Aw


.






Denote the normalized height by Hnormalize. It equals to the average height of character after optimal scaling. The optimal Wnormalize and Hnormalize are computed for every character.


If more than one character is provided, wherein the plurality of characters are provided in a string, form a word, or otherwise determined to be connected (whether by computer-executable instructions or the user) optional step 225 may be initiated. At step 225, one or more characters may undergo a kerning process to determine the average horizontal distance between the central axes of two or more successive characters. In one embodiment, the average distance d between the central axes of successive letters with slant l is assumed to be L/M, where L is the width of the bounding parallelogram of the word and M is the number of letters in the word, wherein the distribution of di is formed because each plurality of character can provide an estimate of the average distance d.


Optional step 230 may also be used where a collection of characters are written in a cursive format or otherwise connected to determine the connection inclination. In one embodiment, step 230 determines the probability of the user to write in cursive style. The process may be combined with an a priori connection-probability table, which describes the easiness of connecting a pair of letters, to decide the probability of connecting two given letters (the “connection inclination” for those two letters) for a particular user.


Suppose the number of letters in a word is n. If the user writes it without connection, there should be k strokes (k may not be equal to n because there may be multi-stroke letters). If l strokes are collected from the word written by the user, then the connection inclination for the word is computed as follows:

Puseri=(k−l)/(n−1)
if Puseri<0, Puseri=0
if Puseri>0, Puseri=1

For the i-th word, we can get a Piuser. Assuming that there are m words, then the connection inclination of the user is computed as follows:







P
user

=


1
m






i
=
1

m




p
user
i

.







The application of connection inclination values is discussed in more detail later in the Specification.


In select embodiments of the invention, step 235 may be utilized to determining the sample comprises a character that is a multi-stroke letter that requires a plurality of user strokes when written and how it connects to other characters. This deserves special attention. Generally, for characters written with a single stroke, the user connects the previous character at the beginning of the stroke and connects the following character at the ending of the stroke. However, for multi-stroke characters, such as the letters “f, i, j, t, x, z”, training may become more complex because different users may have different ways to write this character and connect this it with the proximate characters. For example, as shown in FIG. 5, there are five cases that “x” connects with “a”. Therefore, step 235 may be used to determine the way(s) the user connects the specific character with other characters.


In one embodiment, a graphical user interface that displays the multi-stroke character to the user. The UI may require the user to write a plurality of combinations of “f, i, j, t, x, z” with “a” (such as “af”, “fa”, “ia”, “ai”, etc.) in order to determine which stroke of the letters will be connected with that of other character. As one skilled in the art will realize, other characters besides “a” may be chosen, however, the Applicants have found that the character “a” is a proper candidate for testing because it is usually completed in one stroke, thereby reducing the complexity of analysis, and the stroke for “a” has enough length so that the length test in the connection style detection can be effective.


In step 240, the amount of pressure the user applies while inputting the handwriting sample may be determined. In one embodiment, the user may write the characters on a pressure sensitive keyboard or pad where the pressure of each stroke or segments within each stroke is measured. Such measurements may be used when synthesizing the user's handwriting, such as according to one or more embodiments discussed below.


Further aspects of the invention relate to a computer-implemented method of synthesizing and displaying a representation of a computer user's handwriting. FIG. 6 is a flow diagram of one illustrative method of displaying a representation of a computer user's handwriting on a display device, such as monitor 107 and/or auxiliary display device 199. In step 605, a user input comprising a plurality of characters is received through a user input device, such as a keyboard.


In step 610, it is determining whether at least two characters received in the user input of step 605 should be joined. In one embodiment, computer-executable instructions tangibly embedded on a computer-readable medium dictate that connections may be determined to exist between two characters written as lowercase alphabetic characters and/or numeric characters. In one such embodiment, connection probability tables, for example, one for lowercase alphabetic characters and another for numeric characters may be utilized. These connection probability tables can be estimated from some data set or simply be chosen empirically. An engine may then sample a connection state for proximate characters in a collection of characters, for example, a word.


In one embodiment, a connection table may be generated by combining the user's connection inclination (for example, as calculated in step 230) with a probability table of connections for particular characters. For example, in one embodiment, the probability of two characters, the i-th and the j-th characters, being connected may be estimated with the equation:

if (Puser=0∥Puser=1)
Pi,j=Puser;
else Pi,j=min(max(Pi,j, αPuser),1)


where α is a weight value for Puser, because users usually write less cursively in sample writing than in actual writing. In one embodiment, the computer-readable instruction sets α to be 1.25.


As one skilled in the art will realize, the above equation is but just one exemplary method of determining whether two or more proximate characters should be joined, and that other equations may be used in conjunction with or independently of the above equation without departing from the scope of the invention. Indeed, in yet another embodiment, the inclination may be toggled “on” and “off” by the user and only the probability tables themselves are considered.



FIG. 7 shows one illustrative collection of characters being synthesized with a probability table according to one aspect of the invention. As seen in the figure, a collection of characters 705 is provided by the user through a user input device. In the illustrative example, the collection of characters is in the form of a word, the word being “hello”. A probability table, such as probability table 710 may be accessed to determine whether to connect the individual characters h-e-l-l-o. For the illustrative example, a connection inclination of the user has been estimated at 0.9. This value has been entered into the column 710b. As previously mentioned, the use of a connection inclination is optional and need not be incorporated for use with the probability table.


As seen in the table 710, column 710a provides a row for each of the groupings or proximate characters. In the illustrative example, the first row has the characters “h” and “e” representing the first two characters of the word “hello”. As indicated with column 710c, each pair of proximate characters has a probability of being connected. This value may be determined by initially presenting a plurality of multi-character words to a user to determine the probability that certain character pairings would be connected when written by the user. In one embodiment, the Applicants have discovered that as few as 20 multi-character words can be received from the user to determine a probability value, such as those presented in column 710c. In yet another embodiment, the user's handwriting may be continuously or routinely monitored to determine and update the connection probability of the characters.


Looking to the proximate characters “h” and “e” in the first row, there is an 80% probability (see column 710c; listing a “0.8” probability) that the characters are connected when the user writes them in that combination. The probably values of column 710c may be used to dictate that 80% of the instances where the characters “h” and “e” are presented, they will be connected. In yet another embodiment, the probability values of column 710c may be used in conjunction with a random number to determine if the characters are connected. In one embodiment, a single random number is generated for the entire table (as illustrated in the exemplary table), yet in other embodiments, a different random number may be generated for each character combination (row).


In the exemplary table, the probability values (column 710c) are multiplied with the connection inclination for that user (column 710b) to provide a generated number (column 710d). In one embodiment, if the generated number is higher than the random number, a connection is made for that particular character combination. For example, looking to the first character combination of “h” and “e” (the first row), there is a connection inclination of 0.9 and a probability value of 0.8. Multiplying the connection inclination by the probability value provides a generated number of 0.72. Since the generated number is higher than the random number (0.5), the “h” is connected to the “e”. Conversely, the character combination shown in the second row (“e” and “l”) has a probability value of 0.4, wherein upon being multiplied by the connection inclination (0.9) provides a generated number of 0.36. Since 0.36 is lower than the random number (0.5), the “e” is not connected to the “l”. As seen in the remaining rows of the probability table 710, the generated numbers of each of the remaining proximate character pairings for the word are higher than the random number, thereby resulting in those proximate characters being connected in a cursive fashion.


In step 715, a sample for each character of the word or collection of characters is selected. The selected sample is among a plurality of samples stored on a computer-readable medium to represent the character, wherein the plurality of samples comprises at least one sample of the character being provided as the beginning character among a plurality of other characters, at least one sample of the character being provided as being in the middle of a plurality of other of characters, and at least one sample of the character being provided as the ending character among a plurality of characters, wherein the selected sample comprises at least one segment selected from the group consisting of a heading segment, a tailing segment, and a central axis. The samples may be stored on a remote computer-readable or local medium. In one embodiment, the samples comprise those received in step 205.


Using the illustrative example of FIG. 7, the word “hello” was determined to have all the characters connected with the exception of the “e” and the “l”. Output 715 is an illustrative output of according to one embodiment of the invention. Looking to output 715, a sample for the character “h” will be selected. Since it is the first letter of the word, the sample provided to represent “h” as the beginning character will be selected. However, selecting the sample to represent the character “e” is not as simple. While “e” is not the ending character of the word “hello”, step 710 determined that “e” and “l” are not connected. Therefore, in at least one embodiment of the invention, computer-executable instructions determine the proper sample for “e” is the sample of “e” being provided as the ending character among a plurality of characters.


Similarly, since the first “l” in “hello” is not connected to the preceding character, computer-executable instructions may determine that the proper sample is the sample of the character being provided as the beginning character among a plurality of other characters. Looking to output 715, it is readily apparent that the second “l” appears much different. This is because the second “l” is preceded by a character (“e”) and is followed by another character (“o”); therefore the sample used to represent the second “l” is the sample of the character being provided as being in the middle of a plurality of other of characters. This provides increased personalization of the output 715. Lastly, the character “o” is the final character of the word, and accordingly a sample representing an ending character is utilized.


While the above step introduces variety within the user's handwriting and creates a more realistic recreation than prior art methods, optional step 620 may be utilized to create geometric variation into one or more characters chosen in step 615. It is widely known that when user's write out characters at different times, there are slight variations in the size, curvature, and other characteristics of the characters. Step 620 may perform geometric variation by local random rotation and scaling of one or more stroke pieces, for example, at high curvature points, such as corners of the character. For example, the character “w” has at least 3 points that are corners or have high curvature rates, and at least 2 ending points for which geometric variation may be applied. In one embodiment of the invention, the following equations may be used to provide rotation and/or scaling to the corner points of the character:






Rotate


{






x
1

=



(


x
old

-

x
oldOrigin


)

*
cos





θ

-


(


y
old

-

y
oldOrigin


)

*
sin





θ









y
1

=



(


x
old

-

x
oldOrigin


)

*
sin





θ

+


(


y
old

-

y
oldOrigin


)

*
cos





θ











Scale


{






x
new

=



x
1

*
scale

+

x
newOrigin









y
new

=



y
1

*
scale

+

y
newOrigin











in





which






{






x
oldOrigin

=

x
oldLastEnd








y
oldOrigin

=

y
oldLastEnd















{





x
newOrigin

=

x
newLastEnd








y
newOrigin

=

y
newLastEnd
















The inventors have discovered that selecting θε[−3°,3°], scale ε[0.75,1.05] wherein each are uniformly sampled provides acceptable recreation and variation of the character, however, one skilled in the art will realize the scaling and/or rotation may be performed according to different parameters.


As is widely recognized, individual users vary in the amount of horizontal spacing in-between different characters. Therefore, by determining a horizontal distance between two or more characters of a word or collection of characters, the output will appear more personalized. In one embodiment of the invention, step 625 is implemented to determine a horizontal distance between the central axes of at least two of the samples chosen, wherein the horizontal distance between two samples may be a different distance than the horizontal distance between another two samples chosen.


In one embodiment, specific lines within the character are located, such as for example, one or more of the following: head line (“h”), left line (“l”), right line (“r”), and a tail line (“t”). As one skilled in the art will appreciate, the term “line” simply refers to a segment of the character, as does not require the “line” to be straight. FIG. 8 provides four illustrative characters (805, 810, 815, and 820) to more clearly show these lines according to one embodiment of the invention. As seen with the illustrative figures, the head and tail lines are just the lines passing the starting and the ending points of the stroke, respectively. In one embodiment, the detection of head and tail lines may be based on corners and maximum-minimum x and y values. The left and right lines are the left and right bounding lines of the letter after eliminating the heading and tailing parts of the letter, which are considered to be parts of connection and may be cut appropriately for better connection (see step 630, below).


According to one embodiment, a kerning d from a kerning distribution is sampled, then the horizontal distance between the central axes of current letter and the successive letter may be denoted by md. FIG. 9 shows illustrative character pairs being joined at a horizontal distance from one another. In one embodiment, the characters are placed one by one in a substantially horizontal arrangement according to the kerning and a segment, such as the tail and/or head segments may be adjusted. For example if Li,t<Li,r, such as with like character pairings 915 (pairing “b” with “a”) and 920 (pairing “b” with “d”), the tail is not cut; however, if Li,t>Li+1,l, such as with pairing 910 (pairing “a” with “d”) or Li,t>Li+1,h, such as with pairing 905 (pairing “a” with “a”), then the tail of the ith letter may be cut, for example, at max└Li,r, min(Li+1,h, Li+1,l)┘. Wherein ConCPIndex[1]−=Count(Cut Piece), where ConCPIndex[0] and ConCPIndex[1] are indexes of connection points of the character that may be computed after sampling. In yet further embodiments, the head of a character may be adjusted. In one embodiment, if Li+1,h>Li+1,l, such as seen in character pairings 910 and 920, then the head will not be removed, however, if Li+1,h<Li,r, such as with pairing 915 or Li+1,h<Li,t, such as with pairing 905, then the head may be cut, for example, at min └Li+1,l, max(Li,t, Li,r)┘, wherein ConCPIndex[1]−=Count(Cut Piece) and End If where ConCPIndex[1] indicates the index of the ending connection point of the current character.


As one skilled in the art will realize, a connection segment may be utilized to attach two or more characters (step 630), such as by connecting the tail portion of one character to the head portion of another character. In one embodiment, a 3-order polynomial may be utilized to fit the connection part, which consists of the tailing and heading parts and the line segment linking the ending point of the tailing part and the beginning (or second) point of the heading part. By using this approach, three energy functions are used to measure the closeness of old and new connection parts, the bending energy, and the smoothness of the connection, respectively. According to one embodiment, the polynomial which minimizes the whole energy may be used is the final connection piece.


In one embodiment of the invention, the connection curve can be parameterized by:








P


(
t
)


=




k
=
0

P




P
k



t
k




,

t



[

0
,
1

]

.




Then












E
1

=





0
1





ξ
1



(
s
)








O


(
s
)


-

P


(
s
)





2




s









=





0
1





ξ
1



(
s
)








O


(
s
)


-




k
=
0

P




P
k



s
k






2




s









=






0
1





ξ
1



(
s
)







O


(
s
)




2




s



-

2





k
=
0

P




P
k

·



0
1




s
k




ξ
1



(
s
)




O


(
s
)





s






+













k
=
0

P






l
=
0

P





P
k

·

P
l






0
1





ξ
1



(
s
)




s

k
+
l





s

















E
11

-

2





k
=
0

P




P
k

·


E
12



(
k
)





+




k
=
0

P






l
=
0

P





E
13



(

k
,
l

)





P
k

·

P
l













which measures the closeness of old and new connections,










E
2

=





0
1





ξ
2



(
s
)









O




(
s
)


-


P




(
s
)





2




s









=





0
1





ξ
2



(
s
)









O




(
s
)


-




k
=
1

P



k






P
k



s

k
-
1







2




s









=






0
1





ξ
2



(
s
)








O




(
s
)




2




s



-

2





k
=
1

P




P
k

·



0
1



k






s

k
-
1





ξ
2



(
s
)





O




(
s
)





s






+













k
=
1

P






l
=
1

P





P
k

·

P
l






0
1



k





l







ξ
2



(
s
)




s

k
+
l
-
2





s

















E
21

-

2





k
=
1

P




P
k

·


E
22



(
k
)





+




k
=
1

P






l
=
1

P





E
23



(

k
,
l

)





P
k

·

P
l













which measures the bending energy,










E
3

=





0
1





ξ
3



(
s
)








P




(
s
)




2




s









=





0
1





ξ
3



(
s
)










k
=
2

P




k


(

k
-
1

)




P
k



s

k
-
2






2




s









=






k
=
2

P






l
=
2

P





P
k

·

P
l






0
1




k


(

k
-
1

)




l


(

l
-
1

)





ξ
3



(
s
)




s

k
+
l
-
4





s



















k
=
2

P






l
=
2

P





E
33



(

k
,
l

)





P
k

·

P
l












which measures the smoothness of the connection.


In one embodiment, an attempt is made to minimize














E
=






i
=
1

3




λ
i



E
i









=






i
=
1






3





λ
i



[


E






i





1



-

2





k
=
0






P






P
k

·

E

i





2





(
k
)




+




k
=
0

P






l
=
0

P





E

i





3




(

k
,
l

)





P
k

·

P
l






]









=







i
=
1

3




λ
i



E

i





1




-

2





k
=
0

P




P
k

·




i
=
1

3




λ
i




E

i





2




(
k
)







+













k
=
0






P







l
=
0






P





(




i
=
1






3





λ
i




E

i





3




(

k
,
l

)




)



(


P
k

·

P
l


)











(
0
)









where E31=0, Ei2(k)=0 if k=0 or i=3, and Ei3(k,l)=0 if k<2 or l<2, subject to:











P
0

=

O
S


,





k
=
0

P



P
k


=

O
E


,






P
1

=

O
S



,





k
=
1

P



k






P
k



=

O
E



,




(
1
)








We may remove P0, . . . , P3 in (0) by using the relationship of (1):








P
0

=

O
S


,


P
1

=

O
S



,






P
2

=


3






O
E


-

3






O
S


-

2






O
S



-

O
E


+




k
=
4

P




(

k
-
3

)



P
k





,






P
3

=



-
2







O
E


+

2






O
S


+

O
S


+

O
E


-




k
=
4

P




(

k
-
2

)



P
k





,





where OS, OS′, OE, OE′ are the starting, ending points and their tangent vector of the old connection curve, respectively, and make E a function of P4, . . . , PP. Then compute









0
=





E




P
j









=





-
2



(

j
-
3

)






i
=
1

3




λ
i




E

i





2




(
2
)





+

2


(

j
-
2

)






i
=
1

3




λ
i




E

i





2




(
3
)





-












2





i
=
1

3




λ
i




E

i





2




(
j
)





+

2





l
=
0

P




(






(

j
-
3

)






i
=
1

3




λ
i




E

i





3




(

l
,
2

)





-

(

j
-
2

)











i
=
1

3




λ
i




E

i





3




(

l
,
3

)




+




i
=
1

3




λ
i




E

i





3




(

l
,
j

)








)



P
l





,










(


j
=
4

,





,
P

)







0
=





-

(

j
-
3

)







i
=
1

3




λ
i




E

i





2




(
2
)





+


(

j
-
2

)






i
=
1

3




λ
i




E

i





2




(
3
)





-




i
=
1

3




λ
i




E

i





2




(
j
)




+












(






(

j
-
3

)






i
=
1

3




λ
i




E

i





3




(

0
,
2

)





-

(

j
-
2

)











i
=
1






3





λ





i




E






i





3





(

0
,
3

)



+




i
=
1






3





λ





i





E






i





3





(

0
,
j

)








)



O
S


+












(






(

j
-
3

)






i
=
1

3




λ
i




E

i





3




(

1
,
2

)





-

(

j
-
2

)











i
=
1

3




λ
i




E

i





3




(

1
,
3

)




+




i
=
1

3




λ
i




E

i





3




(

1
,
j

)








)



O
S



+











(






(

j
-
3

)






i
=
1

3




λ
i




E

i





3




(

2
,
2

)





-

(

j
-
2

)











i
=
1






3





λ
i



E

i





3




(

2
,
3

)



+




i
=
1






3





λ
i




E

i





3




(

2
,
j

)








)

×











(


3






O
E


-

3






O
S


-

2






O
s



-

O
E


+




k
=
4

P




(

k
-
3

)



P
k




)

+











(






(

j
-
3

)






i
=
1

3




λ
i




E

i





3




(

3
,
2

)





-

(

j
-
2

)











i
=
1






3





λ





i





E






i





3





(

3
,
3

)




+




i
=
1






3





λ





i





E






i





3





(

3
,
j

)








)

×











(



-
2







O
E


+

2






O
S


+

O
s


+

O
E


-




k
=
4

P




(

k
-
2

)



P
k




)

+













l
=
4

P




(






(

j
-
3

)






i
=
1

3




λ
i




E

i





3




(

l
,
2

)





-

(

j
-
2

)











i
=
1






3





λ
i




E

i





3




(

l
,
3

)




+




i
=
1






3





λ
i




E

i





3




(

l
,
j

)








)



P
l









=




-

(






(

j
-
3

)






i
=
1

3




λ
i




E

i





2




(
2
)





+

(

j
-
2

)











i
=
1






3





λ
i




E

i





2




(
3
)




-




i
=
1






3





λ
i




E

i





2




(
j
)








)


+












[












(

j
-
3

)






i
=
1

3




λ
i




E

i





3




(

0
,
2

)





-

(

j
-
2

)











i
=
1






3





λ
i




E

i





3




(

0
,
3

)




+




i
=
1






3





λ
i




E

i





3




(

0
,
j

)




-










3


(






(

j
-
3

)






i
=
1

3




λ
i




E

i





3




(

2
,
2

)





-

(

j
-
2

)











i
=
1






3





λ
i



E

i





3




(

2
,
3

)



+




i
=
1






3





λ
i




E

i





3




(

2
,
j

)








)


+









2


(






(

j
-
3

)






i
=
1

3




λ
i




E

i





3




(

3
,
2

)





-

(

j
-
2

)











i
=
1






3





λ
i




E

i





3




(

3
,
3

)




+




i
=
1






3





λ
i




E

i





3




(

3
,
j

)








)





]



O
S


+












[












(

j
-
3

)






i
=
1

3




λ
i




E

i





3




(

1
,
2

)





-

(

j
-
2

)











i
=
1






3





λ
i




E

i





3




(

1
,
3

)




+




i
=
1






3





λ
i




E

i





3




(

1
,
j

)




-










2


(






(

j
-
3

)






i
=
1

3




λ
i




E

i





3




(

2
,
2

)





-

(

j
-
2

)











i
=
1






3





λ
i



E

i





3




(

2
,
3

)



+




i
=
1






3





λ
i




E

i





3




(

2
,
j

)








)


+









(






(

j
-
3

)






i
=
1

3




λ
i




E

i





3




(

3
,
2

)





-

(

j
-
2

)











i
=
1






3





λ
i




E

i





3




(

3
,
3

)




+




i
=
1






3





λ
i




E

i





3




(

3
,
j

)








)




]



O
S



+












[





3


(






(

j
-
3

)






i
=
1

3




λ
i




E

i





3




(

2
,
2

)





-

(

j
-
2

)











i
=
1






3





λ
i



E

i





3




(

2
,
3

)



+




i
=
1






3





λ
i




E

i





3




(

2
,
j

)








)


-






2


(






(

j
-
3

)






i
=
1

3




λ
i




E

i





3




(

3
,
2

)





-

(

j
-
2

)











i
=
1






3





λ
i




E

i





3




(

3
,
3

)




+




i
=
1






3





λ
i




E

i





3




(

3
,
j

)








)





]



O
E


+












[





-

(






(

j
-
3

)






i
=
1

3




λ
i




E

i





3




(

2
,
2

)





-

(

j
-
2

)











i
=
1






3





λ
i



E

i





3




(

2
,
3

)



+




i
=
1






3





λ
i




E

i





3




(

2
,
j

)








)


+






(






(

j
-
3

)






i
=
1

3




λ
i




E

i





3




(

3
,
2

)





-

(

j
-
2

)











i
=
1






3





λ
i




E

i





3




(

3
,
3

)




+




i
=
1






3





λ
i




E

i





3




(

3
,
j

)








)




]



O
E



+













l
=
4

P




[









(

l
-
3

)



(






(

j
-
3

)






i
=
1

3




λ
i




E

i





3




(

2
,
2

)





-

(

j
-
2

)











i
=
1






3





λ
i




E

i





3




(

2
,
3

)




+




i
=
1






3





λ
i




E

i





3




(

2
,
j

)








)


-








(

l
-
2

)



(






(

j
-
3

)






i
=
1

3




λ
i




E

i





3




(

3
,
2

)





-

(

j
-
2

)











i
=
1






3





λ
i




E

i





3




(

3
,
3

)




+




i
=
1






3





λ
i




E

i





3




(

3
,
j

)








)


+









(






(

j
-
3

)






i
=
1

3




λ
i




E

i





3




(

l
,
2

)





-

(

j
-
2

)











i
=
1






3





λ
i




E

i





3




(

l
,
3

)




+




i
=
1






3





λ
i




E

i





3




(

l
,
j

)








)




]



P
l











Let the cardinal spline be:








P
n



(
t
)


=




m
=
0

3




p

n
,
m




t
m








and stiffness parameter curve








ξ
i



(
s
)


=




m
=
0


M
i





ξ

i
,
m





s
m

.








For convenience, we assume that the line segment linking the ending point of the former letter and the starting point of the latter letter has been added sufficient number of control points, such that the spline-interpolated curve is sufficiently close to the linking line segment.


The 3-order cardinal spline interpolation formula are:






{






x


(
t
)


=



x
0




P
0



(
t
)



+


x
1




P
1



(
t
)



+


x
2




P
2



(
t
)



+


x
3




P
3



(
t
)











y


(
t
)


=



y
0




P
0



(
t
)



+


y
1




P
1



(
t
)



+


y
2




P
2



(
t
)



+


y
3




P
3



(
t
)














{







P
0



(
t
)


=


a






t
3


-

2





a






t
2


+

a





t










P
1



(
t
)


=



(

a
+
2

)



t
3


-


(

a
+
3

)



t
2


+
1









P
2



(
t
)


=



-

(

a
+
2

)




t
3


+


(


2





a

+
3

)



t
2


-

a





t










P
3



(
t
)


=



-
a







t
3


+

a






t
2












Then










Δ






s
i


=





s

i
+
1


-

s
i


=



0
1










j
=

-
1


2





P
j




(
t
)




O

j
+
i






2




t










=






j
=

-
1


2






l
=

-
1


2




(


O

j
+
i


·

O

l
+
i



)





0
1





P
j




(
t
)





P
l




(
t
)





t












=






j
=

-
1


2






l
=

-
1


2




(


O

j
+
i


·

O

l
+
i



)





0
1






m
=
1

3



m






p

j
,
m




t

m
-
1







n
=
1

3



n






p

l
,
n




t

n
-
1





t















=






j
=

-
1


2






l
=

-
1


2




(


O

j
+
i


·

O

l
+
i



)






m
=
1

3






n
=
1

3



m





n






p

j
,
m




p

l
,
n






0
1




t

m
+
n
-
2





t















=






j
=

-
1


2






l
=

-
1


2




(


O

j
+
i


·

O

l
+
i



)






m
=
1

3






n
=
1

3





m





n


m
+
n
-
1




p

j
,
m




p

l
,
n














=






j
=

-
1


2




O

j
+
i






·



l
=

-
1


2




O

l
+
i







m
=
1

3



m






p

j
,
m







n
=
1

3




n






p

l
,
n




m
+
n
-
1





















In the sequel, we still use s and Δs to denote their scaled versions. However, s is still not exactly the curve length.










E
11

=



0
1





ξ
1



(
s
)







O


(
s
)




2








s









=




i
=
0


K
-
1











s
i


s

i
+
1








m
=
0


M

1
,
i










ξ

1
,
i
,
m




s
m









j
=

-
1


2









P
j



(


s
-

s
i



Δ






s
i



)




O

j
+
i






2








s











=




i
=
0


K
-
1











m
=
0


M

1
,
i












j
=

-
1


2










l
=

-
1


2










s
i


s

i
+
1






ξ

1
,
i
,
m




s
m




P
j



(


s
-

s
i



Δ






s
i



)









P
l



(


s
-

s
i



Δ






s
i



)





O

j
+
i


·

O

l
+
i






s













=




i
=
0


K
-
1







m
=
0


M

1
,
i








j
=

-
1


2






l
=

-
1


2





O

j
+
i


·

O

l
+
i





ξ

1
,
j
,
m






0
1






(


Δ






s
i



s
~


+

s
i


)






m




P
j



(

s
~

)





P
l



(

s
~

)



Δ






s
i





s
~















=




i
=
0


K
-
1











m
=
0


M

1
,
i












j
=

-
1


2










l
=

-
1


2





O

j
+
i


·

O

l
+
i





ξ

1
,
j
,
m



Δ






s
i





0
1






k
=
0

m










C
m
k



(

Δ






s
i


)


k



s
i

m
-
k





s
~

k






n
=
0

3








p

j
,
n





s
~

n






q
=
0

3








p

l
,
q





s
~

q









s
~




















=




i
=
0


K
-
1











m
=
0


M

1
,
i












j
=

-
1


2










l
=

-
1


2





O

j
+
i


·

O

l
+
i





ξ

1
,
i
,
m







k
=
0

m










C
m
k



(

Δ






s
i


)



k
+
1




s
i

m
-
k







n
=
0

3








p

j
,
n







q
=
0

3








p

l
,
q






0
1





s
~


k
+
n
+
q










s
~





















=




i
=
0


K
-
1







j
=

-
1


2




O

j
+
i


·




l
=

-
1


2




O

l
+
i







m
=
0


M

1
,
i






ξ

1
,
i
,
m







k
=
0

m






C
m
k



(

Δ






s
i


)



k
+
1




s
i

m
-
k







n
=
0

3




p

j
,
n







q
=
0

3




p

l
,
q



k
+
n
+
q
+
1






















E
12



(
k
)


=



0
1




s
k




ξ
1



(
s
)




O


(
s
)





s









=




i
=
0


K
-
1







s
i


s

i
+
1








m
=
0


M

1
,
i










ξ

1
,
i
,
m




s

m
+
k







j
=

-
1


2





P
j



(


s
-

s
i



Δ






s
i



)




O

j
+
i





s













=




i
=
0


K
-
1







m
=
0


M

1
,
i








j
=

-
1


2




O

j
+
i




ξ

1
,
i
,
m







s
i


s

i
+
1






s

m
+
k





P
j



(


s
-

s
i



Δ






s
i



)









s













=




i
=
0


K
-
1







m
=
0


M

1
,
i








j
=

-
1


2




O

j
+
i




ξ

1
,
i
,
m






0
1





(


Δ






s
i



s
~


+

s
i


)


m
+
k





P
j



(

s
~

)







Δ






s
i





s
~














=




i
=
0


K
-
1







m
=
0


M

1
,
i








j
=

-
1


2




O

j
+
i




ξ

1
,
i
,
m






0
1






n
=
0


m
+
k











C

m
+
k

n



(

Δ






s
i


)



n
+
1




s
i

m
+
k
-
n





s
~

n






q
=
0

3




p

j
,
q





s
~

q









s
~

















=




i
=
0


K
-
1







m
=
0


M

1
,
i








j
=

-
1


2




O

j
+
i




ξ

1
,
i
,
m







n
=
0


m
+
k







C

m
+
k

n



(

Δ






s
i


)



n
+
1




s
i

m
+
k
-
n







q
=
0

3




p

j
,
q






0
1





s
~


n
+
q










s
~


















=




i
=
0


K
-
1







j
=

-
1


2




O

j
+
i







m
=
0


M

1
,
i






ξ

1
,
i
,
m







n
=
0


m
+
k







C

m
+
k

n



(

Δ






s
i


)



n
+
1




s
i

m
+
k
-
n







q
=
0

3




p

j
,
q



n
+
q
+
1


















E
13



(

k
,
l

)


=



0
1





ξ
1



(
s
)




s

k
+
l





s









=




i
=
0


K
-
1







s
i


s

i
+
1








m
=
0


M

1
,
i






ξ

1
,
i
,
m




s

m
+
k
+
l





s











=




i
=
0


K
-
1







m
=
0


M

1
,
i







ξ

1
,
i
,
m




(


s

i
+
1


m
+
k
+
l
+
1


-

s
i

m
+
k
+
l
+
1



)



m
+
k
+
l
+
1











E
21

=



0
1





ξ
2



(
s
)








O




(
s
)




2




s









=





i
=
0


K
-
1



i


[


K
1

,

K
2


]








s
i


s

i
+
1








m
=
0


M

2
,
i






ξ

2
,
i
,
m




s
m









j
=

-
1


2








P
j



(


s
-

s
i



Δ






s
i



)



/


s








O

j
+
i






2




s











=





i
=
0


K
-
1



i


[


K
1

,

K
2


]








m
=
0


M

2
,
i








j
=

-
1


2






l
=

-
1


2






s
i


s

i
+
1






ξ

2
,
i
,
m




s
m




P
j




(


s
-

s
i



Δ






s
i



)





P
l




(


s
-

s
i



Δ






s
i



)





(

Δ






s
i


)


-
2





O

j
+
i


·

O

l
+
i






s













=





i
=
0


K
-
1



i


[


K
1

,

K
2


]








m
=
0


M

2
,
i








j
=

-
1


2






l
=

-
1


2





O

j
+
i


·

O

l
+
i







ξ

2
,
i
,
m




(

Δ






s
i


)



-
2






0
1





(


Δ






s
i



s
~


+

s
i


)

m




P
j




(

s
~

)





P
l




(

s
~

)



Δ






s
i





s
~















=





i
=
0


K
-
1



i


[


K
1

,

K
2


]








m
=
0


M

2
,
i








j
=

-
1


2






l
=

-
1


2





O

j
+
i


·

O

l
+
i







ξ

2
,
i
,
m




(

Δ






s
i


)



-
1






0
1






k
=
0

m






C
m
k



(

Δ






s
i


)


k



s
i

m
-
k





s
~

k






n
=
1

3




np

j
,
n





s
~


n
-
1







q
=
1

3




qp

l
,
q





s
~


q
-
1






s
~




















=





i
=
0


K
-
1



i


[


K
1

,

K
2


]








m
=
0


M

2
,
i








j
=

-
1


2






l
=

-
1


2





O

j
+
i


·

O

l
+
i





ξ

2
,
i
,
m







k
=
0

m






C
m
k



(

Δ






s
i


)



k
-
1




s
i

m
-
k







n
=
1

3




np

j
,
n







q
=
1

3




qp

l
,
q






0
1





s
~


k
+
n
+
q
-
2






s
~





















=





i
=
0


K
-
1



i


[


K
1

,

K
2


]








j
=

-
1


2




O

j
+
i


·




l
=

-
1


2




O

l
+
i







m
=
0


M

2
,
i






ξ

2
,
i
,
m







k
=
0

m






C
m
k



(

Δ






s
i


)



k
-
1




s
i

m
-
k







n
=
1

3




np

j
,
n







q
=
1

3




qp

l
,
q



k
+
n
+
q
-
1






















E
22



(
k
)


=



0
1




ks

k
-
1





ξ
2



(
s
)





O




(
s
)





s









=

k






i
=
0


K
-
1



i


[


K
1

,

K
2


]








s
i


s

i
+
1








m
=
0


M

2
,
i






ξ

2
,
i
,
m




s

m
+
k
-
1











j
=

-
1


2








P
j



(


s
-

s
i



Δ






s
i



)



/


s








O

j
+
i





s














=

k






i
=
0


K
-
1



i


[


K
1

,

K
2


]








m
=
0


M

2
,
i








j
=

-
1


2




O

j
+
i




ξ

2
,
i
,
m







s
i


s

i
+
1








s

m
+
k
-
1




(

Δ






s
i


)



-
1





P
j




(


s
-

s
i



Δ






s
i



)





s














=

k






i
=
0


K
-
1



i


[


K
1

,

K
2


]








m
=
0


M

2
,
i








j
=

-
1


2




O

j
+
i






ξ

2
,
i
,
m




(

Δ






s
i


)



-
1






0
1





(


Δ






s
i



s
~


+

s
i


)


m
+
k
-
1





P
j




(

s
~

)



Δ






s
i





s
~















=

k






i
=
0


K
-
1



i


[


K
1

,

K
2


]








m
=
0


M

2
,
i








j
=

-
1


2




O

j
+
i




ξ

2
,
i
,
m






0
1






n
=
0


m
+
k
-
1







C

m
+
k
-
1

n



(

Δ






s
i


)


n



s
i

m
+
k
-
n
-
1





s
~

n






q
=
1

3




qp

j
,
q





s
~


q
-
1






s
~


















=

k






i
=
0


K
-
1



i


[


K
1

,

K
2


]








m
=
0


M

2
,
i








j
=

-
1


2




O

j
+
i




ξ

2
,
i
,
m







n
=
0


m
+
k
-
1







C

m
+
k
-
1

n



(

Δ






s
i


)


n



s
i

m
+
k
-
n
-
1







q
=
1

3




qp

j
,
q






0
1





s
~


n
+
q
-
1






s
~



















=

k






i
=
0


K
-
1



i


[


K
1

,

K
2


]








j
=

-
1


2




O

j
+
i







m
=
0


M

2
,
i






ξ

2
,
i
,
m







n
=
0


m
+
k
-
1







C

m
+
k
-
1

n



(

Δ






s
i


)


n



s
i

m
+
k
-
n
-
1







q
=
1

3




qp

j
,
q



n
+
q



















E
23



(

k
,
l

)


=



0
1



kl







ξ
2



(
s
)




s

k
+
l
-
2





s









=

kl





i
=
0


K
-
1







s
i


s

i
+
1








m
=
0


M

2
,
i






ξ

2
,
i
,
m




s

m
+
k
+
l
-
2





s












=

kl





i
=
0


K
-
1







m
=
0


M

2
,
i







ξ

2
,
i
,
m




(


s

i
+
1


m
+
k
+
l
-
1


-

s
i

m
+
k
+
l
-
1



)



m
+
k
+
l
-
1













There is i∉[K1, K2] because the control points on the line segment linking the ending and starting points are not taken into account.













E
33



(

k
,
l

)


=





0
1




k


(

k
-
1

)




l


(

l
-
1

)





ξ
3



(
s
)




s

k
+
l
-
4





s









=




k


(

k
-
1

)




l


(

l
-
1

)







i
=
0


K
-
1







s
i


s

i
+
1








m
=
0


M

3
,
i






ξ

3
,
i
,
m




s

m
+
k
+
l
-
4





s












=




k


(

k
-
1

)




l


(

l
-
1

)







i
=
0


K
-
1







m
=
0


M

3
,
i







ξ

3
,
i
,
m




(


s

i
+
1


m
+
k
+
l
-
3


-

s
i

m
+
k
+
l
-
3



)



m
+
k
+
l
-
3














In order to ensure the smoothness at L1 and L2, ξ3(s) should have peaks around L1 and L2 (shown in FIG. 10a). Intuitively L should satisfy:









L
-

L
1



L
1


=



L
2

-
L


1
-

L
2




,
or






L
=



L
1


1
+

L
1

-

L
2



.









E
11

=





0
1





ξ
1



(
s
)







O


(
s
)




2




s









=






i
=
0


K
-
1







s
i


s

i
+
1








m
=
0


M

1
,
i






ξ

1
,
i
,
m




s
m









j
=

-
1


2





P
j



(


s
-

s
i



Δ






s
i



)




O

j
+
i






2




s











=






i
=
0


K
-
1







m
=
0


M

1
,
i








j
=

-
1


2






l
=

-
1


2






s
i


s

i
+
1






ξ

1
,
i
,
m




s
m




P
j



(


s
-

s
i



Δ






s
i



)





P
l



(


s
-

s
i



Δ






s
i



)





O

j
+
i


·

O

l
+
i






s













=






i
=
0


K
-
1







m
=
0


M

1
,
i








j
=

-
1


2






l
=

-
1


2





O

j
+
i


·

O

l
+
i





ξ

1
,
i
,
m






0
1





(


Δ






s
i



s
~


+

s
i


)

m




P
j



(

s
~

)





P
l



(

s
~

)



Δ






s
i





s
~















=






i
=
0


K
-
1







m
=
0


M

1
,
i








j
=

-
1


2






l
=

-
1


2





O

j
+
i


·

O

l
+
i





ξ

1
,
i
,
m



Δ






s
i




0
1
















Let ξ3(s) be a piece-wise polynomial that satisfies the following condition:















ξ
3



(
0
)


=
a

,







ξ
3



(
1
)


=
a

,







(
2
)













ξ
3



(

L
1

)


=
b

,







ξ
3



(
L
)


=
c

,







ξ
3



(

L
2

)


=
b

,









ξ
3



(

L
1

)


=
0

,







ξ
3



(
L
)


=
0

,







ξ
3



(

L
2

)


=
0

,









Then








ξ
3



(
s
)


=

{











a
-
b


L
1
2




s
2


-



2


(

a
-
b

)



L
1



s

+
a

,





0

s


L
1


,










ξ
~


3
,
3




s
3


-


3
2



(


L
1

+
L

)




ξ
~


3
,
3




s
2


+

3


L
1


L



ξ
~


3
,
3



s

+

[

c
-


1
2




L
2



(


3


L
1


-
L

)





ξ
~


3
,
3




]


,






L
1


s

L

,










ξ
^


3
,
3




s
3


-


3
2



(


L
2

+
L

)




ξ
~


3
,
3




s
2


+

3


L
2


L



ξ
~


3
,
3



s

+

[

c
-


1
2




L
2



(


3


L
2


-
L

)





ξ
~


3
,
3




]


,





L

s


L
2


,










a
-
b



(

1
-

L
2


)

2




s
2


-



2


(

a
-
b

)



L
2




(

1
-

L
2


)

2



s

+

(

a
-



(

a
-
b

)



(

1
-

2


L
2



)




(

1
-

L
2


)

2



)


,





L
2


s

1.









where







ξ
~


3
,
3



=

-


b
-
c



(


L
1

-
L

)



[


(


2


L
1
2


-


L
1


L

-

L
2


)

-


3
2



(


L
1
2

-

L
2


)



]





,







ξ
^


3
,
3


=

-



b
-
c



(


L
2

-
L

)



[


(


2


L
2
2


-


L
2


L

-

L
2


)

-


3
2



(


L
2
2

-

L
2


)



]



.










(
3
)








This gives the coefficients ξ3,i,m.


ξ1(s) should look substantially similar to the graph shown in FIG. 10b. Let ξ1(s) be a piece-wise polynomial that satisfies the following condition:
















ξ
1



(
0
)


=
e

,







ξ
1



(
L
)


=
f

,







ξ
1



(
1
)


=
e

,









ξ
1




(
0
)


=
0

,







ξ
1




(
L
)


=
0

,







ξ
1




(
1
)


=
0

,









then








ξ
1



(
s
)


=

{














ξ
~


1
,
3




s
3


-


3
2


L



ξ
~


1
,
3




s
2


+

(

c
+


1
2



L
3




ξ
~


1
,
3




)


,






0

s

L

,












ξ

^


1
,
3




s
3


-


3
2



(

1
+
L

)




ξ
^


1
,
3




s
2


+

3

L



ξ
^


1
,
3



s

+

[

c
-


1
2




L
2



(

3
-
L

)





ξ
^


1
,
3




]





L

s

1.









where







ξ
~


1
,
3



=

2


(

e
-
f

)



L

-
3




,



ξ
^


1
,
3


=


-
2



(

e
-
f

)





(

1
-
L

)


-
3


.










(
4
)








This gives the coefficients ξ1,i,m.


In select embodiments, pen pressure may be assigned to the connection part. Usually, under normal writing conditions, pen pressure at the connection part is smaller than that in the main body of the character and changes throughout the connecting process. Step 635 may be initiated to assign such pen pressure. In addition to reducing pressure at certain points of the connection part, pressure may also be increased at other points. Indeed, any part of the character and/or connection segment may be assigned a pen pressure value. Illustrating the variance in pen pressure in the connection part can greatly improve the visual quality of synthesized handwriting. The method to assign pen pressure to the connection part can be described below.


Assume that there are m points on the connection-piece (heading and tailing parts), and P1, . . . , Pm are their pressure values, and after the final connection curve is generated, there are n points on the new connection-piece. Then for each point on the final connection curve, the value of pressure can be computed with the equation: {tilde over (P)}i=Pk, where k is the integer part of i/n*m, i=1, . . . , n. The step may render the low-pressure part with small width and high-pressure part with large width.


In yet further embodiments of the invention, the user may utilize aspects of the invention in computing environments where the handwriting output will be displayed in a multi-lined format, such as this paragraph. Therefore, step 640 may be implemented to choose the appropriate inter-line spacing. In most people's handwriting, the top of the second line meets the bottom of the first line, so one embodiment may determine the spacing as follows:

d=Hcapitalletters+Hdescendentletters−Hmiddlezoneletters+Δh

where HCapitalletters, Hdescendentletters and Hmiddlezoneletters are the average heights of all capital letters, all descendent letters, and middle-zone letters, respectively, and Δh is a predefined value. In one embodiment, the Applicant's have determined a value of 3 to be an acceptable Δh.


The present invention has been described in terms of exemplary embodiments. Numerous other embodiments, modifications and variations within the scope and spirit of the appended claims will occur to persons of ordinary skill in the art from a review of this disclosure. For example, one skilled in the art will realize that additional or less steps may be implemented to display and associate the user tiles of the present invention. Moreover, while the exemplary embodiments illustrate the use of user tiles in a PC environment, the invention, however, may be configured for personal gaming systems, such as Sony® Playstation® or Microsoft® Xbox®, handheld systems such as a Palm® or Treo®, among others, for example, cellular-based applications. In still yet further embodiments, the invention is configured for web-based applications that may be incorporated within or independent of cellular-based applications.

Claims
  • 1. A computer-implemented method of facilitating training of a computer to recognize a computer user's handwriting comprising the steps of: (a) receiving, by a computing system configured to facilitate computer recognition of user's handwriting, handwriting samples of at least one character written by the user, the samples comprising at least one sample of the character being provided as the beginning character among a plurality of other characters, at least one sample of the character being provided in the middle of a plurality of other of characters, and at least one sample of the letter being provided as the ending character among a plurality of characters;(b) extracting, by the computing system, a plurality of control points from the samples, wherein the control points represent the shape of the character;(c) determining, by the computing system, the vertical position of the character in relation to a baseline comprising the step of determining the distance from the bottom of the character to a baseline; and(d) normalizing, by the computing system, the at least one sample of at least one character.
  • 2. The computer-implemented method of claim 1, wherein the at least one character is a plurality of characters arranged in a word-type arrangement, the method further comprising the steps of (e) determining, by the computing system, the average horizontal distance between the central axis of at least two characters arranged in the word-type arrangement.
  • 3. The computer-implemented method of claim 1,wherein the at least one character is a plurality of characters arranged in a word-type arrangement, the method further comprising the steps of (e) determining, by the computing system, a connection inclination of at least two successive characters in the word-type arrangement.
  • 4. The computer-implemented method of claim 3, wherein the connection inclination is calculated according to:
  • 5. The computer-implemented method of claim 1, further comprising the steps of: (e) determining, by the computing system, the sample comprises a character that is a multi-stroke letter that requires a plurality of user strokes when written;(f) presenting, by the computing system, a graphical user interface that displays the multi-stroke character of step (e) with a different character that requires a single user stroke, wherein the graphical user interface is presented to the user to indicate the user should provide an input in the form of a handwriting sample that connects the multi-stroke letter with the single stroke character;(g) receiving, by the computing system, an input from the user in the form of a handwriting sample; and(h) determining, by the computing system, how the multi-stroke letter of step (e) is connected to other letters.
  • 6. The computer-implemented method of claim 1, further comprising the step of: (e) prior to normalization, categorizing, by the computing system, at least one character into a group selected from the group consisting of:ascenders, descenders, middle zone, multi-zone, and equivalents thereof.
  • 7. The computer-implemented step of claim 1, further comprising the step of: (e) determining, by the computing system, the amount of pressure the user applies while inputting the handwriting sample in step (a).
  • 8. The computer-implemented method of claim 1, wherein the character is an alphanumeric character.
  • 9. The computer-implemented method of claim 8, wherein the character is provided in lower case format.
  • 10. The computer-implemented method of claim 1, wherein step (c) comprises the step of determining, by the computing system, the ratio of (1 ) the distance from the bottom of the character to a baseline to (2) the overall height of the character.
  • 11. A computer-implemented method of displaying a representation of a computer user's handwriting on a display device comprising the steps of: (a) receiving a user input through a user input device comprising a plurality of characters;(b) determining whether at least two characters received in the user input should be joined;(c) for each character, selecting a sample among a plurality of samples stored on a computer-readable medium to represent the character, wherein the plurality of samples comprises at least one sample of the character being provided as the beginning character among a plurality of other characters, at least one sample of the character being provided in the middle of a plurality of other of characters, and at least one sample of the letter being provided as the ending character among a plurality of characters, wherein the selected sample comprises at least one segment selected from the group consisting of a heading segment, a tailing segment, and a central axis;(d) determining a horizontal distance between the central axis of at least two of the samples, wherein the horizontal distance between one sample may be a different distance than the horizontal distance between another sample;(e) for at least two characters determined to be connected in step (b), adjusting at least a portion of a tailing segment of at least one character and at least a portion of the heading segment of at least one character;(f) joining the at least two characters of step (e); and(g) displaying the at least two characters on a display device, the at least two characters being a representation of the characters received in step (a) in the form of the user's handwriting.
  • 12. The computer-implemented method of claim 11, wherein step (f) includes the use of a connection segment to connect the tailing segment of a first character to the heading segment of a second character.
  • 13. The computer-implemented method of claim 12, wherein the connection segment is shaped according to a 3-order polynomial that considers the closeness of old and new connection parts, the bending energy, and the smoothness of the connection.
  • 14. The computer-implemented method of claim 13, wherein the polynomial that minimizes a whole energy to be used is a final connection piece.
  • 15. The computer-implemented method of claim 11, further comprising the step of: (h) applying a geometric variation of at least one of the samples for the characters selected in (c), wherein the geometric variation comprises a process selected from the group consisting of: scaling and rotation of at least a portion of the sample.
  • 16. The computer-implemented method of claim 11, further comprising the step of: (h) calculating a value of pressure to be applied to at least a portion of a segment of a character.
  • 17. The computer-implemented method of claim 16, where the value of pressure is calculated with the equation {tilde over (p)}i=pk, where k is the integer part of i/n*m, i=1, . . . , n; wherein:m represents m points on a connection piece;p1, . . . ,pm represents their pressure values;n represents that, after a final connection curve is generated, there are n points on a new connection;{tilde over (p)}i represents the value of pressure for each point on the final connection curve.
  • 18. The computer-implemented method of claim 11, wherein the representation of the user's handwriting is displayed on more than one line, further comprising the step of: (h) determining the interline spacing between the lines of handwriting with the equation d=Hcapital—letters +Hdescendent —letters−Hmiddle —zone —letters +Δ,where HCapital —letters, Hdescendent —letters, and Hmiddle —zone —letters are the average heights of all capital letters, all descendent letters, and middle-zone letters, respectively, and Δh is a predefined value.
  • 19. In a computer system having a graphical user interface including a display and a user interface input device, a method of configuring a computer to facilitate computer recognition of a user's handwriting comprising the steps of: (a) displaying on the display device at least one input field for receiving a user input in the form of handwritten sample characters, wherein the handwritten sample characters comprises at least one sample of the character being provided as the beginning character among a plurality of other characters, at least one sample of the character being provided as being the middle of a plurality of other of characters, and at least one sample of the letter being provided as the ending character among a plurality of characters;(b) receiving an input signal indicative of the user interface input device providing at least one sample character comprising at least one segment selected from the group consisting of a heading segment, a tailing segment, and a central axis;(c) based upon the signal, assigning the received sample character to be the representative character for a sub-category selected from the group consisting of: the beginning character among a plurality of other characters, the character being provided as middle character among a plurality of other of characters, and the ending character among a plurality of characters, wherein the selected sample comprises at least one segment selected from the group consisting of a heading segment, a tailing segment, and a central axis; and(d) normalizing the representative character; and(e) storing the assigned, normalized character on a computer readable medium.
  • 20. The method of claim 19, the system further comprising a second user interface input device, the method further comprising the steps of: (f) receiving a input signal indicative of the second user interface input device providing at least two characters;(g) determine whether to join the at least two characters received of step (e);(h) selecting a representative character among a plurality of representative characters stored on the computer-readable medium to represent each of the characters received in step (f), wherein the plurality of characters comprise at least one sample of the character being provided as the beginning character among a plurality of other characters, at least one sample of the character being provided in the middle of a plurality of other of characters, and at least one sample of the letter being provided as the ending character among a plurality of characters;(i) performing geometric variation on at least one of the selected characters; and(j) displaying the at least two characters on a display device, the at least two characters being a representation of the characters received in step (f), wherein the characters are displayed in the form of the user's handwriting.
US Referenced Citations (5)
Number Name Date Kind
4024500 Herbst et al. May 1977 A
5048097 Gaborski et al. Sep 1991 A
5812698 Platt et al. Sep 1998 A
5850477 Takada Dec 1998 A
6175651 Ikebata et al. Jan 2001 B1
Foreign Referenced Citations (1)
Number Date Country
8-50632 Feb 1996 JP
Related Publications (1)
Number Date Country
20070154094 A1 Jul 2007 US