Systems and methods of route guidance on a user device are provided. In one aspect, a system and method transmit partitions of map data to a client device. Each map partition may contain road geometries, road names, road network topology, or any other information needed to provide turn-by-turn navigation or driving directions within the partition. Each map partition may be encoded with enough data to allow them to be stitched together to form a larger map. map partitions may be fetched along each route to be used in the event of a network outage or other loss of network connectivity. For example, if a user deviates from the original route and a network outage occurs, the map data may be assembled and a routing algorithm may be applied to the map data in order to direct the user back to the original route.
|
1. A method of generating a route to a destination comprising:
prefetching, with a processor of a user device, a first plurality of map partition data for a first area from a remote computer at a first point in time, each of the first plurality of map partition data being encoded with information for generating driving directions;
determining, at a second point in time later than the first point in time, whether the remote computer is accessible;
if the remote computer is accessible, fetching, with the processor, a second plurality of map partition data for a second area from the remote computer at the second point in time, the second plurality of map partition data being encoded with information for generating driving directions, the second area being within a predetermined distance from a current location of the user device and partially intersecting the first area;
storing the first plurality of map partition data and the second plurality of map partition data in a memory;
determining, at a third point in time later than the second point in time, whether the remote computer is accessible;
if it is determined that the remote computer is not accessible, assembling map data representing a geographic region, the map data being an assemblage of at least one of the first plurality of map partition data and the second plurality of map partition data stored in the memory; and
generating a route to a destination using the map data.
15. A non-transitory computer readable medium storing instructions executable by a computing device to perform a method of generating a route to a destination, the method comprising:
prefetching a first plurality of map partition data for a first area from a remote computer at a first point in time, each of the first plurality of map partition data being encoded with information for generating driving directions;
determining, at a second point in time later than the first point in time, whether the remote computer is accessible;
if the remote computer is accessible, fetching a second plurality of map partition data for a second area from the remote computer at the second point in time, the second plurality of map partition data being encoded with information for generating driving directions, the second area being within a predetermined distance from a current location of the user device and partially intersecting the first area;
storing the first plurality of map partition data and the second plurality of map partition data in a memory;
determining, and a third point in time later than the second point in time, whether the remote computer is accessible;
if it is determined that the remote computer is not accessible, retrieving map data of the first plurality of map partition data and the second plurality of map partition data from the memory;
assembling the map data representing a geographic region; and
generating a route to a destination using the map data.
9. An apparatus comprising:
a memory capable of caching a plurality of map partition data;
a processor in communication with the memory so as to process the plurality of map partition data in accordance with instructions; and
a display in communication with, and displaying information received from, the processor;
the instructions comprising:
prefetching a first plurality of map partition data for a first area from a remote computer at a first point in time, each of the first plurality of map partition data being encoded with information for generating driving directions;
determining, at a second point in time later than the first point in time, whether the remote computer is accessible;
if the remote computer is accessible, fetching a second plurality of map partition data for a second area from the remote computer at the second point, the second plurality of map partition data being encoded with information for generating driving directions, the second area being within a predetermined distance from a current location of the apparatus and partially intersecting the first area;
storing the first plurality of map partition data and the second plurality of map partition data in a memory;
determining, at a third point in time later than the second point in time, whether the remote computer is accessible;
if it is determined that the remote computer is not accessible, retrieving map data of the first plurality of map partition data and the second plurality of map partition data from the memory;
assembling the map data representing a geographic region; and
generating a route to a destination using the map data.
2. The method of
3. The method of
4. The method of
5. The method of
6. The method of
7. The method of
10. The apparatus of
11. The apparatus of
12. The apparatus of
13. The apparatus of
14. The apparatus of
16. The non-transitory computer readable medium of
17. The non-transitory computer readable medium of
18. The non-transitory computer readable medium of
19. The non-transitory computer readable medium of
20. The non-transitory computer readable medium of
|
The present application is a continuation of U.S. patent application Ser. No. 13/313,628, filed Dec. 7, 2011 which claims the benefit of the filing date of U.S. Provisional Patent Application No. 61/420,515 filed Dec. 7, 2010, the disclosure of which is hereby incorporated herein by reference.
1. Field of the Invention
The present application relates generally to navigation systems.
2. Description of Related Art
With the advent of portable electronic devices, navigation systems are now more commonplace with many users worldwide. Portable electronic devices (“client devices”) such as mobile telephones, PDAs and laptop/palmtop computers may be used while in transit to a specific destination. Navigation servers typically receive requests from a client device for directions to a destination, generate routes by applying routing algorithms to map data, and subsequently provide the route to the client device. Client devices are also capable of storing map data and routing algorithms locally, allowing them to generate routes without the assistance of a navigation server.
The map data generally contains information regarding the locations of streets, connections between streets, and the costs of transitioning between them. The map data may be modeled as a set of data objects (“segments”) connected by links (“arcs”) known as a graph. In a graph data model, each segment represents a street while the arcs represent a transition to the next street. Many popular routing algorithms, such as Dijkstra's algorithm, are designed to operate within the graph model. By using conventional graph theory concepts, routing algorithms attempt to calculate the best route based on metrics (e.g., distance, time, etc.).
After determining a route, navigation servers return the route to the requesting client device, whereupon a map image of the route is then rendered on the client device screen. If a user deviates from the original route, the client device may make an additional route request to the navigation server in order to generate a new route based on the current location. In the event of a network outage, however, the client device might have no access to the map data and routing algorithms on the navigation server.
For systems that download map data, the systems may permit users to regularly download new map data to avoid generating routes based on outdated information.
In one aspect, a system and method is provided that allows a client device to generate routing information using up to date map data.
In another aspect, a method of route guidance for mapping on a user device is provided that may prefetch a plurality of map partition data from a remote computer, each of the plurality of map partition data being encoded with information for generating driving directions. The plurality of map partition data may then be stored in a memory, and it may be determined whether the remote computer is accessible. The plurality of map partition data may be retrieved from the memory, if it is determined that the remote computer is not accessible. The map data representing a geographic region may be assembled, the map data being an assemblage of the plurality of map partition data. A best route may then be generated to a destination using the map data.
A further aspect provides an apparatus comprising a memory storing at least one module, the memory having a cache memory enabled to store a plurality of map partition data. A processor may be in communication with the memory so as to process the plurality of map partition data in accordance with instructions of the at least one module. The apparatus may also include a display in communication with, and displaying information received from, the processor. The at least one module may have instructions to prefetch a plurality of map partition data from a remote computer, each of the plurality of map partition data being encoded with information for generating driving directions; to store the plurality of map partition data in a memory; to determine whether the remote computer is accessible; to retrieve the plurality of map partition data from the memory, if it is determined that the remote computer is not accessible; to assemble map data representing a geographic region, the map data being an assemblage of the plurality of map partition data; and, to generate a best route to a destination using the map data.
In yet another aspect, a method for supplying map data is provided that may generate a best route to a first destination. A request from a client device for a plurality of map partition data may be received, the map partition data may be portions of the map data representing a geographic region. The map data may also be operable for route generation toward a second destination. The plurality of map partition data may then be retrieved. Next, the plurality of map partition data may be transmitted to the client device.
In a further aspect, a system is provided that comprises a server, a memory storing at least one module and a plurality of map partition data, and a processor in communication with the memory so as to process the plurality of map partition data in accordance with instructions in the at least one module. The at least one module may have instructions to generate a best route to a first destination; to receive a request from a client device for a plurality of map partition data that are portions of the map data representing a geographic region, the map data being operable for route generation toward a second destination; to retrieve the plurality of map partition data; and to transmit the plurality of map partition data to the client device.
In yet another aspect, a method of displaying a route on a device is provided that transmits a start location and a destination location to a first computer over a network, the first computer may have access to data identifying a first set of road locations. A second set of road locations selected from a subset of the first set may be received over the network from the first computer, wherein the second set of road locations contains a first route comprising a contiguous series of road locations between the start location and the destination location, and further contains additional road locations that are within a geographic region proximate to the first route. A second route of contiguous road locations may be determined based on the road locations contained in the second set when data identifying a current location of the device indicates that the current location of the device is different than the road locations in the first route, wherein the second route is determined when the device is unable to receive the identification of road locations from the first computer. Next, the second route may be displayed on a display.
In a further aspect, a system of displaying a route on a device is provided comprising a memory storing at least one module, a processor in communication with the memory, and a display in communication with, and displaying information received from, the processor. The at least one module having instructions that instruct the processor to transmit a start location and a destination location to a first computer over a network, the first computer having access to data identifying a first set of road locations; to receive, over the network and from the first computer, a second set of road locations selected from a subset of the first set, wherein the second set of road locations contains a first route comprising a contiguous series of road locations between the start location and the destination location, and further contains additional road locations that are within a geographic region proximate to the first route; to determine a second route of contiguous road locations based on the road locations contained in the second set when data identifying a current location of the device indicates that the current location of the device is different than the road locations in the first route, wherein the second route is determined when the device is unable to receive the identification of road locations from the first computer; and to display the second route on a display.
In another aspect, a method for supplying road data may be provided that receives a start location and a destination location from a first computer over a network, and that transmits, to the first computer, a second set of road locations selected from a subset of the first set, wherein the second set of road locations contains a first route comprising a contiguous series of road locations between the start location and the destination location, and further contains additional road locations that are within a geographic region proximate to the first route.
In one aspect, partitioned map data is transmitted to a client device or a user device. Each map partition may contain road data, such as road geometries, road names, road network topology, or any other information needed to provide driving directions within the partition. Each map partition may be encoded with enough data to allow the partitions to be stitched together to form a larger map. Map partitions may be fetched along each route to be used in the event that the navigation server is not accessible. For example, if a user deviates from the original route and a network outage occurs, the map data may be assembled and a routing algorithm may be applied to the map data in order to direct the user back to the original route.
As shown in
Memories 220 and 162 may store instructions and programs that are executable by processors 210 and 151, including map exporter module 240, prefetcher module 153, and local map router module 154. Memories 220 and 162 may also include data that may be retrieved, manipulated or stored by processors 210 and 151, such as raw map data 272 of routing server 120 and map image tiles 271 of image tile server 110. The memories 220 and 162 may be of any type capable of storing information accessible by processors 210 and 151, such as a hard-drive, memory card, RAM, DVD, CD-ROM, and write-capable memories. The processors 210 and 151 may be any well-known processor, such as processors from Intel Corporation or Advanced Micro Devices. Alternatively, the processors may be dedicated controllers such as an ASIC.
The map exporter module 240 may be any set of instructions to be executed directly (such as machine code) or indirectly (such as scripts) by the processor. Similarly, prefetcher module 153 and local map router module 154 may also be any set of instructions to be executed directly or indirectly by the processor. In that regard, the terms “instructions,” “steps” and “programs” may be used interchangeably herein. The instructions may be stored in object code format for direct processing by the processor, or in any other computer language including scripts or collections of independent source code modules that are interpreted on demand or compiled in advance. Functions, methods and routines of the instructions are explained in more detail below.
Although
Routing server 120 may also comprise a plurality of computers, such as a load balancing network, that exchange information with different nodes of a network for the purpose of receiving, processing and transmitting map data to multiple client devices. In this instance, the client devices will typically still be at different nodes of the network than any of the computers comprising routing server 120.
In one aspect, routing server 120 communicates with one or more client computers 150, 170 as shown in
Although the client computers 150 and 170 may comprise laptop computers, the system and method may also be used in connection with mobile devices capable of wirelessly exchanging data with a server over a network such as the Internet. For example, client computer 170 may be a wireless-enabled PDA or an Internet-capable cellular phone. In either regard, the user may input information using a keypad (in the case of a typical cell phone), a touch screen (in the case of a PDA) or any other means of user input.
Client computers 150 and 170 may include a component to determine the geographic location of the device. For example, mobile device 170 may include a GPS receiver 155. By way of further example, the component may include software for determining the position of the device based on other signals received at the mobile device 170, such as signals received at a cell phone's antenna from one or more cell phone towers if the mobile device is a cell phone.
The image tile server 110, routing server 120, and client computers 150 and 170 are capable of direct and indirect communication with each other, such as over a network 295. Although only a few computers are depicted in
Raw map data 272 may be retrieved, stored or modified by processors 210 and 151 in accordance with the instructions in map exporter module 240 and prefetcher module 153, and local map router module 154. Although the system and method is not limited by any particular data structure, its data may be stored in computer registers, in a relational database as a table having a plurality of different fields and records, extended markup language (“XML”) documents, or flat files. The data may also be formatted in any computer-readable format. Raw map data 272 may include road data used for generating routes.
Map database 270 of image tile server 110 desirably stores map-related information, at least a portion of which may be transmitted to a client device. For example, map database 270 may store map image tiles 271, where each tile is a map image of a particular geographic area. Depending on the resolution (e.g., whether the map is zoomed in or out), one tile may cover an entire region, such as a state, in relatively little detail. Another tile may cover just a few streets in high detail. The map information is not limited to any particular format. For example, the images may comprise street maps, satellite images, or a combination of these, and may be stored as vectors (particularly with respect to street maps) or bitmaps (particularly with respect to satellite images). The various map tiles are each associated with geographical locations, such that the image tile server 110 is capable of selecting, retrieving and transmitting one or more tiles in response to receipt of a geographical location. Map tile locations may be expressed as tile coordinates or other data capable of identifying a geographic area.
Map database 280 contained in data 230 of routing server 120 may store raw map data 272 made up of map partitions of road data covering one or more geographic areas. For example, each map partition may represent a particular neighborhood, city, state, country, etc. As will be explained in further detail below, each map partition may be assembled or stitched to other map partitions. Stitching the multiple map partitions may form a larger map representation. Map locations may be expressed as latitude/longitude positions or other data capable of identifying one or more geographic locations. In one example, map partitions 273 may be transmitted to a client device in a wire format, such as XML. Each map partition 273 may cover an area equal to a respective map image tile 271 and may also cover the same zoom level as the respective map image tile. Across zoom levels, 100 times the covered area may be cached in the same amount of space in contrast to a system which relies on ongoing or continuous access to a map server. In one example, caching may be automatic, for instance activating a prefetching or other caching process when the user's device has WiFi or other network access.
Returning to
The zoom level of each map partition 273 and its corresponding image tile 271 may be scaled in a variety of ways. For example, a zoom level of 0 may display the entire planet while a zoom level of 21 may display individual buildings. The precached map data and corresponding image data may be set to different zoom levels. The chosen zoom level may be based on whether a strong network connection exists. In one example, if a strong network connection exists, a higher zoom level may be cached.
Alternatively, sub-map area 422 may be cells of a spatial index. The cells may be contained in a node or index that is part of a larger hierarchy of interconnected nodes. Each level of the hierarchy may represent a different zoom level. The higher the zoom level, the larger the number of cells in the node and the smaller the size of each cell. The level of the spatial index node may coincide with the zoom level of the sub-map data. The cells covered by the desired sub-map area may be precached by prefetcher module 153.
The prefetcher module 153 may cache appropriate cells of particular nodes at different levels and allow the local map router module 154 to provide more flexible routes. For example, routes through smaller corridors may be generated. In this case, while it may be appropriate in certain circumstances to cache various contiguous areas of map data sufficient for both map rendering and offline routing, not all contiguous portions of the map may need to be cached with the same granularity. While cached regions may be identified by latitude, longitude and radius, a cell-type spatial index may also be used. Thus, if a user commutes from City A to City B, a smaller corridor of cells may be cached for the roads along the route, whereas larger regions may be cached at the starting and destination points. In this case, one vector zoom level may be cached to provide sufficient detail to the user, and depending on network connectivity, one or more additional zoom levels may be fetched for more detailed data.
Sub-map data 600A shows segments 606-609 representing “Tuttle Parkway,” “Mountain Avenue,” “Gifford Avenue,” and “Sip Avenue,” respectfully. Three arcs 606.1-606.3 are shown projecting from segment 606. In particular, segment 606 is connected to segment 607 via arc 606.1, segment 608 via arc 606.2, and segment 609 via arc 606.3.
Prefetcher module 153 may send a request to map exporter module 240 of routing server 120. Prefetcher module 153 may retrieve the map partitions 273 from routing server 120 based on the requested location. The requested location may lie within predetermined sub-map area 422. In one example, the prefetcher module 153 sends the request using a set of latitude/longitude coordinates lying within sub-map area 422. The latitude/longitude coordinates may be used to query map data from map exporter module 240 of routing server 120. Other formats for storing position data may also be used. For example, rather than being associated with absolute values such as latitude/longitude, the values may be relative and in any scale. Once the partitions are retrieved from map exporter module 240, prefetcher module 153 may store the map partitions 273 in cache memory 164 of client 150 for use in the event of a network outage or other loss of connectivity.
If client 150 is unable to communicate over the network, the processor may begin execution of local map router module 154 of client 150. Local map router module 154 may read the map partitions 273 stored in cache memory 164 and begin assembling a map. As stated in the earlier example, map partitions 273 may lie within sub-map area 422, which may be within a predetermined radius around the user. Alternatively, sub-map area 422 may be the entire city or state in which the user is traveling. By way of example, prefetcher module 153 may make map data requests every mile, every city, or every state or province. If a user crosses the border into a new state, prefetcher module 153 may delete map partitions 273 from the cache and request map data for the new state. Prefetcher module 153 may also request map data, such as all streets that are within a certain distance off of the route, or all streets that intersect the route at a point that is within a certain distance from the device's current location. Thus, cache memory 164 may maintain the most up to date map data available to the client 150.
Once local map router module 154 calculates the best route back to the original route, client device 150 may render an image of the best route on display 160, as shown in
The range encompassing precached segments may be expanded in areas known for weak network connectivity. Prefetcher module 153 may also request select areas along the route. For example, prefetcher module 153 may select sub-map area 1009 and 1008 only. Prefetcher module 153 may also select an area around the destination 421.
Prefetcher module 153 may be configured to automatically precache geographic areas a user is most likely to visit based on the user's travel history, search history, personal profile, calendar entries or other resource. The automatic precaching can be triggered when a user device is turned on and is in an area with network (e.g., WiFi) access. Automatic precaching may be enabled depending upon the type of network access available. Thus, when a free network is available, such as a WiFi network, the prefetcher module 153 may perform automatic prefetching. In another example, if a non-free network is available, automatic precaching may not be performed or user authorization may be required before incurring a charge.
The system and method may further require the user to consent to precaching various types of the geographic information before the information is transmitted to or stored by the client, and may further encrypt the precached data during the process of transmission and storage. Precached data may also be deleted automatically or manually upon request by a user.
In one example, a protocol may be defined to prefetch the user's most important N geographic areas (e.g., recently viewed places, frequently visited places, user's home town, or area of work). Each geographic location may be prefetched and stored in cache or permanently stored in some other storage area and loaded into cache at start up. This allows the cached map data to be personalized for a particular user. The precached map data may be automatically updated depending on relevant user events (e.g., moving to a new address, getting a new work address, changing travel habits, etc.). The N places may contain one or more pieces of information, such as name of the place, address, telephone number, latitude/longitude, type (e.g., starred or other type of point of interest), or another identifier.
In another aspect, a user may select the geographic locations for precaching. For example, a user may select an area the user plans to visit. The cache size may be set to a default or may be configurable by a user. A user may select these geographic areas directly on a mobile user device or may select them on a personal computer and synchronize the selected sub-map areas with the sub-map areas stored in the mobile device's cache. A user interface may show a list of places a user has explicitly cached. The list may show download progress for the caching of map data. The user interface may also allow for downloaded maps to be deleted. In one alternative, maps of user-specified places will always be kept, whereas maps of automatically determined places may be cached and deleted based upon usage.
In an alternative, other areas may be precached depending up different criteria. For instance, one or more points of interest may be cached at a very high level of detail, whereas other places may be cached at a very low detail level. In the former case, the user is more likely to want to view maps of those areas relatively frequently, and caching at a high level of detail ensures that detailed maps of the points of interest (e.g., starred or highly ranked places) are available even when network access is limited or nonexistent. In the latter case, this can be used to provide some basic map information to the user at any time.
In addition to the operations illustrated in the previous figures, various operations will now be described. It should be understood that the foregoing or following operations do not have to be performed in the precise order described below. Rather, various steps can be handled in reverse order or simultaneously. Other operations may be added or removed from these procedures.
In block 1306, upon receipt of the other subset of the raw map data 272, processor 151 of client 150 may store the other subset in cache. In block 1306, the processor 151 of client 150 may determine whether the client 150 has deviated from the contiguous series of roads of the route. If it is determined that the client device 150 has deviated, the processor 151 may advance to block 1308 to determine if the server 120 is accessible so that the processor 151 may transmit an additional request for a route. If the server 120 is not available, the processor 151 may advance to block 1310 and generate a new route to another destination location based on the plurality of other roads contained in the other subset of the raw map data 272. The other destination may be the same as the originally generated destination or the other destination may be different than the originally generated destination. If the server 120 is available, the processor 151 may request server 120 to generate the second route in block 1309. The processor 151 of client 150 may then display the second route on a display in block 1311.
While various references have been made to certain modules, namely, map exporter module 240, prefetcher module 153, and local map router module 154, any number of different modules may be used and run on a client and/or a server. The modules discussed are merely illustrative and different aspects of the system and method may use different modules.
In a further example, offline re-routes back to the route the user is following may also be generated to provide turn-by-turn guidance in the absence of a network connection. When a long route is requested when the client device has network access, the return trip may also be fetched, and together with offline rerouting allows navigating home in the absence of a network connection.
In yet another example, requests for tiles to be downloaded (for user-specified places) and requests for tiles to be cached (for automatically determined places) may be distinguishable from ordinary on-demand map tile requests. This can be used for both logging analysis and to enabling the server to deny a cache request when it is not allowed. In order to avoid having to download tiles that have already been fetched for display, a list of tiles are already in the request may be maintained.
As these and other variations and combinations of the features discussed above can be utilized without departing from the systems and methods as defined by the claims, the foregoing description of exemplary embodiments should be taken by way of illustration rather than by way of limitation of the subject matter defined by the claims. It will also be understood that the provision of examples (as well as clauses phrased as “such as,” “e.g.”, “including” and the like) should not be interpreted as limiting the claimed subject matter to the specific examples; rather, the examples are intended to illustrate only some of many possible aspects. Unless expressly stated to the contrary, every feature in a given embodiment, alternative or example may be used in any other embodiment, alternative or example herein.
Miller, Andrew Tesch, Ito, Keith, Siliski, Michael, Kalai, Iljya, Ulanov, Andrey Yuryevich
Patent | Priority | Assignee | Title |
10650621, | Sep 13 2016 | RPX Corporation | Interfacing with a vehicular controller area network |
11232655, | Sep 13 2016 | ioCurrents, Inc. | System and method for interfacing with a vehicular controller area network |
11978160, | Jul 13 2021 | GPU-based digital map tile generation method and system |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Dec 02 2011 | ITO, KEITH | Google Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 037295 | /0071 | |
Dec 05 2011 | ULANOV, ANDREY YURYEVICH | Google Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 037295 | /0071 | |
Dec 05 2011 | MILLER, ANDREW TESCH | Google Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 037295 | /0071 | |
Dec 07 2011 | SILISKI, MICHAEL | Google Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 037295 | /0071 | |
Jan 10 2012 | KALAI, ILJYA | Google Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 037295 | /0071 | |
Dec 14 2015 | Google Inc. | (assignment on the face of the patent) | / | |||
Sep 29 2017 | Google Inc | GOOGLE LLC | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 044566 | /0657 |
Date | Maintenance Fee Events |
Feb 03 2020 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Feb 02 2024 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Date | Maintenance Schedule |
Aug 02 2019 | 4 years fee payment window open |
Feb 02 2020 | 6 months grace period start (w surcharge) |
Aug 02 2020 | patent expiry (for year 4) |
Aug 02 2022 | 2 years to revive unintentionally abandoned end. (for year 4) |
Aug 02 2023 | 8 years fee payment window open |
Feb 02 2024 | 6 months grace period start (w surcharge) |
Aug 02 2024 | patent expiry (for year 8) |
Aug 02 2026 | 2 years to revive unintentionally abandoned end. (for year 8) |
Aug 02 2027 | 12 years fee payment window open |
Feb 02 2028 | 6 months grace period start (w surcharge) |
Aug 02 2028 | patent expiry (for year 12) |
Aug 02 2030 | 2 years to revive unintentionally abandoned end. (for year 12) |