Apple, Inc. v. Motorola, Inc. et al

Filing 12

AMENDED COMPLAINT for Patent Infringement against Motorola Mobility, Inc., Motorola, Inc., filed by Apple, Inc.. (Attachments: #1 Exhibit A - '949 patent, #2 Exhibit B - '002 patent, #3 Exhibit C - '315 patent, #4 Exhibit D - RE '486 patent, #5 Exhibit E - '354 patent, #6 Exhibit F - '263 patent, #7 Exhibit G - '983 patent, #8 Exhibit H - '705 patent, #9 Exhibit I - '647 patent, #10 Exhibit J - '852 patent, #11 Exhibit K - '131 patent, #12 Exhibit L - '337 patent, #13 Exhibit M - '867 patent, #14 Exhibit N - '721 patent, #15 Exhibit O - '599 patent) (Peterson, James) [Transferred from Wisconsin Western on 12/1/2011.]

Download PDF
EXHIBIT I 111111111111111111111111111111111111111111111111111111111111111111111111111 US005946647A United States Patent [19] [11] Miller et al. [45] [54] SYSTEM AND METHOD FOR PERFORMING AN ACTION ON A STRUCTURE IN COMPUTER-GENERATED DATA [75] Inventors: James R. Miller, Mountain View; Thomas Bonura, Capitola; Bonnie Nardi, Mountain View; David Wright, Santa Clara, all of Calif. [73] Assignee: Apple Computer, Inc., Cupertino, Calif. [21] Appl. No.: 08/595,257 [22] Filed: [51] [52] [58] [56] Feb. 1, 1996 6 Int. Cl. U.S. Cl. Field of Search G06F 17/27 704/9; 704/1 704/1,7, 9-10, 704/243; 707/513, 101-104 References Cited U.S. PATENT DOCUMENTS 5,115,390 5/1992 Fukuda et al. . 5,130,924 7/1992 Barker et al. 5,164,899 11/1992 Sobotka et al. 5,202,828 4/1993 Vertelney et al. 5,247,437 9/1993 Vale et al. 5,369,575 11/1994 Lamberti et al. . 5,574,843 11/1996 Gerlach et al. 364/146 704/1 704/9 364/419 704/1 704/1 395/118 OlliER PUBLICATIONS TerryMorse Software "What is Myrmidon" Downloaded from the Internet at URL http://www.terrymorse.com (Publication Date Unknown), 2 pages. Shoens, K. et al. "Rufus System: Information Organization for Semi-Structured Data," Proceedings of the 19th VLDB Conference (Dublin, Ireland 1993), pp. 1-12. 5,946,647 Patent Number: Date of Patent: Aug. 31,1999 Schwarz, Peter and Shoens, Kurt. "Managing Change in the Rufus System," Abstract from the IBM Almaden Research Center, pp. 1-16. Myers, Brad A. "Tourmaline: Text Formatting by Demonstration," (Chapter 14) in Watch What I Do: Programming by Demonstration, edited by Allen Cypher, MIT Press, (Cambridge, MA 1993), pp. 309-321. Maulsby, David. "Instructible Agents," Dissertation from the Department of Computer Science at The University of Calgary (Calgary, Alberta-Jun. 1994), pp. 178, 181-188, 193-196 (from Chapter 5). Rus, Daniela and Subramanian, Devika. "Designing Structure-Based Information Agents," AAAl Symposium (Mar. 1994), pp. 79-86. Primary Examiner~orester W. Isen Assistant Examiner-Patrick N. Edouard Attorney, Agent, or Firm-Carr & Ferrell LLP [57] ABSTRACT A system and method causes a computer to detect and perform actions on structures identified in computer data. The system provides an analyzer server, an application program interface, a user interface and an action processor. The analyzer server receives from an application running concurrently data having recognizable structures, uses a pattern analysis unit, such as a parser or fast string search function, to detect structures in the data, and links relevant actions to the detected structures. The application program interface communicates with the application running concurrently, and transmits relevant information to the user interface. Thus, the user interface can present and enable selection of the detected structures, and upon selection of a detected structure, present the linked candidate actions. Upon selection of an action, the action processor performs the action on the detected structure. 24 Claims, 10 Drawing Sheets 100 J! 120 115 Communications Interface 185 180 170 190 160 r , --H 165.....J- 155 ROM ---11 Operating System Program RAM ------- 120 175 1 Disk Storage CPU 1- 170 FIG. 1 180 { Ji 185 100 1 115 190 { Floppy Disk Drive Communications Interface Input Device _I Printer 110 '-"L' Application IV 167 , riS~~J172 Data --.r1 Output Device d =- ......::I ~ 0\ 0\ .... ~ \C Ul .... '" c"'" '" o"'" ...., ~ ~ .... 'JJ. '""'" '0 '0 '0 ~ '""'" ~ ~ ~ = ~ ..... ..... ~ ~ • 'JJ. • u.s. Patent Aug. 31,1999 Sheet 2 of 10 ~----------------------~ I , ..~: I L- c o C/) o C/) (.) (.) "+:: a> « e c. : : , • , • • • • • • • • • • • • • • • • • • • • • • • : • • • • • • • • • • • • • , • , , , , , , , • • • , • , , , , , , , , , , • , , • • , • , • • • , • , • , , , • , , , • I • I \ , , , , , , I , • I L- a> L- N a> as a> >-2: coo « ~. -------------------_ o c Q) E ~ (.) o o 5,946,647 , , , • , • • • • • • • • • ! ... C\I (!J u.. u.s. Patent Aug. 31,1999 5,946,647 Sheet 3 of 10 o C\l C\l . -----~-------------------------------------~ . • : , . , · . · . • • • , : , , ~ ~ t • ( ( ) • • • • • • • • • • • • • • • • • • • • . " 0 Q ) : ~ (/) : : • "o.Q C : • : • (/) -0 0 : • : IV : (/)<C : • l : « :• • • • • • • • • • • • • • • lo : t :,... lM'L • , • , • , • , ~ : Q) : • . • , • , • . : (1j : : ! · • · , · · • · • • • • · · • • • • • • • : : ~ ~ : : ! • , • , • , , • , • . I • • • , • • • , • ~: ( 1 j : : • E: • : : , ( • • - ' ~: : · : · I • • I \ · • • • , • I , L , E: 1'1"'1: ' - ' . ~ • • ( , , • . , • • • • . I • • I ~ CJ LL 410 / ~ '\ i'. / Call # Put in electronic telephone book Actions: FIG. 4 Write letter Call person (retrieve #) Put in electronic message folder Name: name library Date: date grammar Actions: Put in electronic calendar E-mail address: e-mail address grammar Actions: Send E-Mail Put in E-Mail address book Post-office address: post-office address grammar Actions: Write letter Put in address book Actions: Phone number: phone number grammar ~ 420 o d =- ......::I ~ 0\ 0\ .... ~ \C Ul .... '" c"'" o ...., ~ .... ~ ~ 'JJ. '""'" '0 '0 '0 ~ '""'" ~ ~ ~ = ~ ..... ..... ~ ~ • 'JJ. • This is my new FIG. 5 John Doe Sincerely, E-mail address:Jdoe@work.com address: 1 Hilly Street San Francisco, CA 94105 phone number: (415) 555-1234 Bob: d =- ......::I ~ 0\ 0\ .... ~ \C Ul .... '" c"'" o ...., Ul .... ~ ~ 'JJ. '""'" '0 '0 '0 ~ '""'" ~ ~ ~ = ~ ..... ..... ~ ~ • 'JJ. • u.s. Patent Aug. 31,1999 Sheet 6 of 10 5,946,647 o ,.... LO LO 0 ,... "d- M C\J 0> ,... « 0 I LC) LC) LC) ~ 0) e: ~ E -LC) ,... "d- to: 0) .0 C/) O)C/) 0)-- .... 0 +-Ie: we ~LL .- e: J: ;:j ..c: III) +-10 ro E ,...w .!!2 .0 0 0 e: 0) e: 0 ..c: 0. C/) C/) 0) .... "'C "'C ro E O 0 .:::i .... 0 ~ @ ~ 0) .... 0) 0 0) 0 "'C e: (j) .. C/) C/) 0) .... "'C "'C ro ·ro E w I 0) 0 0 e: £ 0 <.0 • CJ LL u.s. Patent Augo 31,1999 Sheet 7 of 10 5,946,647 o or- LO ~ >. (],) 0 (],) 0 f'.. ~ c .c • (],) () c ~ en (],) c >. E en o~ ..c: t- o • .c 0 CO ~ (J) .c E ~ c (],) C 0 .c 0- en en ~ °co "0 "0 CO W (J) E I 0 J (!J u.. u.s. Patent Aug. 31,1999 5,946,647 Sheet 8 of 10 START Receive Document Content 810 Scan for Patterns in Document Content 820 Link Actions to Detected Structures 825 Retrieve Presentation Regions for Detected Structures No FIG. 8 u.s. Patent Aug. 31,1999 Display Regions 910 930 Display Menu of Actions Execute Action FIG. 9 5,946,647 Sheet 9 of 10 950 u.s. Patent Aug. 31,1999 5,946,647 Sheet 10 of 10 820 START ~ I Retrieve Data to be Analyzed 1010 / I I I ~ Retrieve Grammars 1030 1020 V ~ 1040 Detect Structures Using Grammars + Link Associated Actions to Detected Structures l - - -______ ~_ _ _ _ _ _ _ _ _ _ _ _ _ V 1OSO ------------------ 1 I I Retrieve Library of Strings ~ Detect Identical Strings in Data 1070 1080 ~ Link Associated Actions to Detected Strings /1090 ,r I Perform Other Pattern Analysis ... END FIG. 10 1100 1060 V 5,946,647 1 2 SYSTEM AND METHOD FOR PERFORMING AN ACTION ON A STRUCTURE IN COMPUTER-GENERATED DATA tion of an action and automatically performs the selected action on the structure. BACKGROUND OF THE INVENTION 1. Field of the Invention This invention relates generally to manipulation of structures in computer data. More particularly, the invention relates to a system and method for performing computerbased actions on structures identified in computer data. 2. Description of the Background Art Much data that appears in a computer user's day-to-day activities contains recognizable structures that have semantic significance such as phone numbers, e-mail addresses, post-office addresses, zip codes and dates. In a typical day, for example, a user may receive extensive files from wordprocessing programs and e-mail that contain several of these structures. However, visually searching data files or documents to find these structures is laborious and cognitively disruptive, especially if the document is lengthy and hard to follow. Furthermore, missing a structure such as a date may lead to missing an important meeting or missing a deadline. To help facilitate searching a document for these structures, programmers can create or employ pattern analysis units, such as parsers, to automatically identify the structures. For the purposes of the present description, the term "pattern" refers to data, such as a grammar, regular expression, string, etc., used by a pattern analysis unit to recognize information in a document, such as dates, addresses, phone numbers, names, etc. The term "structure" refers to an instantiation of a pattern in the document. That is, a "date" pattern will recognize the structure "Oct. 31, 1995." The application of a pattern to a document is termed "parsing." Conventional systems that identify structures in computer data do not enable automatic performance of an action on an identified structure. For example, if a long e-mail message is sent to a user, the user may implement a pattern analysis unit to search for particular structures, such as telephone numbers. Upon identification of a structure, the user may want to perform an action on the structure, such as moving the number to an electronic telephone book. This usually involves cutting the structure from the e-mail message, locating and opening the electronic telephone book application program, pasting the structure into the appropriate field, and closing the application program. However, despite the fact that computer systems are getting faster and more efficient, this procedure is still tedious and cognitively disruptive. One type of system that has addressed this problem involves detecting telephone numbers. Such systems enable a user to select a telephone number and request that the application automatically dial the number. However, these systems do not recognize the selected data as a telephone number, and they generally produce an error message if the user selects invalid characters as a phone number. Also, they do not enable the performance of other candidate actions, such as moving the number to an electronic telephone book. That is, if a user wishes to perform a different action on an identified telephone number, such as storing the number in an address book, the user cannot automatically perform the action but must select and transfer the number to the appropriate data base as described above. Therefore, a system is needed that identifies structures, associates candidate actions to the structures, enables selec- 5 10 15 20 25 30 35 40 45 50 55 60 SUMMARY OF THE INVENTION The present invention overcomes the limitations and deficiencies of previous systems with a system that identifies structures in computer data, associates candidate actions with each detected structure, enables the selection of an action, and automatically performs the selected action on the identified structure. It will be appreciated that the system may operate on recognizable patterns for text, pictures, tables, graphs, voice, etc. So long as a pattern is recognizable, the system will operate on it. The present ~nvention has significant advantages over previous systems, III that the present system may incorporate an open-ended number and type of recognizable patterns, an open-ended number and type of pattern analysis units, and further that the system may enable an open-ended number and type (i.e. scripts, macros, code fragments, etc.) of candidate actions to associate with, and thus perform, on each identified structure. The present invention provides a computer system with a central processing unit (CPU), input/output (I/O) means, and a memory that includes a program to identify structures in a document and perform selected computer-based actions on the identified structures. The program includes program subroutines that include an analyzer server, an application program interface, a user interface and an action processor. The analyzer server receives data from a document having recognizable structures, and uses patterns to detect the structures. Upon detection of a structure, the analyzer server links actions to the detected structure. Each action is a computer subroutine that causes the CPU to perform a sequence of operations on the particular structure to which it is linked. An action may specify opening another application, loading the identified structure into an appropriate field, and closing the application. An action may further include internal actions, such as storing phone numbers in an electronic phone book, addresses in an electronic address book, appointments on an electronic calendar, and external actions such as returning phone calls, drafting letters, sending facsimile copies and e-mail, and the like. Since the program may be executed during the run-time of another program, i.e. the application which presents the document, such as Microsoft Word, an application program interface provides mechanisms for interprogram communications. The application program interface retrieves and transmits relevant information from the other program to the user interface for identifying, presenting and enabling selection of detected structures. Upon selection of a detected structure, the user interface presents and enables selection of candidate actions. When a candidate action is selected the action processor performs the selected action on the sel;cted structure. In addition to the computer system, the present invention also provides methods for performing actions on identified structures in a document. In this method, the document is analyzed using a pattern to identify corresponding structures. Identified structures are stored in memory and presented to the user for selection. Upon selection of an identified structure, a menu of candidate actions is presented, each of which may be selected and performed on the selected structure. BRIEF DESCRIPTION OF THE DRAWINGS 65 FIG. 1 is a block diagram of a computer system having a program stored in RAM, in accordance with the present invention. 5,946,647 3 4 FIG. 2 is a block diagram of the program of FIG. 1. FIG. 3 is a block diagram illustrating the analyzer server of FIG. 2. FIG. 4 is a block diagram illustrating a particular example of the analyzer server of FIG. 2. FIG. 5 illustrates a window presenting an example of a document having recognizable structures. FIG. 6 illustrates a window with the identified structures in the example document of FIG. 5 highlighted based on the analyzer server of FIG. 4. FIG. 7 illustrates a window showing the display of a pop-up menu for selecting an action. FIGS. 8 and 9 together are a flowchart depicting the preferred method for selecting and performing an action on an identified structure. FIG. 10 is a flowchart depicting the preferred method for identifying a structure in a data sample. After identifying structures and linking actions, application program interface 230 communicates with application 167 to obtain information on the identified structures so that user interface 240 can successfully present and enable selection of the actions. In a display-type environment, application program interface 230 retrieves the locations in document 210 of the presentation regions for the detected structures from application 167. Application program interface 230 then transmits this location information to user interface 240, which highlights the detected structures, although other presentation mechanisms can be used. User interface 240 enables selection of an identified structure by making the presentation regions mouse-sensitive, i.e. aware when a mouse event such as a mouse-down operation is performed while the cursor is over the region. Alternative selection mechanisms can be used such as touch sensitive screens and dialog boxes. It will be appreciated that detected structures can be hierarchical, i.e. that a sub-structure can itself be selected and have actions associated with it. For example, a user may be able to select the year portion of an identified date, and select actions specific to the year rather than to the entire date. User interface 240 communicates with application 167 through application program interface 230 to determine if a user has performed a mouse-down operation in a particular mouse-sensitive presentation region, thereby selecting the structure presented at those coordinates. Upon selection of this structure, user interface 240 presents and enables selection of the linked candidate actions using any selection mechanism, such as a conventional pull-down or pop-up menu. The above description of the user interface is cast in terms of a purely visual environment. However, the invention is not limited to visual interface means. For example, in an audio environment, user interface 240 may present the structures and associated actions to the user using voice synthesis and may enable selection of a pattern and action using voice or sound activation. In this type of embodiment, analyzer server 220 may be used in conjunction with a text-to-speech synthesis application 167 that reads documents to users over a telephone. Analyzer server 220 scans document 210 to recognize patterns and link actions to the recognized patterns in the same manner as described above. In the audio environment, user interface 240 may provide a special sound after application 167 reads a recognized pattern, and enable selection of the pattern through the use of an audio interface action, such as a voice command or the pressing of a button on the touch-tone telephone keypad as before. Thus, user interface 240 may present the linked actions via voice synthesis. One can create various environments having a combination of sensory mechanisms. Upon selection of a candidate action, user interface 240 transmits the selected structure and the selected action to action processor 250. Action processor 250 retrieves the sequence of operations that constitute the selected action, and performs the sequence using the selected structure as the object of the selected action. Referring now to FIG. 3, a block diagram illustrating an analyzer server 220 is shown. In this figure, analyzer server 220 is described as having a parser 310 and a grammar file 320, although alternatively or additionally a fast string search function or other function can be used. Parser 310 retrieves a grammar from grammar file 320 and parses text using the retrieved grammar. Upon identification of a structure in the text, parser 310 links the actions associated with the grammar to the identified structure. More particularly, parser 310 retrieves from grammar file 320 pointers attached DETAILED DESCRIPTION OF IRE PREFERRED EMBODIMENT Referring now to FIG. 1, a block diagram is shown of a computer system 100 including a CPU 120. Computer system 100 is preferably a microprocessor-based computer, such as a Power Macintosh manufactured by Apple Computer, Inc. of Cupertino, Calif. An input device 110, such as a keyboard and mouse, and an output device 105, such as a CRT or voice module, are coupled to CPU 120. ROM 155, RAM 170 and disk storage 175 are coupled to CPU 120 via signal bus 115. Computer system 100 optionally further comprises a printer 180, a communications interface 185, and a floppy disk drive 190, each coupled to CPU 120 via signal bus 115. Operating system 160 is a program that controls and facilitates the processing carried out by CPU 120, and is typically stored in RAM 170. Application 167 is a program, such as a word-processor or e-mail program, that presents data on output device 105 to a user. The program 165 of the present invention is stored in RAM 170 and causes CPU 120 to identify structures in the data presented by application 167, to associate actions with the structures identified in the data, to enable the user to select a structure and an action, and to automatically perform the selected action on the identified structure. This program 165 may be stored in disk storage 175 and loaded into an allocated section of RAM 170 prior to execution by CPU 120. Another section of RAM 170 is used for storing intermediate results and miscellaneous data 172. Floppy disk drive 190 enables the storage of the present program 165 onto a removable storage medium which may be used to initially load program 165 into computer system 100. Referring now to FIG. 2, a schematic block diagram of program 165 is shown together with its interaction with a document 210. Program 165 contains program subroutines including an analyzer server 220, an application program interface 230, a user interface 240 and an action processor 250. Analyzer server 220 receives data having recognizable patterns from a document 210, which may be retrieved from a storage medium such as RAM 170, ROM 155, disk storage 175, or the like, and presented on output device 105 by application 167. Analyzer server 220 comprises one or more pattern analysis units, such as a parser and grammars or a fast string search function and dictionaries, which uses patterns to parse document 210 for recognizable structures. Upon detection of a structure, analyzer server 220 links actions associated with the responsible pattern to the detected structure, using conventional pointers. 5 10 15 20 25 30 35 40 45 50 55 60 65 5,946,647 5 6 to the grammar and attaches the same pointers to the identified structure. These pointers direct the system to the associated actions contained in associated actions file 330. Thus, upon selection of the identified structure, user interface 240 can locate the linked actions. FIG. 4 illustrates an example of an analyzer server 220, which includes grammars 410 and a string library 420 such as a dictionary, each with associated actions. One of the grammars 410 is a telephone number grammar with associated actions for dialing a number identified by the telephone number grammar or placing the number in an electronic telephone book. Analyzer server 220 also includes grammars for post-office addresses, e-mail addresses and dates, and a string library 420 containing important names. When analyzer server 220 identifies an address using the ..e-mail address" grammar, actions for sending e-mail to the identified address and putting the identified address in an e-mail address book are linked to the address. FIG. 5 shows a window 510 presenting an exemplary document 210 having data containing recognizable structures, including a phone number, post-office address, e-mail address, and name. Window 510 includes a button 520 for initiating program 165, although alternative mechanisms such as depressing the "option" key may be used. Upon initiation of program 165, system 100 transmits the contents of document 210 to analyzer server 220, which parses the contents based on grammars 410 and strings 420 (FIG. 4). This parsing process produces the window shown in FIG. 6. As illustrated in FIG. 6, analyzer server 220 identifies the phone number, post-office address, e-mail address and name. Although not shown in FIG. 6, analyzer server 220 links the actions associated with grammars 410 and strings 420 to these identified structures, and application program interface 230 retrieves information on the location of these structures from application 167. User interface 240 then highlights the identified structures in document 210, and makes the identified structures mouse-sensitive. As shown in FIG. 7, upon recognition of a mouse-down operation over a structure, user interface 240 presents a pop-up menu 710. In this example, pop-up menu 710 displays the candidate actions linked to the selected telephone number grammar 410, including dialing the number and putting the number into an electronic telephone book. Upon selection of the action for putting the number in an electronic telephone book, user interface 240 transmits the corresponding telephone number and selected action to action processor 250. Action processor 250 locates and opens the electronic telephone book, places the telephone number in the appropriate field and allows the user to input any additional information into the file. FIGS. 8 and 9 display a flowchart illustrating preferred method 800 for recognizing patterns in documents and performing actions. This method is carried out during the run-time of application 167. Referring first to FIG. 8, method 800 starts by receiving 810 the content, or a portion of the content, from document 210. Assuming program 165 initiates with the receipt of any text, the received content or portion is scanned 820 for identifiable structures using the patterns in analyzer server 220. Upon detection of a structure based on a particular pattern, actions associated with the particular pattern are linked 825 to the detected structure. Assuming a display-type environment, the presentation region location for a detected structure is retrieved 830 from application 167. If the document content being displayed on output device 105 is changed 840, for example by the user adding or modifying text, method 800 restarts. Otherwise, method 800 continues with block 850. If the presentation regions change 850, for example by the a user scrolling document 210, then new presentation regions from application 167 are again retrieved 830. Otherwise, method 800 continues to block 860. As illustrated by block 860, method 800 loops between blocks 840 and 860 until a request for display of identified structures is received 860. It will be appreciated that the steps of the loop (blocks 840, 850 and 860) can be performed by application 167. Referring also to FIG. 9, when a request for the display of detected structures is received 860, the regions are displayed 910 using presentation mechanisms such as highlighting the presentation region around each detected structure, although alternative presentation mechanisms can be used. If a request for the display of candidate actions linked to a detected structure is not received 920, method 800 returns to block 840. However, if a request is received 920, the actions linked in block 825 are displayed 930. This request for display of candidate actions can be performed using a selection mechanism, such as a mouse-down operation over a detected structure, which causes the candidate actions linked to the structure to be displayed 930. Display 930 of candidate actions may be implemented using a pop-up menu, although alternative presentation mechanisms can be used such as pull-down menus, dialog boxes and voice synthesizers. As illustrated in block 940, if an action from the displayed candidate actions is not selected 940, method 800 returns to block 840. However, if an action is selected 940, the action is executed 950 on the structure selected in block 920. After execution 950 of an action, method 800 returns to block 840. Method 800 ends when the user exits application 167, although other steps for ending method 800 can alternatively be used. Referring now to FIG. 10, a flowchart illustrating the preferred method 820 for scanning and detecting patterns in a document is shown. Method 820 starts by retrieving 1010 data to be analyzed. After the data is retrieved, several pattern analysis processes may be performed on the data. As illustrated in block 1020, a parsing process retrieves 1030 grammars, detects 1040 structures in the data based on the retrieved grammars, and links 1050 actions associated with each grammar to each structure detected by that grammar. As illustrated in block 1060, a fast string search function retrieves 1070 the contents of string library 420, detects 1080 the strings in the data identical to those in the string library 420, and links 1090 actions associated with the library string to the detected string. As illustrated in block 1100, additional pattern analysis processes, such as a neural net scan, can be performed 1100 to detect in the data other patterns, such as pictures, graphs, sound, etc. Method 820 then ends. Alternatively, the pattern analysis processes can be performed in parallel using a multiprocessor multitasking system, or using a uniprocessor multithreaded multitasking system where a thread is allocated to execute each pattern detection scheme. These and other variations of the preferred and alternate embodiments and methods are provided by the present invention. For example, program 165 in FIG. 1 can be stored in ROM, disk, or in dedicated hardware. In fact, it may be realized as a separate electronic circuit. Other components of this invention may be implemented using a programmed general purpose digital computer, using application specific integrated circuits, or using a network of interconnected conventional components and circuits. The analyzer server 220 of FIG. 2 may use a neural net for searching a graphical document 210 for faces, or a musical library for searching a stored musical piece 210 for sounds. The user interface 240 5 10 15 20 25 30 35 40 45 50 55 60 65 5,946,647 7 8 may present structures and actions via voice synthesis over 13. A program storage medium storing a computer proa telephone line connection to system 100. The embodigram for causing a computer to perform the steps of: ments described have been presented for purposes of illusreceiving computer data; tration and are not intended to be exhaustive or limiting, and detecting a structure in the data; many variations and modifications are possible in light of 5 the foregoing teaching. The system is limited only by the linking at least one action to the detected structure; following claims. enabling selection of the structure and a linked action; and What is claimed is: executing the selected action linked to the selected struc1. A computer-based system for detecting structures in ture. data and performing actions on detected structures, com- 10 14. In a computer having a memory storing actions, a prising: system for causing the computer to perform an action on a an input device for receiving data; structure identified in computer data, comprising: an output device for presenting the data; a memory storing information including program routines means for receiving computer data; 15 including means for detecting a structure in the data; an analyzer server for detecting structures in the data, means for linking at least one action to the detected and for linking actions to the detected structures; structure; a user interface enabling the selection of a detected means for selecting the structure and a linked action; and structure and a linked action; and an action processor for performing the selected action 20 means for executing the selected action linked to the linked to the selected structure; and selected structure. a processing unit coupled to the input device, the output 15. In a computer having a memory storing actions, a device, and the memory for controlling the execution of method for causing the computer to perform an action on a the program routines. structure identified in computer data, comprising the steps 2. The system recited in claim 1, wherein the analyzer 25 of: server stores detected structures in the memory. receiving computer data; 3. The system recited in claim 1, wherein the input device detecting a structure in the data; receives the data from an application running concurrently, and wherein the program routines stored in memory further 30 linking at least one action to the detected structure; comprise an application program interface for communicatenabling selection of the structure and a linked action; and ing with the application. executing the selected action linked to the selected struc4. The system recited in claim 1, wherein the analyzer ture. server includes grammars and a parser for detecting struc16. The method recited in claim 15, wherein the computer tures in the data. 35 data is received from the application running concurrently. 5. The system recited in claim 4, wherein the analyzer 17. The method recited in claim 15, wherein the memory server includes actions associated with each of the contains grammars, and wherein the step of detecting a grammars, and wherein the analyzer server links to a structure further comprises the steps of retrieving a grammar detected structure the actions associated with the grammar 40 and parsing the data based on the grammar. which detects that structure. 18. The method recited in claim 17, wherein the grammar 6. The system recited in claim 1, wherein the analyzer is associated with a particular action, and wherein the step server includes a string library and a fast string search of linking at least one action to the detected structure function for detecting string structures in the data. 7. The system recited in claim 6, wherein the analyzer 45 includes the step of linking the particular action to the detected structure. server includes actions associated with each of the strings, 19. The method recited in claim 15, wherein the memory and wherein the analyzer server links to a detected structure contains strings, and wherein the step of detecting a structure the actions associated with the grammar which detects that further comprises the steps of retrieving a string from the string structure. 8. The system recited in claim 1, wherein the user 50 memory and scanning the data to identify the string. 20. The method recited in claim 15, further comprising interface highlights detected structures. after the step of detecting a structure, the step of highlighting 9. The system recited in claim 1, wherein the user the detected structure. interface enables selection of an action by causing the output 55 21. The method recited in claim 15, further comprising, device to display a pop-up menu of the linked actions. after the step of linking at least one action to the detected 10. The system recited in claim 1, wherein the programs structure, the step of displaying and enabling selection of an stored in the memory further comprise an application runaction for performance on the detected structure. ning concurrently that causes the output device to present 22. A computer-based method for causing a computer to the data received by the input device, and an application program interface that provides interrupts and communi- 60 identify, select and perform an action on a structure in computer data received from a concurrently running cates with the application. application, said application presenting the computer data to 11. The system recited in claim 1, wherein the user the user, the method comprising the steps of: interface enables the selection of a detected structure and a receiving computer data from the application; linked action using sound activation. 65 detecting a structure in the computer data; 12. The system recited in claim 1, wherein a first one of the actions may invoke a second one of the actions. linking at least one action to the detected structure; 5,946,647 9 10 communicating with the application to determine the 23. The method recited in claim 15, wherein the step of location of the detected structure as presented by the enabling uses sound activation. application, to enable selection of the detected structure 24. The method recited in claim 15, wherein a first one of and a linked action, and to determine if the detected 5 the actions may invoke a second one of the actions. structure and a linked action have been selected; and performing a selected action linked to the detected pattern. * * * * *

Disclaimer: Justia Dockets & Filings provides public litigation records from the federal appellate and district courts. These filings and docket sheets should not be considered findings of fact or liability, nor do they necessarily reflect the view of Justia.


Why Is My Information Online?