Methods and apparatuses for display and traversing of links in page character array

Information

  • Patent Grant
  • 8527861
  • Patent Number
    8,527,861
  • Date Filed
    Friday, April 13, 2007
    17 years ago
  • Date Issued
    Tuesday, September 3, 2013
    11 years ago
  • Inventors
  • Original Assignees
  • Examiners
    • Rutledge; Amelia
    Agents
    • Morgan, Lewis & Bockius LLP
Abstract
A method for processing a page character array finds links and creates link groups containing adjacent link characters. Adjacency of link characters is preferably defined as characters which are separated by any combination of no characters, blank space characters, line feed characters, or separator characters, such as vertical or horizontal separator bars or other separator characters. Once link groups have been defined, the method lays out each link group for display in an optimized form. Links are displayed as buttons. An optimized form of display includes centering all the buttons in a vertical list. Another optimized form of display includes laying out the link group as a rectangular matrix of buttons. According to another aspect, each of the links in a link group are logically mapped to a distinct user input, such as a key or voice command. The logical mapping aspect and optimized display aspect are optionally combined for certain types of hardware. For example, if keys are physically adjacent to any part of the display, the links are displayed near the keys, or in horizontal and/or vertical alignment with the keys, so that the key to which a link is mapped is apparent from its position on the display screen. As another example, the name of key or command to which a link is mapped is displayed within or beside the button containing the name of the link.
Description
CROSS REFERENCE TO RELATED PATENT

The following U.S. patent is assigned to the assignee of the present application, and its disclosure is incorporated herein by reference:


U.S. Pat. No. 6,547,830, issued Apr. 15, 2003, by Paul Mercer and entitled, “METHOD AND ARTICLE OF MANUFACTURE FOR MAXIMIZING THE AMOUNT OF TEXT DISPLAYED.”


BACKGROUND OF THE INVENTION

1. Field of the Invention


The present invention pertains to the field of browsers for displaying page character arrays, such as HTML web pages, which have link characters representing links to other page character arrays. Specifically, the present invention pertains to the field of small display devices, such as cellular telephones.


2. Discussion of the Related Art


Many devices, such as handheld devices, have relatively small displays for providing information to users. Typically, handheld devices are designed to be mobile, lightweight, and small, which necessitates a relatively small display. A cellular telephone is an example of a handheld device having a small display. The cellular telephone's small display provides only enough space for a few lines of text which may include a name and a telephone number. Large amounts of text are not easily provided on a small display.


Moreover, users of handheld devices may require more information than can be easily provided on a small display. A typical user may want to have information that requires extensive text such as weather forecasts, driving directions, or stock updates. This type of information generally requires numerous lines of text that may not fit on a small display. For example, a user may desire to access an internet page having a variety of fonts identifying links or other usable information. Large amounts of information may be obtained from remote locations, such as servers on the internet, which are accessible by a handheld device, but the amount of information provided to a user is limited by the small display of the handheld device.


The content of internet web pages is specified by page character arrays containing, for example, HTML (Hyper Text Markup Language) code or another descriptor language's code, such as HDML, WML, SGML, or XML. Any device, such as a browser, attempting to display web pages must be able to interpret the codes in the page character arrays that describe the web pages. A link character is a type of character in page character array describing a web page that represents a pointer to another web page specified by another page character array.


Conventional browsers display link characters in page character arrays as blue underlined text. Groups of links are conventionally constructed of link characters separated by separator bars and/or blank spaces. Conventional browsers make no attempt to optimize the display of groups of links based upon the display size or hardware configuration of the machine running the browser. In other words, aside from underlining the links and coloring them blue, a conventional browser makes no other decisions about how to display a link. Links may be interspersed with text, graphics, and other links; the placement of the link on the display depends upon the surrounding context.


Frequently, web pages include “link bars” which are a series of several links placed adjacently or in close proximity to one another. The links in the link bars are sometimes separated by vertical bars, placed on separate lines, or include blank spaces between them. Conventionally, there is no explicit indication in the page character array that a series of links are associated to one another. As a consequence of this fact, a series of links may be intended to fit on a single line by the author of the web page. However, when the page is accessed by a small screen device, all the links can not fit on a single line due to the limited width of the display. This results in a confusing and visually displeasing result on the small screen device.


Furthermore, conventional browsers make no attempt to provide a mechanism, other than cursor pointing and clicking, by which the user can select a link in a web page so that another web page can be retrieved. Small screen devices, such as cellular phones, typically do not have mouses or cursor pointing and clicking capability.


As is apparent from the above discussion, a need exists for an acceptable and visually pleasing way to display of groups of links for small screen displays. A need also exists for the provision of a link selection mechanism for machines which do not have cursor pointing and clicking capabilities.


SUMMARY OF THE INVENTION

Conventional browsers display link characters in page character arrays as blue underlined text. Groups of links are conventionally constructed of link characters separated by separator bars and/or blank spaces. Conventional browsers make no attempt to optimize the display of groups of links based upon the display size or hardware configuration of the machine running the browser. Conventional browsers make no attempt to provide a mechanism, other than cursor pointing and clicking, by which the user can select a link. An object of the present invention is to optimize the display of groups of links for small screen displays. Another object of the present invention is to provide an efficient link selection mechanism for machines which do not have cursor pointing and clicking capabilities.


According to an aspect of the present invention, a method for processing a page character array finds links and creates link groups containing adjacent link characters. Adjacency of link characters is preferably defined as characters which are separated by any combination of no characters, blank space characters, line feed characters, or separator characters, such as vertical or horizontal separator bars or other separator characters. By filtering out line feeds, links which would conventionally be displayed as vertical link lists are detected and grouped as link groups for optimized display according to the present invention.


Once link groups have been defined, the method lays out each link group for display in an optimized form. In the preferred embodiment of the present invention, links are displayed as buttons. An optimized form of display according to the present invention includes centering all the buttons in a vertical list. Another optimized form of display according to the present invention includes laying out the link group as a rectangular matrix of buttons.


According to another aspect of the present invention, each of the links in a link group is logically mapped to a distinct user input. For example, if a link group consists of nine links, then each of the links is mapped to one of the nine keys 1 through 9. If the link group is currently being displayed, then by pressing any of the keys 1 through 9, the machine traverses the corresponding link. As another example, in a machine with a microphone, each of the links is mapped to a specific voice command. This voice command mapping is alternatively coupled with the keystroke mapping. Thus, the user either presses the 3 key or says the word “three” to instruct the machine to traverse the third link in a link group. The logical mapping of links to a distinct user input provides a mechanism for selecting the link which was not specified by the page character array, but rather which is intelligently instantiated according to the present invention.


The logical mapping aspect and optimized display aspect of the present invention are optionally combined for certain types of hardware. For example, in a cellular telephone having keys 1 through 9 physically configured in a standard three-by-three telephone keypad matrix, the links are laid out on the display screen in a three-by-three rectangular matrix such that the upper left link corresponds to the key 1 and the lower right link corresponds to the key 9. As another example, if keys are physically adjacent to any part of the display, the links are displayed near the keys, or in horizontal and/or vertical alignment with the keys, so that the key to which a link is mapped is apparent from its position on the display screen. As yet another example, the name of key or command to which a link is mapped is displayed within or beside the button containing the name of the link; thus, additional information not specified in the page character array is interjected into the display according to the present invention to facilitate link selection.


These and other features, aspects, and advantages of the present invention are fully described in the Detailed Description of the Invention, which discusses the Figures in narrative form.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1A illustrates a cellular telephone having software according to an embodiment of the present invention.



FIG. 1B illustrates a block diagram of a device according to an embodiment of the present invention.



FIG. 2 illustrates a software and hardware block layer diagram according to an embodiment of the present invention.



FIG. 3 illustrates a page character array used as input to the methods according to the present invention.



FIG. 4 illustrates a conventional browser's display screen appearance after displaying the page character array shown in FIG. 3.



FIG. 5 illustrates a method of processing a page character array according to the present invention.



FIG. 6 illustrates a display screen appearance after displaying the page character array shown in FIG. 3 using a method according to the present invention shown in FIGS. 5 and 13.



FIG. 7 illustrates an input device to link correspondence table generated by a method according to the present invention shown in FIGS. 5 and 15 for the page character array shown in FIG. 3 and the display screen appearance shown in FIG. 6.



FIG. 8 illustrates a method of implementing the step shown in FIG. 5 of finding links and creating link groups according to the present invention.



FIG. 9 illustrates a continuation of the page character array shown in FIG. 3 used as input to the methods according to the present invention.



FIG. 10A illustrates a link group extracted from the page character array shown in FIG. 3 by a method according to the present invention shown in FIG. 8.



FIG. 10B illustrates another link group extracted from the page character array shown in FIGS. 3 and 9 by a method according to the present invention shown in FIG. 8.



FIG. 11 illustrates an intermediate page character array generated from the page character array shown in FIGS. 3 and 9 by a method according to the present invention shown in FIG. 8.



FIG. 12 illustrates a conventional browser's display screen appearance after displaying the page character array shown in FIG. 9.



FIG. 13 illustrates a method of implementing the step shown in FIG. 5 of laying out link groups for a display screen in an optimized form according to the present invention.



FIG. 14 illustrates a display screen appearance after displaying the page character array shown in FIG. 9 using a method according to the present invention shown in FIGS. 5 and 13.



FIG. 15 illustrates a method of implementing the step shown in FIG. 5 of logically mapping link groups to the distinct user input according to the present invention.



FIG. 16 illustrates a display screen appearance in relation to input device keys after displaying the page character array shown in FIG. 3 using a method according to the present invention shown in FIGS. 5 and 13.



FIG. 17 illustrates an input device to link correspondence table generated by a method according to the present invention shown in FIGS. 5 and 15 for the page character array shown in FIG. 3 and the display screen appearance shown in FIG. 16.



FIG. 18 illustrates a display screen appearance after displaying the page character array shown in FIG. 3 using a method according to the present invention shown in FIGS. 5 and 15.





The Figures are more fully described in narrative form in the Detailed Description of the Invention. In the Figures, like method steps are labeled with like reference numerals.


DETAILED DESCRIPTION OF THE INVENTION


FIG. 1A illustrates a device having a small display according to an embodiment of the present invention. In an embodiment, the device may be a handheld device. In particular, FIG. 1A illustrates a cellular telephone 1 having a small display 15. Cellular telephone 1 also includes input device 16 and, in particular, a numeric keypad. Display 15 provides a window 2 having text 3 according to an embodiment of the present invention. An expanded view of window 2 and text 3 is illustrated in FIG. 3 and described below. Cellular telephone 1 has wireless access to the world-wide-web (“www”) or internet 18 and/or may optionally be connected to other data networks such as the Wireless Access Protocol (“WAP”).


While a cellular telephone embodiment of the present invention is illustrated in FIG. 1A, one of ordinary skill in the art would appreciate that many other embodiments of the present invention fall within the scope of the appended claims. For example, embodiments of the present invention may include pagers, palm top computers, personal digital assistants (“PDA”), digital video device (“DVD”) players, digital cameras, printers, or an equivalent thereof. Generally, an embodiment of the present invention may include any information appliance. An information appliance is any mobile device that is designed to provide users with access to information stored on the device, or to information stored elsewhere when connected to data resources via a wired or wireless connection.


According to embodiments of the present invention, cellular telephone 1, supports wireless protocol communications, including the Global System for Mobile communications (“GSM”), Time Division Multiple Access (“TDMA”), Personal Digital Cellular (“PDC”), Code Division Multiple Access (“CDMA”), W-CDMA, or CDMA-2000.



FIG. 1B illustrates a hardware/software block diagram according to an embodiment of the present invention. A device 17 according to an embodiment of the present invention includes an electronics bus 14 for electrically coupling various device components. Ellipses are shown to identify other software and hardware components that may be present in an embodiment of the present invention. For example, device 17 may be a cellular telephone which has communication software and wireless communication hardware.


Processor 10 is coupled to bus 14. In an embodiment, processor 10 may be an embedded microprocessor such as a Sharp® Microelectronics ARM7 processor, a low power 32 bit reduced instruction set computer (“RISC”) processor. In another embodiment, processor 10 may be a Motorola® 68K Dragonball microprocessor. In alternate embodiments, processor 10 may be a Power PC, MIPS, or X86 processor.


Memory 11 is also coupled to bus 14 and stores link group software 12 according to an embodiment of the present invention. In an alternate embodiment, link group software 12 may be stored on persistent storage device such as a magnetic hard disk, a floppy magnetic disk, CD-ROM or other write data storage technology, singly or in combination. Memory 11 can include read-only-memory (“ROM”), ready-access-memory (“RAM”), virtual memory or other memory technology, singly or in combination. In an embodiment, memory 11 is an approximately 50K ROM.


Speaker/microphone 17 is also coupled to bus 14 and is used as an audio input/output device in an embodiment of the present invention. Input device 16 is coupled to bus 14. In an embodiment, input device 16 may be a numeric keypad or a touch sensitive screen. Small display 15 is also coupled to bus 14. In an embodiment, small display 15 may be a bit map display having a pixel size of 80×60. In alternate embodiments, the small display 15 may have a pixel size up to and including 128×64, 160×240, or 320×240.



FIG. 2 illustrates a software and hardware block layer diagram 30 according to an embodiment of the present invention. System software 32 and system hardware 31 are used in connection with application program interface 33 to support a graphical user interface 34 according to an embodiment of the present invention.


System software 32 may include a real time operating system software for controlling internal operation of device 17. System software 32 may also include a web browser for accessing internet 18 over a wired or wireless connection.


In an embodiment, graphical user interface 34 is used to provide information and/or text to display 15 on cellular telephone 1 illustrated in FIG. 1A. Link group software 12 is used in connection with graphical user interface software 34 to provide link group information to a small display 15. In an embodiment, link group software 12 is able to map a hypertext markup language (“HTML”) page from internet 18 to small display 15 by using link group software 12 which is described below.



FIG. 3 illustrates a page character array 300 used as input to the method according to the present invention. The characters 301 through 309 are link characters representing links to page character arrays named A through I, respectively. Characters 310 through 316 represent vertical splitter bars. Characters 317 through 321 represent line feed characters, which are logically equivalent to carriage return characters. Characters 322 through 331 represent text characters. Character 332 represents a blank space.


For the purposes of explanation of the present invention, the term “character” refers to a token of the document encoding standard, for example ASCII, UNICODE, HTML, and XML. In other words, a “character” is any string or code that has some defined significance. A link character represents an actionable token, such as retrieving another page character array, or executing an arbitrary computer function such as playing a sound, or initiating a computer transaction. A blank space or line feed character refers to any token which creates white space or a sequence of codes that result in blank space.



FIG. 4 illustrates a conventional browser's display screen appearance after displaying the page character array 300 shown in FIG. 3. Specifically, a conventional browser displays links A through I as blue underlined text 401 through 409 which correspond to link characters 301 through 309, respectively, shown in FIG. 3. Vertical splitter bars 410 through 416 illustrated in FIG. 4 are displayed by a conventional browser as a result of interpretation of vertical splitter characters 310 through 316 shown in FIG. 3. The links F, G, H, and I, appear on a lower line than the links A, B, C, D, and E because line feed character 317 advances the display to the subsequent line. Blank space 417 illustrated in FIG. 4 is a result of the conventional browser's interpretation of line feed characters 318 and 319. The text 418 illustrated in FIG. 4 is a result of the conventional browser's interpretation of text characters 322 through 332. Blank space 419 is a result of the conventional browser's interpretation of line feed characters 320 and 321 shown in FIG. 3. As is clearly illustrated by FIG. 3, the page character array 300 contains no explicit specification that links A through I are related to each other or are to be displayed in any particular specialized manner because they are related links.



FIG. 5 illustrates a method 500 of processing a page character array according to the present invention. The method starts with step 501. At step 502, the method finds links and creates link groups (or in other words hyperlink groupings). As will be discussed later, link groups consist of adjacent link characters within the page character array. At step 503, the method lays out the link groups created in step 502 for display in an optimized form. At step 504, link groups created in step 502 are logically mapped to a distinct user input, such as the touching of a specific key, or the receipt of a specific voice command. The method 500 is finished at step 505. It is to be noted that steps 503 and 504 are alternatively optional according to the present invention. In other words, after the link groups are created in step 502, either an optimized display can be generated according to the present invention in step 503 or a logical mapping of the link groups to a distinct user input can be performed by step 504. Thus, in alternative embodiments, either step 503 or step 504 is omitted according to the present invention. In the preferred embodiment, however, both steps 503 and 504 are performed according to the present invention.



FIG. 6 illustrates a display screen appearance 600 after displaying the page character array shown in FIG. 3 using a method according to the present invention shown in FIGS. 5 and 13. Buttons 601 through 609 are a result of the interpretation of link characters 301 through 309 by the method according to the present invention. The display screen appearance 600 illustrated in FIG. 6 represents one possible optimized screen display corresponding to a nine link group detected in step 502 and displayed in step 503 as the display screen appearance 600. There are many other possible screen layouts which may be created in alternative to display screen appearance 600, as will be described below, according to the present invention.



FIG. 7 illustrates an input device to link correspondence table 700 generated by a method according to the present invention shown in FIGS. 5 and 15 for the page character array 300 shown in FIG. 3 and the display screen appearance 600 shown in FIG. 6. As will be described below, step 504 logically maps each of the keys 1 through 9 to a corresponding one of the links A through I, as illustrated in Table 700. Thus, when the user strikes one of the keys 1 through 9 while the link group containing links A through I is in the display screen, the link corresponding to the key pressed will be traversed by the method according to the present invention.



FIG. 8 illustrates a method of implementing the step shown in FIG. 5 of finding links and creating link groups according to the present invention. Thus, the method 502 illustrated in FIG. 8 is an exploded view of the method step 502 shown in FIG. 5 and represents the presently preferred embodiment for executing the step 502 shown in FIG. 5. However, it is to be understood that various additions and modifications to the method 502 shown in FIG. 8 can be alternatively implemented without departing from the spirit and scope of the present invention. The method starts at step 801 and at step 802 the page character array is accessed. The next character is retrieved from the page character array at step 803. Test 804 determines if the character retrieved in step 803 is a link. In several page character array description languages, such as HTML, there are several alternative characters which represent links. Test 804 detects all such link characters. If the character retrieved in step 803 is a link, then the method 502 opens a new empty link group at step 805. At step 806, the character previously determined by step 804 to be a link is added to the new link group created in step 805. The next character in the page character array is then retrieved at step 807. Test 808 determines if the character retrieved by step 807 is a link. If the character is a link then the method reverts to step 806 and that link is added to the current link group which was previously created in step 805. If the character retrieved in step 807 is not a link, then test 809 determines if the character is a blank space or line feed character. If the character retrieved in step 807 is a blank space or line feed, then the method 502 essentially filters it out of the page character array by advancing back to step 807 to retrieve the next subsequent character. If the character is not a blank space or line feed, then step 810 determines if the character is a link separator character. Link separator characters are alternatively any one of vertical splitter characters, horizontal splitter characters, or other arbitrary characters, such as a plus or minus sign, which are used to separate link characters. If the character is determined to be a link separator by step 810, it is also essentially filtered out by the method 502 because the method then reverts back to step 807 to retrieve the next subsequent character. However, if the character is not a link separator, then the link group opened in step 805 is closed at step 811. The method then reverts to step 803 to retrieve the next character in the page character array. If at any point steps 803 or 807 do not detect any more characters in the page character array, then the method is done at step 812 as the page character array has been fully parsed.



FIG. 9 illustrates a continuation of the page character array 300 shown in FIG. 3 used as input to the methods according to the present invention. Characters 901 through 904 represent links, characters 905 through 908 represent blank spaces, and character 909 represents a line feed or carriage return.



FIG. 10A illustrates a link group extracted from the page character array 300 shown in FIG. 3 by a method 502 according to the present invention shown in FIG. 8. Specifically, all of the link characters 301 through 309 illustrated in FIG. 3 have been grouped into a first link group 1000 containing only the characters representing the links. The vertical splitter characters 310 through 316 as well as the line feed character 317 shown in FIG. 3 have been filtered out by the method 502.



FIG. 10B illustrates another link group 1050 extracted from the page character array 900 shown in FIGS. 3 and 9 by a method 502 according to the present invention shown in FIG. 8. Specifically, link characters 901 through 904 have been grouped into a second link group 1050 by the method 502. Blank space characters 905-908 have been filtered out, along with line feed character 909.



FIG. 11 illustrates an intermediate page character array 1100 generated from the page character array shown in FIGS. 3 and 9 by a method 502 according to the present invention and shown in FIG. 8. Specifically, the method 502 has detected the first link group 1000 and second link group 1050 and replaced them with characters 1101 and 1102 representing pointers to the link groups 1000 and 1050, respectively. The remaining characters and the intermediate page character array 1100 represent characters from the page character array 300 which were not grouped into a link group.



FIG. 12 illustrates a conventional browser's display screen appearance 1200 after displaying the page character array 900 shown in FIG. 9. Link characters 901 through 904 are interpreted by a conventional browser and displayed as blue underlined text 1201 through 1204, respectively. Blank space characters 905 and 906 are interpreted by a conventional browser and create the space 1205 illustrated in FIG. 12. Similarly, blank space characters 907 and 908 correspond to space 1206 illustrated in FIG. 12. Line feed character 909 is interpreted by a conventional browser to place the subsequent characters on a lower line, which creates the two-line appearance 1200 illustrated in FIG. 12.



FIG. 13 illustrates a method of implementing the step 503 shown in FIG. 5 of laying out link groups for a display screen in an optimized form according to the present invention. The method starts at 1301. At step 1302, link characters are laid out as buttons, such as illustrated in FIG. 6. A button is preferably enclosed by a circular or oval shaped boundary. At step 1303, the method 503 lays out the buttons in predetermined screen locations based upon the hardware upon which the method is executing. The method is completed at step 1304. Thus, FIG. 13 illustrates the method of implementing step 503 shown in FIG. 5, and is therefore an exploded view of the steps required to implement step 503 shown in FIG. 5.



FIG. 14 illustrates a display screen appearance 1400 after displaying the page character array 900 shown in FIG. 9 using a method 502 according to the present invention shown in FIGS. 5 and 13. In the screen display appearance 1400, buttons 1401 through 1402 correspond to characters 901 through 904 shown in FIG. 9. In the display screen appearance 1400, buttons 1400 through 1404 are horizontally centered in a vertical list. This horizontal centering represents an embodiment of an optimized form of display of a link group according to the present invention.



FIG. 15 illustrates a method 504 of implementing the step shown in FIG. 5 of logically mapping link groups to distinct user input according to the present invention. The method starts at step 1501. Test 1502 determines if a link group is currently in the display screen. If the link group is not currently in the display screen, then the method ends at step 1505. In other words, no action is taken by step 504 in the event that a link group is not currently being displayed in the display screen. Step 1303 illustrated in FIG. 13 lays out the buttons in a predetermined screen location based upon a hardware in a logical frame buffer. Only a portion of the logical frame buffer is actually displayed at any given time. If the link group is in the portion of the screen layout which is in the display screen, then step 1503 creates a correspondence between the links and the displayed link group and key strokes or voice commands. This is illustrated, for example, by the Table 700 shown in FIG. 7. At step 1504, the machine interprets key strokes or voice commands as a command to traverse the corresponding link. If a link group is not currently in the display screen, then key strokes or voice commands are not interpreted as link invocations.



FIG. 16 illustrates a display screen appearance 1600 in relation to input device keys 1601 through 1605 after displaying the page character array 300 shown in FIG. 3 using a method 500 according to the present invention shown in FIGS. 5 and 13. The links A through F shown in FIG. 16 are selected by the user by pressing one of the L or R keys 1601 or 1602 and one of the T, M, or B keys 1603 through 1605. For example, link A is traversed by pressing the L key 1601 and the T key 1603. The F link is traversed by pressing the R key 1602 and the B key 1605. In the example shown in FIG. 16, links are laid out in optimized form by step 503 so as to be vertically and horizontally aligned with the input keys to which they are logically mapped by step 504. Another example of the combination of steps 503 and 504 is found in FIG. 6, where links A through I are laid out so as to physically correspond to numbers 1 through 9 on a standard telephonic keypad.



FIG. 17 illustrates an input device to link correspondence table 1700 generated by a method 504 according to the present invention shown in FIGS. 5 and 15 for the page character array 300 shown in FIG. 3 and the display screen appearance shown in FIG. 16. Specifically, each of the links is mapped to a unique combination of the keys 1601 through 1605.



FIG. 18 illustrates a display screen appearance 1800 after displaying the page character array 300 shown in FIG. 3 using a method according to the present invention shown in FIGS. 5 and 15. In FIG. 18, the keys to which links A, B, and C are logically mapped by step 504 are actually displayed alongside the link names. In this respect, the present invention optionally displays in step 503 an indication of the physical key to which the link is mapped in step 504. Thus, link C is selected by pressing the 3 key as shown in the screen display appearance 1800. Alternatively to the above-described laying out of the indication of the corresponding mapped keystroke along with each link name for each link in the link group illustrated in FIG. 18, the indication of the corresponding mapped keystroke is laid out as a small captioned box next to or above the layout of the link (not unlike a footnote) to indicate the mapping relationship.


As shown in FIGS. 16 and 18, only a portion of the entire first link group is displayed on the display screen. Specifically, in FIG. 16, links G, H, and I could not fit on the display screen 1600, and in FIG. 18, links D through I could not fit on the display screen 1800. As the user scrolls down so that the remaining links become visible and the first few links in the link group are not visible, the method 504 optionally creates a different mapping of the input keys to the links in the link group, or optionally maintains the same correspondence between input keys and links. In the example shown in FIG. 16, it is anticipated that as links G, H, and I become visible, the mapping of the T, M, and B keys 1603 through 1605 is altered so that horizontal alignment is maintained. If the user scrolls down so that links G and H are visible but links A and B are not visible, then links A and B are no longer selectable by the user. However, in the example shown in FIG. 18, as the user scrolls down such that links D, E, and F are visible instead of links A, B, and C, then the method 504 according to the present invention preferably maintains the mapping of keys 4, 5, and 6 to links D, E, and F, and therefore links A, B, and C are still selectable by the user by depressing the appropriate keys even though they are no longer visible on the display screen.


The foregoing description of the preferred embodiments of the present invention has been provided for the purposes of illustration and description. It is not intended to be exhaustive or to limit the invention to the precise forms disclosed. Obviously, many modifications and variations will be apparent to practitioners skilled in the art. The embodiments were chosen and described in order to best explain the principles of the invention and its practical applications, thereby enabling others skilled in the art to understand the invention for various embodiments and with the various modifications as are suited to the particular use contemplated. It is intended that the scope of the invention be defined by the following claims and their equivalents.

Claims
  • 1. A mobile device having a display screen, comprising: a processor; anda processor readable storage medium having processor readable program code embodied in said processor readable storage medium, said processor readable program code for programming the device to:find links within a page character array and filter out of the page character array characters which are not links;create one or more link groups each having a plurality of links;lay out each link group for display in optimum form on the display screen of the mobile device at predetermined display screen locations based upon hardware of the mobile device, wherein the predetermined screen locations correspond to discrete user locations;display on the display screen of the mobile device a first portion of the link group layout, wherein the first portion does not include all links of the link group;logically map each of the displayed links of the first portion of the link group to a distinct user input, in which correspondence between links in the link group and keystrokes or voice commands is created;alter the display of the link groups to display a second portion of the link group layout; andlogically map each of the displayed links of the second portion of the link group to a distinct user input;wherein the mapping of each of the displayed links of the second portion of the link group does not alter the mapping of the first portion of the link group such that the mapping of links of the first and the second portions of the link group are maintained concurrently.
  • 2. A mobile device as in claim 1, wherein adjacent link characters comprise link characters separated in the page character array by any combination of: no other characters, blank space characters, line feed characters, and link separator characters.
  • 3. A mobile device as in claim 1, wherein the program code lays out links as buttons.
  • 4. A mobile device as in claim 1, wherein the program code centers links in a vertical list.
  • 5. A mobile device as in claim 1, wherein the program code lays out links in a rectangular matrix.
  • 6. A mobile device as in claim 1, wherein the program code lays out an indication of a corresponding mapped keystroke along with each link name for each link in the link group.
  • 7. A method comprising: finding links within a page character array and filter out of the page character array characters which are not links;creating one or more link groups each having a plurality of links;laying out each link group for display in optimum form on the display screen of the mobile device at predetermined display screen locations based upon hardware of the mobile device, wherein the predetermined screen locations correspond to discrete user locations;displaying on the display screen of the mobile device a first portion of the link group layout, wherein the first portion does not include all links of the link group;logically mapping, using one or more processors, each of the displayed links of the first portion of the link group to a distinct user input, in which correspondence between links in the link group and keystrokes or voice commands is created;altering the display of the link groups to display a second portion of the link group layout; andlogically mapping each of the displayed links of the second portion of the link group to a distinct user input,wherein the mapping of each of the displayed links of the second portion of the link group does not alter the mapping of the first portion of the link group such that the mapping of links of the first and the second portions of the link group are maintained concurrently.
  • 8. The method of claim 7, wherein adjacent link characters comprise link characters separated in the page character array by any combination of: no other characters, blank space characters, line feed characters, and link separator characters.
  • 9. The method of claim 7, wherein laying out each link group for display includes laying out links as buttons.
  • 10. The method of claim 7, wherein laying out each link group for display includes laying out links as centered in a vertical list.
  • 11. The method of claim 7, wherein laying out each link group for display includes laying out links in a rectangular matrix.
  • 12. The method of claim 7, further comprising: laying out an indication of a corresponding mapped keystroke along with each link name for each link in the link group.
  • 13. A processor readable storage medium having processor readable program code embodied in the processor readable storage medium, the processor readable program code for programming the device to: find links within a page character array and filter out of the page character array characters which are not links;create one or more link groups each having a plurality of links;lay out each link group for display in optimum form on the display screen of the mobile device at predetermined display screen locations based upon hardware of the mobile device, wherein the predetermined screen locations correspond to discrete user locations;display on the display screen of the mobile device a first portion of the link group layout, wherein the first portion does not include all links of the link group;logically map each of the displayed links of the first portion of the link group to a distinct user input, in which correspondence between links in the link group and keystrokes or voice commands is created;alter the display of the link groups to display a second portion of the link group layout; andlogically map each of the displayed links of the second portion of the link group to a distinct user input;wherein the mapping of each of the displayed links of the second portion of the link group does not alter the mapping of the first portion of the link group such that the mapping of links of the first and the second portions of the link group are maintained concurrently.
CLAIM OF PRIORITY

This application is a continuation of U.S. patent application Ser. No. 10/443,683, filed May 22, 2003, now abandoned, which is a continuation of U.S. patent application Ser. No. 09/374,223, filed Aug. 13, 1999, abandoned.

US Referenced Citations (332)
Number Name Date Kind
4974191 Amirghodsi et al. Nov 1990 A
5128672 Kaehler Jul 1992 A
5282265 Rohra Suda et al. Jan 1994 A
5303406 Hansen et al. Apr 1994 A
5386556 Hedin et al. Jan 1995 A
5434777 Luciw Jul 1995 A
5479488 Lenning et al. Dec 1995 A
5577241 Spencer Nov 1996 A
5608624 Luciw Mar 1997 A
5682539 Conrad et al. Oct 1997 A
5727950 Cook et al. Mar 1998 A
5748974 Johnson May 1998 A
5794050 Dahlgren et al. Aug 1998 A
5826261 Spencer Oct 1998 A
5848410 Walls et al. Dec 1998 A
5877757 Baldwin et al. Mar 1999 A
5895466 Goldberg et al. Apr 1999 A
5899972 Miyazawa et al. May 1999 A
5905498 Diament May 1999 A
5915001 Uppaluru Jun 1999 A
5915249 Spencer Jun 1999 A
5937163 Lee et al. Aug 1999 A
5963208 Dolan et al. Oct 1999 A
5963964 Nielsen Oct 1999 A
5987404 Della Pietra et al. Nov 1999 A
6029135 Krasle Feb 2000 A
6052656 Suda et al. Apr 2000 A
6081750 Hoffberg et al. Jun 2000 A
6088731 Kiraly et al. Jul 2000 A
6138158 Boyle et al. Oct 2000 A
6144938 Surace et al. Nov 2000 A
6188999 Moody Feb 2001 B1
6212564 Harter et al. Apr 2001 B1
6226655 Borman et al. May 2001 B1
6233559 Balakrishnan May 2001 B1
6246981 Papineni et al. Jun 2001 B1
6300947 Kanevsky Oct 2001 B1
6317594 Gossman et al. Nov 2001 B1
6317831 King Nov 2001 B1
6321092 Fitch et al. Nov 2001 B1
6334103 Surace et al. Dec 2001 B1
6400806 Uppaluru Jun 2002 B1
6405238 Votipka Jun 2002 B1
6417873 Fletcher et al. Jul 2002 B1
6421672 McAllister et al. Jul 2002 B1
6434524 Weber Aug 2002 B1
6446076 Burkey et al. Sep 2002 B1
6453292 Ramaswamy et al. Sep 2002 B2
6466654 Cooper et al. Oct 2002 B1
6499013 Weber Dec 2002 B1
6501937 Ho et al. Dec 2002 B1
6513063 Julia et al. Jan 2003 B1
6523061 Halverson et al. Feb 2003 B1
6526395 Morris Feb 2003 B1
6532444 Weber Mar 2003 B1
6532446 King Mar 2003 B1
6598039 Livowsky Jul 2003 B1
6601026 Appelt et al. Jul 2003 B2
6604059 Strubbe et al. Aug 2003 B2
6615172 Bennett et al. Sep 2003 B1
6633846 Bennett et al. Oct 2003 B1
6647260 Dusse et al. Nov 2003 B2
6650735 Burton et al. Nov 2003 B2
6665639 Mozer et al. Dec 2003 B2
6665640 Bennett et al. Dec 2003 B1
6691111 Lazaridis et al. Feb 2004 B2
6691151 Cheyer et al. Feb 2004 B1
6735632 Kiraly et al. May 2004 B1
6742021 Halverson et al. May 2004 B1
6757362 Cooper et al. Jun 2004 B1
6757718 Halverson et al. Jun 2004 B1
6772394 Kamada Aug 2004 B1
6778951 Contractor Aug 2004 B1
6792082 Levine Sep 2004 B1
6807574 Partovi et al. Oct 2004 B1
6810379 Vermeulen et al. Oct 2004 B1
6813491 McKinney Nov 2004 B1
6832194 Mozer et al. Dec 2004 B1
6842767 Partovi et al. Jan 2005 B1
6851115 Cheyer et al. Feb 2005 B1
6859931 Cheyer et al. Feb 2005 B1
6895380 Sepe, Jr. May 2005 B2
6895558 Loveland May 2005 B1
6928614 Everhart Aug 2005 B1
6937975 Elworthy Aug 2005 B1
6952799 Edwards et al. Oct 2005 B2
6964023 Maes et al. Nov 2005 B2
6980949 Ford Dec 2005 B2
6985865 Packingham et al. Jan 2006 B1
6996531 Korall et al. Feb 2006 B2
6999927 Mozer et al. Feb 2006 B2
7020685 Chen et al. Mar 2006 B1
7027974 Busch et al. Apr 2006 B1
7036128 Julia et al. Apr 2006 B1
7050977 Bennett May 2006 B1
7062428 Hogenhout et al. Jun 2006 B2
7069560 Cheyer et al. Jun 2006 B1
7092887 Mozer et al. Aug 2006 B2
7092928 Elad et al. Aug 2006 B1
7127046 Smith et al. Oct 2006 B1
7136710 Hoffberg et al. Nov 2006 B1
7137126 Coffman et al. Nov 2006 B1
7139714 Bennett et al. Nov 2006 B2
7139722 Perrella et al. Nov 2006 B2
7177798 Hsu et al. Feb 2007 B2
7197460 Gupta et al. Mar 2007 B1
7200559 Wang Apr 2007 B2
7203646 Bennett Apr 2007 B2
7216073 Lavi et al. May 2007 B2
7216080 Tsiao et al. May 2007 B2
7225125 Bennett et al. May 2007 B2
7233790 Kjellberg et al. Jun 2007 B2
7233904 Luisi Jun 2007 B2
7266496 Wang et al. Sep 2007 B2
7277854 Bennett et al. Oct 2007 B2
7290039 Lisitsa et al. Oct 2007 B1
7299033 Kjellberg et al. Nov 2007 B2
7310600 Garner et al. Dec 2007 B1
7324947 Jordan et al. Jan 2008 B2
7349953 Lisitsa et al. Mar 2008 B2
7376556 Bennett May 2008 B2
7376645 Bernard May 2008 B2
7379874 Schmid et al. May 2008 B2
7386449 Sun et al. Jun 2008 B2
7392185 Bennett Jun 2008 B2
7398209 Kennewick et al. Jul 2008 B2
7403938 Harrison et al. Jul 2008 B2
7409337 Potter et al. Aug 2008 B1
7415100 Cooper et al. Aug 2008 B2
7418392 Mozer et al. Aug 2008 B1
7426467 Nashida et al. Sep 2008 B2
7447635 Konopka et al. Nov 2008 B1
7454351 Jeschke et al. Nov 2008 B2
7467087 Gillick et al. Dec 2008 B1
7475010 Chao Jan 2009 B2
7483894 Cao Jan 2009 B2
7487089 Mozer Feb 2009 B2
7496498 Chu et al. Feb 2009 B2
7496512 Zhao et al. Feb 2009 B2
7502738 Kennewick et al. Mar 2009 B2
7508373 Lin et al. Mar 2009 B2
7522927 Fitch et al. Apr 2009 B2
7523108 Cao Apr 2009 B2
7526466 Au Apr 2009 B2
7529671 Rockenbeck et al. May 2009 B2
7529676 Koyama May 2009 B2
7539656 Fratkina et al. May 2009 B2
7546382 Healey et al. Jun 2009 B2
7548895 Pulsipher Jun 2009 B2
7555431 Bennett Jun 2009 B2
7571106 Cao et al. Aug 2009 B2
7599918 Shen et al. Oct 2009 B2
7620549 Di Cristo et al. Nov 2009 B2
7624007 Bennett Nov 2009 B2
7634409 Kennewick et al. Dec 2009 B2
7636657 Ju et al. Dec 2009 B2
7640160 Di Cristo et al. Dec 2009 B2
7647225 Bennett et al. Jan 2010 B2
7657424 Bennett Feb 2010 B2
7672841 Bennett Mar 2010 B2
7676026 Baxter, Jr. Mar 2010 B1
7684985 Dominach et al. Mar 2010 B2
7693715 Hwang et al. Apr 2010 B2
7693720 Kennewick et al. Apr 2010 B2
7698131 Bennett Apr 2010 B2
7702500 Blaedow Apr 2010 B2
7702508 Bennett Apr 2010 B2
7707027 Balchandran et al. Apr 2010 B2
7707032 Wang et al. Apr 2010 B2
7707267 Lisitsa et al. Apr 2010 B2
7711672 Au May 2010 B2
7716056 Weng et al. May 2010 B2
7720674 Kaiser et al. May 2010 B2
7720683 Vermeulen et al. May 2010 B1
7725307 Bennett May 2010 B2
7725318 Gavalda et al. May 2010 B2
7725320 Bennett May 2010 B2
7725321 Bennett May 2010 B2
7729904 Bennett Jun 2010 B2
7729916 Coffman et al. Jun 2010 B2
7734461 Kwak et al. Jun 2010 B2
7752152 Paek et al. Jul 2010 B2
7774204 Mozer et al. Aug 2010 B2
7783486 Rosser et al. Aug 2010 B2
7801729 Mozer Sep 2010 B2
7809570 Kennewick et al. Oct 2010 B2
7809610 Cao Oct 2010 B2
7818176 Freeman et al. Oct 2010 B2
7822608 Cross, Jr. et al. Oct 2010 B2
7826945 Zhang et al. Nov 2010 B2
7831426 Bennett Nov 2010 B2
7840400 Lavi et al. Nov 2010 B2
7840447 Kleinrock et al. Nov 2010 B2
7873519 Bennett Jan 2011 B2
7873654 Bernard Jan 2011 B2
7881936 Longé et al. Feb 2011 B2
7912702 Bennett Mar 2011 B2
7917367 Di Cristo et al. Mar 2011 B2
7917497 Harrison et al. Mar 2011 B2
7920678 Cooper et al. Apr 2011 B2
7925525 Chin Apr 2011 B2
7930168 Weng et al. Apr 2011 B2
7949529 Weider et al. May 2011 B2
7974844 Sumita Jul 2011 B2
7974972 Cao Jul 2011 B2
7983915 Knight et al. Jul 2011 B2
7983917 Kennewick et al. Jul 2011 B2
7983997 Allen et al. Jul 2011 B2
7987151 Schott et al. Jul 2011 B2
8000453 Cooper et al. Aug 2011 B2
8005679 Jordan et al. Aug 2011 B2
8015006 Kennewick et al. Sep 2011 B2
8024195 Mozer et al. Sep 2011 B2
8036901 Mozer Oct 2011 B2
8041570 Mirkovic et al. Oct 2011 B2
8041611 Kleinrock et al. Oct 2011 B2
8055708 Chitsaz et al. Nov 2011 B2
8069046 Kennewick et al. Nov 2011 B2
8073681 Baldwin et al. Dec 2011 B2
8082153 Coffman et al. Dec 2011 B2
8095364 Longé et al. Jan 2012 B2
8099289 Mozer et al. Jan 2012 B2
8107401 John et al. Jan 2012 B2
8112275 Kennewick et al. Feb 2012 B2
8112280 Lu Feb 2012 B2
8140335 Kennewick et al. Mar 2012 B2
8165886 Gagnon et al. Apr 2012 B1
8166019 Lee et al. Apr 2012 B1
8190359 Bourne May 2012 B2
8195467 Mozer et al. Jun 2012 B2
8204238 Mozer Jun 2012 B2
8219407 Roy et al. Jul 2012 B1
20020069063 Buchner et al. Jun 2002 A1
20040135701 Yasuda et al. Jul 2004 A1
20050071332 Ortega et al. Mar 2005 A1
20050080625 Bennett et al. Apr 2005 A1
20050119897 Bennett et al. Jun 2005 A1
20050143972 Gopalakrishnan et al. Jun 2005 A1
20060018492 Chiu et al. Jan 2006 A1
20060122834 Bennett Jun 2006 A1
20060143007 Koh et al. Jun 2006 A1
20070055529 Kanevsky et al. Mar 2007 A1
20070058832 Hug et al. Mar 2007 A1
20070088556 Andrew Apr 2007 A1
20070100790 Cheyer et al. May 2007 A1
20070118377 Badino et al. May 2007 A1
20070174188 Fish Jul 2007 A1
20070185917 Prahlad et al. Aug 2007 A1
20070282595 Tunning et al. Dec 2007 A1
20080015864 Ross et al. Jan 2008 A1
20080021708 Bennett et al. Jan 2008 A1
20080034032 Healey et al. Feb 2008 A1
20080052063 Bennett et al. Feb 2008 A1
20080120112 Jordan et al. May 2008 A1
20080129520 Lee Jun 2008 A1
20080140657 Azvine et al. Jun 2008 A1
20080221903 Kanevsky et al. Sep 2008 A1
20080228496 Yu et al. Sep 2008 A1
20080247519 Abella et al. Oct 2008 A1
20080249770 Kim et al. Oct 2008 A1
20080300878 Bennett Dec 2008 A1
20090006100 Badger et al. Jan 2009 A1
20090006343 Platt et al. Jan 2009 A1
20090030800 Grois Jan 2009 A1
20090058823 Kocienda Mar 2009 A1
20090076796 Daraselia Mar 2009 A1
20090100049 Cao Apr 2009 A1
20090112677 Rhett Apr 2009 A1
20090150156 Kennewick et al. Jun 2009 A1
20090157401 Bennett Jun 2009 A1
20090164441 Cheyer Jun 2009 A1
20090171664 Kennewick et al. Jul 2009 A1
20090290718 Kahn et al. Nov 2009 A1
20090299745 Kennewick et al. Dec 2009 A1
20090299849 Cao et al. Dec 2009 A1
20100005081 Bennett Jan 2010 A1
20100023320 Di Cristo et al. Jan 2010 A1
20100036660 Bennett Feb 2010 A1
20100042400 Block et al. Feb 2010 A1
20100088020 Sano et al. Apr 2010 A1
20100145700 Kennewick et al. Jun 2010 A1
20100204986 Kennewick et al. Aug 2010 A1
20100217604 Baldwin et al. Aug 2010 A1
20100228540 Bennett Sep 2010 A1
20100235341 Bennett Sep 2010 A1
20100257160 Cao Oct 2010 A1
20100277579 Cho et al. Nov 2010 A1
20100280983 Cho et al. Nov 2010 A1
20100286985 Kennewick et al. Nov 2010 A1
20100299142 Freeman et al. Nov 2010 A1
20100312547 van Os et al. Dec 2010 A1
20100318576 Kim Dec 2010 A1
20100332235 David Dec 2010 A1
20100332348 Cao Dec 2010 A1
20110060807 Martin et al. Mar 2011 A1
20110082688 Kim et al. Apr 2011 A1
20110112827 Kennewick et al. May 2011 A1
20110112921 Kennewick et al. May 2011 A1
20110119049 Ylonen May 2011 A1
20110125540 Jang et al. May 2011 A1
20110130958 Stahl et al. Jun 2011 A1
20110131036 Di Cristo et al. Jun 2011 A1
20110131045 Cristo et al. Jun 2011 A1
20110144999 Jang et al. Jun 2011 A1
20110161076 Davis et al. Jun 2011 A1
20110175810 Markovic et al. Jul 2011 A1
20110184730 LeBeau et al. Jul 2011 A1
20110218855 Cao et al. Sep 2011 A1
20110231182 Weider et al. Sep 2011 A1
20110231188 Kennewick et al. Sep 2011 A1
20110264643 Cao Oct 2011 A1
20110279368 Klein et al. Nov 2011 A1
20110306426 Novak et al. Dec 2011 A1
20120002820 Leichter Jan 2012 A1
20120016678 Gruber et al. Jan 2012 A1
20120020490 Leichter Jan 2012 A1
20120022787 LeBeau et al. Jan 2012 A1
20120022857 Baldwin et al. Jan 2012 A1
20120022860 Lloyd et al. Jan 2012 A1
20120022868 LeBeau et al. Jan 2012 A1
20120022869 Lloyd et al. Jan 2012 A1
20120022870 Kristjansson et al. Jan 2012 A1
20120022874 Lloyd et al. Jan 2012 A1
20120022876 LeBeau et al. Jan 2012 A1
20120023088 Cheng et al. Jan 2012 A1
20120034904 LeBeau et al. Feb 2012 A1
20120035908 LeBeau et al. Feb 2012 A1
20120035924 Jitkoff et al. Feb 2012 A1
20120035931 LeBeau et al. Feb 2012 A1
20120035932 Jitkoff et al. Feb 2012 A1
20120042343 Laligand et al. Feb 2012 A1
20120271676 Aravamudan et al. Oct 2012 A1
Foreign Referenced Citations (16)
Number Date Country
198 41 541 Dec 2007 DE
1245023 Oct 2002 EP
06 019965 Jan 1994 JP
2001 125896 May 2001 JP
2002 024212 Jan 2002 JP
2003517158 May 2003 JP
2009 036999 Feb 2009 JP
10-0776800 Nov 2007 KR
10-0810500 Mar 2008 KR
10 2008 109322 Dec 2008 KR
10 2009 086805 Aug 2009 KR
10-0920267 Oct 2009 KR
10 2011 0113414 Oct 2011 KR
WO9749044 Dec 1997 WO
WO 2006129967 Dec 2006 WO
WO 2011088053 Jul 2011 WO
Non-Patent Literature Citations (96)
Entry
Rob Barrett, et al., 1997, “How to personalize the Web” in Proceedings of the ACM SIGCHI Conference on Human factors in computing systems (CHI '97) ACM, New York, NY, USA, p. 75-82.
Netscape 3.01 history screendumps, 5 pages (1996).
Bussler, C., et al., “Web Service Execution Environment (WSMX),” Jun. 3, 2005, W3C Member Submission, http://www.w3.org/Submission/WSMX, 29 pages.
Cheyer, A., “About Adam Cheyer,” Sep. 17, 2012, http://www.adam.cheyer.com/about.html, 2 pages.
Cheyer, A., “A Perspective on AI & Agent Technologies for SCM,” VerticalNet, 2001 presentation, 22 pages.
Domingue, J., et al., “Web Service Modeling Ontology (WSMO)—An Ontology for Semantic Web Services,” Jun. 9-10, 2005, position paper at the W3C Workshop on Frameworks for Semantics in Web Services, Innsbruck, Austria, 6 pages.
Guzzoni, D., et al., “A Unified Platform for Building Intelligent Web Interaction Assistants,” Proceedings of the 2006 IEEE/WIC/ACM International Conference on Web Intelligence and Intelligent Agent Technology, Computer Society, 4 pages.
Roddy, D., et al., “Communication and Collaboration in a Landscape of B2B eMarketplaces,” VerticalNet Solutions, white paper, Jun. 15, 2000, 23 pages.
Glass, J., et al., “Multilingual Spoken-Language Understanding in the MIT Voyager System,” Aug. 1995, http://groups.csail.mit.edu/sls/publications/1995/speechcomm95-voyager.pdf, 29 pages.
Goddeau, D., et al., “A Form-Based Dialogue Manager for Spoken Language Applications,” Oct. 1996, http://phasedance.com/pdf/icslp96.pdf, 4 pages.
Goddeau, D., et al., “Galaxy: A Human-Language Interface to On-Line Travel Information,” 1994 International Conference on Spoken Language Processing, Sep. 18-22, 1994, Pacific Convention Plaza Yokohama, Japan, 6 pages.
Meng, H., et al., “Wheels: A Conversational System in the Automobile Classified Domain,” Oct. 1996, httphttp://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.16.3022, 4 pages.
Phoenix Solutions, Inc. v. West Interactive Corp., Document 40, Declaration of Christopher Schmandt Regarding the MIT Galaxy System dated Jul. 2, 2010, 162 pages.
Seneff, S., et al., “A New Restaurant Guide Conversational System: Issues in Rapid Prototyping for Specialized Domains,” Oct. 1996, citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.16...rep..., 4 pages.
Vlingo InCar, “Distracted Driving Solution with Vlingo InCar,” 2:38 minute video uploaded to YouTube by Vlingo Voice on Oct. 6, 2010, http://www.youtube.com/watch?v=Vqs8XfXxgz4, 2 pages.
Zue, V., “Conversational Interfaces: Advances and Challenges,” Sep. 1997, http://www.cs.cmu.edu/˜dod/papers/zue97.pdf, 10 pages.
Zue, V. W., “Toward Systems that Understand Spoken Language,” Feb. 1994, ARPA Strategic Computing Institute, ©1994 IEEE, 9 pages.
Martin, D., et al., “The Open Agent Architecture: A Framework for building distributed software systems,” Jan.-Mar. 1999, Applied Artificial Intelligence: An International Journal, vol. 13, No. 1-2, http://adam.cheyer.com/papers/oaa.pdf, 38 pages.
Alfred App, 2011, http://www.alfredapp.com/, 5 pages.
Ambite, JL., et al., “Design and Implementation of the CALO Query Manager,” Copyright © 2006, American Association for Artificial Intelligence, (www.aaai.org), 8 pages.
Ambite, JL., et al., “Integration of Heterogeneous Knowledge Sources in the CALO Query Manager,” 2005, The 4th International Conference on Ontologies, DataBases, and Applications of Semantics (ODBASE), Agia Napa, Cyprus, ttp://www.isi.edu/people/ambite/publications/integration—heterogeneous—knowledge—sources—calo—query—manager, 18 pages.
Belvin, R. et al., “Development of the HRL Route Navigation Dialogue System,” 2001, in Proceedings of the First International Conference on Human Language Technology Research, Paper, Copyright © 2001 HRL Laboratories, LLC, http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.10.6538, 5 pages.
Berry, P. M., et al. “PTIME: Personalized Assistance for Calendaring,” ACM Transactions on Intelligent Systems and Technology, vol. 2, No. 4, Article 40, Publication date: Jul. 2011, 40:1-22, 22 pages.
Butcher, M., “EVI arrives in town to go toe-to-toe with Siri,” Jan. 23, 2012, http://techcrunch.com/2012/01/23/evi-arrives-in-town-to-go-toe-to-toe-with-siri/, 2 pages.
Chen, Y., “Multimedia Siri Finds and Plays Whatever You Ask for,” Feb. 9, 2012, http://www.psfk.com/2012/02/multimedia-siri.html, 9 pages.
Cheyer, A. et al., “Spoken Language and Multimodal Applications for Electronic Realties,” © Springer-Verlag London Ltd, Virtual Reality 1999, 3:1-15, 15 pages.
Cutkosky, M. R. et al., “PACT: An Experiment in Integrating Concurrent Engineering Systems,” Journal, Computer, vol. 26 Issue 1, Jan. 1993, IEEE Computer Society Press Los Alamitos, CA, USA, http://dl.acm.org/citation.cfm?id=165320, 14 pages.
Elio, R. et al., “On Abstract Task Models and Conversation Policies,” http://webdocs.cs.ualberta.ca/˜ree/publications/papers2/ATS.AA99.pdf, 10 pages.
Ericsson, S. et al., “Software illustrating a unified approach to multimodality and multilinguality in the in-home domain,” Dec. 22, 2006, Talk and Look: Tools for Ambient Linguistic Knowledge, http://www.talk-project.eurice.eu/fileadmin/talk/publications—public/deliverables—public/D1—6.pdf, 127 pages.
Evi, “Meet Evi: the one mobile app that provides solutions for your everyday problems,” Feb. 8, 2012, http://www.evi.com/, 3 pages.
Feigenbaum, E., et al., “Computer-assisted Semantic Annotation of Scientific Life Works,” 2007, http://tomgruber.org/writing/stanford-cs300.pdf, 22 pages.
Gannes, L., “Alfred App Gives Personalized Restaurant Recommendations,” allthingsd.com, Jul. 18, 2011, http://allthingsd.com/20110718/alfred-app-gives-personalized-restaurant-recommendations/, 3 pages.
Gautier, P. O., et al. “Generating Explanations of Device Behavior Using Compositional Modeling and Causal Ordering,” 1993, http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.42.8394, 9 pages.
Gervasio, M. T., et al., Active Preference Learning for Personalized Calendar Scheduling Assistancae, Copyright © 2005, http://www.ai.sri.com/˜gervasio/pubs/gervasio-iui05.pdf, 8 pages.
Glass, A., “Explaining Preference Learning,” 2006, http://cs229.stanford.edu/proj2006/Glass-ExplainingPreferenceLearning.pdf, 5 pages.
Gruber, T. R., et al., “An Ontology for Engineering Mathematics,” in Jon Doyle, Piero Torasso, & Erik Sandewall, Eds., Fourth International Conference on Principles of Knowledge Representation and Reasoning, Gustav Stresemann Institut, Bonn, Germany, Morgan Kaufmann, 1994, http://www-ksl.stanford.edu/knowledge-sharing/papers/engmath.html, 22 pages.
Gruber, T. R., “A Translation Approach to Portable Ontology Specifications,” Knowledge Systems Laboratory, Stanford University, Sep. 1992, Technical Report KSL 92-71, Revised Apr. 1993, 27 pages.
Gruber, T. R., “Automated Knowledge Acquisition for Strategic Knowledge,” Knowledge Systems Laboratory, Machine Learning, 4, 293-336 (1989), 44 pages.
Gruber, T. R., “(Avoiding) the Travesty of the Commons,” Presentation at NPUC 2006, New Paradigms for User Computing, IBM Almaden Research Center, Jul. 24, 2006. http://tomgruber.org/writing/avoiding-travestry.htm, 52 pages.
Gruber, T. R., “Big Think Small Screen: How semantic computing in the cloud will revolutionize the consumer experience on the phone,” Keynote presentation at Web 3.0 conference, Jan. 27, 2010, http://tomgruber.org/writing/web30jan2010.htm, 41 pages.
Gruber, T. R., “Collaborating around Shared Content on the WWW,” W3C Workshop on WWW and Collaboration, Cambridge, MA, Sep. 11, 1995, http://www.w3.org/Collaboration/Workshop/Proceedings/P9.html, 1 page.
Gruber, T. R., “Collective Knowledge Systems: Where the Social Web meets the Semantic Web,” Web Semantics: Science, Services and Agents on the World Wide Web (2007), doi:10.1016/j.websem.2007.11.011, keynote presentation given at the 5th International Semantic Web Conference, Nov. 7, 2006, 19 pages.
Gruber, T. R., “Where the Social Web meets the Semantic Web,” Presentation at the 5th International Semantic Web Conference, Nov. 7, 2006, 38 pages.
Gruber, T. R., “Despite our Best Efforts, Ontologies are not the Problem,” AAAI Spring Symposium, Mar. 2008, http://tomgruber.org/writing/aaai-ss08.htm, 40 pages.
Gruber, T. R., “Enterprise Collaboration Management with Intraspect,” Intraspect Software, Inc., Instraspect Technical White Paper Jul. 2001, 24 pages.
Gruber, T. R., “Every ontology is a treaty—a social agreement—among people with some common motive in sharing,” Interview by Dr. Miltiadis D. Lytras, Official Quarterly Bulletin of AIS Special Interest Group on Semantic Web and Information Systems, vol. 1, Issue 3, 2004, http://www.sigsemis.org 1, 5 pages.
Gruber, T. R., et al., “Generative Design Rationale: Beyond the Record and Replay Paradigm,” Knowledge Systems Laboratory, Stanford University, Dec. 1991, Technical Report KSL 92-59, Updated Feb. 1993, 24 pages.
Gruber, T. R., “Helping Organizations Collaborate, Communicate, and Learn,” Presentation to NASA Ames Research, Mountain View, CA, Mar. 2003, http://tomgruber.org/writing/organizational-intelligence-talk.htm, 30 pages.
Gruber, T. R., “Intelligence at the Interface: Semantic Technology and the Consumer Internet Experience,” Presentation at Semantic Technologies conference (SemTech08), May 20, 2008, http://tomgruber.org/writing.htm, 40 pages.
Gruber, T. R., Interactive Acquisition of Justifications: Learning “Why” by Being Told “What” Knowledge Systems Laboratory, Stanford University, Oct. 1990, Technical Report KSL 91.17, Revised Feb. 1991, 24 pages.
Gruber, T. R., “It Is What It Does: The Pragmatics of Ontology for Knowledge Sharing,” (c) 2000, 2003, http://www.cidoc-crm.org/docs/symposium—presentations/gruber—cidoc-ontology-2003.pdf, 21 pages.
Gruber, T. R., et al., “Machine-generated Explanations of Engineering Models: A Compositional Modeling Approach,” (1993) in Proc. International Joint Conference on Artificial Intelligence, http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.34.930, 7 pages.
Gruber, T. R., “2021: Mass Collaboration and the Really New Economy,” TNTY Futures, the newsletter of the Next Twenty Years series, vol. 1, Issue 6, Aug. 2001, http://www.tnty.com/newsletter/futures/archive/v01-05business.html, 5 pages.
Gruber, T. R., et al.,“NIKE: A National Infrastructure for Knowledge Exchange,” Oct. 1994, http://www.eit.com/papers/nike/nike.html and nike.ps, 10 pages.
Gruber, T. R., “Ontologies, Web 2.0 and Beyond,” Apr. 24, 2007, Ontology Summit 2007, http://tomgruber.org/writing/ontolog-social-web-keynote.pdf, 17 pages.
Gruber, T. R., “Ontology of Folksonomy: A Mash-up of Apples and Oranges,” Originally published to the web in 2005, Int'l Journal on Semantic Web & Information Systems, 3(2), 2007, 7 pages.
Gruber, T. R., “Siri, a Virtual Personal Assistant—Bringing Intelligence to the Interface,” Jun. 16, 2009, Keynote presentation at Semantic Technologies conference, Jun. 2009. http://tomgruber.org/writing/semtech09.htm, 22 pages.
Gruber, T. R., “TagOntology,” Presentation to Tag Camp, www.tagcamp.org, Oct. 29, 2005, 20 pages.
Gruber, T. R., et al., “Toward a Knowledge Medium for Collaborative Product Development,” in Artificial Intelligence in Design 1992, from Proceedings of the Second International Conference on Artificial Intelligence in Design, Pittsburgh, USA, Jun. 22-25, 1992, 19 pages.
Gruber, T. R., “Toward Principles for the Design of Ontologies Used for Knowledge Sharing,” in International Journal Human-Computer Studies 43, p. 907-928, substantial revision of paper presented at the International Workshop on Formal Ontology, Mar. 1993, Padova, Italy, available as Technical Report KSL 93-04, Knowledge Systems Laboratory, Stanford University, further revised Aug. 23, 1993, 23 pages.
Guzzoni, D., et al., “Active, A Platform for Building Intelligent Operating Rooms,” Surgetica 2007 Computer-Aided Medical Interventions: tools and applications, pp. 191-198, Paris, 2007, Sauramps Médical, http://lsro.epfl.ch/page-68384-en.html, 8 pages.
Guzzoni, D., et al., “Active, A Tool for Building Intelligent User Interfaces,” ASC 2007, Palma de Mallorca, http://lsro.epfl.ch/page-34241.html, 6 pages.
Guzzoni, D., et al., “Modeling Human-Agent Interaction with Active Ontologies,” 2007, AAAI Spring Symposium, Interaction Challenges for Intelligent Assistants, Stanford University, Palo Alto, California, 8 pages.
Hardawar, D., “Driving app Waze builds its own Siri for hands-free voice control,” Feb. 9, 2012, http://venturebeat.com/2012/02/09/driving-app-waze-builds-its-own-siri-for-hands-free-voice-control/, 4 pages.
Intraspect Software, “The Intraspect Knowledge Management Solution: Technical Overview,” http://tomgruber.org/writing/intraspect-whitepaper-1998.pdf, 18 pages.
Julia, L., et al., Un éditeur interactif de tableaux dessinés à main levée (An Interactive Editor for Hand-Sketched Tables), Traitement du Signal 1995, vol. 12, No. 6, 8 pages. No English Translation Available.
Karp, P. D., “A Generic Knowledge-Base Access Protocol,” May 12, 1994, http://lecture.cs.buu.ac.th/˜f50353/Document/gfp.pdf, 66 pages.
Lemon, O., et al., “Multithreaded Context for Robust Conversational Interfaces: Context-Sensitive Speech Recognition and Interpretation of Corrective Fragments,” Sep. 2004, ACM Transactions on Computer-Human Interaction, vol. 11, No. 3, 27 pages.
Leong, L., et al., “CASIS: A Context-Aware Speech Interface System,” IUI'05, Jan. 9-12, 2005, Proceedings of the 10th international conference on Intelligent user interfaces, San Diego, California, USA, 8 pages.
Lieberman, H., et al., “Out of context: Computer systems that adapt to, and learn from, context,” 2000, IBM Systems Journal, vol. 39, Nos. 3/4, 2000, 16 pages.
Lin, B., et al., “A Distributed Architecture for Cooperative Spoken Dialogue Agents with Coherent Dialogue State and History,” 1999, http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.42.272, 4 pages.
McGuire, J., et al., “SHADE: Technology for Knowledge-Based Collaborative Engineering,” 1993, Journal of Concurrent Engineering: Applications and Research (CERA), 18 pages.
Milward, D., et al., “D2.2: Dynamic Multimodal Interface Reconfiguration,” Talk and Look: Tools for Ambient Linguistic Knowledge, Aug. 8, 2006, http://www.ihmc.us/users/nblaylock/Pubs/Files/talk—d2.2.pdf, 69 pages.
Mitra, P., et al., “A Graph-Oriented Model for Articulation of Ontology Interdependencies,” 2000, http://ilpubs.stanford.edu:8090/442/1/2000-20.pdf, 15 pages.
Moran, D. B., et al., “Multimodal User Interfaces in the Open Agent Architecture,” Proc. of the 1997 International Conference on Intelligent User Interfaces (IUI97), 8 pages.
Mozer, M., “An Intelligent Environment Must be Adaptive,” Mar./Apr. 1999, IEEE Intelligent Systems, 3 pages.
Mühlhäuser, M., “Context Aware Voice User Interfaces for Workflow Support,” Darmstadt 2007, http://tuprints.ulb.tu-darmstadt.de/876/1/PhD.pdf, 254 pages.
Naone, E., “TR10: Intelligent Software Assistant,” Mar.-Apr. 2009, Technology Review, http://www.technologyreview.com/printer—friendly—article.aspx?id=22117, 2 pages.
Neches, R., “Enabling Technology for Knowledge Sharing,” Fall 1991, Al Magazine, pp. 37-56, (21 pages).
Nöth, E., et al., “Verbmobil: The Use of Prosody in the Linguistic Components of a Speech Understanding System,” IEEE Transactions on Speech and Audio Processing, vol. 8, No. 5, Sep. 2000, 14 pages.
Rice, J., et al., “Monthly Program: Nov. 14, 1995,” The San Francisco Bay Area Chapter of ACM SIGCHI, http://www.baychi.org/calendar/19951114/, 2 pages.
Rice, J., et al., “Using the Web Instead of a Window System,” Knowledge Systems Laboratory, Stanford University, http://tomgruber.org/writing/ksl-95-69.pdf, 14 pages.
Rivlin, Z., et al., “Maestro: Conductor of Multimedia Analysis Technologies,” 1999 SRI International, Communications of the Association for Computing Machinery (CACM), 7 pages.
Sheth, A., et al., “Relationships at the Heart of Semantic Web: Modeling, Discovering, and Exploiting Complex Semantic Relationships,” Oct. 13, 2002, Enhancing the Power of the Internet: Studies in Fuzziness and Soft Computing, SpringerVerlag, 38 pages.
Simonite, T., “One Easy Way to Make Siri Smarter,” Oct. 18, 2011, Technology Review, http:// www.technologyreview.com/printer—friendly—article.aspx?id=38915, 2 pages.
Stent, A., et al., “The CommandTalk Spoken Dialogue System,” 1999, http://acl.ldc.upenn.edu/P/P99/P99-1024.pdf, 8 pages.
Tofel, K., et al., “SpeakTolt: A personal assistant for older iPhones, iPads,” Feb. 9, 2012, http://gigaom.com/apple/speaktoit-siri-for-older-iphones-ipads/, 7 pages.
Tucker, J., “Too lazy to grab your TV remote? Use Siri instead,” Nov. 30, 2011, http://www.engadget.com/2011/11/30/too-lazy-to-grab-your-tv-remote-use-siri-instead/, 8 pages.
Tur, G., et al., “The CALO Meeting Speech Recognition and Understanding System,” 2008, Proc. IEEE Spoken Language Technology Workshop, 4 pages.
Tur, G., et al., “The-CALO-Meeting-Assistant System,” IEEE Transactions on Audio, Speech, and Language Processing, vol. 18, No. 6, Aug. 2010, 11 pages.
Vlingo, “Vlingo Launches Voice Enablement Application on Apple App Store,” Vlingo press release dated Dec. 3, 2008, 2 pages.
YouTube, “Knowledge Navigator,” 5:34 minute video uploaded to YouTube by Knownav on Apr. 29, 2008, http://www.youtube.com/watch?v=QRH8eimU—20on Aug. 3, 2006, 1 page.
YouTube,“Send Text, Listen to and Send E-Mail ‘By Voice’ www.voiceassist.com,” 2:11 minute video uploaded to YouTube by VoiceAssist on Jul. 30, 2009, http://www.youtube.com/watch?v=0tEU61nHHA4, 1 page.
YouTube,“Text'nDrive App Demo—Listen and Reply to your Messages by Voice while Driving!,” 1:57 minute video uploaded to YouTube by TextnDrive on Apr. 27, 2010, http://www.youtube.com/watch?v=WaGfzoHsAMw, 1 page.
YouTube, “Voice on the Go (BlackBerry),” 2:51 minute video uploaded to YouTube by VoiceOnTheGo on Jul. 27, 2009, http://www.youtube.com/watch?v=pJqpWgQS98w, 1 page.
International Search Report and Written Opinion dated Nov. 29, 2011, received in International Application No. PCT/US2011/20861, which corresponds to U.S. Appl. No. 12/987,982, 15 pages (Thomas Robert Gruber).
Related Publications (1)
Number Date Country
20070186148 A1 Aug 2007 US
Continuations (2)
Number Date Country
Parent 10443683 May 2003 US
Child 11735293 US
Parent 09734223 Aug 1999 US
Child 10443683 US