Systems and methods for smart city search

Information

  • Patent Grant
  • 8249804
  • Patent Number
    8,249,804
  • Date Filed
    Wednesday, August 20, 2008
    16 years ago
  • Date Issued
    Tuesday, August 21, 2012
    12 years ago
Abstract
A method, machine-readable medium, and system involve receiving user input with a navigation device regarding a desired city name. A determination is made regarding whether the user input matches city names in a Last Used City List (LUCL). A Global City List (GCL) is consulted when the user input does not match the city names in the LUCL. A matching city name is selected as a best candidate.
Description
FIELD OF THE INVENTION

At least some embodiments of the disclosure relate generally to the field of navigation and, more particularly, searching of cities and locations.


BACKGROUND

Global Navigation Satellite Systems (GNSS) allow navigation services including automatic route calculation from a current location to a destination location and guiding a driver of a vehicle to that destination with real time instructions in conjunction with a visual display of route segments as the vehicle progresses along the route.


The satellites transmit signals comprising very precise location parameters and timing signals that are received by mobile device processors allowing a processor to determine their respective three dimensional positions and velocities.


Navigation systems conventionally provide a recommended route from a starting point to a desired destination. Typically, the starting point and desired destination are selected from a large database of roads stored in a mass media storage, such as a CD ROM or SD card, which includes the roads in the area to be traveled by the user. The navigation system can be, for example, located in a personal computer or installed in a vehicle or carried by a pedestrian. If the navigation system is installed in a vehicle, the starting point is typically the current position of the vehicle, which can be input to the navigation system by an associated position determining system that may include a GPS receiver.


The navigation system determines a route from the starting point to the destination. Usually there are many potential routes between the selected starting point and the desired destination. Typical navigation systems select a recommended route based upon certain “cost” values associated with each segment of road in the road database. These cost values include the length of the road segment and the estimated time of travel through the road segment. The navigation system selects the potential route with the lowest total cost to be the recommended route. Depending upon the conventional algorithm of the navigation system, the navigation system may, for example, recommend the route with the shortest total length, the lowest total time, or some weighted average of length and time.


The recommended route then may be displayed to the user as a map showing the starting point and desired destination and highlighting the recommended route. If the navigation system is installed in a vehicle, the navigation system may display the current position of the vehicle and provide turn-by-turn instructions to the driver, guiding the driver to the selected destination.


Navigation systems typically include a graphical user interface that allows a user to input the desired destination. The user often needs to input a city name for the desired destination, for example, as part of the destination address. As another example, the desired destination is a Point of Interest in or near a city. Since a full keyboard is impractical in a vehicle, a conventional graphical user interface includes a touch screen or a directional input device such as a four-way button. The user is presented with the letters of the alphabet arranged in a single large rectangular array, which is usually called soft keyboard. One typical system requires the user to scroll through the alphabet one letter at a time using the directional input device, selecting a desired letter when it becomes highlighted. These systems have the disadvantage of inputting a given letter. With such systems, inputting the city name can also be very time consuming and frustrating for a user.


Many conventional mobile navigation applications allow users to find a city by entering a partial or full city name. Such applications will search for matches in a global city name list sorted alphabetically. All city name matches contain the characters entered by the user as their leading substring. A Next-Letter-Tree (NLT) may be used to support city name entry on the soft keyboard. Because many city names have similar spellings, it usually takes many keystrokes to narrow down the matching cities. The applications may further ask users to pick a city among multiple matches if a partial name is input. Because it is inconvenient for a user to provide inputs to small mobile devices, users want to minimize the number of keystrokes to perform tasks such as locating a desired city.


SUMMARY

A method, machine-readable medium, and system involve receiving a user input with a navigation device regarding a desired city name. A determination is made regarding whether the user input matches city names in a Last Used City List (LUCL). A Global City List (GCL) is consulted when the user input does not match the city names in the LUCL. A matching city name is selected as a best candidate.





BRIEF DESCRIPTION OF THE DRAWINGS

The embodiments are illustrated by way of example and not limitation in the figures of the accompanying drawings in which like references indicate similar elements.



FIG. 1 is a block diagram of a navigation device in accordance with one embodiment of the present invention.



FIG. 2 illustrates an input screen in accordance with one embodiment of the present invention.



FIG. 3 illustrates a list screen in accordance with one embodiment of the present invention.



FIG. 4 is a flow chart of a method to find a best candidate when a city list does not include a spatial index in accordance with one embodiment of the present invention.



FIG. 5 is a flow chart of a method to list matching cities by distance in accordance with one embodiment of the present invention.



FIG. 6 is a flow chart of a method to find a best candidate when a city list includes a spatial index in accordance with one embodiment of the present invention.





DETAILED DESCRIPTION

The following description and drawings are illustrative and are not to be construed as limiting. Numerous specific details are described to provide a thorough understanding of the invention. However, in certain instances, well known or conventional details are not described in order to avoid obscuring the description. References herein to one or an embodiment in the present disclosure can be, but are not necessarily, references to the same embodiment.


Reference in this specification to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the disclosure. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment, nor are separate or alternative embodiments mutually exclusive of other embodiments. Moreover, various features are described which may be exhibited by some embodiments and not by others. Similarly, various requirements are described which may be requirements for some embodiments but not other embodiments.



FIG. 1 is a block diagram of a navigation device 100 in accordance with one embodiment of the present invention. In one embodiment, the navigation device 100 is a GPS vehicle navigation device. The navigation device 100 includes an input device 102, a storage media 104, a database 106, a microphone 108, a speaker 110, a display 112, a memory 114, a CPU 116, and a GPS receiver 118 coupled together through a bus 120.



FIG. 2 illustrates an exemplary touch sensitive character input screen 200 as displayed on the input device 102. In one embodiment, a keyboard and mouse can be used instead of the input screen 200 to provide inputs to the navigation device 100. The input screen 200 includes a title field 202, an input textbox 204, alphanumberic keys 206, a backspace key 208, a list key 210, and other keys commonly found on a conventional keyboard. Not all keys 206 are necessarily enabled at a given time. As the user enters characters, keys 206 that are not likely to be used by the user may be disabled as indicated by the depicted shading for certain of the keys 206. In one embodiment, NLT can be used for predictive character selection.


A user sequentially depresses keys on the input screen 200 to enter the name of a city that the user wishes to find with the navigation device 100. Based on the characters or letters entered by the user, a “best” candidate for the city sought by the user is selected by the navigation device 100 and displayed in the input textbox 204.


To minimize keystrokes by the user, and optimize the speed of correctly determining the city name sought by the user, a best candidate is selected from sequential resort to the following two lists of cities: 1. Last Used City List (LUCL) and 2. Global City List, as described in more detail below. Once selected, the best candidate is displayed in the input textbox 204 after each character entry by the user. In this manner, space on the input screen 200 is conserved while, at the same time, the best candidate is displayed in response to character entry by the user. If users do not select the best candidate presented in the input textbox 204 and continue entering characters, this candidate is disregarded in the following candidate selections and the next best candidate is displayed.


In one embodiment, characters typed by the user in the input textbox 204 may be displayed in dark color while predicted characters are displayed in light color. The contrast between dark colored characters and light colored characters distinguishes the letters in the displayed city name that have been input by the user versus the letters in the displayed city name that have not been input by the user. In another embodiment, the characters input by the user and the characters not input by the user in the displayed city name are distinguished in another manner without the use of color or shade of the characters in the input textbox 204.


When the first character of the desired city name is typed by the user, the LUCL is checked first. The best candidate is the first match which contains the characters entered by the user as its leading substring. The LUCL contains a bound on or range of the number of city names that were last used by the user. In one embodiment, the number of last used city names in the LUCL is 20. In another embodiment, the number of last used city names in the LUCL is a number other than 20, depending on a particular application and other factors such as ease and speed of use. Likewise, the number of last used city names in the LUCL may even be a range of numbers.


The LUCL may contain a list of city names along with associated upper-level administrations such as the state in which the city is located. In one embodiment, the city name and associated upper-level administration of the best candidate are displayed together in the input textbox 204. In one embodiment, the LUCL may also contain the names of municipalities, counties, states, and other geographic regions and upper level administrations by themselves. Names of cities and other regions in the LUCL are unique, and the LUCL preferably does not contain duplicate occurrences of a city or other region.


The LUCL is sorted by time with the most recently selected city name positioned at the top of the LUCL. Other previously selected city names are then listed below the most recently selected city name, with the most recent selections at the top of the LUCL and the least recent selections at the bottom of the LUCL. The most recently selected city name is preferably stored in RAM during search. In the event of multiple city name matches with the input provided by the user, the first match is the most recently match in the LUCL, and is selected as the best candidate.


As stated above, the number of city names in the LUCL preferably does not exceed a certain number, or falls within a certain range. Accordingly, previously selected city names that fall outside the certain number or range of the LUCL do not appear in the LUCL. Limiting the size of the LUCL in this manner renders the LUCL easy to maintain. By sorting and prioritizing on the basis of previous selections, the number of sorts is minimized and the time required to find the city name sought by the user is fast.


As the user sequentially enters characters on the input screen 200, the best candidate from the LUCL is displayed in the input textbox 204. The user may select the best candidate by touching the displayed city name in the input textbox 204. In one embodiment, the user may select the displayed best candidate by touching another key on the input screen 200.


When there is no matching entry in the LUCL, the Global City List (GCL) is then checked for a city match that is geographically nearest to the user's current position. In accordance with the present invention, the GCL may be associated without a spatial index or with a spatial index.


When the GCL does not have a spatial index, the GCL includes a name list sorted alphabetically and, for each city, location information with an indication of latitude and longitude only. In accordance with the GCL, the navigation device 100 performs the following process to find a best candidate.


As a user of the navigation device 100 enters characters, a binary search is run to find upper and lower boundaries of a matching subset list in the alphabetically sorted GCL. The subset list is continuous. All city names in the subset list contain the characters entered by the user as their leading substring.


The subset list is re-sorted based on the geographic distance between each city name and the current position of the navigation device 100. Because the GCL does not have a spatial index, the calculation of geographic distances between the navigation device 100 and city names involves processing by the navigation device 100 and attendant delay. Thus, to ensure timely response, and to minimize undue delay, the subset list can be reduced to a manageable number of city names before re-sorting by adjusting the lower boundary if the number of city names exceeds a certain threshold.


In one embodiment, the threshold number of city names is approximately 200. In another embodiment, the threshold number depends on, for example, the processing speed and power of the navigation device 100 as well as other factors to optimize the speed of re-sorting the subset list for a particular environment and user expectations. In one embodiment, to save time, a Manhattan distance calculation algorithm is used as the geographic distance between each city name and the current position of the navigation device 100. In one embodiment, another distance calculation algorithm may be used for the geographical distance. The first city name in the re-sorted subset list, which is geographically nearest to the current position, is displayed as the best candidate.


When the number of matches in the Global City List is larger than the threshold number, users are prompted to enter more characters. The best candidate is not necessarily the geographically nearest match in the Global City List. When the number of matches is smaller than the threshold number, the user has an option to display the subset list of matches sorted by geographic distance. In this regard, a list key 210 on the input screen 200 is enabled when the number of matches is smaller than the threshold number. The enabled list key 210 may be depressed when the displayed best candidate is not desired by the user. As shown in FIG. 3, depression of the enabled list key 210 causes display of a list screen 300 showing a list 304 of matching city names sorted by distance to the current position. The list screen 300 displays matching city names from the subset list. In one embodiment, the best candidate is highlighted in the list screen 300 and appears in the top portion of the list screen 300 where the user is more likely focused. An alphabetical order button 310 is located on the list screen 300. If the city name desired by the user cannot be easily found on the list screen 300, the user may depress the alphabetical order button 310. Upon depression of the alphabetical order button 310, all matching city names are displayed in the list screen 300 in alphabetical order. This option is also helpful for cases when the same city name exists in multiple regions.


A scroll up button 306 and a scroll down button 308 on the list screen 300 allow the user of the navigation device 100 to scroll through matching city names in the subset list and thus find the desired city name. In accordance with the present invention, only the top matching city names from the subset list needed to fill the list screen 300 are initially fetched and displayed on the list screen 300. By fetching only a portion of all the matching city names in the subset list, the time delay required to display city names on the list screen 300 can be minimized. The time savings is especially great when the subset list of matching city names is large. Through selection of the scroll up button 206 and the scroll down button 308, the user may scroll to matching city names in the subset list that are not initially displayed in the list screen 300. The matching city names are additionally fetched and displayed in accordance with scrolling by the user. By displaying matching city names as they are desired by the user, the present invention avoids the inefficiencies of conventional systems that retrieve city names from a global city list all at one time.


When a GCL that is sorted alphabetically includes a spatial index, searching for the geographically nearest city names is more efficient. In accordance with the present invention, the navigation device 100 performs the following process to search for the geographically nearest city names. City names within a predetermined distance from the current position of the navigation device 100, or search radius, are retrieved. The predetermined distance can be appropriately increased if the number of city names within the predetermined distance is small or decreased if the number of city names within the predetermined distance is large. The subset list is re-sorted based on the geographic distance between each city name and the current position of the navigation device 100 and the user. In one embodiment, to save time, Manhattan distance calculation algorithm can be used.


As characters are entered by the user, the first matching city name will have a leading substring that matches the characters entered by the user. The first matching city name in the re-sorted subset list is displayed as the best candidate.


If there is no city name in the subset list that matches the characters inputted by the user, the first matching city name in the GCL is selected as the best candidate. The best candidate is then displayed.


At the option of the user, the list key 210 can be depressed by the user to see on the list screen 300 all matching city names in the subset list within the predetermined distance sorted by geographic distance. If there is no matching city name in the subset list, all matching city names in the GCL can be displayed. Otherwise, upon depression of the alphabetical order button 310, all matching city names are displayed in the list screen 300 in alphabetical order.


Voice recognition can also be used in accordance with the present invention. The user can provide city names using spoken words and voice commands as user input to the navigation device 100 appropriately configured to receive such words and commands. Once spoken words or voice commands are received by the navigation device 100, a phrase matching the city name provided by the user is searched for in a recognition vocabulary and a best candidate is found. In one embodiment, the recognition vocabulary is the GCL. Because the GCL can be quite large and because some city names have the same or similar pronunciation, multiple matching city names may exceed a predefined confidence level. When two or more matching city names exceed the predefined confidence level, the LUCL and the geographic distance from the city name to the current position of the navigation device 100 can be used to filter or resort matching city names accordingly and the device can present the best candidate or a list of candidates in a sorted order.


As provided by the present invention, the selection of a desired city name is optimized because users desiring mobile navigation information often target or prefer city names that they have selected before or that are near their current position. Further, as provided by the present invention, the time required to find and select a desired city name is fast and often immediate.



FIG. 4 is a flow chart of an exemplary method 400 involving determination of a best candidate when the GCL has no spatial index. The method begins at block 402 and proceeds to block 404. At block 404, characters entered by the user are received by the navigation device 100. The method 400 proceeds to decision block 406 where the navigation device 100 attempts to find a matching city name in the LUCL based on the user input. If a matching city name is found, the method 400 proceeds to block 408 where the most recently used matching city name is picked as the best candidate. The method 400 proceeds to block 410 where the best candidate is displayed. The method 400 proceeds to block 420 where the method 400 ends.


If a matching city name is not found at decision block 406, the method 400 proceeds to block 412. At block 412, the number of matching city names in the GCL is checked, and the method 400 proceeds to decision block 414. At decision block 414, if the number of matching city names exceeds a threshold number (for example, 200), the method 400 proceeds to block 416. At block 416, the subset list is reduced to the first matching city names within the threshold number (for example, 200), and the method 400 proceeds to block 418. At block 418, the geographically nearest matching city name is picked as the best candidate, and the method 400 proceeds to block 410. At block decision 414, if the number of matching city names does not exceed a threshold number (for example, 200), the method 400 proceeds to block 418.



FIG. 5 is a flow chart of an exemplary method 500 involving the listing of matching city names by geographic distance when the GCL has no spatial index. The method 500 begins at block 502 and proceeds to block 504. At block 504, characters entered by the user are received by the navigation device 100. The method 500 proceeds to block 506 where the number of matching city names in the GCL is checked. The method proceeds to decision block 508 where it is determined whether the number of matching city names exceeds a certain threshold (e.g., 200). If so, the method 500 proceeds to block 504 where more characters are entered by the user. If not, the method 500 proceeds to block 510 where the list key 210 is enabled.


The method 500 proceeds to block 512 where an indication that the list key 210 has been depressed is received. The method 500 proceeds to block 514 where the matching city names are sorted in geographic distance in ascending order and displayed in the list screen 300. The method 500 proceeds to block 516 where an indication that the alphabetical order button 310 has been depressed is received. The method 500 proceeds to block 518 where matching city names are displayed in alphabetical order. The method 500 proceeds to end at block 520.



FIG. 6 is a flow chart of an exemplary method 600 involving determination of a best candidate when the GCL has a spatial index. The method 600 begins at block 602 and proceeds to block 604 where characters input by the user are received by the navigation device 100. The method proceeds to decision block 606 where it is determined if matching city names are found in the LUCL. If so, the method 600 proceeds to block 608 where the most recently used matching city name is picked as the best candidate. The method 600 proceeds to block 610 where the best candidate is displayed and the method proceeds to block 624 where the method 600 ends.


At decision block 606, if matching city names are not found in the LUCL, the method 600 proceeds to block 612 where matching city names within a certain geographic distance (e.g., 20 miles) are searched for. The method 600 proceeds to decision block 614 where it is determined if any matching city names are found. If so, the method 600 proceeds to block 622 where the geographically nearest city is picked as the best candidate, and the method 600 proceeds to block 610. If not, the method 600 proceeds to block 616 where matching city names within another certain geographic distance (e.g., 50 miles) are searched for. The method 600 proceeds to decision block 618 where it is determined if any matching city names are found. If so, the method 600 proceeds to block 622. If not, the method 600 proceeds to block 620 where the first matching city name in the GCL is picked as the best candidate. The method 600 proceeds to block 610.


In one embodiment, the input device 102 of the navigation device 100 includes the touch sensitive character input screen 200 to receive user inputs. In one embodiment, a keyboard and a mouse are used instead of the input screen 200. The navigation device 100 includes the storage media 104, the database 106, and the memory 114, each of which may be constitute a machine-readable medium on which one or more sets of instructions (e.g., software) are stored. The one or more sets of instructions embody any one or more of the methodologies or functions described herein. The software may also reside, completely or at least partially, within the CPU 116 during execution thereof by the CPU 116 and the navigation device 100. The software may further be transmitted or received over a network.


The term “machine-readable medium” should be taken to include a single medium or multiple media (e.g., a centralized or distributed database, and/or associated caches and memory) that store the one or more sets of instructions. The term “machine-readable medium” shall also be taken to include any medium that is capable of storing, encoding or carrying a set of instructions for execution by the machine and that cause the machine to perform any one or more of the methodologies of the present invention. The term “machine-readable medium” shall accordingly be taken to include, but not be limited to, solid-state memories, optical, and magnetic media.


In general, the routines executed to implement the embodiments of the disclosure, may be implemented as part of an operating system or a specific application, component, program, object, module or sequence of instructions referred to as “programs.” For example, one or more programs may be used to execute specific processes described herein. The programs typically comprise one or more instructions set at various times in various memory and storage devices in the machine, and that, when read and executed by one or more processors, cause the machine to perform operations to execute elements involving the various aspects of the disclosure.


Moreover, while embodiments have been described in the context of fully machines, those skilled in the art will appreciate that the various embodiments are capable of being distributed as a program product in a variety of forms, and that the disclosure applies equally regardless of the particular type of machine or computer-readable media used to actually effect the distribution. Examples of machine-readable media include but are not limited to recordable type media such as volatile and non-volatile memory devices, floppy and other removable disks, hard disk drives, optical disks (e.g., Compact Disk Read-Only Memory (CD ROMS), Digital Versatile Disks, (DVDs), etc.), among others, and transmission type media such as digital and analog communication links.


Although embodiments have been described with reference to specific exemplary embodiments, it will be evident that the various modification and changes can be made to these embodiments. Accordingly, the specification and drawings are to be regarded in an illustrative sense rather than in a restrictive sense. The foregoing specification provides a description with reference to specific exemplary embodiments. It will be evident that various modifications may be made thereto without departing from the broader spirit and scope as set forth in the following claims. The specification and drawings are, accordingly, to be regarded in an illustrative sense rather than a restrictive sense.

Claims
  • 1. A computer implemented method comprising: receiving, with a navigation device, user input regarding a desired city name;determining whether the user input matches a city name in a Last Used City List;when determined that the user input matches the city name in the Last Used City List, selecting the city name in the Last Used City List that matches the user input as a best candidate;when determined that the user input does not match any city name in the Last Used City List, consulting a Global City List, wherein consulting the Global City List includes: determining whether a number of city names in the Global City List matching the user input exceeds a predetermined threshold; andselecting a city name in the Global City List matching the user input that is geographically nearest to the navigation device as a best candidate when the number of city names in the Global City List matching the user input does not exceed the predetermined threshold; anddisplaying the best candidate in response to character entry by the user.
  • 2. The method of claim 1, further comprising selecting the matching city name most recently used as the best candidate from the Last Used City List sorted by time.
  • 3. The method of claim 1, wherein the consulting the Global City List further comprises having the GCL in alphabetical order.
  • 4. The method of claim 1, wherein the consulting the Global City List further comprises reducing the number of matching city names to a predetermined threshold by picking first predetermined number of matches and disregarding the remainder when the number of matching city names exceeds the predetermined threshold.
  • 5. The method of claim 1, further comprising: enabling a list key of the navigation device when the number of matching city names in the Global City List does not exceed a predetermined threshold;receiving an indication of selection of the list key; andlisting the matching city names.
  • 6. The method of claim 5, further comprising sorting the matching city names by geographic distance.
  • 7. The method of claim 6, further comprising: receiving an indication to display the matching city names in alphabetical order; anddisplaying the matching city names in alphabetical order.
  • 8. The method of claim 5, further comprising: checking the number of matching city names in the Global City List; andreceiving further user input regarding the desired city name until the number of matching city names does not exceed the predetermined threshold before the enabling, the receiving, and the listing.
  • 9. The method of claim 1, wherein the consulting a Global City List with spatial index comprises:selecting cities which are within a first predetermined geographic distance from the navigation device;determining whether city names match a substring entered by a user; andselecting the matching city name that is geographically nearest to the navigation device as the best candidate when the matching city names are within the first predetermined geographic distance from the navigation device.
  • 10. The method of claim 9, wherein the consulting a Global City List with spatial index further comprises determining whether the matching city names are within a second predetermined geographic distance from the navigation device when no matching city names are found within the first predetermined geographic distance.
  • 11. The method of claim 10, wherein consulting the Global City List with spatial index further comprises selecting a first of the matching city names in the Global City List as the first best candidate when none of the matching city names are within the second predetermined geographic distance.
  • 12. The method of claim 10, wherein consulting the Global City List with spatial index further comprises selecting the matching city name that is geographically nearest to the navigation device as the first best candidate when the matching city names are within the second predetermined geographic distance.
  • 13. The method of claim 10, wherein the second predetermined geographic distance is greater than the first predetermined geographic distance.
  • 14. The method of claim 1, wherein the user input includes voice commands.
  • 15. The method of claim 1, further comprising disregarding the best candidate presented previously and displaying a next best candidate, if a user does not select the previously presented best candidate and continues entering characters.
  • 16. A non-transitory machine-readable medium that provides instructions for a processor, which when executed by the processor cause the processor to perform a method comprising: receiving, with a navigation device, user input regarding a desired city name;determining whether the user input matches a city name in a Last Used City List;when determined that the user input matches the city name in the Last Used City List, selecting the city name in the Last Used City List that matches the user input as a best candidate;when determined that the user input does not match any city name in the Last Used City List, consulting a Global City List, wherein consulting the Global City List includes: determining whether a number of city names in the Global City List matching the user input exceeds a predetermined threshold; andselecting a city name in the Global City List matching the user input that is geographically nearest to the navigation device as a best candidate when the number of city names in the Global City List matching the user input does not exceed the predetermined threshold; anddisplaying the best candidate in response to character entry by the user.
  • 17. The machine-readable medium of claim 16, wherein the consulting the Global City List (GCL) further comprises: determining whether the number of matching city names exceeds a predetermined threshold; andselecting the matching city name that is geographically nearest to the navigation device when the number of matching city names does not exceed the predetermined threshold.
  • 18. A system comprising: means for receiving user input regarding a desired city name;means for determining whether the user input matches city names in a Last Used City List;means for, when determined that the user input matches the city name in the Last Used City List, selecting the city name in the Last Used City List that matches the user input as a best candidate;means for, when determined that the user input does not match any city name in the Last Used City List, consulting a Global City List, wherein consulting the Global City List includes: determining whether a number of city names in the Global City List matching the user input exceeds a predetermined threshold; andselecting a city name in the Global City List matching the user input that is geographically nearest to the navigation device as a best candidate when the number of city names in the Global City List matching the user input does not exceed the predetermined threshold; andmeans for displaying the best candidate in response to character entry by the user.
US Referenced Citations (141)
Number Name Date Kind
5515283 Desai et al. May 1996 A
5802492 DeLorme et al. Sep 1998 A
5819200 Tamai et al. Oct 1998 A
5832408 Tamai et al. Nov 1998 A
5987375 Tamai Nov 1999 A
6037942 Millington Mar 2000 A
6049755 Lou et al. Apr 2000 A
6067502 Hayashida et al. May 2000 A
6078864 Long et al. Jun 2000 A
6081609 Narioka Jun 2000 A
6084989 Eppler Jul 2000 A
6092076 McDonough et al. Jul 2000 A
6107944 Behr et al. Aug 2000 A
6108603 Karunanidhi Aug 2000 A
6108604 Fukaga et al. Aug 2000 A
6115669 Watanabe et al. Sep 2000 A
6124826 Garthwaite et al. Sep 2000 A
6125326 Ohmura et al. Sep 2000 A
6141621 Piwowarski et al. Oct 2000 A
6148261 Obradovich et al. Nov 2000 A
6151552 Koizumi et al. Nov 2000 A
6154699 Williams Nov 2000 A
6163269 Millington et al. Dec 2000 A
6172641 Millington Jan 2001 B1
6175801 Millington Jan 2001 B1
6177943 Margolin Jan 2001 B1
6178380 Millington Jan 2001 B1
6184823 Smith et al. Feb 2001 B1
6189130 Gofman et al. Feb 2001 B1
6201540 Gallup et al. Mar 2001 B1
6204778 Bergan et al. Mar 2001 B1
6205397 Eslambolchi et al. Mar 2001 B1
6212474 Fowler et al. Apr 2001 B1
6223118 Kobayashi et al. Apr 2001 B1
6229546 Lancaster et al. May 2001 B1
6249740 Ito et al. Jun 2001 B1
6252814 Tran et al. Jun 2001 B1
6253151 Ohler et al. Jun 2001 B1
6256029 Millington Jul 2001 B1
6278942 McDonough Aug 2001 B1
6308134 Croyle et al. Oct 2001 B1
6320517 Yano et al. Nov 2001 B1
6321158 DeLorme et al. Nov 2001 B1
6349257 Liu et al. Feb 2002 B1
6356210 Ellis Mar 2002 B1
6360167 Millington et al. Mar 2002 B1
6362751 Upparapalli Mar 2002 B1
6363322 Millington Mar 2002 B1
6370475 Breed et al. Apr 2002 B1
6377278 Cutright et al. Apr 2002 B1
6381536 Satoh et al. Apr 2002 B1
6385535 Ohishi et al. May 2002 B2
6385542 Millington May 2002 B1
6397145 Millington May 2002 B1
6405130 Piwowarski Jun 2002 B1
6408243 Yofu Jun 2002 B1
6415224 Wako et al. Jul 2002 B1
6427115 Sekiyama Jul 2002 B1
6430501 Slominski Aug 2002 B1
6453235 Endo et al. Sep 2002 B1
6484089 Millington Nov 2002 B1
6484094 Wako Nov 2002 B1
6487494 Odinak et al. Nov 2002 B2
6515595 Obradovich et al. Feb 2003 B1
6529822 Millington et al. Mar 2003 B1
6529824 Obradovich et al. Mar 2003 B1
6539301 Shirk Mar 2003 B1
6565610 Wang et al. May 2003 B1
6574551 Maxwell et al. Jun 2003 B1
6609062 Hancock Aug 2003 B2
6631322 Arthur et al. Oct 2003 B1
6671617 Odinak et al. Dec 2003 B2
6704649 Miyahara Mar 2004 B2
6728608 Ollis et al. Apr 2004 B2
6728636 Kokijima et al. Apr 2004 B2
6748323 Lokshin et al. Jun 2004 B2
6765554 Millington Jul 2004 B2
6774932 Ewing Aug 2004 B1
6782319 McDonough Aug 2004 B1
6816596 Peinado et al. Nov 2004 B1
6819301 Nagamatsu et al. Nov 2004 B2
6839628 Tu Jan 2005 B1
6842695 Tu Jan 2005 B1
6873907 Millington et al. Mar 2005 B1
6885874 Grube et al. Apr 2005 B2
6917982 Dueck et al. Jul 2005 B1
6938028 Ito Aug 2005 B1
7031834 Ito et al. Apr 2006 B2
7031836 Branch Apr 2006 B2
7058504 McDonough et al. Jun 2006 B2
7170518 Millington et al. Jan 2007 B1
7218246 Chiba May 2007 B2
7233860 Lokshin et al. Jun 2007 B2
7260475 Suzuki Aug 2007 B2
7321826 Sheha et al. Jan 2008 B2
7333820 Sheha et al. Feb 2008 B2
7343242 Breitenberger et al. Mar 2008 B2
7353107 Breitenberger et al. Apr 2008 B2
7379812 Yoshioka et al. May 2008 B2
7421334 Dahlgren et al. Sep 2008 B2
7480566 Laverty Jan 2009 B2
7512487 Golding et al. Mar 2009 B1
7546202 Oh Jun 2009 B2
7590490 Clark Sep 2009 B2
7925438 Lo Apr 2011 B2
20020151315 Hendrey Oct 2002 A1
20030036842 Hancock Feb 2003 A1
20030036848 Sheha et al. Feb 2003 A1
20030167120 Kawasaki Sep 2003 A1
20030182052 DeLorme et al. Sep 2003 A1
20030191578 Paulauskas et al. Oct 2003 A1
20040204821 Tu Oct 2004 A1
20050107948 Catalinotto May 2005 A1
20060080031 Cooper et al. Apr 2006 A1
20060089788 Laverty Apr 2006 A1
20060106534 Kawamata et al. May 2006 A1
20060212217 Sheha et al. Sep 2006 A1
20060265422 Ando et al. Nov 2006 A1
20070027628 Geelen Feb 2007 A1
20070073480 Singh Mar 2007 A1
20070088494 Rothman et al. Apr 2007 A1
20070130153 Nachman et al. Jun 2007 A1
20070204218 Weber et al. Aug 2007 A1
20070213929 Tanizaki et al. Sep 2007 A1
20070233384 Lee Oct 2007 A1
20080076451 Sheha et al. Mar 2008 A1
20080134088 Tse et al. Jun 2008 A1
20080167809 Geelen Jul 2008 A1
20080177470 Sutardja Jul 2008 A1
20090138190 Kulik May 2009 A1
20090150064 Geelen Jun 2009 A1
20090171576 Kim et al. Jul 2009 A1
20090171584 Liu Jul 2009 A1
20090182498 Seymour Jul 2009 A1
20090182500 Dicke Jul 2009 A1
20090187340 Vavrus Jul 2009 A1
20090187341 Vavrus Jul 2009 A1
20090187342 Vavrus Jul 2009 A1
20090216732 Feng Aug 2009 A1
20090326794 Lungwitz et al. Dec 2009 A1
20100286901 Geelen et al. Nov 2010 A1
Foreign Referenced Citations (18)
Number Date Country
2001194172 Jul 2001 JP
2002048574 Feb 2002 JP
2006250875 Sep 2006 JP
2007155582 Jun 2007 JP
2007178182 Jul 2007 JP
2008002978 Jan 2008 JP
19990011004 Feb 1999 KR
19990040849 Jun 1999 KR
20020084716 Nov 2002 KR
20040106688 Dec 2004 KR
20070080726 Aug 2007 KR
2008070226 Jun 2008 WO
2008073717 Jun 2008 WO
2008100656 Aug 2008 WO
2008112335 Sep 2008 WO
2008130722 Oct 2008 WO
2008134093 Nov 2008 WO
2009036052 Mar 2009 WO
Related Publications (1)
Number Date Country
20100049696 A1 Feb 2010 US