GB2234102A - Handwritten keyboardless-entry computer system - Google Patents
Handwritten keyboardless-entry computer system Download PDFInfo
- Publication number
- GB2234102A GB2234102A GB9019254A GB9019254A GB2234102A GB 2234102 A GB2234102 A GB 2234102A GB 9019254 A GB9019254 A GB 9019254A GB 9019254 A GB9019254 A GB 9019254A GB 2234102 A GB2234102 A GB 2234102A
- Authority
- GB
- United Kingdom
- Prior art keywords
- symbol
- handwritten
- screen
- symbols
- stroke
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/01—Input arrangements or combined input and output arrangements for interaction between user and computer
- G06F3/048—Interaction techniques based on graphical user interfaces [GUI]
- G06F3/0487—Interaction techniques based on graphical user interfaces [GUI] using specific features provided by the input device, e.g. functions controlled by the rotation of a mouse with dual sensing arrangements, or of the nature of the input device, e.g. tap gestures based on pressure sensed by a digitiser
- G06F3/0488—Interaction techniques based on graphical user interfaces [GUI] using specific features provided by the input device, e.g. functions controlled by the rotation of a mouse with dual sensing arrangements, or of the nature of the input device, e.g. tap gestures based on pressure sensed by a digitiser using a touch-screen or digitiser, e.g. input of commands through traced gestures
- G06F3/04883—Interaction techniques based on graphical user interfaces [GUI] using specific features provided by the input device, e.g. functions controlled by the rotation of a mouse with dual sensing arrangements, or of the nature of the input device, e.g. tap gestures based on pressure sensed by a digitiser using a touch-screen or digitiser, e.g. input of commands through traced gestures for inputting data by handwriting, e.g. gesture or text
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/01—Input arrangements or combined input and output arrangements for interaction between user and computer
- G06F3/03—Arrangements for converting the position or the displacement of a member into a coded form
- G06F3/033—Pointing devices displaced or positioned by the user, e.g. mice, trackballs, pens or joysticks; Accessories therefor
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06V—IMAGE OR VIDEO RECOGNITION OR UNDERSTANDING
- G06V30/00—Character recognition; Recognising digital ink; Document-oriented image-based pattern recognition
- G06V30/10—Character recognition
- G06V30/32—Digital ink
- G06V30/333—Preprocessing; Feature extraction
- G06V30/347—Sampling; Contour coding; Stroke extraction
-
- G—PHYSICS
- G09—EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
- G09B—EDUCATIONAL OR DEMONSTRATION APPLIANCES; APPLIANCES FOR TEACHING, OR COMMUNICATING WITH, THE BLIND, DEAF OR MUTE; MODELS; PLANETARIA; GLOBES; MAPS; DIAGRAMS
- G09B5/00—Electrically-operated educational appliances
- G09B5/06—Electrically-operated educational appliances with both visual and audible presentation of the material to be studied
- G09B5/065—Combinations of audio and video presentations, e.g. videotapes, videodiscs, television systems
-
- F—MECHANICAL ENGINEERING; LIGHTING; HEATING; WEAPONS; BLASTING
- F02—COMBUSTION ENGINES; HOT-GAS OR COMBUSTION-PRODUCT ENGINE PLANTS
- F02B—INTERNAL-COMBUSTION PISTON ENGINES; COMBUSTION ENGINES IN GENERAL
- F02B75/00—Other engines
- F02B75/02—Engines characterised by their cycles, e.g. six-stroke
- F02B2075/022—Engines characterised by their cycles, e.g. six-stroke having less than six strokes per cycle
- F02B2075/025—Engines characterised by their cycles, e.g. six-stroke having less than six strokes per cycle two
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Computer Vision & Pattern Recognition (AREA)
- Human Computer Interaction (AREA)
- Educational Administration (AREA)
- Educational Technology (AREA)
- Business, Economics & Management (AREA)
- Position Input By Displaying (AREA)
- Character Discrimination (AREA)
Abstract
A keyboardless-entry computer system includes a transparent input screen (18) that generates positional information when contacted by a stylus (16), and a display screen (20) mounted below the input screen (18) such that a character that is displayed can be seen below the input screen (18). The system includes a computer (14) programmed to compile the positional information into Strokes, to calculate Stroke characteristics, and then compare the Stroke characteristics with those stored in a database in order to recognise the symbol drawn by the stylus (16). The system may be used to edit text or complete standard forms, e.g. with medical data. <IMAGE>
Description
HANDWRITTEN KEYBOARDLESS-ENTRY COMPUTER SYSTEM
The present invention relates generally to a keyboardless input system to a computer, and when combined with a central processing unit, to a keyboardless-entry computer system. More particularly, the present invention relates to an information storage, manipulation and transfer device on which text, data, computer commands and functions can be entered by writing alphanumeric or any other characters and symbols by hand with a penlike stylus on an Input/Output (I/O) screen. In a preferred embodiment the I/O screen includes a transparent touch screen incorporated over a substantially flat output display. The present invention in its preferred embodiment is a self-contained computer system but can also function as a peripheral to a host computer.
Large amounts of information and sophisticated applications software are now available on conventional keyboard computers. The utility of this information and of application software could be greatly increased if text and data could be entered and applications software manipulated by writing in a mcrma} fashion -diT.:tly on a. fiat display. Thus, there is a need to allow the utility of computer technology to be extended for use by non-keyboard oriented individuals. There is also a need for a portable computer system that is lightweight, reliable, accurate, inexpensive and permits use while standing or -walking. One way to reduce expense and si:e- #nd- increase utility is to employ a keyboardless entry system, such as a touch screen.However, this type of input device does not easily allow accurate detailed input within a real time framework with high resolution in a manner which is famiiiar and natural to the user.
Many positioning technologies can be used to meet the requirements of the position sensing input technology.
Essentially these requirements include accuracy, resolution and speed. The technologies include: mechanical, electrostatic, electromagnetic, acoustic, optical, and inertial. The desire in this system is to have its use as similar as possible to ##ting wi-til pen or pencil on paper. .One - problem is proximity -- a pen on paper only leaves a trail when actually in contact.
Many of these technologies require an additional "pen down" sensor which is awkward to use in many commercial pens.
Another problem is writing angle -- a pen leaves the same trail independent of writing angle. Many of these technologies have the--position detector displaced from the wen tip, so pen angle causes erroneous displacements. Beyond these general problems, each technology has numerous advantages and disadvantages in (1) the pen: size, weight, shape and whether it needs to be powered and/or wired, and (2) the writing. sirface-.
transparency, smoothness, "feel", and whether or not physical contact is needed (as opposed to pressure transmitted through overlaying sheets of paper).
A number of self-contained devices for viewing and processing large amounts of information are known. Most employ optical, magnetic or solid-state electronic storage means to store data. Illustrative of this body of art is U.S. Patent 4,159,417 to Rubincam which discloses a portable electronic book configured to provide selective page by page call-up of large amounts of digital data and displays it on a flat, solid-state screen. The preferred embodiment in the Rubincam patent uses an insertable holographic card, which may contain several hundred pages of text in digital form, as the main storage means. Rubincam's device, however, does not allow new information or text to be entered or manipulated.
In U.S. Patent 4,016,542 to Azure an electronic data collection system is disclosed which employs a solid state Random Access Memory (RAt) for its primary memory. This patent, which discloses a conventional keyboard for data entry, is directed to a hand-held portable data storage and transmission system, as well as an LED display and various Input/Output (I/O) connectors.
U.S. Patent 3,487,731 to Frank discloses a means of converting handwriting into character data through the use of a computer system. The disclosed invention is based on matrix pattern matching and does not employ any coincident display technology.
U.S. Patent No. 4,491,960 to Brown shows a handwritten symbol recognition system in which an array of image Points, in the form of a raster line sampling, is converted into segmentoriented lists which are filtered and compressed to obtain topologic features which are then analyzed with a logic tree decision mechanism.
U.S. Patent No. 4,262,281 to Buckle et al. discloses a handwriting recognition device. The disclosed embodiment is for use with a host computer and does not employ coincident display technology.
U.S. Patent No. 4,475,239 to Van Raamsdonk discloses a text editing apparatus. The '239 patent calls for the use of paper as a medium for the entering of editing functions and requires a conventional keyboard for the inputting of text.
U.S. Patent 4,521,909 to Wang shows a dual level pattern recognition system. The system is designed for use with an optical instrument.
U.S. Patent 9,520,357 to Cattleberry et al. discloses an electroscopic information display and entry system with writing stylus. The disclosed embodiment does not claim to have the speed or accuracy to enable handwritten character recognition.
Additional prior art which discloses portable electronic devices that provide large amounts of various types of stored information include U.S. Patents 4,218,760 to Levy; 4,4II5,4#6 to Lane; and 3,932,-55-9 to Xriakides et al. The
Levy and Kriakides et al. patents pertain to electronic dictionaries, while the Laine patent discloses a programmable television reminder system. None of these devices disclose the use of a handwritten input.
Din .U~S Patents 4,071,691 4,129,747, 4,198,539, 4,293,734, 4,302,011, 4,353,552, 4,371,746 and 4,430,917 to
William Pepper, Jr. various methods or machine-human interfaces using finger touch are disclosed. The preferred embodiments in each of these inventions lack sufficient speed and resolution to allow handwritten character recognition with a stylus and are designed for other purposes. U.S. Patent 4,318,096 to Pepper teaches the use of a conductive stylus. The '096 patent pertains to graphic design and allows line width and line intensity to vary by applying pressure on the stylus with the results displayed on a conventional CRT screen. U.S. Patent 3,699,439 to Turner and U.S.
Patent 4,055,726 to Turner et al discloses two methods for electronic position sensing through the use of a probe.
The invention in its various aspects is defined in the appended claims to which reference should now be made.
A preferred embodiment of the invention which is described in more detail below with reference to the drawings comprises a unique keyboardless computer system which has the ability to recognise and display Handwritten Symbols and cause the computer to display Font Symbols and, if desired, to execute editing functions pursuant to Editing Symbols, quickly, easily and at reasonable cost.
This preferred embodiment includes a computer housing with a flat display panel on which a user may "write" with a stylus, and has a capability to recognise Handwritten Symbols written on the panel with the Stylus and convert them to displayed Font Symbols, and/or to execute Editing Functions with Editing Symbols, all with a minimum of technical complexity for the user. Once the keyboardless, portable computer is loaded with the desired information and applications software, information and software can be used and responded to without requiring skills or knowledge related to state-of-the-art computers or other data source. The ease-of-use of the input technology of the apparatus enhances the utility of the computer for keyboard oriented individuals.
Its portability also allows it to be used in applications and settings in which portable keyboard computers are awkward, difficult or impossible to use. For example, a multiplicity of blank, fully or partly completed forms may be stored in the portable computer memory. In-a-hospital, tshests" of patient data can be stored in the memory of the portable computer, called up by a nurse as the nurse makes rounds and relevant data, such as blood pressure, temperature, etc., can then be entered manually- with -a stylus~ These corrected or. expanded forms can then be down-loaded into a central computer memory.
The requirements of the position sensing input technology are accuracy (Point to Point), resolution (absolute position) and speed (Points per unit time) to adequately define the written Stroke for recognition analysis. For the recognition apparatus and methods presently used, as described below, the present minimum requirements are accuracy of 0.125mm (0.005 inch), resolution of 0.375mm (0.015 inch) and speed of 150 Points per second. This accuracy allows a 6rtrn (1/4") high writing line with over 10 raw input Points along a Stroke of a small letter. The resolution provides positioning of the symbol to within two pixels on a present display of 640 pixels to 225rrni (9 inches).The -spe-ed -#ermits -ab-out# .ao raw input Points for a -rapidly written single letter (1/3 second).
One embodiment of the present invention comprises a transparent input screen. As the user writes alphanumeric or other characters or symbols on the input screen, the character is represented as a stream of Points emulating written input with pen on paper. Once the discrete alphanumeric and other characters or symbols are complete, they are translated into computer text or computer commands that can be displayed on a display screen at a location that is preferably beneath the area on the input screen where they were entered. The embodiment also comprises a pattern recognition algorithm which allows the translation of any written character or symbol, such as ideographs and scientific symbols, into computer text.
In a particular, presently preferred embodiment, a keyboardless computer is configured as a manipulation and display device comprising a transparent touch screen and associated electronics placed over an SO column by 25 line or larger display screen; a stylus for entry of data; a microprocessor and storage means; artificial intelligence/pattern recognition software and editing software; and a battery power system; and other I/O means.
As used herein, "Handwritten Symbols" are any symbols capable of being handwritten and having communicative effect.
By way of example, and not limitation, numbers, letters, "kanji" (Japanese ideograms) or other language symbols, editing symbols and engineering, scientific, architectural and mathematical symbols are Handwritten Symbols. Other examples of Sandwritten Symbols are free-hand drawings or signatures or any other such written information uniquely configured by a particular writer. handwritten Symbols may also include
Editing Symbols (defined below).
As used herein, "Font Symbols" are computer-generated symbols which are displayed in a predetermined font format. By way of example and not limitation, alphanumeric symbols may be
Font Symbols and displayed in numerous font formats. Japanese or Chinese "ideograms" may also be Font Symbols, as may be engineering, scientific, mathematical, architectural or other such characters. Other examples of Font Symbols include any form which can be stored and displayed by a computer, e.g., a drawing of a car or a house.
As used herein, an "Editing Symbol" is a symbol (such as a caret, horizontal line, short vertical line, long vertical line, etc.) which is intended, when recognized, to cause the computer to execute a particular Editing Function (defined below), such as insert test (caret), delete text (horizontal line) delete a letter (short vertical line) or move a margin (long vertical line), to list a few representative examples.
"Editing Function" means any computer-generated text editing aperatisn, such as by way of example and not limitation, insert text, -delete test, move text-and-substitute text. Some primary Editing Functions are listed towards the end of the description below.
The preferred embodiment of a keyboardless entry computer system will now be'described that includes a transparent input screen that generates positional information when contacted by a styles, and a display s-creen mounted physically below the input screen such that a character that is displayed can be seen below the input screen. The system includes a computer programmed to compile the positional information into Strokes, to calculate Stroke characteristics, and then compare the Stroke characteristics with those stored in a database in order to recognise the symbol drawn by the stylus.Key features of the system are: (A) transparent position sensing subsystem; (B) underlying display on which to mimic drawing of sensed-positions and to show characters or symbols; (C) means to convert sensed positions first into plotted Points and then into recognised characters or symbols; and (D) means to "learn" to associate sensed input positions with a character or symbol. The apparatus can be housed in a portable unit having dimensions up to about 400mm by 400mum by 100mm (16" x 16" x 4") and -a- weight of up to about 7 kilograms -(15 pounds), with a selfcontained power supply.
Brief Description of the Drawings
The preferred embodiment of the invention will be described in more detail by way of example with reference to the drawings, in which:
Fig. 1 is a schematic system block diagram of an embodiment of the present invention;
Fig. 2 is a perspective view of the housing containing the operating elements of the system;
Fig. 2A is an enlarged portion of Fig. 2, with parts removed to show the positional relationship between the touch input screen and the display screen.
Fig. 3 is a schematic diagrammatic view of the input screen, stylus and associated electronics;
Fig. = is an overall schematic system block diagram of the apparatus of a keyboardless entry computer system according to the present invention;
Fig. 5 is a schematic block diagram depicting the movement of data within the system when modified by handwritten characters and commands; Fig. 6 is an overall system block diagram depicting the hierarchy of software used to operate the system;
Fig. 7 is a generalized block diagram of the character and pattern recognition algorithm.
Figs. 8A and 8B together are a detailed block diagram of the pattern recognition algorithm.
Fig. 9 is a schematic block diagram of the Stroke characterization subroutine.
Fig. 10 is a top plan view of a screen illustrating the initializing of the database for Handwritten Symbols.
Figs. 11A through 111 are a series of top plan views of screens depicting the operation of a text editing system.
Figs. 12A through 12G are a series of top plan views of screens depicting the operation of aa:data entry system.
Fig. 13 is a generalized block diagram of the Linus
Editor.
Detailed Description of the Preferred Embodiments: With reference - -now to the ì.##res, wherein like numerals indicate like elements throughout the several views, and in particular with reference to Fig. 1, an overall block diagram of a portable handwritten, keyboardless entry computer system 10 is depicted. The complete computer#system is encased in a housing 12, indicated g-aphically by the dashed line, and includes a conventional, general purpose digital microcomputer 14, described in greater detail hereinbelow. Input information is provided to microcomputer 14 by stylus 16 "writing" on writing or input screen 18. Stylus 16 (Fig. 2) is connected to the computer of system 10 with wire 17 (Fig. 2).As stylus 16 writes on input screen 18, a plurality of locating signals representative of.2.pLurality of corresponding positional coordinates are transmitted to microcomputer 14. Microcomputer 14 has been programmed in accordance with a computer program described hereinbelow, to recognize the stream of locating signals and to store these signals in a computer memory. The programmed microcomputer 14 also provides a corresponding plurality of display signals -to -a -disp-l'ay- -s=#n 20 Both input screen 18 and display screen 20 are described in greater detail hereinbelow.
Referring now to Fig. 2, there is shown a perspective view of keyboardless computer system 10 embodying the features of the present invention. Keyboardless computer system 10 is contained in housing 12, which is a rectangular enclosed casing having a sloped top surface 22 with a multi-line, solid state display area 24. Input screen 18 is depicted in Fig. 2A as being positioned over display screen 20. In this example, display screen 20 displays a plurality of horizontal lines 25 with the following indicia:
Name
Address
Handwritten entries are made above each line 25. The distance or space between two lines 25, denoted 26, is used by the system to normalize all distances, and lines 25 themselves serve as a reference axis or base line.
Below display area 24 on top surface 22 is a key input section 26 comprised of a plurality of "Softkeys" 28.
So#tkeys 28 can be prograr.med by the operator for any purpose, such as to enter co.- ter commands. Exemplary commands for
Softkeys 28 are "store," "recall," and "delete." In addition,
Softkeys 28 can be used to switch between different programs or between modes (e.g. data entry mode and edit mode). However,
Softkeys 28 are optional and are used to supplement the input obtained by handwriting the entries. Stylus 16, used for writing input data and commands in display area 24, also is used to activate the selected Softkey 28. An ON-OFF switch 30 is positioned on the side of housing 12 adjacent to Softkeys 28. A data output or peripheral connector 31 is located on the upper right side of housing 12.
Input screen 18 can be a conventional resistive type touch screen in which a voltage is applied to the screen edges and a stylus detects the voltage at the touched location. The writing surface is a transparent material, typically glass, coated with a thin, uniform, conductive layer (presently, vacuum deposited indium tin oxide). Vertical bus bars or conducting strips (not shown) are used along the two sides to apply the reference voltage to determine the "X" coordinates of the stylus position and horizontal bus bars or conducting strips tnot-shown) are used along the-bottom -and top to apply the reference voltage to determine the "Y" coordinates of the stylus position.In this embodiment, stylus 16 is merely an electric probe that, when physically in contact with the conductive layer, detects the local voltage at the Point of contact, which will vary with the distance from the conducting strips or bus bars. With the origin at the Point of voltage application, the X, Y coordinates are inversely proportional to the impressed voltage. Stylus 16 must make good contact to minimize adding resistanc-e that would lower the voltage detected, and thus. add an erroneous distance increment. In a presently preferred embodiment, a soft graphite tip is used.
The voltage is conducted from the pen through a wire, such as wire 17 in Fig. 2, to an analog to digital converter for use in the computations described below. The stylus may be a charged pen as described herein, a light pen as is well known in the art, or any other hand-held device which can outline Hand written Symbols 4n a -screen.
An example of a conventional electrostatic screen is disclosed in the aforementioned 4,318,096 Pepper patent. This resistive type screen has the advantage that the interference caused by the user's hand touching the screen is minimized.
B > th hnrizontal and vertica#l#position sensing is-pro- vided by alternately switching the voltage impressed on a conductive layer between the pairs of horizontal and vertical bus bars by an interface and multiplexer controlled by a microcomputer or microcontroller. In one commercially available input or touch screen, the bus bars are broken into a series of short strips with diodes to prevent the horizontal strips from shorting out vertical strips and vice versa. This technique is used in a commercially available touch screen from Touch
Technologies of Annapolis, MD. and Elographics of Oak Ridge,
Tenn.
Referring now to Fig. 3, an alternate embodiment of a low power position sensing novel input screen 33 is described in greater detail. Input screen 33 is also for determining an
X,Y position on an electrically resistive plate 34. A stylus 35 containing a voltage source, such as battery 36 or a voltage transmitted to stylus 35 from an external source such as the system power supply, is used to touch screen 34 and apply a voltage at the touched position. When the touched position is charged by stylus 35 with a positive voltage with respect to a plurality of plate measurement Points 37, the voltages at these
Points will vary with the distance to the pen position, such as position X1, Y1, indicated at 38.These voltages are sequentially measured in the X and E directions by using conventional means, such as disclosed in the aforementioned prior art patents. In Fig. 3 these means are a conventional interface/multiplexer 42. A conventional Analog-to-Digital converter 43 converts the detected voltages into a digital signal. A microcontroller 44 receives the digital signal, performs standard checks to insure the signal's numerical value is "valid" (e.g. is within the possible range of voltages), and then converts the voltages to X and Y distances in the manner described herein. Microcontroller 44 is conventional, but could be replaced by a system computer. Microcontroller 44 provides a digital signal representative of the X and Y distances to measuring Point 38 to an output port 46. Port 46 can be a conventional RS 232 port. Alternatively, microcontroller 44 could translate Point X1, Y1 to any other reference Point, such as a Point on base line 25 (Fig. 2).
As long as there is no contact by stylus 35 at position 38 or any other p#sition -ofl .plate > 4, no current flows and power consumption is minimal. An incident measurement of the voltage at the measurement Points may occur by using ramped voltage at the positioning Point and timing when the measuring
Point voltage exceeds a preset back voltage.
There. are various options for the input or touch screens 18 and 33: resistive plate 34 or its equivalent for screen is can be transparent or translucent and the position Point can be made by a stylus or a finger of the user, or a connecting Point of an overlapping conductive screen (such as the commercially available touch screens from Touch Technology, Annapolis, MP.). Input screens 18 and 33 can be a physical solid surface which is transparent,
or translucent and can be glass or plastic such as Mylar
(Registered Trademark). The surface can be coated with a conductive/resistive substance like indium tin oxide.Other physical surfaces can use sound or electromagnetic radiation transmission from the touched position to a reference Point or Points and the distance is determined by the time delay or phase shift. Alternatively, input screens 18 and 33 can use an ethereal or geometric surface defined by an electromagnetic, optical or sonic field.
Position detection can be accomplished with electrical contact closure by resistive, capacitive or inductive coupling, remote sensing by sonic, electric or magnetic fields or by light (UV, IR, or microwave) scanning.
The advantages of the low power position sensing input arrangement over other such screens are: 1) it makes stand-by power requirements minimal; 2) it eliminates distortion due to opposing parallel "bus" bars in conventional touch screens; and 3) when a ramped voltage is employed,
it eliminates the need for an A/D chip which is a major cost factor in state-of-the-art touch screen technology.
The coefficient of friction of the screen 18 is desirably selected to be "rough" enough to offer some resistance to the movement of stylus 16 on the screen. If the screen were too smooth, the stylus would slide too easily and would be difficult to control.
Reference is now made to Fig. 4 which discloses an overall system block diagram of the major electronic circuitry used in the preferred embodiment of the present invention.
Microcomputer 14 includes a microprocessor 50, interconnected to a plurality of other electronic elements by means of data path or bus 52. A Read-Only-Memory (ROM) 54 which is programmed with the operating and application programs and a battery powered##andom Access Memory (RAM) 56 is connected for bidirectional data flow onto bus 52. Microprocessor 50 may be a conventional single-chip eight-bit or sixteen-bit device which functions to execute the fixed control programs residing in ROM 5, and further receives control programs from and provides control signals to the other electronic elements via bus 52.Microprocessor 50 may be of the type commercially designated Z80 (manufactured by Zilog Microcomputers of
Cupertino, California), of a type 8088 device (manufactured by
Intel Corp. of Santa Clara, California) or any similar or more powerful microprocessor. ROM 54 may be of the type 2564 or 4764, both manufactured by Texas Instruments of Dallas, Texas.
The storage capacity of RAM 56 is determined in part by the sizes of the application programs, the operating program and the database. As discussed below, RAM 56 may be of the static
SRAM or dynamic DRAM type. The primary requirements of RAM 56 are that it have sufficient storage capacity and that it require a minimum of input power.
A battery 58, such as a lithium battery, provides power for -:naking the memory of RAM 56 non-volatile for extended periods of time. A battery pack 60 containing the well-known rechargeable types of batteries is used to provide the various voltage levels required by the other electronic elements of microcomputer 14
Alternately, the storage function of RAM 56 may be served by a non-volatile device which requires no power for maintaining storage, such as an electronically erasable and reprogrammable memory (PROM), or devices using magnetic bubbles or capacitance. State-of-the-art disk or tape may also be used for mass storage.Suitable bubble memory devices include types 711C and 7114 which have storage capacities of 1 megabit and 4 megabits respectively. (Both are manufactured by Intel Corp.).
Eurthermore, it is possible to use a single integrated circuit chip which includes microprocessor 50, at least part of ROM 54 and at least part of k^s; 56.
Also connected to bus 52 is an EIA RS-232 serial inter space 62 which provides a means for inputting and outputting data.
Data is provided to bus 52, (usually to RAM 56) by interconnecting an external data source to RS-232 port 62 directly to the microprocessor 50 and other elements of the microcomputer 14.
Offloading data from RAM 56 can also be done by microprocessor -50 to in external cornptiter, -other .dita gathering --device, a mass data storage device (e.g. floppy and hard disk drives) or an electronic telecommunications system. In like manner data can be communicated through port 62 to a printer (not shown) from interconnecting bus 52.
Stylus.16 is used to write on input screen 18 and to cause the generation of X,Y coordinate information by conventional touch screen interface electronics circuitry. The coor donate informaticn is communicated 'via the bus 52 fo-r control use by system 10. The solid state display 20 consisting of a multi-line display -- illustratively SO columns by 25 lines -is interconnected to bus 52 through a display interface 66.
The fundamental requirements for the display are that it be sub stantially flat and sufficiently thin for use in the present invention. The display may be of the following types: scanning types such as a cathode ray tube, projected types such as a rear-view projector, light emitting array of Points types (e.g., electroluminescent or plasma discharge) and light blocking array of Points types (e.g., liquid crystal displays, solid state PLTZ or magneto-optical). In addition, it is preferable that the display be compatible with input screen 18 in size, configuration and transparency, and that both be low power consuming types.
The X,Y coordinates are input to keyboardless computer 1 via input screen interface electronics 64 and communicated via bus 52 to microprocessor 50 which executes programs stored in ROE 54 and RAM 56.
The number of Points (i.e., sets of X,Y coordinates) used in defining each Handwritten Symbol and the speed at which
Points are identified are important for practical utility. It is desirable to use at least about 4 Points per millimetre (100
Points per inch) and at least about 100 Points per second to define Handwritten Symbols. It is to be noted that the more
Points per unit length that are identified, the greater the accuracy of the system in identifying Handwritten Symbols -- however, more Points being identified will slow down the speed of identification and require more computer memory. Accordingly, a balance will have to be achieved, based on the size (available memory and processing ability) of the computer system and the requirement for speed of response and accuracy.For most purposes, standards in the range ram about 4 Points per znm (100 Points per inch) and 100 Points per seccod to about 8 Points per rtrn (200 Points per inch) and 200 Points per second will be suitable.
It is also to be noted that the greater the precision
of the system in identifying the X,Y coordinates of each Point the fewer the number of Points needed to be identified unit length and per second to accurately identify Handwritten Symbols. Conversely the less the accuracy, the more Points that are needed.
Point resolution is needed to place Points where intended, e.ç., to write an editing symbol precisely between the two -characters. Ideally,- resolution 'to a single display pixel is desirable. However, operationally, resolution within two displayed pixels is sufficient for a display with 640 pixels in a 225mm (nine inch) horizontal scanline.
When switch 30 (Fig. 2) is positioned to "power on", the basic display mode is activated and microcomputer 14
(Fig. 4) programmed by the operating system, causes a menu to be displayed on display screen 20 (Fig. 1). The menu presents -Cwaricus soft#are -op-i#ns. A prima-y software function, editing, functions in a manner similar to conventional word processing software with the difference being that handwritten characters, symbols and commands are interpreted by the system as if they were entered from a conventional keyboard.The system is capable of learning the editing symbols used by a particular writer for functions such as indent, insert, delete, move and reformat and translates those symbols into digital command functions. Optionally, Softkeys 28 (Fig. 2), activated by touching those#areas on the input screen-with stylus 16, function like conventional hard function keys on a computer keyboard.
The system is particularly adapted for use as an interaetive screen editor or word processor. After a writer retrieves a document by (for example) touching the displayed name of an existing file with the stylus or by writing the name of the file on the screen, all usual editing functions can be performed with stylus entry. When the user wishes to change a displayed character or symbol, he may simply write over the displayed character or symbol and as described hereinbelow the pattern recognition algorithm will translate the written entry into computer text. For example, the editing software allows text to be eliminated by simply drawing a line through it and a conventional caret symbol may be used to change the operating mode to the insert, mode.In the insert mode, display screen 20 provides additional space for entry of handwritten characters or symbols which are inserted in the text after the Point where a caret was written in. Text can be moved simply by placing brackets or other user-defined delimiters around a displayed phrase or word and writing a caret or other user-de'ined symbol in the area of the text in which the user wishes this material to appear. New margins can be set by drawing vertical lines down the side of the displayed text where the new margins should appear.
The basic editor software also allows new documents to be created by simply writing Handwritten Symbols on the screen.
All documents can be stored, changed and communicated in the manner in which these functions are accomplished on a conventional word processing system with the difference that these functions are accomplished with handwritten Editing
Symbols on the (optional) screen or by touching the Softkeys with the stylus. The composite text thus produced and stored can be subsecuently offloaded through the RS 232 port 62 (Fig.
4) to another computer, a similar device, an external data gathering device or recording device, into a printer or through a telecommunications system.
In addition to these major operating modes, a number of an#illary-elenents -and features add to the utility of the system. A conventional alphanumeric keyboard (not shown) containing a full set of keys can be connected to a con ventional keyboard interface (not shown) to support the entry -of.alphanumeric characters. An.AC/#C.power connectcr may also be used in those applications when portability is not needed and when needed to meet the power requirements of screen technologies such as gas plasma displays and electroluminescent displays.
In actual use the Begbozardless computer can function in any application or environment in which handwritten input translated into computer text is useful or necessary. Illustratively, the device can function as a new generation word processor, or for use in fields such as sales, nursing, inventory control, census taking, claims adjusting, to name just a few of its many uses or as a general learning and testing device in education. Since the pattern recognition z#o-ftware--can-. learn--and translate into computer text .from languages which are not made up of a small or limited set of alphanumeric characters (e.g., Japanese, Korean, and Chinese), it has particular utility for word processing and telecommunications in these languages.
- In practice, its is particularly desirable to use a single computer screen to display any initial forms, Font Symbols or other displays to be edited, and to create a nearby "window" of blank space where Handwritten
Symbols are to be written, displayed and identified, and where the font Symbols c-orresponding to the Handwritten -Symbol-s are to be displayed. In this way, the user can view the text being edited and the proposed insert or change without significant movement Cif -any) of the head and eyes. This is illustrated in Figs. liy to liD.This feature (proximity on one screen of text to be edited and the window into which new text is to be handwritten) is very important to the simple, rapid, comfortable use of the system.
In a preferred embodiment of this invention, the system "learns" the handwriting of a particular user prior to actual use. For example, if using the Roman alphabet, the twenty-six letters of the alphabet and the numerals from 0 to 9 would be inserted into the database. Punctuation symbols, such as periods, commas, question marks, colons, semi-colons, hyphens and the like could also be inserted. There is virtually no limit to the Handwritten Symbols which can be recognized and stored in the database. Of course, the computer will have to store a suitable array of Font Symbols for conversion of the handwritten Symbols. Different sets of Font
Symbols could be created and stored in the permanent memory of the computer, as in RO chip 54.For example, in English language usage, a chip could contain one (or more) fonts of numbers and letters, suitable punctuation symbols and appropriate mathematical symbols. Other chips could have stored Font Symbols for the Arabic, Cyrillic or Greek alphabets, Japanese, Chinese or Norean "Konji", symbols for use by architects or engineers, or chemical symbols (e.g., benzene rings and the like).
In Fig. 10, one of a series of learning screens is displayed and the user is prompted to write the numbers 0 through 4. The computer will attempt to match the written numbers with the existing database (if any). If it cannot be matched because there is no existing database or because there is a poor match with an existing database, the character is added to the database. This learning process continues until all of the alphanumeric (or other) characters and symbols to be used are entered into the database. The system has the capa bility.of storing multiple Stroke characterization databases for systems used by more than one user. The existence of a unique Stroke characterization database for each user has the further advanage of making the writing angle irrelevant.As a result, the system is -adaptable #to all handwriting styles and is usable by right-handed and left-handed persons. One feature may desirably be incorporated into the
apparatus to accommodate left-handed and right-handed persons.
This feature is a receptacle (not shown) for the stylus connector on either side of housing 12, so that the stylus 16 mty be 'connected on the left side for left-handed persons and on the right side for right-handed persons.
Fig. 10 also provides an example of the use of 11Softkeys". In addition to the input line, a variety of
Softkeys appear. Each Softkey corresponds to a function that can be performed by the system. In order to execute the funtion, the user merely touches the indicated Point with the pen. -The .Softkey will then appear in reverse video and the selected function is performed. There are numerous advantages to Softkeys over traditional function keys.Some of the more significant of these are that the user is no longer required to memorize what function key performs what function; the need for keyboard overlays is eliminated: and different sowtkeys can be made available (displayed and made operational) at different
Points within a program.
Figures 11A to Ill demonstrates some of the simplifications in word processing made possible through the use of this invention. in Fig lea a standard- screen of text is displayed. The user of the keyboardless entry system decides that additional information needs to be added and draws an insert symbol (e.q., caret) on the screen at the desired position. A data entry "window" then appears. (Fig. liB).
The text is written in as Handwritten Symbols (Fig. liy), matched (converted to Font Symbols) (Fig. liD), and then inserted (Fig. liE). The operator reconsiders the addition and draws a horizontal line through the new material. (Fig. liy).
It is immediately erased. (Fig. 11G). Next, the operator decides that a larger right-hand margin would be more appropriate for the text. A vertical line is drawn on the screen (Fig. llH) and the margin is automatically adjusted (Fig. ill).
A generalized block diagram of the editing process is provided in Fig. 13 and a description of that figure appears hereinbelow.
Figures 12#-12G illustrate how a blank form may be used for 2 hospital patient. The user of the system first calls up the proper blank form (Fig. 12A). This may be done, for example, by touching an appropriate Softkey. The area where the infornation, in this case a pulse observation, is to be inserted is touched with the pen (Fig. 12B). After the desired location is highlighted, a "window" appears directly below the space where the observation is to be recorded (Fig.
12C). The nurse then touches the pen on the match box which appears highlighted (Fig. 12D). The software then matches the handwritten input to the corresponding Font Symbols and displayes the result (Fig. i2E). If there is an accurate match, the "insert" block is touched (Fig. 12F), and the new observation is added to the patient's records (Fig. 12G). This mechanism is clearly applicable to a wide variety of "blank forms" in which data is inserted into a form or corrected. For example, it could be used to correct or update financial information in a spreadsheet program. Other information can be recorded in the same manner.
The reason for using a black background and white letters for the newly entered Font Symbols is to facilitate checking the accuracy of the inputted character. Although this -is .preèr#la, ..i-t is not essential and 2 white background and black letters is also acceptable.
The ability to create a window and input data on the same screen and in physical proximity to the text being edited or space for data to.be input is an important feature of the apparatus, for it permits ease and speed in the use of the apparatus The user's eye may focus on the space where the data will be inserted and the ability to contemporaneously display Handwritten Symbols and the corresponding Font Symbols makes it easy to see errors, when the system "misreads" a Handwritten Symbol, and then correct errors quickly and easily.
Referring first to Fig. 5, the overall operation and functioning of the pattern recognition software will now be described. When' the operating 'jsystem -calls the pattern recognition program, the program begins in terminal 75 where a number of variables and counters are initialized. The software then proceeds to decision diamond 76 where the program determines if stylus 16 (Fig. 2) is in contact with input screen is (Fig.
2A). The system provides. a "pen down" signal, as shown in processing box 78, as well as the X,Y coordinate voltages as locating signals, as described above. Microcomputer 14 (Fig.4) converts the X,Y coordinate locating signals into Stroke characteristics using programs stored in ROM 54 (Fiq. 4), or a separate microcomputer can do the conversion, such as microcontroller 44. If a pen down signal is received, the software proceeds to processing box 80 where the individual locating signals are combined into "Strokes," a Stroke being defined as the Point locating signals produced between a "pen down" signal and a "pen up" signal.
The system then calculates a transform, as described below, for each Point, transforming the Point coordinates from the X,Y cartesian coordinate system to a relational coordinate system. The software next proceeds to processing box 82, where it compares the Stroke with previously entered Strokes accumulated into a database, and determines if the Stroke is represented by a symbol in the database. If a match is found (if the Font Symbol represented by the Strokes is recognized), as indicated in decision diamond 84, microprocessor 50 (Fig. 4) causes the symbol to be sent to display screen 20 (Fig. 4) as indicated in processing box E6.If a match is not found, microprocessor 50 (Fig. 4) causes a message to be displayed, as indicated in processing box 88, which requests further input from stylus on input screen 18 (Fig. 4) by either flashing an entry which is close to a match or a non-recognition symbol.
As mentioned above, the software compares the Stroke characteristics of each Handwritten Symbol to data entries previously stored in a database. In a preferred embodiment, the database is arranged into sections of characters or symbols by the number of Strokes needed to make the character or symbol. Within each section, the entries are randomly arranged at first, but after use, as explained herein, the most frequently used entries "rise" to the top of the database. It should be noted that each user will have his or her own particular style of writing a Handwritten Symbol and that each
Handwritten Symbol may have a number of different variations.
For example, many people write the lower case letter "h" using a single Stroke. They do this by starting the pen on the writing tablet at a Point where they wish to place the top of the letter, drawing a vertical line downwardly to the base line, then without removing the pen from the paper, proceeding back up to the midPoint of the previously drawn vertical line, over to the right and down to the base line when the pen is picked up from the paper. On the other hand, these same people may draw the upper case letter "s" using two Strokes. They do this by drawing the left hand vertical line and horizontal line as is done for the lower case "h", picking the pen up from the tablet, and then drawing the right hand vertical line.
Appendix I displays the data of the Stroke data Points for these two letters as the data is stored in memory after having been generated by an embodiment of the present invention.
As shown in Appendix I, the letter "h" as drawn at one particular time by one user has one Stroke (ns = 1) with 20
Points (np = 20) and x and y coordinate characteristics for the minimum, mean and maximum normalized values (1/80th of a line width) as follows: -17 and -6; 0 and 18; and 19 and 60, respectively. The values in the first vertical column are the Pointto Point slopes, normalized to 360 /256. The values in the second vertical column are the Point-to-Point average vertical positions above the base line, normalized to 1/80 of the line width. A typical line width is about lmm (0.04 inches).
Referring now to Fig. 6, a software hierarchy of programs is depicted. At the top, overseeing the entire operation of computer system 10 (Fig. 1), is an operating system as indicated by box 90. Applications programs shown in boxes 92 and 94, residing in RAM 56 (Fig. 4) and ROM 54 (Fig. 4) can be executed by microprocessor 50 (Fig. 4) under control of the operating systems. When a Handwritten Character is required or is indicated by an interrupt, handwriting recognition software 96 is called.A first subroutine, indicated in box 98, encodes -the X,Y coordinates into Strokes. The .characteristics of the
Strokes are then defined by a subroutine 100 followed by comparisons of the Strokes with a database that has been loaded from ROM 54 (Fig. 4) into RAM 56 (Fig. 4). The comparison is made by a subroutine 102. When the operating system is in the "learr.ing" mode, the database is updated with the new Stroke data and symbols, as indicated in box 104. Similarly, a previously stored document can be edited by applications program 92 by using edit function 94 as called by the operator, who provides the instructions as input using the subroutines 98, 100 and 102 of handwriting recognition program 92.
Referring now also to Fig. 7, operating system 90 (Fig. 6) executes the Handwritten Character recognition software 6 (Fig. 6) by accepting as input the X,Y coordinate
Points, depicted in box 110, of the position of stylus 16 (Fig.
2) on input screen 18 (Eig. 2) and encodes these Points into
Strokes as depicted in box 112. The program then characterizes the Strokes by some description set, such as considering the length, curvature, slope, and position of the Stroke, as depicted in box 114. In box 116 the best comparison is then found of the characterized Stroke or sequence of Strokes with those in the database. If a sufficiently close match is found, the character is identified in box 118 and the database entry is swapped with the entry above it as shown in box 120. In this way, the most frequently identified characters will "rise" to the top of the database and the overall system performance, as measured in time to find a match, will be increased. If a match is not found, the user can add to the bottom of the database, as indicated in box 122.
With reference now to Figs. 8 and 9, a flowchart of the computer program to recognize a particular Stroke sequence is set forth. The computer program begins in terminal 150 and proceeds to process the X,Y voltages from processing box 152,
the voltages having been converted to a digital signal. The
program then proceeds to decision-box 154 where the program
determines whether the pen or stylus 16 (Fig. 2) is out of
contact with input screen 18. This determination is made by
both the X voltage and the Y voltage being zero. If the program determines that the pen -is -up, then the Stroke is
determined as having been completed and the program branches to
decision box 156.In decision box 156, the program determines
whether there are less than three Points in the Stroke and if
so the program branches to decision box 158. In decision box 158, the program determines whether there are zero Points in
the Stroke. If there are zero Points in the Stroke, then the
program loops back to the beginning of processing box 152 where
another set of Points is read. If the Point counter (incre meted in processing box 164) indicates that there are more
than zero Points, the program branches to processing box 172.
In processing box 172 the Stroke is identified as a dot and its
height above the base line (SiBL) is calculated in processing box 17;. From processing box 173 the program proceeds to processing box 171.
However, if the pen down signal is received, the pro
gram branches to processing box 160 where the voltages are
scaled to determine the coordinate Point using the following
formulas:
X = a1v1 + b1 Y=a2v2 +b2.
The constants al and bt are scaling parameters that are deter -mined -from calibrating the input surface -of- the particular dis
play.
Once the voltages are scaled, the program proceeds to decision diamond 162 where the program determines whether it is an erroneous Point. This is done by comparing the distance between Points and eliminating a Point if the distance is to great (greater than 2.5mm or 0.10 inches is presently used). On the other hand, a Point is also eliminated if the Points are too close together. Points are presently thinned out if they are within about 0.4mm (0.015 inches).
The comparison problem that exists for the first
Point is resolved by determining if a Point is the first Point after a pen is down and then that Point is used only to check the next Point which is accepted, assuming that that Point is within the maximum distance of 2.5mum (0.10 inches).
If the distance between Points is determined as being outside the two criteria, the program drops the Point and branches back to the top of processing box 152 to read another pair of coordinate Point voltages.
On the other hand, if the Points fall within the criteria, the program continues to processing box 164 where a
Point counter is incremented to keep track of the number of
Points. This number is used in decision diamond 156, as mentioned hereinabove. The program then continues to processing box 166 where the Points are smoothed according to any one of a number of formulae. Smoothing is used to minimize noise from digitization, from erratic hand motion and from electronic noise. The simplest smoothing technique is a multiple Point average which results in calculating new Points (x.'y.') as follows:
And similarly for yj, smoothed over Points n1 - n2.
Another simple method is called the running weighted average method and utilizes the following formula: Xj' = αXj + (1 - α) Xj' -1
Alpha is a weighting constant that is usually positive (and less than one) and has been used at 0.25. he summati ons have been taken with n2 minus n1 equal to one.A third method involves what is called a spline fit wherein the following formu a is used: Xj' = (xj-l + 4 x j + xj+1) Any of the foregoing methods can be applied either bef-ore-or-aftar filtering. The filtering is done so as to reduce the number of input Points and to space data so that difference and/or angle calculations can be made within acceptable random error bounds. A simple process of thinning a sequence of Points by excluding the acceptance of subsequent
Points within set distance of the previously accepted Points has been found to be an effective filter.
From processing box 166, the program proceeds to processing box 168 where the Point is stored in an array that is incremented for each new Point since the last pen down signal. Zhus an addressable array of Points is created for each sequence of Points obtained from a pen down to a pen up signal. This sequence of Points is called a Stroke. From processing box 168, the program loops back to the top of processing box 152 where another Point is obtained until a pen up signal ends the Stroke.
In decision diamond 156, a determination was made as to whether there were less than three Points in a Stroke. By definition, if there are three or more Points in a Stroke, the
Stroke is a line and not a dot. If there are three or more
Points in the Stroke, the program branches to subroutine box 170. In subroutine box 170, discussed in greater detail hereinbelow with respect to Fig. 9, the Stroke is characterized as to its slope and base line height.
As can be seen from the foregoing, the segmentation of the stream of coordinate Points into a Stroke is based primarily on the determining when stylus 16 is up or not in contact with the surface of input screen 18. Alternatively, a stream of Points can be segmented to form Strokes on the basis of other considerations. For example they can be segmented based upon changes in a locally calculated curvature or upon a large local curvature. Local curvature is calculated by the change in distance along the input coordinates divided into the change in slope. This produces radius of curvature. When the radius of curvature changes rapidly with respect to distance along the input coordinates, or if the radius is too small, then a segmentation Stroke is assumed to end, and a new Stroke begun. Further segmentation techniques can look at the relative maximum and minimum in one or both coordinates and/or the curve crossings in the coordinates. However, these latter two methods have been determined to be less effective.
Characterizing a Stroke reduces the sequence of coordinates defining the Stroke or segment to a set of characteristics that are unique, generalized and minimal. Unique ness refers to both factors that the same characteristics are generated by-the same coordinates and-that the characteristics are sufficient to regenerate an approximation to the original coordinate sequence. The term "generalized" is used to mean that the characterization is invariant under such transformaffons-so that the symbols are-invariant (e.g., translation and scaling or stretching or small tilt). The scaling of all distances is accomplished by taking a ratio of the distance to a writing entry line width.
The minimal set of segment characteristics have the following features:
(1) Stroke position: one or more of centroid/average, extent extreme or beginning and ending Points determined relative to the writing entry line, to previous Strokes, or to character extent or center;
(2) Stroke shape is characterized by one or more of average slope, change in slope (which is a measure of average curvature) and/or a change in curvature, by sequence of slopes over specific length segments or over fractional lengths, or by a gross description of linear direction or circular completion and opening direction;
(3) And Stroke length as characterized by distance along the curve and/or the extent extremum along the coordinate system.
In one embodiment of the present invention, positioning by centroid, extent extremum, and starting and ending coordinates have been successfully used. The Stroke shape is encoded as a sequence of slopes and vertical positions -trelative-to-Stroke centroid). The Stroke length can be approximated by the number of filtered Points. Alternatively, the average curvature can be encoded in total slope change (along with length), change in starting to ending slope or fitting# the slope angle versus length curve for rate of change of slope angle. Additional characteristics that could be used include location of coordinate relative extrema, curve crossing, cusps, and Stroke direction. A particular method used to determine the unique characteristics is set forth below.
1. The numerical values of the Criteria for each
Stroke of the Handwritten Symbol are determined.
2. The database values for each stroke of the previously learned Handwritten Symbol is determined and subtracted from the newly determined values respectively.
3. The absolute values of each difference are scaled, to make each of the five measurements reasonably equivalent to the others such as lengths scaled to height between lines.
4. The five thus-determined values are added.
5. A predetermined threshold is used as "goodness" test of recognition -- too high a value and Font Symbols are infrequently recognized and too low a value causes Font Symbols to be misidentified. Thresholds of approximately 1,000 are used initially and then switched to approximately 100 for improved recognition. If the threshold is exceeded, the comparison is discarded and an error message is created and displayed.
6. The database is searched to find a numerical minimum difference. If the minimum difference is below the acceptable threshold for recognition, the corresponding Font
Symbol is displayed on the screen or the command is performed, as the case may be.
It has also been found that the preferred classification of a Stroke is a continuous one,- rather than one that is grossly discrete. For example, determining a slope by angle in 256 directions rather than in 8 is desirable. Other noncontinuous classifications can include bars/arches/hooks, number and closure .o.cusps. or horizontal or vertical Strokes.
From subroutine 170, the program proceeds to processing box 171 where both an individual Stroke and one or more preceding Strokes are compared with a database entry that is stored in RAM 56 (Fig. 4).
This comparison initially begins with three eliminat ing-questions#that..are asked by flit program in -decision disk monds 174, 176, and 178. In each case, if the database entry is eliminated, the program proceeds to a processing box 180 where the address of the next data entry is received and from which the program loops back to the top of processing box 171.
In decision diamond 174, the first eliminator is asked by seeking if the number of Strokes are different. If the number of Strokes are the same, the -program proceeds to decision diamond 176 where the average Height Above Base Line (HABL) is calculated and compared with the HABL of the data entry. The entry is eliminated if the difference in the average HABL's is greater than one-half the height of the entry line. From a negative -determination in decision .diamond .176, the program proceeds to decision diamond 178 where the number of Points per
Stroke are compared and the database entry is eliminated if the difference in number of Points is greater than ten.This determination varies from that made in decision diamond 174 because it is. concerned only with the number of Points for each
Stroke. However, in decision diamond 174, certain letters, such as the capital letters "E" and "A", have more than one
Stroke per letter.
If a data entry is not eliminated by decision diamond 178, then the program proceeds to processing box 182 where the program calculates a gauge to be used to determine the closeness of the match between the selected entry in the database and the drawn Stroke. A presently preferred gauge is the sum of the absolute values of the differences between the Stroke values and the database entry values of:
a) distances or lengths n units of 1/80th of the
line height (e.g., space 26, Fig. 2); and
b) the slopes in units of 1/256th of 3600 over all
the Points along the diagonal of the comparison
matrix.
Alternatively, Dynamic Prosramming Techniques can be used to optimize the coparison using off-diagonal elements as well.
From processing box 182, the program proceeds to deci sion diamond 186 where a match is determined. In actuality, a match is determined by the application of an arbitrary gauge (maximum allowable variance), which is the sum of absolute values of the differences between the entered Stroke characterization and that of the stored database entry. In processing box 183, the lower of the present gauge and the previous lower gauge is saved as the best match. The program then goes to decision diamond 184 where a determination is made whether the present entry is the last database entry. If it is not, the program branches to processing box 180 where the next entry is selected. If it is the last entry, the program proceeds to decision diamond 185 where a determination of a match is made on the basis of the gauge being below a predetermined threshold. This threshold is set by the user based on experience with the system.
If no match is obtained, the program branches to decision diamond 188 where a determination is made whether all
Strokes have been checked. If the last Stroke has been checked, then the present Stroke is compared in sequence with a previous Stroke to all two Stroke entries. As in the comparison with all one Stroke dictionary entries, the best fit comparison for all entered Strokes is the recognized symbol or sequence cf symbols.
However, if the last Stroke has been read and there still is not a match, then the program proceeds to processing box 190 where a question is displayed on display screen 20 asking the user if a new Font Symbol should be added to the database. The user responds and that response i-s used in decision diamond 192. Either the Stroke sequence is added to the database in processing box 194 and the program branches back to the top of processing box 152, or the program branches imme diately to the top of processing box 152.
On the other hand, if a match is determined in :ision diamond 186, the program branches to processing box 195 where the program shuffles the database by interchanging the --serial 10-cation of the matched entry with the entry above it.
The program then proceeds to processing box 196 where the program zeros the Point counter and the increment counter. The program next proceeds to processing box 198 where the matched and characterized Stroke or Strokes are displayed by the com puter-as the identified #-ont'#-Symbol. #This. display is located at the position in which the entry was made on input screen 18 (Fig. 2).
From processing box 198, the program proceeds to processing box 200 where the program can act on any commands which it has interpreted. An alternative characterization of the Stroke uses the Points themselves rather than the length, scope, curvature and position.
With reference now to Fig. 9, this Stroke characterization is depicted in greater detail. Stroke characterization subroutine 170 essentially performs a mathematical transformation of each Point on a Point-by-Point basis to transform the
Points from an X,Y Cartesian coordinate system to one in which the coordinates are the normalized slope of each Point and the normalized height of each Point above the base line (HABL).
Subroutine 170 first calculates the Point to Point slope in processing box 220 and then calculates the height of each Point above the base line in processing box 222. The slope and HABL of each Point are then normalized respectively to 1j256th of 2 Pi and to 1/80th of the width of the entry line in processing box 224. From processing box 224, the system pro creeds to processing box 226 where the calculated normalized values for each Point are stored in an addressable array. The subroutine then returns to the program through terminal 228.
When the comparison is made between each Stroke and the stored values, the comparison is made by the normalized
Point slope and Point height above base line. As mentioned above, a match is determined by an arbitrary gauge which is the sum of absolute values of the differences between the written
Stroke and the stored or dictionary Stroke. The system learns by adding new Strokes to the dictionary database. Once the database fills up, those Font Symbols that are infrequently used are replaced by new entries.
In a working embodiment of the present invention, the algorithm successfully identified upper and lower case letters and numbers when written discretely from one another. For
Handwritten Symbols that are written such that they are continuous, direct extrapolation would require searching a database sequentially for one, two, three, etc. Stroke symbols and looking for the best fit Upon identification of a Stroke fit, a "new" letter is tenatively recognized, except that the next few Strokes are analyzed to check if they change the previous symbol for a better fit. For example, two Strokes that have.beem identified as "ones" would be combined and changed to the capital letter "P." once a cross bar was identified.
The system design demonstrated by Figs. 7 to 9 could easily be coded by one with ordinary skill in the art of computer programming into almost any computer language. The source code listings for one application program utilizing-the disclosed invention is included as Appendix II. The software
In Appendix II is written in Microsoft Basic, a common computer language available for virtually all microcomputers and operating systems. The program is a complete text editing demonstration which shows the improvements that can be made upon traditional word processing systems.
Program lines 2600 to 4000 contain the character recognition subroutine which includes the software code necessary to get X and Y coordinates. This section of the program corresponds to Fig. 8.
Szzgram lines 26~0 to 2699 Mke up a subroutine designed to obtain the X and T coordinates of a given Point.
This code corresponds to boxes 152, 154, 160, 162, 164, 166 and 168 of Fig. 8.
Program lines 3000 to 3339 constitute a Point and Stroke.-analysis and characterozation routine embodying boxes 156, 158, 170, 172 and 173 of Fig. 8.
Program lines 3700 to 3790 make up a subroutine designed to compare the analyzed Strokes to a Stroke database.
These program lines embody boxes 171 to 184 of Fig. 8.
Program lines 3810 to 3980 make up a subroutine which is designed to learn a new character. This code embodies boxes 186, 188, 190, 192 and 194 of Fig. 8.
Program lines 3060 to 3273 make up a subroutine designed for Stroke characterization purposes. This section of the code corresponds to Fig. 9.
Program lines 3060 to 3095 are used to calculate
Point-to-Point slopes and embody box 220.
Program lines 3058, 3241 and 3262 are used to calculate a height above baseline (HABL) and correspond to box 222 of Fig. 9.
Progras lines 3253, 3270-3273 are used to normalize the Point height and slope and correspond to box 224 of Fig. 9.
Program line 3253 is used to store the height above baseline and embodies box 226 of Fig. 9.
The foregoing program can be stored in the memory of a microcomputer of microprocessor with a requirement of approximately 25k of machine memory, so that it can be seen that the use of the program does not use up a lot of expensive memory and is relatively fast in executing the program's operation. If the program is written in a language other than
Basic, requiring less memory, such as assembly language, the size of the program can be made smaller.
Boxes 195 to 200 of Fig. 8 appear in logical places throughout the code.
A dictionary of the variables of the relevant code section is included as Appendix III.
With reference now to Fig. 13, a flowchart for the editing software ("Editor") demonstrated by Figs. llA to ill and described above is depicted. Once the Editor is loaded into the system (box 229), control of the screen is returned to the system. The system then proceeds in the normal manner described above to acquire Points and display them (box 230), convert the Points into Strokes (box 231), characterize each
Stroke (box 232), and attempt to match the Stroke or Strokes with the databe-se (box 233). In processing box 234, the-system sends each Handwritten Symbol to the Editor to interpret and execute a command if necessary. At decision diamond 235, the
Editor determines whether the Handwritten Symbol is an Editing
Symbol or a Font Symbol.If the character is determined to be an Editing Symbol, the Editor proceeds to processing box 236 where it determines which Editing Symbol has been entered and executes the Editing Function. If the character is determined not to be an Editing Symbol, then the alphanumeric character corresponding to the handwritten entry is displayed at processing box 237. In an alternate configuration of the Editor,
Font Symbols will only be accepted when the Editor is in the "Insert Mode " . The sTructure insures that each Font Symbol is verified before being added to a document.
The Editor uses a variety of symbols designed to make editing on the system similar to, but much more efficient than, traditional editing with pencil and paper. These primary editing functions Include, but are not limited to: -DELEr symbol - "~~~~~~~~" A horizontal line drawn through a character or characters. The Editor will remove the underlying characters and reformat the text.
ADJUST M,XRGINS symbol - "|" A vertical line longer then the height of one line on the display. The Editor will adjust the margin to the indicated position and reformat the text.
INSERT symbol - "A" A caret drawn at the Point where text is to be added. The Editor displays an input writing line (Fig. 118) and when input is recognized inserts it into the text.
f~i;R# TEXT symbols - " < " and " > " A less than and greater than symbol drawn at the beginning and end of a block of text. The marked text is displayed in reverse video and then special block functions can be performed.
DELETE IRKED TEXT - A delete symbol drawn within marked text will erase the marked text and reformat.
MOVE MARKED TEXT - An insert symbol drawn anywhere within the text moves the marked text to the indicated position, deletes it from its origional position and reformats the text.
REPLACE #-.RKED TEXT - An insert symbol drawn within the marked text displays an input line and replaces the marked text with the inputted text.
The Editing Symbols described above can be changed to the particular Editing Symbols preferred by each user, thereby custoriz.ng the Editor and preventing new users from having to learn unfamiliar Editing Symbols.
Further modifications and enhancements to the present system will be apparent to those skilled in the art. For ~example, the common characteristics of each Font Symbol could be extracted and organized into a synthetic symbol. The synthetic symbol's characteristics could then be exaggerated to maximize their variance from all other synthetic symbols. This would create a very compact, optimal database. On the other hand, as an example, a database created by the described preferred embodiment of the invention usually results in two to three different characterizations for each symbol.
The system has numerous useful applications, almost without lititation. The most ob-vious applications are text editing and filling out and modifying forms. Some of the many other applications that may not come to mind as readily are writing in languages utilizing large numbers of symbols like Japanese or
Chinese, writing in Arabic and similar languages made up of a limited number of compiex-symbola; -'writing chemical equations, including those involving organic compounds; writing music (a "window" with five parallel lines can be provided for musical applications); writing symbols and codes for graphic manipulation of data, including the transfer of graphic data to a spreadsheet; in education, as where predetermined questions are presented on the streane;-and the-=nswers written in long-hand; as in teaching mathematics, as i#hen-numbers are manually inserted in equations and the equation analyzed to determine the result using those numbers; in CAD/CAM applications involving symbols, geometric shapes and the like.
We have described a particular preferred embodiment of a keyboardless computer on which usual computer functions are performed by writing in a normal manner with a pen-like stylus on an input screen placed directly over a flat display. The keyboardless computer illustrated is -ideally -configured for use -by -non-keyboard oriented individuals, by keyboard individuals for whom the utility of the computer is enhanced, and in various settings and applications in which keyboard entry is awkward or impossible.
Computer-based information and application software can be loaded into a portable device for later viewing, manipulation of text and data, and adding new text and data in a normal handwriting mode.
Thereafter the user may transmit this computer text to another computer, a similar device, an external electronic storage device, a hard copy printer, or through a telecommunications system. The computer is capable of recognising Handwritten Symbols with a high degree of accuracy and of "learning" individual styles of handwriting. The data and commands can be input with the aid of a stylus.
Although the invention has been described in terms of a selected preferred embodiment encompassing the apparatus and methods aspects of a keyboard less computer system, the invention should not be deemed limited thereto, since other embodiments and modifications will readily occur to one skilled in the art.
APPENDIX I 'h' (1) ns - 1 x = (-17,..0..19) y = (-6..l8..60)
1) np = 20 x = (-17..0..19) y = (-6..18..60)
5, 42
-57, 34
-85, 26
-71, 19
-76, 10
-64, 3
-89, -3
-72, -9
-85, -17
-72, -24
47, -17
56, -11
43, -3
39, 3
11, 7
-9, 5
-57, -3
-71, -11
-71, -18 'H' (1) ns = 2 x = (-27..0..37) y = (-20.18.61) 1) np = 14 x = (-27..-12..-2) y = (-20..22..61)
37
4, 38
-39, 32
-48, 25
-58, 16
-71, 8
-72, 2
-64, -4
-89, -11
-72, -17 - --ao, -24 ---89, -30
-80, -36 .
2) np - 20 x = (-21...10..37) y = (-15..16..59)
27, 43
-80, 37
-71, 29
-98, 23
-80, 16
-78, 8
-85, 1
-89, -6
-80, -12
-80, -18
-64, -25
-64, -31
48, -25
56, -18
48, -12
64, -6
-89, 1
-124, 0
-124, -2
APPENDIX III
Al - angle of slope between Point M and M1 A2 - previous angle
DA1 - change in angle (A1-A2)
SEND - flag for end of Stroke
ZX - double precision X position summation by arc length weighting
ZY - double precision Y position summation by arc length weighting
ZA - double precision angle summation by arc length weighting
ZDA - double precision change in angle summation
ZL - double precision length NSP - number of Points in Stroke, counter NSTRK -number of Strokes
XX - maximum X
XN - minimum X
YX - maximum Y
YN - minimum Y
Ml - Pointer to previous Point
M2 - (1) minimum number of Points for which to adjust for 2n angle
M3 - (2) minimum number of Points for which to calculate change
in change in angle
NLONG - counter (not used)
M - Pointer to Point being considered
NP - number of Points
X - array of X coordinate
Y - array of Y coordinate
DX - change in X
DY - change in Y
ADX - absolute value of DX
ADY - absolute value of DY
DS - pseudo arc length ADX + ADY AY - calibration multiplier for vertical (Y) direction, e.g.
AY 0 Omean coordinate system true downward ADA - running average change in angle
DA2 - previous change in angle
ASTRT - array for starting angle of Stroke
SZL - single precision Stroke length
SNO - array of number of the 1st Point for each Stroke LETS - height between lines divided by 5 in display coordinates
used as a measure SL - array of Stroke lengths sealed to height between lines
AEND - array of angles at end of Strokes
SC - array of angle changes for eachs troke
AZA - average angle through Stroke
SX - array of averages centroid X coordinate for each Stroke
SY - array of averages centroid Y coordinate for each Stroke
SA - array of averages angle (slope) coordinate for each Stroke
SXX - array of maximum X coordinate for each Stroke
SXN - array of minimum X coordinate for each Stroke
SYN - array of minimum Y coordinate for each Stroke
SYX - array of maximum Y coordinate for each Stroke
DBUG - debugging flag for printing
INPUT - string of input bytes to be rejected
XP, YP - input coordinates
XPA - average 2 Points in X direction
YPA - average 2 Points in Ydirection XPO - initial X average on pan down
YPO - initial Y average on pan down
I - display pixel corresponding to X coordinate input
J - display pixel corresponding to Y coordinate input
N - counter of input Points MM - counter for timing pan up
NU - counter for timing pan up
Claims (1)
1. An input/output or I/O device for providing input signals to a utilization device that are representative of a graphical character produced by a user and for receiving output signals from the utilization device and providing a visual representation of the output signals, said I/O device comprising:
(a) a display means for providing a visual, display of a graphical character in response to output signals provided by the utilization device;
(b) an input screen means for producing a train of input signals as a graphical character or symbol is sketched by a user, said input screen means comprising a translucent input screen having top and bottom surfaces, said bottom surface being disposed with respect to said display surface such that the visual display produced by said display means is visible from said top surface of said input screen; and
(c) means for determining the identity of said graphical character and providing output signals representative thereof to said display means.
2. An I/O device as claimed in claim 1 wherein said display means comprises a display surface on which the graphical character is produced; and
said input screen means bottom surface is disposed in close proximity above said display surface such that the visual display produced by said display means is visible from the top side of said input screen.
3. An I/O device as claimed in claim 1 wherein said input screen means includes a substantially flat plate, and wherein said input screen top surface is the top surface of said plate.
4. An .1/0 device as claimed in claim 3 and further including an indicating means operated by a user for cooperating with said input screen top surface such that said input screen means generates said train of input signals when said indicating means is in a predetermined position with respect to said plate top surface.
5. An I/O device as claimed in claim 4 wherein said input screen means generates an input signal when said indicating means is in contact with said input screen top surface.
6. An I/O device as claimed in claim 5 wherein:
(a) said pLate has electrical characteristics such that the voltage at any Point thereon varies in a known manner with the distance from the location at which a voltage is applied thereto;
(b) said input screen means further includes means for selectively sequentially applying a voltage along one
Cartesian axis of said plate and then along the other Cartesian axis of said plate; and
(c) said indicating ~means .is elongate and has a tip at one end thereof and includes a voltage detecting means that provides a signal representative of the voltage present where said tip contacts said input screen plate.
7. An I/O device as claimed in claim 5 wherein:
(a) said plase Mas electric-al-chtracteristics such that the voltage at any Point thereon varies in a known manner with the distance from the location at which a voltage is applied thereto;
(b) said input screen means further includes means for selectively sequenff ally sampling at an origin thereon the voltage along one Cartesian axis of said plate and then along the other Cartesian axis of said plate; and
(c) said indicating means is elongate with a tip at one end thereof and includes a means for applying a known voltage to said tip; said sampling means detecting the voltages at said origin when said tip contacts said input screen plate and provides a signal representative of the detected voltages.
-8. An I/O device as claimed in claim 2 wherein said display screen has a display area on which graphic symbols can be generated and a key input area by which command signals for the utilization~device can be generated when contact is made with the correspondingarea thereabove-on said input screen.
9. A handwriting character recognition apparatus comprising:
(a) a display means having a display surface for providing a visual display of graphical characters in response to a plurality of display signals;
(b) a writing surface means for receiving graphical characters handwritten by a user, said writing surface means being disposed in close proximity with respect to said display means and comprised of a substantially translucent surface which has positional coordinates associated therewith;
(c) an indicating means operated by a user in connection with said writing surface means for producing writing signals in cooperation with said writing surface means;
(d) position detecting means for converting said writing signals into locating signals representative of the positional coordinates of said indicating means with respect to said writing surface;;
(e) a processing means for receiving and storing said locating signals as they are produced and for generating said display signals such that said display means can graphically display the graphical character after it has been produced by said indicating means; said processing means being comprised of-a character recognition -means for-comparing said produced locating signals representative of a graphical character with a plurality of stored database signals for identifying said graphical character.
10. A handwriting character recognition apparatus as claimed in claim 9 wherein said writing surface means includes a substantially flat plate which produces a signal when said indicating means is in contact therewith.
11. A handwriting character recognition apparatus as claimed in claim 9 and further including means for converting said positional corrdinates into -relational 'coordinates.
12. A handwriting character recognition apparatus as claimed in claim 11 and further including means for dividing up a stream of locating signals into sections representative of a
Stroke; and means for calculating Stroke characteristics which can be compared with Stroke characteristics of the database signals.
12 A -handwriting character recognition apparatus,as claimed in claim 9 wherein said processing means further includes means for updating said stored database signals with said produced locating signals when no correct graphical character is identified.
14. A method -of. recognizing v Ban-dwritten Symbol comprising the steps of:
(a) generating a stream of locating signals for
Points by moving a stylus about locations proximate to a writing surface means that generates a signal representative of said location of said stylus;
(b) dividing up a stream of locating signals into sections representative of a Stroke; { > c} calculating Stroke characteristics;
(d) comparing said calculated Stroke characteristics with Stroke characteristics previously stored in a database; and
(e) determining the best comparison and indicating if said best comparison is good enough to be a match.
15. Apparatus for recognizing Handwritten Symbols and displaying Handwritten and Font Symbols on a screen comprising:
(a) A visual display screen having the graphic capability to display Font Symbols and execute predetermined conmands;
(b) Hand-held means to write or draw Handwritten
Symbols on or over said screen;
(c) Means to display a true representation of the Handwritten Symbols on said screen as they are created;
(d) Digitizing means to sense the position of said hand-held means and to convert the same into a series of electrical signals defining the position, size and shape of each
Handwritten Symbol;
(e) Means to compare predetermined characteristics of each digitized Handwritten Symbol with a database of predetermined characteristics of Font Symbols to assess the identity of each Font Symbol;; (f) Means to convert the Handwritten Symbol to a predetermined Font Symbol or a command and to display the Font
Symbol on the screen in close proximity to the screen area in which the Handwritten Symbol was originally entered or to exe- cute the command, as the case may be.
16. Apparatus as set forth in Claim 15, including means to display predetermined fonts of symbols in the form of text or forms on said screen, whereby the Handwritten Symbols can be used to input information to complete a form or to edit a predetermined text.
17. Apparatus as set forth in Claim 15, wherein said apparatus comprises a portable unit having dimensions up to about 400mm by 400mm by lOCmm, a weight of up to about 7 kilo -gra:ns- hand is adapted to include a. self-contained power supply
18. Apparatus as set forth in Claim 15, including means to display predetermined symbols in a font and command representing symbols on said screen, to permit handwritten symbols representing each predetermined symbol to be manually defined on the screen and means to identify the manually defined symbol with#: the corresponding predetermined symbol in said database.
19. Apparatus as set forth in Claim 18, including means to modify said database when a Handwritten Symbol causes an erroneous Font Symbol to be displayed on the screen or command to be performed, as the case may be.
20. Apparatus as set forth in Claim 16, including means to create a window of empty space on said screen upon a predetermined command for entering Handwritten Symbols in said window.
21. Apparatus as set forth in Claim 15, including areas on said screen sensitive to touch to cause predetermined functions to be performed.
22. Apparatus as set forth in Claim 1, wherein said screen is substantially flat and adapted to be used in a substantially horizontal position.
23. Apparatus as set forth in Claim 15, including
Softkeys on said. screen and means to execute operational commands in response to touching any of said Softkeys.
24. A microprocessor-based process for recognition, translation and display of Handwritten Symbols and execution of commands comprising the steps of:
(a) Creating a personalized database for each individual user of the process by having the user initially input a Handwritten Symbol for each character corresponding with a font to be displayed or command to be executed;
(b) Determining a unique set of characteristics to characterize each such symbol and storing it in the database
(c) Writing or drawing Handwritten Symbols on a computer screen with a stylus;
(d) Digitizing each Handwritten Symbol to identify the X y coordinates of a multiplicity of Points defining the Symbol;;
(e) Processing the digitized characteristics of each Handwritten Symbol to determine the predetermined characteristics of the Symbol;
(f) Search the database to find a "hit," a perfeet or the closest correspondence to the characteristics; (g) Displaying the Font Symbol or performing the command most closely associated with the "hit" characteristics.
25. A process as set forth in Claim 24, including the additional steps of: (a) Determining if the Font Symbol displayed or command performed is an error; and
(b) If there is an error, re-inputting a Handwritten Symbol for the desired Font Symbol or command to modify the database.
26. A process as set forth in Claim 24, including the additional step of: (a) - Substantially - contemporaneously displaying the Handwritten Symbol on the screen as it is being written or drawn.
27. A process as set forth in Claim 24, wherein steps (b) and (c) involve a.determination of the (i) length, (ii) aver.a.ge -slope, (iii) centroid height above base lxne, (iv) curvature (rate of change in slope) and (v) comparison of the location of the centroid of each Stroke with the centroid of the Handwritten Symbol.
28. A process as set forth in Claim 27, wherein step (f) comprises:
(a) Determining the value of each of the five characteristics;
(b) Subtracting the database value of the characteristic from the newly-measured value;
(c) Scaling the absolute values of each measure ment; to make each of the five measurements reasonably equivalent to the others; (d) Adding all five ualues; (e) If a predetermined threshold is exceeded, discarding the comparison and creating an error message; and
(f) Searching the database to find a numerical "hit," or, if not feasible, the closest numerical match between the database value and the newly .inp#tted- 'value.
29. A process as set forth in Claim 24, wherein the error rate is 5% or less.
30. A process as set forth in Claim 28, wherein the program for step (f) requires less than 6K of machine memory.
31. A process as set forth in Claim 24, wherein said
Handwritten Symbols include Editing Symbols and said process includes recognition of the Editing Symbols drawn on the screen and executing the Editing #Functions represented.
32. A process as set forth in Claim 24, in which text in Font Symbol format is displayed on the screen, and including the steps of:
(a) Creating a window on the screen proximate to, but not overlying, an area of said text to be edited;
(b) Inputting and displaying said Handwritten
Symbols in said window;
(c) Displaying the Font Symbols corresponding to said Handwritten Symbols in close proximity to said Handwritten Symbols.
33. A process as set forth in claim 24, including the steps of:
(a) Creating one or more Softkeys on said screen to cause the computer to perform operational functions; and
(b) Touching one or more of said Softkeys to execute the corresponding functions.
-34. A process as set forth in Claim 24, including the steps of determining the x,y coordinates of from about 4 to 8 Points per mm and from about 100 to 200 points per second in characterizing said Handwritten Symbols.
Amendments to the claims
have been filed as follows
1. A handwriting character recognition apparatus ccmprising: a display means;
- hand held mean for use by a user to write or draw a handwritten symbol on or over at least a portion of the display screen; digitising means for digitising a handwritten symbol written by a user with the hand beld means to produce .di.gi'tised signals;
means for convertirrg the digitised signals into one or more strokes and points defining the handwritten symbol;
means for processing the characteristics of each stroke to determine the characteristics of (i) the length of the stroke,
(ii) the average slope of the stroke, (iii) the stroke centroid's height above a predetermined base line, (iv) the rate of change -in the slope of the stroke, and (v) the location of the centroid of the strOke -compared to the location of-the centroid of the handwritten symbol; and
means for comparing the characteristics of the strokes with a database of characateristics of predetermined symbols to determine the best comparison with a predetermined symbol.
2. Apparatus ,ac=rding- to - claim 1, -further comprising means coupled to the digitising means and to the display screen for displaying on the display screen an image of the handwritten symbol as it is written.
3. Apparatus according to claim 1 or 2 , further comprising means for indicating if the best comparison is good enough to be a match.
4. A method of receiving a handwritten symbol, comprising:
using a hand held means to write or draw a handwritten
symbol on or over at least a portion of a display screen;
digitising each handwritten symbol to produce digitised
signals representative of strokes and points defining the
handwritten symbol;
processing the characteristics of each stroke to
determine characteristics of (i-) the length of the stroke,
(ii) the average slope of the stroke, (iii) the stroke
centroid's height above a predetermined base line, (iv) the rate
of change in the slope of the stroke, and (v) the location of the tentroid of the stroke compared to the location on the centroid of the handwritten symbol; and
comparing the characteristics of the strokes with a
database of characteristics of predetermined symbols to determine
the best comparison with a predetermined symbol.
5. A method according to claim 4, #urther including
displaying an image of the handwritten symbol on the screen as it
is written.
6. A method according to claim 4 or 5, further including
indicating if the best comparison is good enough to be a match.
7. A method according to claim 4, 5 or 6, further
including:
creating a personalised database for each individual
user of the method, by having each user initially input a
handwritten symbol for each character; and
determining a unique set of stroke characateristics to
characterise each symbol and storing it in the database.
8. A method according to claim 4, 5, 6 or 7, nc uc nc the
additional steps of:
(a) determ#n:ng if the symbcl displayed is an error: and
(b) if there is an error, re-inputting a handwritten symbol for the desired symbol to modify the -database 9. A method according to any of claims 4 to 8, including the additional steps of:
(a) substantially contemporaneously displaying the handwritten symbol on the screen as it is being written or drawn.
10. ~ A method according to any of claims 4 to 9, wherein the processing step comprises:
(a) determining the value of each of the five characteristics; tb) subtracting the database value of the characteristic from the newly-measured value; - (c) scaling the absolute value of each measurement to make each of the five-measurements reasonably equivalent to the others;
(d) adding all five values; (e) if the predetermined threshold predetermined is discarding the comparison and creating an error message; and (f) searching the database to find a numerical matr#c:"hit" or, if not feasible, the closest numerical match betweenn the database value and the newly inputted value.
11. A method according to claim 10, wherein the program for step (f) requires less than 6K of machine memory.
12. A method .according to any of and said 11 wherein said handwritten symbols include editing symbols and said method includes recognition of the editing symbols drawn on the screen and executing the editing functions represented.
A method according to any of claims 4 to 12, in which text in font symbol formar is displayed on the screen, and including the steps of: (a) creating a window on the screen proximate to, but not overlying, an area of said text to be edited;
(b) inputting and displaying said handwritten symbols in said window; and
(c) displaying the font symbols corresponding to said handwritten symbols in close proximity to said handwritten symbols.
14. A method according to any of claims 4 to 13, including the steps of:
(a) creating one or more softkeys on said screen to cause the microprocessor to perform operational functions; and
(b) touching one or more of said softkeys to execute the corresponding functions: 15. A method according to any of claims 4 to 14, wherein the step of digitising comprising adigitising each handwritten symbol to defining x,y coordinates of a multiplicity of points into strokes defining the handwritten symbol, further including the s'teps of determining the x,y coordinates of from about 100 to 200 points per second in characterising said handwrittensymbols.
16. A method isaccording to any of claims 4 to 15, wherein the end of a stroke is determined by the detection of a change in angle or direction exceeding a maximum set threshold.
17. A computer, operating in accordance with the method of any of claims 4 to 16.
Applications Claiming Priority (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US88951386A | 1986-07-25 | 1986-07-25 | |
US07/029,772 US4972496A (en) | 1986-07-25 | 1987-03-24 | Handwritten keyboardless entry computer system |
GB8717453A GB2193827B (en) | 1986-07-25 | 1987-07-23 | Handwritten keyboardless-entry computer system |
SG54994A SG54994G (en) | 1986-07-25 | 1994-04-22 | Handwritten keyboardless-entry computer system |
Publications (3)
Publication Number | Publication Date |
---|---|
GB9019254D0 GB9019254D0 (en) | 1990-10-17 |
GB2234102A true GB2234102A (en) | 1991-01-23 |
GB2234102B GB2234102B (en) | 1991-04-24 |
Family
ID=27449960
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
GB9019253A Expired - Lifetime GB2234101B (en) | 1986-07-25 | 1987-07-23 | Handwritten keyboardless-entry computer system |
GB9019254A Expired - Lifetime GB2234102B (en) | 1986-07-25 | 1990-09-04 | Handwritten keyboardless-entry computer system |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
GB9019253A Expired - Lifetime GB2234101B (en) | 1986-07-25 | 1987-07-23 | Handwritten keyboardless-entry computer system |
Country Status (1)
Country | Link |
---|---|
GB (2) | GB2234101B (en) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP0607926A2 (en) * | 1993-01-18 | 1994-07-27 | Sharp Kabushiki Kaisha | Information processing apparatus with a gesture editing function |
EP0887753A1 (en) * | 1996-11-15 | 1998-12-30 | Toho Business Management Center | Business management system |
EP1103883A2 (en) * | 1999-11-29 | 2001-05-30 | Xerox Corporation | Input mode selection on a palmtop computer |
Families Citing this family (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
FR2701132B1 (en) * | 1993-02-04 | 1995-03-31 | Ioan Montane | Processing installation for the exploration of screens intended for blind operators and corresponding method. |
DE19646733A1 (en) * | 1996-11-13 | 1998-05-14 | Rene Baltus | Signature writing surface for signature checking device |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
GB2102944A (en) * | 1981-07-20 | 1983-02-09 | Gen Electric Co Plc | Light pen arrangements |
EP0156394A2 (en) * | 1984-03-30 | 1985-10-02 | Hitachi, Ltd. | Method and apparatus for recognizing and displaying handwritten characters and figures |
EP0157354A2 (en) * | 1984-03-28 | 1985-10-09 | Hitachi, Ltd. | Method for designating a recognition mode in a hand-written character/graphic recognizer |
-
1987
- 1987-07-23 GB GB9019253A patent/GB2234101B/en not_active Expired - Lifetime
-
1990
- 1990-09-04 GB GB9019254A patent/GB2234102B/en not_active Expired - Lifetime
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
GB2102944A (en) * | 1981-07-20 | 1983-02-09 | Gen Electric Co Plc | Light pen arrangements |
EP0157354A2 (en) * | 1984-03-28 | 1985-10-09 | Hitachi, Ltd. | Method for designating a recognition mode in a hand-written character/graphic recognizer |
EP0156394A2 (en) * | 1984-03-30 | 1985-10-02 | Hitachi, Ltd. | Method and apparatus for recognizing and displaying handwritten characters and figures |
Cited By (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP0607926A2 (en) * | 1993-01-18 | 1994-07-27 | Sharp Kabushiki Kaisha | Information processing apparatus with a gesture editing function |
EP0607926A3 (en) * | 1993-01-18 | 1994-12-07 | Sharp Kk | Information processing apparatus with a gesture editing function. |
US5502803A (en) * | 1993-01-18 | 1996-03-26 | Sharp Kabushiki Kaisha | Information processing apparatus having a gesture editing function |
EP0887753A1 (en) * | 1996-11-15 | 1998-12-30 | Toho Business Management Center | Business management system |
EP0887753A4 (en) * | 1996-11-15 | 2000-09-27 | Toho Business Management Cente | Business management system |
US6618504B1 (en) | 1996-11-15 | 2003-09-09 | Toho Business Management Center | Business management system |
EP1103883A2 (en) * | 1999-11-29 | 2001-05-30 | Xerox Corporation | Input mode selection on a palmtop computer |
EP1103883A3 (en) * | 1999-11-29 | 2002-07-31 | Xerox Corporation | Input mode selection on a palmtop computer |
US6498601B1 (en) | 1999-11-29 | 2002-12-24 | Xerox Corporation | Method and apparatus for selecting input modes on a palmtop computer |
Also Published As
Publication number | Publication date |
---|---|
GB2234101B (en) | 1991-04-24 |
GB2234102B (en) | 1991-04-24 |
GB2234101A (en) | 1991-01-23 |
GB9019254D0 (en) | 1990-10-17 |
GB9019253D0 (en) | 1990-10-17 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US5933526A (en) | Handwritten keyboardless entry computer system | |
US4972496A (en) | Handwritten keyboardless entry computer system | |
US5157737A (en) | Handwritten keyboardless entry computer system | |
US6721452B2 (en) | System and method of handwritten character recognition | |
Schomaker | From handwriting analysis to pen-computer applications | |
US20070286486A1 (en) | System and method for automated reading of handwriting | |
JPH10510639A (en) | Multi pen stroke character set and handwritten document recognition system | |
US7911452B2 (en) | Pen input method and device for pen computing system | |
GB2234102A (en) | Handwritten keyboardless-entry computer system | |
Brocklehurst | The NPL electronic paper project | |
KR102293361B1 (en) | Apparatus and method for providing handwriting calibration function | |
CA1302572C (en) | Handwritten keyboardless entry computer system | |
JP3357343B2 (en) | I / O device | |
JPH0594564A (en) | Data processing system | |
CA1325481C (en) | Handwritten keyboardless entry computer system | |
Guyon et al. | Handwriting as computer interface | |
US20230298367A1 (en) | Display apparatus, formatting method, and non-transitory computer-executable medium | |
Thomassen et al. | Real-time processing of cursive writing and sketched graphics | |
Ford | On-line recognition of connected handwriting | |
JP2804660B2 (en) | Document processing device | |
JP2021096844A (en) | Display unit, display method, and program | |
Ward | Annotated Bibliography in On-line Character Recognition, Pen Computing, Gesture User Interfaces and Tablet and Touch Computers | |
JPH04155596A (en) | Handwritten character input device | |
JPH04303279A (en) | Information processor | |
JPH04109329A (en) | Data input system |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
732E | Amendments to the register in respect of changes of name or changes affecting rights (sect. 32/1977) | ||
732E | Amendments to the register in respect of changes of name or changes affecting rights (sect. 32/1977) | ||
PE20 | Patent expired after termination of 20 years |
Effective date: 20070722 |