This description relates to presenting driving directions for a travel route between an origin location and a destination location.
A travel route between an origin location and a destination location may be determined by a computer system, which may be referred to as a mapping system. The mapping system may make this determination by searching for an optimal path through a directed graph (e.g., a collection of nodes and edges) that represents a network of roads and intersections. Each edge (or link) of the graph may represent a road in a map, and each node of the graph may represent an intersection of two or more roads or a terminal point of a road, such as a dead end road.
A user of a mapping system may want to see driving directions, which may be in the form of maneuvers in the travel route with a narrative description of each maneuver to be made. The driving directions may be difficult to comprehend, particularly while attempting to follow the driving directions and drive a vehicle at the same time. This may be particularly true when a mapping system displays a maneuver for each link in the graph that represents the route.
In one general aspect, driving directions having multiple maneuvers are displayed by accessing route information for a route from an origin to a destination and generating maneuvers for the route based on the route information. A first maneuver is combined with a second maneuver based at least in part upon the first maneuver being associated with a highway interchange and the second maneuver being associated with the highway interchange, and the combined route maneuver is presented on a user system.
Implementations may include one or more of the following features. For example, additional interchange maneuvers may be identified, and redundant interchange maneuvers may be eliminated such that a particular highway or a particular interstate is only included in one interchange maneuver for the route.
The combined route maneuver may be displayed in driving directions that are displayed by a system connected to an Internet service provider, a printer or display device associated with the user system, a personal digital assistant, or a display device associated with an on-board navigation system of a vehicle.
The combined route maneuver on the user system may be presented using text that starts with “Merge onto” and includes text associated with a particular road name that is appended with “via” and an exit number associated with the combined maneuver or with “via” and exit information associated with the combined maneuver.
In another general aspect, driving directions having multiple maneuvers are displayed by accessing route information for a route from an origin to a destination and generating maneuvers for the route based on the route information. A first maneuver is combined with a second maneuver based at least in part upon the first maneuver including a reference to a particular road, and the combined route maneuver is presented on a user system.
Implementations may include one or more of the features noted above. In addition, combining a first maneuver with a second maneuver to produce a combined route maneuver may be based at least in part upon the first maneuver including a reference to a particular road unless an intersection between the first maneuver and the second maneuver includes an intersecting forward link.
Implementations of any of the techniques described may include a method or process, an apparatus or system, or computer software on a computer-accessible medium. The details of particular implementations are set forth below. Other features will be apparent from the description and drawings, and from the claims.
Techniques are provided for reducing the number of maneuvers presented in narrative driving directions for a route from an origin location to a destination location. The techniques may help to present driving directions that more closely approximate the style of person-to-person communication of directions. For example, the techniques help to narrow the list of maneuvers to provide a list of relevant roads and a description of a maneuver related to each road. The resulting displayed narrative driving directions may be referred to as succinct driving directions.
The succinct driving directions may be closer to the way one person conveys driving directions to another person. For example, a person may indicate a turn direction (e.g., left or right turn or merge onto an interstate) and a road name. By contrast, a conventional mapping system may provide a maneuver that corresponds to each link in a route in which a road in the route is depicted by multiple links. The challenge is to identify information that is needed by a driver to follow a route, while elminating other extraneous information.
The display of fewer maneuvers for a route may enable a user to understand the displayed travel route more quickly than when a large number of narrative driving direction maneuvers are displayed for the travel route. For example, a user may be able to quickly view nine route maneuvers to understand the state roads, highways and interstates that are included in the travel route, and, in so doing, to understand the maneuvers that are to be made to follow the travel route between the origin and destination.
For illustrative purposes,
Referring to
The client device 120 (or the host device 135) is generally capable of executing instructions under the command of a client controller 125 (or a host controller 140). The client device 120 (or the host device 135) is connected to the client controller 125 (or the host controller 140) by a wired pathway 150 or 155, a wireless data pathway 150 or 155 capable of delivering data, or, when the client controller 125 (or host controller 140) is a software application loaded on the client device 120 (or the host controller 140), a virtual pathway.
Each of the client device 120, the client controller 125, the host device 135, and the host controller 140 typically includes one or more hardware components and/or software components. An example of a client device 120 or a host device 135 is a general-purpose computer (e.g., a personal computer) capable of responding to and executing instructions in a defined manner. Other examples include a special-purpose computer, a workstation, a server, a device, a component, other physical or virtual equipment or some combination thereof capable of responding to and executing instructions.
An example of the client controller 125 or the host controller 140 is a software application loaded on the client device 120 or the host device 135 for commanding and directing communications enabled by the client device 120 or the host device 135. Other examples include a program, a piece of code, an instruction, a device, a computer, a computer system, or a combination thereof, for independently or collectively instructing the client device 120 or the host device 135 to interact and operate as described. The client controller 125 and the host controller 140 may be embodied permanently or temporarily in any type of machine, component, physical or virtual equipment, storage medium, or propagated signal capable of providing instructions to the client device 120 or the host device 135.
The communications link 115 typically includes a delivery network 160 that provides a direct or indirect communication link between the client system 105 and the host system 110, irrespective of physical separation. Examples of a delivery network 160 include the Internet, the World Wide Web, WANs, LANs, analog or digital wired and wireless telephone networks (e.g., PSTN (“Public Switched Telephone Network”), ISDN (“Integrated Services Digital Network”), and DSL (“Digital Subscriber Line”) including various forms of DSL such as SDSL (“Single-line Digital Subscriber Line”), ADSL (“Asymmetric Digital Subscriber Loop), HDSL (“High bit-rate Digital Subscriber Line”), and VDSL (“Very high bit-rate Digital Subscriber Line)), radio, television, cable, satellite, and/or any other delivery mechanism for carrying data. The communications link 115 may include communication pathways 150 and 155 that enable communications through the one or more delivery networks 160 described above. Each of the communication pathways 150 and 155 may include, for example, a wired, wireless, virtual, cable or satellite communications pathway.
Examples of each element within the communication system of
The client device 220 typically includes a general purpose computer 270 having an internal or external storage 272 for storing data and programs such as an operating system 274 (e.g., DOS, Windows®, Windows® 95, Windows® 98, Windows® 2000, Windows® NT, Windows® Millennium Edition, Windows® XP, OS/2, or Linux) and one or more application programs. Examples of application programs include authoring applications 276 (e.g., word processing programs, database programs, spreadsheet programs, presentation programs, and graphics programs) capable of generating documents or other electronic content; client applications 278 (e.g., AOL (“America Online”) client, CompuServe client, AIM (“America Online Instant Messenger”) client, AOL TV (“America Online Television”) client, and an ISP (“Internet Service Provider”) client) capable of communicating with other computer users, accessing various computer resources, and viewing, creating, or otherwise manipulating electronic content; and browser applications 280 (e.g., Netscape's Navigator and Microsoft's Internet Explorer) capable of rendering standard Internet content.
The general-purpose computer 270 also includes a central processing unit 282 (CPU) for executing instructions in response to commands from the client controller 225. In one implementation, the client controller 225 includes one or more of the application programs installed on the internal or external storage 272 of the general-purpose computer 270. In another implementation, the client controller 225 includes application programs externally stored in and executed by one or more device(s) external to the general-purpose computer 270.
The general-purpose computer 270 typically includes a communication device 284 for sending and receiving data. One example of the communication device 284 is a modem. Other examples include a transceiver, a set-top box, a communication card, a satellite dish, an antenna, or another network adapter capable of transmitting and receiving data over the communications link 215 through a wired or wireless data pathway 250. The general-purpose computer 270 also may include a TV (“television”) tuner 286 for receiving television programming in the form of broadcast, satellite, and/or cable TV signals. As a result, the client device 220 can selectively and/or simultaneously display network content received by the communications device 284 and television programming content received by the TV tuner 286.
The general-purpose computer 270 typically includes an input/output interface 288 to enable a wired or wireless connection to various peripheral devices 290. Examples of peripheral devices 290 include, but are not limited to, a mouse 291, a mobile phone 292, a personal digital assistant (PDA) 293, a keyboard 294, a display monitor 295 with or without a touch screen input, and/or a TV remote control 296 for receiving information from and rendering information to subscribers. Other examples may include voice recognition and synthesis devices.
Although
Referring to
The route includes links AB 310L, BD 320L, DF 325L, FG 330L, GH 335L, HI 340L, IJ 345L and JK 350L. The routing graph 300 also includes nodes A 310N, B 315N, C 320N, C1322N, D 325N, E 330N, F 335N, G 340N, H 350N, I 355N, J 360N and K 365N. The routing graph 300 also includes link BC1355L, BC 357L and ED 325L that are adjacent to the route but not included in the route. The routing graph 300 also includes a line 370L that presents a regional dividing line separating a region that includes nodes 320N to node 335N and links 310L to 327L from a different region that includes nodes 340N to 365N and links 330L to 350L. For example, the line 370L may separate one county within a state from another county.
More specifically, the process 400 begins when the mapping system receives link information for a route (step 410). In one implementation, the mapping system receives a list of links associated with a particular route and, using the list of links, the mapping system accesses link information for the links. In another implementation, the mapping system receives the link information in lieu of a list of links.
The link identifier 510 uniquely identifies a particular link to which the link information applies. The link classification 515 identifies the type of road that corresponds to the link. Examples of the type of road include a fully-controlled limited access highway, a partially-controlled limited access highway, an artery, or a local road.
The computed turn angle 520 indicates the degree of angle involved in a turn from the link to another link in the route. The computed turn angle 520, for example, may be one of a sharp left, a sharp right, a slight left, a slight right, a merge, or straight. The computed turn angle 520 may be determined based the end-node turn degree of the link and the begin-node turn degree of the next link in the route. The computed turn angle 520 may be determined based on dynamic execution of a process to determine a turn angle. The computed turn angle 520 also may be stored in relation to the route for later use.
The signed direction 525 indicates the travel direction of the road that corresponds to the link as indicated by posted signs along the road. A signed direction typically is one of north, south, east or west. Additionally or alternatively, the signed direction 525 may be stored in association with the road name (such as being stored as a suffix to the road name).
The sign information 530 indicates information about one or more exit signs that applies to the link. The sign information includes a toward-location 532 that identifies a city name or road name that occurs along the road to which the exit applies. The sign information also includes a branch-to-road 534 that identifies the road to which the exit applies and an exit number 536 for the exit. Thus, the components 532, 534 and 536 of sign information 530 describe the typical sign information that is shown by an exit sign to a limited-access road. For example, an exit sign indicating that an exit numbered 21A branches to I-95 North toward New York has sign information 530 of a toward-location 532 of “New York,” a branch-to-road 534 of “I-95North,” and an exit number 536 of “21A.” A link may include sign information 530 for more than one sign.
The road name 540 indicates the name of the road that corresponds to the link. Together, the link classification 515, the signed direction 525 and the road name 540 identify a particular road. For example, the particular road name “I-235 South” is identified using a link classification 515 of “Fully-controlled Limited Access Highway,” a signed direction 525 of “South” and a road name 540 of “235.”
The alternate road name 545 indicates an alternate name of the road when one exists. For example, a road may have both an alphabetical name (such as “Washington Avenue”) and a road number assigned by a state highway authority (such as “PA-235”) or a national highway authority (such as “Interstate-95”). In some implementations, the alternate road name may include multiple alternative road names.
The internal link indicator 550 identifies whether a link is an internal link. An internal link is a link that occurs at an intersection of doubly-digitized roads. A doubly-digitized road is a two-way road represented as two separate roads. For example, Interstate-95 may be represented as Interstate-95 North and Interstate-95 South. An internal link is described more fully below.
The ramp indicator 555 identifies whether the link corresponds to a ramp of a road.
The limited-access indicator 560 identifies whether the link corresponds to a limited-access road. In one example, an interstate highway is a fully-controlled limited-access road in which access to and from the interstate is through a highway interchange rather than a direct intersection of two roads. A highway interchange may occur with any type of highway that includes exits and ramps. In another example, a road may be a partially-controlled limited-access road when access to and from a road is sometimes controlled through a highway interchange and sometimes not so controlled.
The distance 565 indicates the distance to traverse the link. The optional time 570 identifies an average time for traversing the link. The compass direction 575 identifies the general direction of travel of a vehicle on a road that corresponds to the link. The compass direction 575 may be the same, or different from, the signed direction 525 of the link.
The link information 500 also may include other types of attributes, such as whether a link includes a fork in a road.
Referring again to
The mapping system also checks alternate road names of links to identify links that may be combined (step 425). For example, the mapping system may compare whether the road name 540 or the alternative road name 545 of one link is the same as a road name 540 or an alternate road name 545 of an adjacent link. If so, the mapping system determines whether the adjacent link involves a turn, and if not, the mapping system combines the two links, as described more fully below with respect to
The mapping system creates maneuvers from the link information (step 430). To do so, the mapping system generates maneuver information based on link information for the one or more links used to generate a particular maneuver. The maneuver information may be substantially similar to link information as described above with respect to
The mapping system combines maneuvers involved in a highway interchange into one maneuver (step 440). The combined maneuver may be referred to as an interchange maneuver. The interchange maneuver may describe entering or exiting a limited access road. The limited access road may be a fully controlled limited-access road or a partially-controlled limited-access road. The combination of maneuvers involved in a highway interchange may be accomplished by identifying maneuvers that have the same sign information 530 and then combining and/or eliminating maneuvers that have same sign information 530, as described more fully below with respect to
The mapping system eliminates redundant interchange maneuvers (step 445). This may be accomplished, for example, by eliminating an interchange maneuver when the road name or the alternate road name of the maneuver is the same as the previous maneuver, as described more fully below with respect to
The mapping system generates succinct driving direction text for the maneuvers (step 450). In some implementations, the mapping system generates text that includes the phrase “Continue to follow” and identifies a particular road name or a road number when a maneuver includes multiple road names and the maneuver includes a turn, such as a left turn or a right turn (and not a merge), or when two links that share a road name or an alternate road name have been combined to form the maneuver. One example of such succinct driving direction text is shown in succinct driving direction 613 of
In some implementations, the mapping system generates text that includes the phrase “Merge onto,” text associated with a particular road name or road number, and “via” and an exit number and/or exit information. Examples of such succinct driving direction text is shown in succinct driving directions 614 and 615 of
Optionally, the mapping system stores the succinct driving direction text (step 455). The mapping system also optionally displays the succinct driving directions (step 460). The succinct driving directions may be displayed on a client system display, such as the display 295 of
As shown in
As an example of eliminating internal links to create a maneuver, the driving maneuver 612 of
The link information 810 includes a portion of link information, such as information about links included in the link data structure 500 of
The maneuvers 820 also includes a maneuver 823 that results from combining links 327L and 330L. While these links represent different road names 540, they share a common alternate road name 545 and, accordingly, may be combined.
Each of the maneuvers 821–823 in the maneuver information 820 includes a maneuver identifier 825, a computed turn angle 830, a road name 835, an alternate road name 840 and a first maneuver indicator 845. The maneuver identifier 825 uniquely identifies a maneuver. In this example implementation, the maneuver identifier 825 identifies the links used to create the maneuver. The maneuver information also includes other information from the information, such as computed turn angle 830, road name 835 and alternate road name 840, for the links that were combined in the maneuver. Also, the maneuver information includes an indication that a particular maneuver (here, maneuver 821) is the first maneuver in the succinct driving directions for a route. As shown, the internal link 312L is combined with the first link 310L in the route to create the first maneuver 821 in the route, and the internal link 314L is combined with the link 320L to create maneuver 822.
By eliminating internal links from maneuvers in the succinct driving directions, the mapping system has created a single maneuver for the left turn at the intersection 600 and has avoided generating driving directions that include multiple maneuvers for the intersection 600.
Some implementations may use another process to eliminate internal links. For example, a mapping system of another implementation may combine links 312L and 314L into a joint internal link, which is then combined with an adjacent non-internal link (such as 320L in this example).
As noted above,
Though the road names 540 for the links 327L (“Jefferson Ave.”) and 330L (“Monroe Ave.”) do not match, the mapping system determines that the alternate road name 545 (“SR-49”) in the link 327L matches the alternate road name 545 (“SR-49”) in the link 330L. The mapping system also checks that the computed turn angle 520 of the link 330L is straight, and, since it is, the mapping system combines the links 327L and 330L to create maneuver 823 in maneuver information 820. The mapping system uses the road name 540 of the first of the links 327L and 330L being compared (here, 327L) as the road name 835 of the maneuver 823. The mapping system uses the alternate road name 545 of the link 327L as the alternate road name 840 of the maneuver 823. Using an alphabetical road name as the road name and a state road number (such as “SR-49”) as the alternate road name for the maneuver may be useful.
Other implementations may use a different process to determine a road name and an alternative road name for a maneuver. Some implementations may also cross-check the road names and alternate road names of the links being compared—that is, the road name of a particular link is compared both with the road name and the alternate road name of another link and the alternate road name of the particular link also is compared both with the road name and the alternate road name of the other link. The cross-checking of road names and alternate road names may help to reduce the number of driving maneuvers presented in the succinct driving directions.
In some implementations, the mapping system checks whether the intersection of two links that are included in the route and share a road name also includes an intersecting forward link (which is described more fully below). When the intersection of the two route links includes an intersecting forward link, the mapping system does not combine the two route links to create a single maneuver. Instead, the mapping system creates a maneuver for each of the two route links.
To determine whether an intersection of the two route links includes an intersecting forward link, the mapping system compares the computed turn angle of the turn from the first route link to the second route link with a computed turn angle of the turn from the first route link to the non-route link that intersects both route links. When the computed turn angle of the first route link to the non-route link is straight (that is, about 180 degrees) or closer to 180 degrees than the computed turn angle of the first route link and the second route link, the mapping system does not combine the two route links into a single maneuver.
Referring again to
To identify each of the maneuvers as relating to a particular interchange, the mapping system identifies consecutive maneuvers that each have a road classification 927 of “Fully-controlled Limited Access Highway” and which have the same road name 930 (here, “I-95”) and signed direction 940 (here, “South”) as each of the other maneuvers 921–923 in the particular interchange.
The mapping system checks whether the maneuvers 921–923 can be combined into a single interchange maneuver. To do so, the mapping system determines whether a portion of the signed information 950 for the maneuvers 921–923 match. Here, the signed information 950 for maneuver 921 matches one of the sign portions of the signed information 950 for maneuver 922 (here, “Toward Washington, Branch to I-95/S, Exit 11B” that is identified as “Sign 1” in maneuver 922 and identified as “Sign 2” in maneuver 921). The mapping system combines maneuver 921 and maneuver 922 using the sign information common to both maneuvers 921 and 922 (here, “Toward Washington, Branch to I-95/S, Exit 11B”). The mapping system also determines that the computed turn angle 930 of the maneuver 923 has a value of “Merge” and uses the computed turn angle 930 of maneuver 923 to combine maneuver 923 with the other maneuvers 921 and 922.
The resulting interchange maneuver 924 includes the road classification 927, the road name 921 and the signed direction 940 that is shared by maneuvers 921–923. The interchange maneuver 924 also includes the sign information 940 that is shared by maneuvers 921–922 and the computed turn angle 930 “merge” of maneuver 923.
Some implementations may check to ensure that the road name 935 and signed direction 940 of the interchange maneuver corresponds to the branch-to portion of the sign information 950 of the interchange maneuver. If not, the mapping system determines that an error has occurred in creating the interchange maneuver and does not combine the maneuvers into a single interchange maneuver.
As shown by
Although
The techniques and concepts describe processing link information to generate maneuver information and processing the generated maneuver information to generate succinct driving directions. The described techniques and concepts are not limited to being performed only on link information or maneuver information. The techniques described as being performed on link information also may be performed on maneuver information, and the techniques described as being performed on maneuver information also may be performed on link information.
Implementations may include a method or process, an apparatus or system, or computer software on a computer medium. It is intended that various modifications may be made without departing from the spirit and scope of the following claims. For example, advantageous results still could be achieved if steps of the disclosed techniques were performed in a different order and/or if components in the disclosed systems were combined in a different manner and/or replaced or supplemented by other components.
Other implementations are within the following claims.
Number | Name | Date | Kind |
---|---|---|---|
5311173 | Komura et al. | May 1994 | A |
5504482 | Schreder | Apr 1996 | A |
5508930 | Smith, Jr. | Apr 1996 | A |
5513110 | Fujita et al. | Apr 1996 | A |
5752217 | Ishizaki et al. | May 1998 | A |
5802492 | DeLorme et al. | Sep 1998 | A |
5935193 | Saiki | Aug 1999 | A |
5938720 | Tamai | Aug 1999 | A |
5948040 | DeLorme et al. | Sep 1999 | A |
6049753 | Nimura | Apr 2000 | A |
6085147 | Myers | Jul 2000 | A |
6172641 | Millington | Jan 2001 | B1 |
6282489 | Bellesfield et al. | Aug 2001 | B1 |
6338021 | Yagyu et al. | Jan 2002 | B1 |
6349261 | Ohnishi et al. | Feb 2002 | B1 |
6351707 | Ichikawa | Feb 2002 | B1 |
6356911 | Shibuya | Mar 2002 | B1 |
6363322 | Millington | Mar 2002 | B1 |
6526348 | McDonough | Feb 2003 | B1 |
6577937 | Shuman et al. | Jun 2003 | B1 |
6771189 | Yokota | Aug 2004 | B1 |
20010021895 | Yamazaki | Sep 2001 | A1 |
20010047241 | Khavakh et al. | Nov 2001 | A1 |
20020011941 | Endo et al. | Jan 2002 | A1 |
20020067728 | Okamoto | Jun 2002 | A1 |
20020077745 | Ohmura et al. | Jun 2002 | A1 |
Number | Date | Country |
---|---|---|
WO 0022593 | Apr 2000 | WO |