WO2009006427A1 - System and method for accessing, viewing, editing and converting digital map information - Google Patents

System and method for accessing, viewing, editing and converting digital map information Download PDF

Info

Publication number
WO2009006427A1
WO2009006427A1 PCT/US2008/068829 US2008068829W WO2009006427A1 WO 2009006427 A1 WO2009006427 A1 WO 2009006427A1 US 2008068829 W US2008068829 W US 2008068829W WO 2009006427 A1 WO2009006427 A1 WO 2009006427A1
Authority
WO
WIPO (PCT)
Prior art keywords
map
format
data
digital
display
Prior art date
Application number
PCT/US2008/068829
Other languages
French (fr)
Inventor
Gil Fuchs
Darrell L. Mathis
Original Assignee
Tele Atlas North America, Inc.
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from US12/163,816 external-priority patent/US20090015595A1/en
Priority claimed from US12/163,824 external-priority patent/US20090015596A1/en
Priority claimed from US12/163,840 external-priority patent/US20090006480A1/en
Priority claimed from US12/163,833 external-priority patent/US20090013273A1/en
Application filed by Tele Atlas North America, Inc. filed Critical Tele Atlas North America, Inc.
Publication of WO2009006427A1 publication Critical patent/WO2009006427A1/en

Links

Classifications

    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09BEDUCATIONAL OR DEMONSTRATION APPLIANCES; APPLIANCES FOR TEACHING, OR COMMUNICATING WITH, THE BLIND, DEAF OR MUTE; MODELS; PLANETARIA; GLOBES; MAPS; DIAGRAMS
    • G09B29/00Maps; Plans; Charts; Diagrams, e.g. route diagram
    • G09B29/10Map spot or coordinate position indicators; Map reading aids
    • G09B29/106Map spot or coordinate position indicators; Map reading aids using electronic means

Definitions

  • the invention is related to systems for displaying, editing and using digital maps, and particularly to a system and method for converting digitai map information, and generating digital map information from digital map displays.
  • Digital maps are often also used in commercial environments, for example in calculating optimized routes for delivery drivers to take when performing deliveries, or for providing accurate directions for emergency and medical crews to follow when responding to emergency calls.
  • the digital map industry has also supplied maps to the military for use in military applications.
  • Digital maps find a use in all aspects of commercial enterprise, including for ground-based, maritime, and aviation purposes.
  • PDA Personal Digital Assistant
  • Figure 1 shows a typical example of how a digital map is used by a software application to provide map and direction information to an operator.
  • a display screen 100 under control of the operator or user can be used to display a graphical window 102, and thereon a digital version of the map 104, i.e. a digital map.
  • the operator may select any object or item within the map to find out information that item.
  • a second window 106 can be used to provide map or object information, information about the map and the items contained therein can be used to provide, for example, driving directions 108 to the operator from a first location to a second location.
  • GDF Geographic Data Fiie
  • Mavteq Mavteq, inc.
  • the GDF format is particulariy useful for transferring map data between two or more systems. Since collecting the original map data is very time consuming, and must be performed to high accuracy of the data, it is sometimes desirable to be able to convert the data from one map format to another map format, so that the data need not be collected multiple times. Similarly it is sometimes desirable to make map data available in new formats that may be better suited for use in new applications.
  • a system and method for converting digital map information using displayable map information as an intermediary is generaily related to systems for accessing, displaying, editing and using digitai maps.
  • the system can receive data into the viewer application in a first map format and then provide or output that data in a second map format
  • Different map formats can be interpreted and/or optionaiiy dispiayed in a universal display format.
  • the universal display format can include item coordinates, or higher level descriptions of geometry and topology in the map.
  • a map format legend associated with a particuiar map format can then be used to interpret the universal display format, and output the data into that map format.
  • a plurality of different map legends can be used to allow different map formats to be output, in this manner the system allows for easy and universal converting of map formats, [0008]
  • An embodiment of the present invention is generally related to systems for displaying, editing and using digital maps.
  • the system includes a viewer application together with a data abstraction iayer and a plurality of different data abstraction interfaces.
  • the data abstraction tayer can be used to atiow different map formats to be parsed and viewed. This aiiows the system to receive data in any of a variety of different input map formats.
  • the map can then be edited, viewed, displayed on a display screen, or output.
  • the map can also be used to create or display a map in a universal display format that is independent of the originai format.
  • a system and method for using layers and grids to access, view, edit and store digital map data is generally related to systems for displaying, editing and using digital maps.
  • the system assists in previewing and outputting data to different map formats.
  • Some maps include multiple I ⁇ v ⁇ ts of tiled map information.
  • the map can be displayed on a display screen in a universal display format that is independent of the original format, and can then be parsed using a map legend.
  • Features are provided to allow output of different types or sets of map data based on the currently displayed map.
  • a system and method for providing efficient access to digital map data is generally related to systems for accessing, displaying, editing and using digital maps.
  • each map item is not necessarily stored or encoded using a consistent byte length. Instead, to save overall storage requirements, the map items can be stored as different byte length variables.
  • the system comprises a bit stream processor that provides a staging area for efficient reading and writing of map data, and also provides security for adjoining data portions that use different byte length variables.
  • An input map or map data can be read into the system, and optionally written to an output map.
  • map data is read into the system, instead of reading it directly from disk storage to the display screen, which takes time, the bit stream processor places the map data in memory and reads it from there.
  • the bit stream processor can cache the map data in the cache, and write it from there.
  • Figure 1 shows a typicai example of how a digital map is used by a software application to provide map information to an operator.
  • Figure 2 illustrates a screen display as it may be used by a user or operator to view and edit a digital map
  • Figure 3 illustrates how the operator can select from either the graphical view and from a variety of map items displayed therein, and display a text view which illustrates attributes associated with each item
  • Figure 4 iiiustrates how a semantic network can be used to provide a basis for map understanding
  • Figure 5 further illustrates how a semantic network can be used to provide a basis for map understanding.
  • Figure 6 iiiustrates a schematic of an embodiment, in which the system allows for a variety of map formats to be retrieved, manipulated, viewed, and edited by an operator or user according to the above description.
  • Figure 7 shows a screenshot of an embodiment that can be integrated or used with a viewer application to allow viewing and editing of digital maps.
  • Figure 8 iiiustrates a schematic of an embodiment, in which the system is extensible to provide support for additional map formats,
  • Figure 9 is a flowchart of a method for providing support for additional map formats.
  • Figure 10 illustrates a schematic of an embodiment which allows for a variety of map formats to be retrieved, manipulated, viewed, edited, and converted into other map formats.
  • Figure 11 illustrates a map legend cross-reference table in accordance with an embodiment
  • Figure 12 illustrates another schematic of one type of system that allows for a variety of map formats to be retrieved, manipulated, viewed, and edited.
  • Figure 13 illustrates another schematic of one type of system that allows for a variety of map formats to be retrieved, manipulated, viewed, and edited.
  • Figure 14 illustrates a flowchart that can be used with an embodiment, in which the system allows for a variety of map formats to be retrieved, manipulated, viewed, and edited by an operator or user.
  • Figure 15 illustrates a schematic of an embodiment that allows for a preview of an output digital map format, such as a PSI format map, to be compared to an input map format for use in converting between map formats.
  • an output digital map format such as a PSI format map
  • Figure 16 illustrates a schematic of another embodiment that allows for a preview of an output digital map format, such as a PSI format map, to be compared to an input map format, for use in converting between map formats.
  • an output digital map format such as a PSI format map
  • Figure 17 illustrates a flowchart that can be used with an embodiment, in which the system allows for an output digital map format, such as a PS! format map, to be compared to an input map format, for use in converting between map formats.
  • an output digital map format such as a PS! format map
  • Figure 18 shows a screenshot of an embodiment that can be integrated or used with a viewer application to allow viewing and editing of digital maps.
  • Figure 1S shows another screenshot of an embodiment that can be integrated or used with a viewer application to allow viewing anci editing of digital maps.
  • Figure 20 illustrates multiple levels and tiles of information as stored in a mufti-level map format (e.g .PSI).
  • Figure 21 shows another screenshot of an embodiment that can be integrated or used with a viewer application to allow viewing and editing of digital maps.
  • Figure 22 shows another screenshot of an embodiment that can be integrated or used with a viewer application to allow viewing and editing of digital maps.
  • Figure 23 illustrates a flowchart that can be used with an embodiment, in which the system allows for levels of a particular map formats to be retrieved, manipulated, viewed, edited, and output by an operator.
  • Figure 24 illustrates a schematic of an embodiment that allows for map data to be read, edited, and stored into the system.
  • Figures 25-28 illustrate screensnots of a viewer for displaying, previewing, and accessing levels of a multi-level digital map data.
  • Embodiments of the present invention are generally related to systems for displaying, editing and using digital maps, and particularly to systems and methods for generating digital map information from digital map displays, the use of data abstraction layers or interfaces to support multiple map formats, and tie use of grids for efficient access to map data.
  • Electronic or digital maps are nowadays provided in a variety of different map formats.
  • One exampie of these map formats is the Geographic Data File (GDF) format co- deveioped by Tele Atias, Inc. and Navfeq, Inc.
  • GDF Geographic Data File
  • the GDF format is particularly useful for transferring map data between two or more systems.
  • Another example of a digital map format is the Public Sector information (PSi) format developed by a consortium of international companies from Europe, Japan, and the United States.
  • PSi Public Sector information
  • the system includes a viewer application together with a data abstraction layer and a plurality of different data abstraction interfaces.
  • the data abstraction layer can be used to aliow different map formats (e.g. GDF or PSS) to be parsed and viewed. This allows the system to receive data in any of a variety of different input map formats.
  • the map can then be edited, viewed, displayed on a display screen, or output.
  • the map can also be used to create or display a map in a universal display format that is independent of the original format.
  • the system is able to receive data into the viewer application in a first map format (e.g. GDF) and then provide or output that data in a second map format (e.g.
  • a data abstraction layer and interfaces can be used to aliow different map formats to be displayed in a universal display format.
  • a map format legend associated with a particular map format can then be used to interpret the universal display format, and output the data into that map format
  • a plurality of different map legends can be used to aliow different map formats to be output.
  • the system allows for easy and universal converting of map formats.
  • the system aiso reduces the need for customized programming necessary to support those different formats from (M * N) converters to IVH-N converters (where IVi and N are the numbers of different input formats and different output formats respectively).
  • techniques are provided that assist in debugging either the map data itself, or the conversion of the map data from one map format to another map format.
  • Techniques are also provided that assist in previewing and oufputting data to particular map formats, for example formats such as PSI that can include multiple levels of tiled map information. Since the map can be displayed on a display screen in a universal display format that is independent of the original format, and can then be parsed using a map legend, techniques can be used to output different types or sets of map data based on the currently displayed map, if a user modifies the map display to display a greater, or lesser, detail of resolution, then the set of map data that is output can also be varied accordingly,
  • GPS Global Positioning Systems
  • Digital maps are used both in commercial environments, for example in calculating optimized routes for delivery drivers to take when performing deliveries, or for providing accurate directions for emergency and medical crews to follow when responding to emergency calls,; and in consumer-oriented environments, for example, to provide personal direction finding in Personal Digital Assistant (PDA) and other devices,
  • PDA Personal Digital Assistant
  • map data [0041] One aspect of the increasing use of digital map data is the fact that many different formats have been developed, by many different entities, to store, share, and use the map data, in some instances or applications certain map formats are more suitable or more efficient than other map formats. Some examples of how map data can be used, and the consequences of those uses include:
  • Map formats that are most suitable for data transfer have a clearly defined specification and fields.
  • Map Storage TM Depending on the application to which the map data will be used, some formats may have less storage requirements than other formats, Map Stem Update - For a company that must regularly update its map data, the ability to quickly and easily modify map items is important.
  • Map Digitizing - Some map formats are better suited to the task of map digitization.
  • map data As will be evident from the above list, the different uses to which map data is gathered, stored, shared, and used, will have a large impact on the idea! requirements of a particular map data format, and will determine the most suitable map format for that task. It is unlikely that any single map format can simultaneously address the need of every application to which that map data could be put to use. To minimize the need to have to recreate the map data for each format, techniques that can allow a company to easily interoperate between multiple map formats are desirable.
  • embodiments of the invention can be used to provide a means such as a viewer or editor application by which an operator can view, verify, edit, and convert electronic or digital map data from one format to another.
  • a computer is used to allow the operator perform this task, by providing a mechanism by which maps of various different formats can be retrieved into the memory of the computer and on which the map viewer or map editor software application runs.
  • a primary purpose of the viewer/editor is in industrialized or commercial map development applications.
  • the system can be provided to allow operators to maintain the accuracy of map data, for example by updating the maps to reflect changes to the underlining geography, and converting maps from one map format to another for use in particular commercial applications.
  • Embodiments of the invention can also be used in everyday or consumer- oriented usage, for example integrated into portable or handheld electronic devices, or in navigation devices, where the operator wishes to access map data in a different format, or on a detailed level which is not possible using existing means,
  • the system aliows for identifying map items within an electronic or digital map when the map is retrieved into the computer.
  • map item or “item” is used to refer to any item displayed on a map, or any item included within a map but not currently displayed. For example, some items may only be items of information, such as the attributes of a location or a business, in which case those items are more properly thought of as map item information.
  • map items can be stored in the memory of a computer or other electronic device in the form of software objects.
  • Each map item, now represented as an object, may include a number of associated parameters, typically arranged as field/value pairs.
  • each map stem may include Sinks to one or more other map items.
  • OOP object oriented programming
  • this linking is typically provided by the use of pointers, wherein pointers are used to Sink related objects together. Since the map items are linked in such a manner, once a first map item is identified or selected, for exampie by the actions of an operator or by some other means, then pointers can be followed to other map items Jinked to that first map item, and so on. In this way, the operator can traverse a link of map items.
  • the system provides a means by which the attributes representing the map item are dispSayed in a textual manner.
  • some embodiments may include a text window wherein the fields of the text window correspond to the object attributes. Grouped together the f ⁇ eids comprise a "record".
  • Each map item or item of information can be represented by an object in memory; while each object in memory includes a number of attributes.
  • Figure 2 iilustrates a screen dispSay as it may be used by a user or operator to view and edit a digital map. As shown in Figure 2, in a typical implementation, the graphica!
  • a graphicai view window 202 on the operator's display screen or display 200, together with the map items that comprise the graphica! view.
  • the operator may at any time open a text window for displaying a text view of map items.
  • the text window 210 opens automaticaiiy when a map item is selected.
  • the text view window is updated 212 to display the record associated with that map item.
  • the text view is automatically updated, so that at any point in time the operator can see visibly both from the graphica!
  • FIG. 3 illustrates how the operator can select from either the graphica! view and from a variety of map items displayed therein, and display a text view which illustrates linkages between the map items and other attributes associated with each item. Conversely, the operator can select a record item from the text view and allow the graphical view to be automatically updated to focus on that view.
  • Figure 3 illustrates a typical digital or exemplary graphicai view 202, in which a map 204 of an area is shown.
  • a Park A 230 is bordered by a number of streets, in this example indicated as street A 220, street B 224, and street C 228.
  • the map shown in Figure 3 is very simple, and not entirely typical of the type of compiicated maps that may typically be used: however, it is shown here for ease of illustration.
  • a text view window 210 is displayed, typicaiiy in the operators screen although in some instances could be displayed on a remote screen.
  • the text view displays a record associated with a particular map item. For each map item there is at ieast one corresponding record. When both the graphica!
  • the operator can. as an initial step, select any item that is visible within the graphica! view, in this instance street A, and allow the system to display the attributes and fields (i.e., the record) associated with that map item in the text view window. Seiecting a new item automatically causes the text view to change 240 to that new item.
  • the text view window displays fields (242-252) that are associated with the map item. For example, as shown in FJgure 3, street A has a record which includes name field 242 and rush-hour field 252. Additionally, any links between this map item and any other map items are shown and indicated by a visible marker 249. These semantic links aiiow map items to be linked according to some underlining logical reason or format.
  • Fields 248 and 250 of Figure 3 are identified as semantic links indicating that they link to other map items, in this case street B and street C respectiveiy.
  • the iogic or format of linking is defined by the person responsible for the map format.
  • the format and thus the linking may depend on whether the map format is in GDF or PSI format, or in some other proprietary or nonproprietary format. Because the original map format developer defines what they perceive to be important links or associations within that map format, the system can make use of the underlying map format to determine which links it should display within the text view, rather than imposing its own sense of hierarchy or format.
  • map item information that can be displayed includes information that relates a street to special street dosing times. For example, during rush hour some streets may be designated as one-way streets This information is typically difficult to show on a map. and as such is similarly difficult to update or debug.
  • the special street closing information can be associated with the visible street map item.
  • the appropriate map item information record is displayed in the text view, as will the information that pertains to street closing. Often this information wiif be represented not as discrete fields but as links to a street closing information record. Selecting that item from the text view allows the operator to traverse to the relevant information, and to view, update, or debug it
  • Figure 4 and Figure S iSiusirate how a semantic network is used to provide a basis for map understanding in accordance with an embodiment
  • the semantic network 290 provides an understanding of the variety of underiying map item types.
  • the semantic network allows the system to understand that a iake item type may adjoin a street item type, or a park item type; or that a street item type may inci ⁇ de a street corner item (i.e. a junction) type, and that a building item type typically has a street address and may also be located on a corner.
  • Embodiments of the system can make use of this understanding to create relationships between actual map items, as shown by way of exampie in Figure 5.
  • the system uses its semantic understanding of the relationships between map item types to create relationships or links between the various map data elements.
  • R ⁇ iationships can be created linking map items of different type (for exampie linking a street item to a lake item), in the example shown in Figure 5, the streets named 35 th Street and A Street are linked to Great Lake by relationships 293 and 294 respectively.
  • Figure 6 illustrates a schematic of one type of system in accordance with an embodiment, in which the system allows for a variety of map formats to be retrieved.. manipulated, viewed, and edited by an operator or user according to the above description.
  • the system 404 typically inciudes a memory 418, a processor 419, and a storage or repository 420 of some sort.
  • the system further includes a display device 422 or monitor, including a graphical user interface or GUI 423 operating thereon by which the system can display digital maps and other information.
  • the system may interpret it in a number of ways.
  • the map format is known, for example the map is in a GDF format 408 or some other ISO standard format, then the system may use a format semantic definition file 414 incorporated within the logic of the system, which is used to interpret the map format.
  • the semantic definition file can be used by the system to interpret the hierarchy of objects within the map, and relationships between those objects.
  • map format is a proprietary format 412
  • additional semantic definition files, or hard coding 416 can be used within the logic of the system to interpret the underlining map format and convert it to a semantic linkage of objects in memory, which are then interpreted by the system and used to provide features such as the parallel traversal mechanism and the actual map display,
  • an important feature of the system is its ability to work with a variety of present and future map formats. Because the system may manipulate different semantic definition files, it can be customized to work with many formats simultaneously.
  • Figure 7 shows a scr ⁇ enshot 421 of an embodiment which can be integrated or used within a viewer or other application to allow access, viewing, editing, or conversion of digital maps.
  • the map viewing feature can also be integrated into, or used with, new or existing map viewer/editor applications.
  • GDF Geographic Data File
  • PSI PSI formats
  • the system includes a data abstraction layer (DAL) and/or a plurality of different data abstraction interfaces.
  • the data abstraction layer can be used to allow different map formats (e.g. GDF, PSI) to be parsed and viewed. This allows the system to receive data in any of a variety of different input map formats. The map can then be displayed on a display screen to create a viewable map in a universal display format that is completely independent of the original format.
  • Figure 8 illustrates a schematic of an embodiment, in which the system is designed to be extensible and to provide support for additiona! map formats.
  • the system 404 typically again includes a memory 418, processor 419, storage 420 of some sort, display device 422, and a graphical user interface 423.
  • a grid definition file 414 can be inci ⁇ ded to provide a layering or grid functionality, which is described in further detail below.
  • a data abstraction layer 425 can be provided to abstract the map format from the semantic definition. Additional data abstraction interfaces can be plugged into the data abstraction layer to provide access to different input map formats.
  • the system can comprise a data abstraction interface for the GDF map format 427, and/or another data abstraction interface for the PSi map format 429, This aliows support for new map formats to be easily added, simply by adding a new data abstraction interface to the DAL, In those instances when the map format is a proprietary format, then additional semantic definition files or hard coding can also be provided within the logic of the system to interpret the underlying map format.
  • the data abstraction interface for that input map format together with the semantic definition file, is used to convert map items into a semantic linking of items that can be understood by the system.
  • the map is then displayed on the user interfaces as a digitai map 424.
  • the map can optionally be displayed in universal screen coordinates, which allows for additional functionality and features, also described in further detail below.
  • FIG. 9 is a flowchart of a method for providing support for additional map formats.
  • step 430 the system is initiated, and the data abstraction layer is loaded, together with any data abstraction interfaces, in step 432, additional data abstraction interfaces can be added or "plugged in” as necessary to support additional map formats,
  • step 434 the digital map, or map information, is received in an input format.
  • step 436 the system recognizes the input format and users the corresponding data abstraction interface to retrieve the map items.
  • the system uses the semantic definition file to determine any linking between the map items, and convert the map data to a universal display format.
  • step 440 the digital map is displayed on the display screen or user interface.
  • the system supports the PSi digital map format.
  • the PSI format uses levels and tiles of map information, and is particularly suited for run-time access from local media (hard drive, CD, DVD, flash ROM), including storage and access on-board a vehicle or automobile.
  • the PSi format is also designed to be particularly suitable for incremental data updates. For example, whenever there is a change in some portion of the map data, the entire map need not be changed, instead, only a tile (of some ievei or some content ⁇ need be replaced.
  • the structure of the PSI map format is described in further detail below, but generally allows map information to be divided into "building blocks", levels, or layers, each of which levels contains some subset of the iotai information of the file, for example the basic map display, routing, name information block, guidance, positioning, POi information, advanced map dispiay (e.g. 3D imagery), and updated infrastructure, in accordance with an embodiment, the content of the PSi format is tiled into a p ⁇ uraiity of levels, with the highest number level being the most detailed ievei with as much content and shape as is possible within that particuiar map (i.e. it is logicaily at the lowest level of the map hierarchy).
  • the iowest-numbered level has iess detaii and is at the top of the hierarchy.
  • Each level inciudes tiles of information that comprise the ievei, so that for example, Resolution decreases, but totai area size increases, with each successively Sower ievei in the map, in this manner, an appiication can use the i ⁇ wer ievei tiles for macroscopic mapping, and the higher ievei tiies for more detailed mapping, Furthermore, since different types of map data can be stored at the different levels, this aSiows for easier updating of those map Seveis and map data as necessary.
  • the system is abie to receive data into the viewer appiication in a first or originai map format (e.g. GDF) and then provide or output that data in a second or new map format (e.g. PSI).
  • a pluraiity of different data abstraction layers can be used to allow different map formats to be interpreted and/or optionally viewed in a universal display format.
  • dispiay format can inciude item coordinates, or higher ievei descriptions of geometry and topology in the map, in accordance with an embodiment, a map format iegend associated with a particular format can then be used to interpret the universal display format, and output the data into that output format.
  • a piurality of different map iegends can be used to aSiow different map formats to be output. In this manner the system allows for easy and universal converting of map formats.
  • the system can be used to access map formats of another type, or to convert between different map formats, for example between GDF and PSI, and other formats.
  • Figure 10 illustrates a schematic of a system that can be used with an embodiment of the invention, in which the system allows for a variety of map formats to be retrieved, manipulated, viewed, edited, and converted into other formats by an operator or user.
  • the system 404 again typically includes a memory, processor, and a storage or repository of some sort, together with a display device or monitor, including a graphical user interface or GUI operating thereon by which the system can display a digital map.
  • the system includes one or a plurality of map legends 441, 443 that can be used by the system to interpret the hierarchy of objects within a particular map format as it is displayed on the screen, and relationships between those objects.
  • a single semantic definition file can be used for several map formats.
  • separate semantic definition files can be used for different map formats, including for exampie a semantic definition file for GDF, a semantic definition file for PSI, and so on.
  • the system comprises a map legend crosstable 442 which, when combined with the map legends, aliows the system to interpret a map as it is displayed 426 on the graphical user interface, and then output 428 the map data to a new map format
  • a single map iegend can be used for several map formats.
  • separate different map legends can be used for different map formats, inciuding for example a map legend for GDF display, a map legend for PSI display, and so on.
  • Support for additional map formats can be added to the system by adding additional map legend information to an existing legend crosstable, and/or by adding additional map legends.
  • the system aliows map data of a first map format 'A" (for example a GDF format map) to be retrieved and viewed as a digital map on the display.
  • a first map format 'A for example a GDF format map
  • the system can use one or more of the map legends to interpret the map objects and display them 426 on the screen.
  • the system can then interpret 428 the displayed digita! map objects, using the map legend, to determine appropriate information for the objects that are currently displayed in the map and, and convert or save those objects into a second or output map format IV C" (for exampie a PSI map).
  • a selection of the displayed objects, or the entire map can be converted in this manner.
  • Figure 11 illustrates a map iegend crosstabie in accordance with an embodiment.
  • the legend crosstable is used to map item legend information from one map format legend (e.g. GDF), to another map format legend (e g. PSI).
  • a plurality of entries 447 in the crosstabSe link the displayable (in screen coordinates) map item types of a first format, with corresponding displayable ⁇ in screen coordinates) map item types of a second format. Additional map formats and map iegends can be added by adding to the legend crosstabie.
  • a map of one format can be easily converted to one or several other map formats.
  • a map item of one format may correspond to two or more map items in another format.
  • some map items of one format may have no corresponding map item in the other format.
  • This information can be recorded in the legend crosstabie by means of an index or pointers, together with as necessary multiple pointers, or in some instance an absent or null pointer for certain map items.
  • Figure 12 illustrates a system that can be used with an embodiment of the invention, in which the system allows for a variety of map formats to be retrieved, manipulated, viewed, and edited by an operator or user according to the above description,
  • the system first receives map data in a map format "A" (for example GDF).
  • A for example GDF
  • the system uses an input map legend and semantic definition file to determine objects in the map to clispiay.
  • the system displays the chosen level, and maintains an object tabie for the displayed map objects.
  • the system displays the map and the map objects on the screen.
  • the displayed map is in universal screen coordinates and, subject to the differences between the map legends, is independent of the underlying map data.
  • To convert the displayed map into an output format the system retrieves the map legend (or if several map legends exist then the map legend that corresponds to the output format).
  • the system applies the map legend of the output format to the displayed map, and uses it to interpret those objects that are currently displayed.
  • the system then prepares the currently displayed map objects for output, and saves the map info the desired format "C" (for example PSl).
  • the map format is of a type that displays levels of information or sequential tiling (for example the PS! format)
  • the map data can be retrieved and displayed at those different levels.
  • the map data content within the PSI format can be tiled into a plurality of levels.
  • the system allows such data to be retrieved and displayed at the desired level. That level of information (corresponding to the currently displayed map) can then be output to the desired format. This allows map a desired level of map information to be output without requiring that the entire map be converted from one format to another format. Additional information about the PSI map format is described in further detail below. It will be evident that the system described herein can provide support for other input map formats, in addition to GDF and PSI.
  • Figure 13 illustrates a system that can be used in accordance with an embodiment, in which the system allows for an input map format to be received, and a variety of map formats to be created, manipulated, yiewed, edited and output by an operator or user according to the above description.
  • an input format for example PS! or GDF
  • the system uses one of a plurality of map legends 449 to display the map data on the screen.
  • the system uses another one of the plurality of map iegends to interpret portions or the entire map as dispiayed, and to either edit the map, convert map information, or output the map or portions thereof in another or a proprietary map format.
  • FIG 14 illustrates a flowchart that can be used with an embodiment of the invention, in which the system allows for a variety of map formats to be retrieved, manipulated, viewed, and edited by an operator or user according to the above description.
  • the system in step 450 the system first receives map data in a particular map format, in step 452 the system uses a semantic definition file to determine objects in the map to display. If the map data is capable of being viewed at different levels or different degrees of information, then in step 454 the system displays the chosen ievel. In step 456 the system maintains an object fable for the displayed map objects. In step 457 the system retrieves a map legend for the input map format.
  • step 458 the system then displays the map and/or a selection of the map objects on the screen.
  • step 460 the system retrieves the map legend for the output map format, in step 462 the system applies the map legend to the displayed map and uses it, together with the legend crosstable, to interpret those objects that are currently displayed, in step 464 the system then prepares the currently displayed map objects for output, and outputs the map into the desired format.
  • the system can be used to view, edit, or debug map data, and perform conversions of map data. Techniques are also provided that assist in previewing and debugging the conversion of the map data from one map format to another format. Embodiments of the system allow for either alternately or concurrently presenting two or more digital maps in different map formats, and/or both a graphical map and textual information describing the objects or items within those maps. The system allows the user to compare the maps, and to preview conversions of maps, and to view or modify records within a map by either selecting items from a graphical map or from a text view.
  • the user can display one or more digital maps on a computer screen, and display or preview another map format or a text view on the same or a different computer screen.
  • the map window and/or text window changes to reflect the properties of the map item currently selected.
  • the operator can then navigate between map objects better from the graphical view or the text view
  • Each map object or item is associated with a particular data record that describes the properties or attributes of that item.
  • these properties may include, for example, a street name, or some relationship of this object to another object. The relationship may be.
  • the system makes use of these relationships by extracting relationship information from the map itself and displaying it to the user in the text view format so that the user can then select from this text information to easily navigate between map objects, and to make changes to the information defining or associated with those objects.
  • Modifying a text record to update an attribute associated with an object can be used to produce an immediate change in the graphical map itself.
  • the record associated with an object provides an easy mechanism by which a map editor can change object attributes, in this way the map can be viewed in a more useable manner, and can be easily and quickly updated to reflect changes in the underlying objects.
  • Figure 15 iiSustrates an embodiment that ailows a preview of an output digitai map format, such as a PSi format map. to be compared to an input map format, for use in converting between map formats. This ailows for a digital map to be previewed, converted, and debugged against an input map source. As shown in Figure 15, a digital map tn an original input format 530 is received info the system.
  • the input map format can be any format, for exampie GDF or another map format
  • the input digital map 424, together with a preview of the output map data can be displayed together or overiaid S32 on the same GUI 423 for an operator to review.
  • This provides the operator with a preview of what the output map data or digital map wii ⁇ look iike following conversion.
  • a GDF format map can be displayed on the same screen, or overiaid with, a PSi format map of the same map area.
  • PSi format map of the same map area.
  • PSI output a PS! grid can be overlaid on the original map data to reflect the grid-like layout of the PSi format, and to show the operator what the eventual output PSI map would iook like.
  • the additional map format data can be retneved, or generated from the original source using the techniques described above. Overlaying the two sets of data, or displaying the two sets in ciose proximity allows the operator to quickly review differences between the maps.
  • the operator can also retrieve a text record 210 for any map item, to make changes directly into the data record for that item If the operator wishes, they can output the converted digital map data in a target map format, for exampie PSi. In accordance with an embodiment, the operator can also edit the converted digital map data as necessary.
  • Figure 16 illustrates another embodiment that allows for a preview of an output digital map format to be compared to an input map format, for use in converting between map formats.
  • a digital map such as a PSI format map to be previewed, converted, and debugged against an input map source.
  • the original version 540 of the digital map 424, together with a preview of the output map data 541. can be displayed together or side by side on the same GUS 423 for an operator to review. This provides the operator with a preview of what the output map data or digital map wiii look like following conversion.
  • a GDF format map can be displayed on the same screen side by side with a PSl format map of the same map area.
  • a PSI grid can be overlaid on the preview to reflect the grid-like layout of the PSI format, and to show the operator what the eventual output PSI map wouid iook iike.
  • the additional map format data can be retrieved, or generated from the original source, and the operator can also retrieve a text record for any map item to make changes directly into the data record or can output the converted digital map data in a target map format, for example PSI.
  • the operator can also edit the converted digital map data as necessary.
  • FIG 17 illustrates a flowchart that can be used with an embodiment, in which the system allows for an output digital map format, such as a PSi format map, to be compared to an input map format, for use in converting between map formats.
  • an output digital map format such as a PSi format map
  • This ailows for a digital map such as a PSI format map to be previewed, converted, and debugged against an input map.
  • the system receives map data in a first map format (e.g. GDF),
  • the system receives, creates, or converts the map data into a corresponding second map format (e.g. PSI).
  • step 554 the system displays the first map and second map in user interface on display screen, either superimposed or side-by- side.
  • step 556 the system allows the operator to view, edit, and debug map data in the second map format, including optional use of text record if desired, in step 558, when the operator is satisfied with map data, the system receives a command from the operator to save the map data, In step 560, the system prepares the currently displayed map data for output, and outputs the data to the desired format (e.g. PSI).
  • desired format e.g. PSI
  • the system also allows for debugging that includes an analysis of the target format in terms of data specification, rather than data content
  • the operator can determine the extent to which the target or output map format is able to reflect the data content of the source or input map format.
  • This may include aspects such as the flexibility of the attributes within the data (for example, whether a particular type of attribute can be represented in the output, and whether the representation handles unusual cases), and the efficiency of the data representation ⁇ for example, the size and the complexity of the data output representation).
  • an input map or source data may support area features with multiple faces in its map format; however, a particular choice of output map format might only support a single face per area, thus forcing multiple area features to capture the same content.
  • An embodiment of the system can be used to visualize and detect such potential problems.
  • different map formats handle area features differently.
  • an area feature may consist of many faces. This is common in the GDF format when in feature mode: the various faces of the area are the regions enclosed by the road network that surround and sometimes bisect or intersect the area.
  • the PSI format there are three different methods of encoding an area.
  • the RELATIVE and DIFF encoding methods support the notion of multiple faces in which the list of coordinates includes flags to mark the end of a face. However, if the attribute CoordCompression is set to COMPRESS1ON_NONE, then the RELATIVE and DiFF encodings are not allowed, and an area can instead have only one face.
  • the system must either (a) ignore the area, (b) signal an error condition, or (c) generate an area feature in the output for each face of the input area feature.
  • the park area feature can be described as a composite area that is in turn comprised of smaller areas or faces.
  • Embodiments of the system can also be useful in debugging the translation process itself For example, if the output has missing or wrong attributes or geometry, then the issue may be the translation itself, rather than the data content of the source, or any restrictions imposed by the output map format.
  • Map Level and THe Features in accordance with an embodiment, techniques are provided that assist in reading, storing, and outputting data to various formats, and in particular to formats such as PSI that can include multtpie levels of tiled map information.
  • a digital map can be displayed on a display screen in a universai dispiay format that is independent of the original format
  • the digital map as displayed can then be parsed using a map legend, and techniques can be used to output different map data based on the currently viewed map display, if a user modifies the map dispiay to display a greater (or iesser) detail of resoiution, then the set of map data that is output can also be varied accordingly.
  • the system optionaiiy inciudes features for handling those map formats that include levels of information or sequential tiling (for example the PSi format).
  • Figure 18 shows a screenshot 470 of an embodiment that can be integrated or used with a viewer apptication to aiiow viewing and editing of digital maps.
  • Figure 19 shows another, close-up view 472 of the same map.
  • the displayed map is a PSl format map.
  • the PSI format is divided info "building blocks", levels, or layers, each of which ieveis contains some subset of the total information of the file; e.g., the basic map dispiay, routing, name information block, guidance, positioning, PO!
  • Figure 20 illustrates multiple levels and tiies of information as stored in a multi-level map format such as PSI.
  • the underlying digital map 480 can be represented as a piuraiity of levels 482, 484, 486.
  • the highest-numbered ievel 13 is the most defaiied ievei, with as much content and shape as is possible within that particular map, i.e. it is logically at the iowest level of the map hierarchy.
  • the lowest-numbered level 0 is at the top of the map hierarchy.
  • Each level inciudes tiles of information that comprise that ievel.
  • each Ievei 13 tile is about 2 kilometers by 2 kilometers in area; whereas a ievei 12 tile loses some resolutions and is about 5 by 5 kilometers in tile area, it wiil be evident that PSi is described here by means of example, and that other multi-level map formats, having different arrangements of levels and tiies could be used).
  • selecting a particular level from the pull- down menu dispiays the tiles corresponding to that level.
  • the system automatically hides the boundaries between the tiles
  • the boundaries between the tiies are not only used for display purposes.
  • the system can aiso allow for an input map format to be received, and a variety of map formats to be created, manipulated, viewed, edited and output by an operator or user according to the above description, including where desired portions or the entire map as displayed.
  • the system can aiso output the displayed map or portions thereof in another or a proprietary map format in accordance with an embodiment this technique is further used to interpret information from any map displayed on the screen (from any source and any original map format), and convert the information to corresponding PSI tiles (which can also be automatically clipped on tile boundaries, even across resolution differentials).
  • PSI tiles which can also be automatically clipped on tile boundaries, even across resolution differentials.
  • Figure 21 shows another screenshot 490 of an embodiment that can be integrated or used with a viewer application to allow viewing and editing of digital maps.
  • a pull- down menu can be used to display selected PSI levels, if the operator desires then the system can be used to save map features to a particular PSI Sevei. Since different map formats may use different resolutions to store and display maps, the system must take this into account when saving data to a different format. For example, in the GDF format the resolution is at most 7 decimal points for iat long pairs in degrees. In the PSl format the resolution can be more precise (in the area of sub-centimeter accuracy), in accordance with an embodiment, when the system converts map data from GDF to PSI, the system deliberately leaves "tails" on each feature.
  • FIG. 22 shows another screenshot 492 of an embodiment that can be integrated or used with a viewer application to allow viewing and editing of digital maps. As shown in Figure 22, attributes for individual map objects can be edited before outputting them (to PSi or another format). This ensures that when saved, the data more accurately matches the operator's requirements.
  • Figure 23 illustrates a flowchart that can be used with an embodiment to ailow for conversion of map data to PSI format. As shown in Figure 23 t in step 500 the system first receives map data in a particular input map format (e.g. GDF).
  • a particular input map format e.g. GDF
  • step 502 the system uses a semantic definition file to determine objects in the map to display, in step S04 the system then uses the map legend for the input map format to display the map and the map objects on the screen, in step 506 the system allows the operator to specify a particular PSI ievei to which the system should save the map data.
  • step 508 the system applies the map legend of the output format to the specified ieve! of the displayed map (or to the ievei of the map that is currently specified and displayed) and uses it to interpret those objects that are currently displayed on the screen. In this manner the operator can either display a particuSar map level, and then export or output that level.
  • step SOS the system prepares the currently displayed map objects for output, and outputs the data to the desired format (e.g. PSi).
  • desired format e.g. PSi
  • the system aiso includes features to aiiow efficient access and storage of map data. This is of particular use with some data formats, including PSi, which are designed to reduce overall data storage space in return for slightly longer access (reading and writing) times, in some map data formats each map item is not necessarily stored or encoded using a consistent byte-aligned number of bit length. For example the number of bits in a variable may not be byte-aligned such as 16, 32 or 64 bits, but could instead be 7 bits, 13 bits, or some other length. Instead, to save overaii storage requirements, the map items can be stored as different byte length variables. This necessitates additional processing during reading and writing the data.
  • a bit stream processor provides a reader and/or a writer functionality, which ailows the system to read and/or write an arbitrary number of bits at any bit position in the data stream.
  • the order of access can aiso be random.
  • Typical access to any data stream is byte oriented, so that reading or writing data normally requires the application to consider the nearby bits in the same byte being considered. For reading, this means that unwanted bits must be excluded and the remainder must be shifted to their proper position in the fina! result If the desired bits also span byte boundaries then there are additional complications in piecing together bits from multiple bytes to assemble the desired result. For writing, it is even more complicated, since the unreferenced bits in a byte must be preserved. This means bytes must be read, partially altered and written again. An additional issue is maintaining correct byte order when reading and writing values in environments in which the underlying machine byte order is different, such as big-endian and little-endian architectures, so that the same bit stream will work in ail environments.
  • the bit stream processor including a bit reader and/or writer addresses these problems by viewing the data stream as bit stream instead of a byte stream.
  • access to the stream occurs at the current bit position. After reading or writing a number of bits at the current bit position, the current position is changed to the position after the last bit that was read or written. Numeric values that are retrieved from or written to such a data stream are viewed independently of their physical context in the bit stream, in particular there is no need to be concerned about ignoring or preserang neighboring bits in physical bytes. This is handled automatically by the reader/writer as needed.
  • bit position can be set to any desired position in the bit stream, so that random access is easy.
  • reading and writing can be mixed in any desired combination. This supports easy creation of data in which some parts of the stream content are not yet known, oniy its size and position. This might occur for example if a count of the number of items needs to be recorded, but the number will depend on processing that has not yet been done. The writer can then skip over this part of the data, write other data content, and then iater return to this position in the stream and compiete or update it.
  • A1 and Am will be partial bytes where A1 contains the low order bits of B1 starting at the current bit position, and Am contains the high order bits of Bm 1 while aii other Ai wiii contain the full byte contents of the corresponding byte Bi.
  • the reader shifts the bits of each byte Bi, with appropriate masking of B1 and Bm 1 and assembles the bytes into a final numeric vaiue A.
  • the writer can engage in a similar process, except that the masked bits in B1 and 8m will be added to the biocks A1 and Am to form a complete byte, and then the bytes A1 through Am will replace B1 through Bm in the bit stream.
  • the bit reader and writer treat the data stream as a buffer in memory. This is convenient, since it allows any memory buffer to be managed by a bit stream reader or writer with virtually no overhead. Only the location and size of the buffer needs to be specified to initiaiize the reader or writer. This is also useful in a conventional database environment where binary content ts recorded as blob. Once the blob is retrieved it can be immediateiy attached to a reader and treated as a bit stream source. Conversely, when a buffer is created with a bit stream writer it can then be stored in a physical storage medium, such as a database or some other file system.
  • the bit stream reader and writer includes the ability to resize the buffer as needed, without disturbing the reader/writer state.
  • the current bit position can be retrieved and modified at any time, Reading and writing on a bit stream can foe mixed in any order,
  • FIG. 24 illustrates a schematic of an embodiment that allows for map data to be read, edited, and stored into the system.
  • the system 570 comprises a disk storage 572, memory 574, cache 576, and a bit stream processor 578.
  • the bit stream processor provides a staging area for efficient reading and writing of map data, and also provides security for adjoining data portions that use different byte length variables.
  • An input map 580 including map data can be read into the system, and optionaiiy written to an output map 581.
  • Input and output map formats include PSI and other map formats, As map data is read 583 into the system, instead of reading it directly from disk storage to the display screen, which takes time, the bit stream processor piaces the map data in memory and reads it from there.
  • the bit stream processor caches the map data in the cache, and writes it from there.
  • the bit stream processor can be used to read and write PSt format map data.
  • the PSI format requires a stream of data items or various sizes (from 1 to 32 bits) that are packed with no unused space or data alignment assumptions. This means that at a low level all data must be converted to or from a bit stream.
  • the map viewer application can inciude a PSl component which implements a bit stream reader and writer. This is used as the finai step on output to generate PSI data, and the first step on input to interpret and represent PSI data.
  • bit stream reader and writer allow the writing/reading of N bits of data to/from the memory buffer at any given bit position, without disturbing neighboring bits. Since data must be accessed in units of a byte ⁇ a minimum of 8 bits), the reader and writer must concern themselves with joining fractions of bytes of data, so that the process is invisible to the calling software.
  • bit stream is also a means of compressing the data.
  • Navigation systems that use digital maps typicaSSy have memory constraints (often moreso than processor constraints). As such a goal is often to balance memory and processor speed.
  • Formats such as the PS! format use tiles, wherein the system may not know the number of points/iines/areas generated until it is compieted (a minimalist approach). After completion it must then go back and update the tile contents at particular positions to update these numbers. If the system performs a full unpacking of a tile, then it must place all of the content into unique variables which can be accessed directly and quickly. However, this approach requires the system to accept the cost of the fully unpacked data size within memory. If large tiles or many tiles are used then this approach might not be feasible.
  • the system can choose to not unpack or store anything, except the information that is required to answer the current query. While this approach is minimal in terms of space usage, if requires r ⁇ digesting the tile bit stream every time the system must process a query that involves something in that tile. While this approach is smaller, it may also be slower.
  • the system digests the data as if is read, and 5 stores the bit locations of various "memory markers" in the bit stream. Such markers can include, for example, the start of an "Area Feature List" or the Start of a "Line Feature List", In PSi, the format aiiows the system to provide information about area features if it is known where the area feature iist starts. As such, in accordance with an embodiment the system does not then need to start digesting the bit stream from the beginning to again determine
  • the system stores not just the beginning of the areas, but also the start of each area feature, in a iist in 1-1 correspondence with the area features. Then each feature is a direct lookup into the tile data.
  • an input map 800 can be read into the viewer application.
  • the map can be tilted 802 or displayed in three dimensional view.
  • a magnifying glass 606 can be used to focus on a section of the map, or a level of map data. This can be used with the debugging features as described above to compare and debug map data.
  • the magnifying glass can be used to view levels of 5 map information, such as in a PSI or other muiti-ievei format digital map, and then edit or output that level of the map.
  • the operator can easily change the focus area 610 of the magnifying glass, to view a different portion of the map, or a different level of a multi-level map. Using this approach, different levels of map data can be accessed, viewed, edited, and stored as output.
  • the present invention includes a computer program product which is a storage medium (media) having instructions stored fhereon/in which can be used to program a computer to perform any of the processes of the present invention.
  • the storage medium can include, but is not limited to. any type of disk including floppy disks, opticas discs, DVD, 5 CD-ROMs, microdrive, and magneto-optical disks, ROMs, RAIVIs, EPROIVIs, EEPROMs, DRAMs, VRAMs, flash memory devices, magnetic or optica! cards, ⁇ anosystems (including molecular memory ICs), or any type of media or device suitable for storing instructions and/or data.
  • the present invention includes software for controlling both the hardware of the general purpose/specialized computer or microprocessor, and for enabling the computer or microprocessor to interact with a human user or other mechanism utilizing the results of the present invention.
  • Such software may include, but is not limited to, device drivers, operating systems, and user applications.
  • such computer readable media further includes software for performing the present invention, as described above, included in the programming (software) of the general/special ized computer or microprocessor are software modules for implementing the teachings of the present invention.

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Mathematical Physics (AREA)
  • Business, Economics & Management (AREA)
  • Educational Administration (AREA)
  • Educational Technology (AREA)
  • General Physics & Mathematics (AREA)
  • User Interface Of Digital Computer (AREA)
  • Processing Or Creating Images (AREA)
  • Instructional Devices (AREA)

Abstract

A system and method for accessing, viewing, editing and converting digital map information The system comprises a data abstraction layer and a plurality of different data abstraction interfaces able to receive data into the viewer application in a first map format and then provide or output that data in a second map format Different map formats can be interpreted and/or displayed in a universal display format The universal display format can include item coordinates, or higher level descriptions of geometry and topology in the map. Map legends can be used to allow different map formats to be output Some map formats can include multiple levels of tiled map information The system can comprise a bit stream processor that provides a staging area for efficient reading and writing of map data, and also provides security for adjoining data portions that use different byte length variables.

Description

SYSTEM AND METHOD FOR ACCESSING, ViEWING, EDSTIiMG AND CONVERTING DJGITAL MAP 5NFORMATfON
Inventors: Gil Fuchs
Darrell Mathis
COPYRIGHT NOTICE
A portion of the disclosure of this patent document contains material which is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure, as it appears in the Patent and Trademark Office patent file or records, but otherwise reserves aii copyright rights whatsoever.
Field of the i nvention :
[0001] The invention is related to systems for displaying, editing and using digital maps, and particularly to a system and method for converting digitai map information, and generating digital map information from digital map displays.
Background:
[0002] The use of digital geographic or map data has become commonpiace in today's modern, computerized society. Commonly referred to as electronic maps, digitai maps, digitized maps, or simply as maps, this geographic or map data can be used in a wide variety of applications. A typical application is in the travel industry, whereby digital maps are used to quickly and automatically chart travel routes, and to locate destinations. Digital maps have found a particularly common everyday use in automobiles, wherein Global Positioning Systems (GPS) are used in association with a digital map to automatically track the position of a car and display the position on a map, for instance to guide the driver to a particular destination.
[0003] Digital maps are often also used in commercial environments, for example in calculating optimized routes for delivery drivers to take when performing deliveries, or for providing accurate directions for emergency and medical crews to follow when responding to emergency calls. For many years, the digital map industry has also supplied maps to the military for use in military applications. Digital maps find a use in all aspects of commercial enterprise, including for ground-based, maritime, and aviation purposes. As people become more familiar in carrying handheld electronic and Personal Digital Assistant (PDA) devices, which are increasingly distributed together with digital maps stored therein, the electronic or digital map industry has also become familiar in consumer-oriented applications. [0004] Figure 1 shows a typical example of how a digital map is used by a software application to provide map and direction information to an operator. As shown in Figure 1, a display screen 100 under control of the operator or user can be used to display a graphical window 102, and thereon a digital version of the map 104, i.e. a digital map. The operator may select any object or item within the map to find out information that item. A second window 106 can be used to provide map or object information, information about the map and the items contained therein can be used to provide, for example, driving directions 108 to the operator from a first location to a second location.
[0005] To take advantage of the increased usage and funciionaiify of digital maps, severai different data formats or digital map formats have been developed. One exampie of these map formats is the Geographic Data Fiie (GDF) map format co-developed by Tele Atlas. Inc., Mavteq, inc., and others. The GDF format is particulariy useful for transferring map data between two or more systems. Since collecting the original map data is very time consuming, and must be performed to high accuracy of the data, it is sometimes desirable to be able to convert the data from one map format to another map format, so that the data need not be collected multiple times. Similarly it is sometimes desirable to make map data available in new formats that may be better suited for use in new applications. However, to date no current system allows for easy converting between different map formats. [0006] Furthermore, along with this increased usage and functionality of electronic maps, the need has arisen to insure that these electronic maps are provided in such a way that they are flexible enough to aSiow for changes in the geography or in the political use of the underlying geographical area. For example, in urban areas the location and usage of surface streets may change on a regular basis. At street intersections, the direction of traffic flow, traffic restrictions, or turn lanes that are in pSace one day, might the very next day be reversed, removed, or changed in some other way. An electronic map that is several years old (or in some cases even several days old) is of iesser use in such an environment, because the image the map displays, and the information it provides, is no longer reiiabiy related to the underlying geography. As such, electronic map vendors continuously seek new ways in which they can regularly update and check the accuracy of their electronic maps, and do so in an easy manner such that the map need not be created from scratch each time, but can instead be updated or derived from previous versions of the map to reflect the new geography. Such a process is akin to the debugging process famiiiar to software application developers who must strive to fix problems and errors in their underlying software code. However, traditional means of debugging map data tend to be tedious, time- consuming, and format-specific. The overall result of this is that electronic maps created and updated using tradifionai methods are relatively inflexible and pose a barrier which discourages map vendors from updating their maps on a regular basis. Summary,:
[0007] in accordance with an embodiment, disclosed herein is a system and method for converting digital map information using displayable map information as an intermediary. An embodiment of the present invention is generaily related to systems for accessing, displaying, editing and using digitai maps. The system can receive data into the viewer application in a first map format and then provide or output that data in a second map format Different map formats can be interpreted and/or optionaiiy dispiayed in a universal display format. Depending on the particular embodiment the universal display format can include item coordinates, or higher level descriptions of geometry and topology in the map. In accordance with an embodiment, a map format legend associated with a particuiar map format can then be used to interpret the universal display format, and output the data into that map format. A plurality of different map legends can be used to allow different map formats to be output, in this manner the system allows for easy and universal converting of map formats, [0008] In accordance with an embodiment, disclosed herein is a system and method for viewing and editing digital maps using plugin data abstraction layers for different digital map formats. An embodiment of the present invention is generally related to systems for displaying, editing and using digital maps. The system includes a viewer application together with a data abstraction iayer and a plurality of different data abstraction interfaces. The data abstraction tayer can be used to atiow different map formats to be parsed and viewed. This aiiows the system to receive data in any of a variety of different input map formats. The map can then be edited, viewed, displayed on a display screen, or output. The map can also be used to create or display a map in a universal display format that is independent of the originai format. [0009] in accordance with an embodiment, disclosed herein is a system and method for using layers and grids to access, view, edit and store digital map data. An embodiment of the present invention is generally related to systems for displaying, editing and using digital maps. The system assists in previewing and outputting data to different map formats. Some maps include multiple Iβvβts of tiled map information. The map can be displayed on a display screen in a universal display format that is independent of the original format, and can then be parsed using a map legend. Features are provided to allow output of different types or sets of map data based on the currently displayed map. if a user modifies the map display to dispiay a greater, or lesser, detail of resolution, then the set of map data that is output can be varied accordingly. [0010] in accordance with an embodiment, disclosed herein is a system and method for providing efficient access to digital map data. An embodiment of the present invention is generally related to systems for accessing, displaying, editing and using digital maps. In some map data formats each map item is not necessarily stored or encoded using a consistent byte length. Instead, to save overall storage requirements, the map items can be stored as different byte length variables. In accordance with an embodiment, the system comprises a bit stream processor that provides a staging area for efficient reading and writing of map data, and also provides security for adjoining data portions that use different byte length variables. An input map or map data can be read into the system, and optionally written to an output map. As map data is read into the system, instead of reading it directly from disk storage to the display screen, which takes time, the bit stream processor places the map data in memory and reads it from there. As map data is written to the system for storage or output the bit stream processor can cache the map data in the cache, and write it from there.
Description of the iJDrawincjs:
[0011] Figure 1 shows a typicai example of how a digital map is used by a software application to provide map information to an operator.
[0012] Figure 2 illustrates a screen display as it may be used by a user or operator to view and edit a digital map,
[0013] Figure 3 illustrates how the operator can select from either the graphical view and from a variety of map items displayed therein, and display a text view which illustrates attributes associated with each item,
[0014] Figure 4 iiiustrates how a semantic network can be used to provide a basis for map understanding,
[0015] Figure 5 further illustrates how a semantic network can be used to provide a basis for map understanding. [0016] Figure 6 iiiustrates a schematic of an embodiment, in which the system allows for a variety of map formats to be retrieved, manipulated, viewed, and edited by an operator or user according to the above description.
[0017] Figure 7 shows a screenshot of an embodiment that can be integrated or used with a viewer application to allow viewing and editing of digital maps. [0018] Figure 8 iiiustrates a schematic of an embodiment, in which the system is extensible to provide support for additional map formats,
[0019] Figure 9 is a flowchart of a method for providing support for additional map formats.
[0020] Figure 10 illustrates a schematic of an embodiment which allows for a variety of map formats to be retrieved, manipulated, viewed, edited, and converted into other map formats. [0021] Figure 11 illustrates a map legend cross-reference table in accordance with an embodiment
[0022] Figure 12 illustrates another schematic of one type of system that allows for a variety of map formats to be retrieved, manipulated, viewed, and edited. [0023] Figure 13 illustrates another schematic of one type of system that allows for a variety of map formats to be retrieved, manipulated, viewed, and edited.
[0024] Figure 14 illustrates a flowchart that can be used with an embodiment, in which the system allows for a variety of map formats to be retrieved, manipulated, viewed, and edited by an operator or user. [0025] Figure 15 illustrates a schematic of an embodiment that allows for a preview of an output digital map format, such as a PSI format map, to be compared to an input map format for use in converting between map formats.
[0026] Figure 16 illustrates a schematic of another embodiment that allows for a preview of an output digital map format, such as a PSI format map, to be compared to an input map format, for use in converting between map formats.
[0027] Figure 17 illustrates a flowchart that can be used with an embodiment, in which the system allows for an output digital map format, such as a PS! format map, to be compared to an input map format, for use in converting between map formats.
[0028] Figure 18 shows a screenshot of an embodiment that can be integrated or used with a viewer application to allow viewing and editing of digital maps.
[002Θ] Figure 1S shows another screenshot of an embodiment that can be integrated or used with a viewer application to allow viewing anci editing of digital maps.
[0030] Figure 20 illustrates multiple levels and tiles of information as stored in a mufti-level map format (e.g .PSI). [0031] Figure 21 shows another screenshot of an embodiment that can be integrated or used with a viewer application to allow viewing and editing of digital maps.
[0032] Figure 22 shows another screenshot of an embodiment that can be integrated or used with a viewer application to allow viewing and editing of digital maps.
[0033] Figure 23 illustrates a flowchart that can be used with an embodiment, in which the system allows for levels of a particular map formats to be retrieved, manipulated, viewed, edited, and output by an operator.
[0034] Figure 24 illustrates a schematic of an embodiment that allows for map data to be read, edited, and stored into the system.
[0035] Figures 25-28 illustrate screensnots of a viewer for displaying, previewing, and accessing levels of a multi-level digital map data. DβtaJjed.Pescriβtion:
[0036] Embodiments of the present invention are generally related to systems for displaying, editing and using digital maps, and particularly to systems and methods for generating digital map information from digital map displays, the use of data abstraction layers or interfaces to support multiple map formats, and tie use of grids for efficient access to map data. Electronic or digital maps are nowadays provided in a variety of different map formats. One exampie of these map formats is the Geographic Data File (GDF) format co- deveioped by Tele Atias, Inc. and Navfeq, Inc. The GDF format is particularly useful for transferring map data between two or more systems. Another example of a digital map format is the Public Sector information (PSi) format developed by a consortium of international companies from Europe, Japan, and the United States. Since collecting the originai map data is time consuming, and must be performed with high accuracy, it is sometimes ciesirabϊe to be able to convert the data from one map format to another map format, so that the data need not be collected multiple times. Simiiarly it is sometimes desirable to make map data available in new formats that may be better suited for use in new applications,
[0037] in accordance with an embodiment, the system includes a viewer application together with a data abstraction layer and a plurality of different data abstraction interfaces. The data abstraction layer can be used to aliow different map formats (e.g. GDF or PSS) to be parsed and viewed. This allows the system to receive data in any of a variety of different input map formats. The map can then be edited, viewed, displayed on a display screen, or output. The map can also be used to create or display a map in a universal display format that is independent of the original format. [0038] in accordance with another embodiment, the system is able to receive data into the viewer application in a first map format (e.g. GDF) and then provide or output that data in a second map format (e.g. PSI). As described above, a data abstraction layer and interfaces can be used to aliow different map formats to be displayed in a universal display format. In accordance with an embodiment, a map format legend associated with a particular map format can then be used to interpret the universal display format, and output the data into that map format A plurality of different map legends can be used to aliow different map formats to be output. In this manner the system allows for easy and universal converting of map formats. The system aiso reduces the need for customized programming necessary to support those different formats from (M*N) converters to IVH-N converters (where IVi and N are the numbers of different input formats and different output formats respectively).
[0039] In accordance with another embodiment, techniques are provided that assist in debugging either the map data itself, or the conversion of the map data from one map format to another map format. Techniques are also provided that assist in previewing and oufputting data to particular map formats, for example formats such as PSI that can include multiple levels of tiled map information. Since the map can be displayed on a display screen in a universal display format that is independent of the original format, and can then be parsed using a map legend, techniques can be used to output different types or sets of map data based on the currently displayed map, if a user modifies the map display to display a greater, or lesser, detail of resolution, then the set of map data that is output can also be varied accordingly,
D ϊQϊtat Map Viewer
[0040] As described above, the use of digital geographic or map data has become commonplace in today's modern, computerized society. A typical application of digital maps is in the travel industry, whereby digital maps are used to quickly and automatically chart travel routes, and to locate destinations. Digital maps have found a particularly common everyday use in automobiles, wherein Global Positioning Systems (GPS) are used in association with a digital map to automatically track the position of a car and display the position on a map, for instance to guide the driver to a particular destination. Digital maps are used both in commercial environments, for example in calculating optimized routes for delivery drivers to take when performing deliveries, or for providing accurate directions for emergency and medical crews to follow when responding to emergency calls,; and in consumer-oriented environments, for example, to provide personal direction finding in Personal Digital Assistant (PDA) and other devices,
[0041] One aspect of the increasing use of digital map data is the fact that many different formats have been developed, by many different entities, to store, share, and use the map data, in some instances or applications certain map formats are more suitable or more efficient than other map formats. Some examples of how map data can be used, and the consequences of those uses include:
Data Transfer - Once collected, the original map data may need to be transferred from one entity to another, including between different companies or different industry partners. Map formats that are most suitable for data transfer have a clearly defined specification and fields.
Data Access - Depending on the application to which the map data may be used, issues such as speed of access to data items may be a factor. This may be particularly important in end- user or consumer-oriented applications. Map Storage ™ Depending on the application to which the map data will be used, some formats may have less storage requirements than other formats, Map Stem Update - For a company that must regularly update its map data, the ability to quickly and easily modify map items is important.
Data Testing and Quality Control - For those companies that develop their own map databases and update map item information, a map format that can be easily debugged may be important.
Map Digitizing - Some map formats are better suited to the task of map digitization.
Data Gathering ™ Some map formats are better suited to the task of data gathering and storing data in the map itself.
[0042] As will be evident from the above list, the different uses to which map data is gathered, stored, shared, and used, will have a large impact on the idea! requirements of a particular map data format, and will determine the most suitable map format for that task. It is unlikely that any single map format can simultaneously address the need of every application to which that map data could be put to use. To minimize the need to have to recreate the map data for each format, techniques that can allow a company to easily interoperate between multiple map formats are desirable.
[0043] Generally described, embodiments of the invention can be used to provide a means such as a viewer or editor application by which an operator can view, verify, edit, and convert electronic or digital map data from one format to another. A computer is used to allow the operator perform this task, by providing a mechanism by which maps of various different formats can be retrieved into the memory of the computer and on which the map viewer or map editor software application runs. A primary purpose of the viewer/editor is in industrialized or commercial map development applications. The system can be provided to allow operators to maintain the accuracy of map data, for example by updating the maps to reflect changes to the underlining geography, and converting maps from one map format to another for use in particular commercial applications.
[0044] Embodiments of the invention can also be used in everyday or consumer- oriented usage, for example integrated into portable or handheld electronic devices, or in navigation devices, where the operator wishes to access map data in a different format, or on a detailed level which is not possible using existing means, In accordance with an embodiment the system aliows for identifying map items within an electronic or digital map when the map is retrieved into the computer. As used herein the term "map item" or "item" is used to refer to any item displayed on a map, or any item included within a map but not currently displayed. For example, some items may only be items of information, such as the attributes of a location or a business, in which case those items are more properly thought of as map item information. Once these map items have been identified, they can be stored in the memory of a computer or other electronic device in the form of software objects. Each map item, now represented as an object, may include a number of associated parameters, typically arranged as field/value pairs. Sn addition, each map stem may include Sinks to one or more other map items. In the object oriented programming (OOP) world, this linking is typically provided by the use of pointers, wherein pointers are used to Sink related objects together. Since the map items are linked in such a manner, once a first map item is identified or selected, for exampie by the actions of an operator or by some other means, then pointers can be followed to other map items Jinked to that first map item, and so on. In this way, the operator can traverse a link of map items. In some embodiments the system provides a means by which the attributes representing the map item are dispSayed in a textual manner. For example, some embodiments may include a text window wherein the fields of the text window correspond to the object attributes. Grouped together the fϊeids comprise a "record". Each map item or item of information can be represented by an object in memory; while each object in memory includes a number of attributes. [0045] Figure 2 iilustrates a screen dispSay as it may be used by a user or operator to view and edit a digital map. As shown in Figure 2, in a typical implementation, the graphica! or digital map 204 is dispiayed in a graphicai view window 202 on the operator's display screen or display 200, together with the map items that comprise the graphica! view. The operator may at any time open a text window for displaying a text view of map items. In other embodiments, the text window 210 opens automaticaiiy when a map item is selected. When the operator selects a map item from the graphica! view window, the text view window is updated 212 to display the record associated with that map item. As the operator selects different map items from the graphica! view, the text view is automatically updated, so that at any point in time the operator can see visibly both from the graphica! view window and from the text view window which object they are working with, In addition, modifications to the record in the text view window can be automatically updated 214 in the graphica! view. For example, if the operator traverses through the text view window to other map items, the graphica! view window changes to zoom in or to focus on the currently selected map item. [0046] Figure 3 illustrates how the operator can select from either the graphica! view and from a variety of map items displayed therein, and display a text view which illustrates linkages between the map items and other attributes associated with each item. Conversely, the operator can select a record item from the text view and allow the graphical view to be automatically updated to focus on that view. Figure 3 illustrates a typical digital or exemplary graphicai view 202, in which a map 204 of an area is shown. A Park A 230 is bordered by a number of streets, in this example indicated as street A 220, street B 224, and street C 228. The map shown in Figure 3 is very simple, and not entirely typical of the type of compiicated maps that may typically be used: however, it is shown here for ease of illustration. [0047] Optionally, a text view window 210 is displayed, typicaiiy in the operators screen although in some instances could be displayed on a remote screen. The text view displays a record associated with a particular map item. For each map item there is at ieast one corresponding record. When both the graphica! view and the text view are displayed, the operator can. as an initial step, select any item that is visible within the graphica! view, in this instance street A, and allow the system to display the attributes and fields (i.e., the record) associated with that map item in the text view window. Seiecting a new item automatically causes the text view to change 240 to that new item. The text view window displays fields (242-252) that are associated with the map item. For example, as shown in FJgure 3, street A has a record which includes name field 242 and rush-hour field 252. Additionally, any links between this map item and any other map items are shown and indicated by a visible marker 249. These semantic links aiiow map items to be linked according to some underlining logical reason or format. Fields 248 and 250 of Figure 3 are identified as semantic links indicating that they link to other map items, in this case street B and street C respectiveiy. Typically the iogic or format of linking is defined by the person responsible for the map format. For example, the format and thus the linking may depend on whether the map format is in GDF or PSI format, or in some other proprietary or nonproprietary format. Because the original map format developer defines what they perceive to be important links or associations within that map format, the system can make use of the underlying map format to determine which links it should display within the text view, rather than imposing its own sense of hierarchy or format.
[0048] This ensures that embodiments of the invention can be used with all map formats including current formats and those yet to be developed. For example, in the example shown in Figure 3, in the graphical view the selected street A intersects both streets 8 and C, and Park A. which in turn means the record attributes associated with this street also include links to streets A and 8. Other links may include that the intersection is associated with park A, for example, forming a corner point of the park (although these links are not shown here). This linking is created because the map format includes information about the streets and its intersection with other streets, and not because the user has guessed in any manner,
[0049] One example of map item information that can be displayed includes information that relates a street to special street dosing times. For example, during rush hour some streets may be designated as one-way streets This information is typically difficult to show on a map. and as such is similarly difficult to update or debug. In accordance with an embodiment, the special street closing information can be associated with the visible street map item. When an operator selects the street map item the appropriate map item information record is displayed in the text view, as will the information that pertains to street closing. Often this information wiif be represented not as discrete fields but as links to a street closing information record. Selecting that item from the text view allows the operator to traverse to the relevant information, and to view, update, or debug it
Digital Map Semantic Network
[0050] Figure 4 and Figure S iSiusirate how a semantic network is used to provide a basis for map understanding in accordance with an embodiment As shown in Figure 4, the semantic network 290 provides an understanding of the variety of underiying map item types. For exampie, the semantic network allows the system to understand that a iake item type may adjoin a street item type, or a park item type; or that a street item type may inciυde a street corner item (i.e. a junction) type, and that a building item type typically has a street address and may also be located on a corner.
[0051] Embodiments of the system can make use of this understanding to create relationships between actual map items, as shown by way of exampie in Figure 5. When an actual set of data is retrieved into memory, the system uses its semantic understanding of the relationships between map item types to create relationships or links between the various map data elements. Rβiationships can be created linking map items of different type (for exampie linking a street item to a lake item), in the example shown in Figure 5, the streets named 35th Street and A Street are linked to Great Lake by relationships 293 and 294 respectively. These intβr-typβ Sinks are used to Sink certain map items referred to herein as "cousins", can be iater used to allow an operator to traverse between map items of different type, either from the text view window or from the graphical view window. [0052] Relationships can also be created linking map items of the same type (for example linking one street item to another street item, or one building item to another building item). In the example shown in Figure S, the streets 35tfi Street and A Street are linked to one another by a relationship 295, while the Empire Building and the Ford Building (both of which are buildings) are linked to one another by a relationship 296. These intra- type links are used to link certain map items referred to herein as "siblings", can be later used to allow an operator to traverse between map items of the same type, again either from the text view window or from the graphical view window.
System implementation
[0053] Figure 6 illustrates a schematic of one type of system in accordance with an embodiment, in which the system allows for a variety of map formats to be retrieved.. manipulated, viewed, and edited by an operator or user according to the above description. As shown in Figure 6, the system 404 typically inciudes a memory 418, a processor 419, and a storage or repository 420 of some sort. The system further includes a display device 422 or monitor, including a graphical user interface or GUI 423 operating thereon by which the system can display digital maps and other information.
|0054J When a digital map is retrieved from externa! storage 406 (which in some instances may be the same medium as storage 42O)1 the system may interpret it in a number of ways. When the map format is known, for example the map is in a GDF format 408 or some other ISO standard format, then the system may use a format semantic definition file 414 incorporated within the logic of the system, which is used to interpret the map format. For example, the semantic definition file can be used by the system to interpret the hierarchy of objects within the map, and relationships between those objects. In other instances, for example when the map format is a proprietary format 412, additional semantic definition files, or hard coding 416 can be used within the logic of the system to interpret the underlining map format and convert it to a semantic linkage of objects in memory, which are then interpreted by the system and used to provide features such as the parallel traversal mechanism and the actual map display, As mentioned above, an important feature of the system is its ability to work with a variety of present and future map formats. Because the system may manipulate different semantic definition files, it can be customized to work with many formats simultaneously.
Data Abstraction Layer for Support of Map Format inputs [0055] Figure 7 shows a scrβenshot 421 of an embodiment which can be integrated or used within a viewer or other application to allow access, viewing, editing, or conversion of digital maps. The map viewing feature can also be integrated into, or used with, new or existing map viewer/editor applications. It will be evident to one skilled in the art that embodiments can be used with other viewer applications and with other map formats than those illustrated below, and that the invention is not limited to the particular implementation shown and described hereunder. Particularly, while the Geographic Data File (GDF) map format (an industry standard map format) and the PSI formats are used herein to describe features of the invention, other map formats may be used. Embodiments of the system are flexible enough that it can be used with most map formats currently available today, and also with those yet to be developed.
[0056] In accordance with an embodiment, the system includes a data abstraction layer (DAL) and/or a plurality of different data abstraction interfaces. The data abstraction layer can be used to allow different map formats (e.g. GDF, PSI) to be parsed and viewed. This allows the system to receive data in any of a variety of different input map formats. The map can then be displayed on a display screen to create a viewable map in a universal display format that is completely independent of the original format. [0057] Figure 8 illustrates a schematic of an embodiment, in which the system is designed to be extensible and to provide support for additiona! map formats. As shown in Figure 8, the system 404 typically again includes a memory 418, processor 419, storage 420 of some sort, display device 422, and a graphical user interface 423. Optionaily, a grid definition file 414 can be inciυded to provide a layering or grid functionality, which is described in further detail below.
[0058] To accommodate multiple input map formats 408, 409, 412, a data abstraction layer 425. together with data abstraction interfaces, can be provided to abstract the map format from the semantic definition. Additional data abstraction interfaces can be plugged into the data abstraction layer to provide access to different input map formats. For exampie, in accordance with one embodiment the system can comprise a data abstraction interface for the GDF map format 427, and/or another data abstraction interface for the PSi map format 429, This aliows support for new map formats to be easily added, simply by adding a new data abstraction interface to the DAL, In those instances when the map format is a proprietary format, then additional semantic definition files or hard coding can also be provided within the logic of the system to interpret the underlying map format. [0059] In accordance with an embodiment, when the map format is retrieved the data abstraction interface for that input map format, together with the semantic definition file, is used to convert map items into a semantic linking of items that can be understood by the system. The map is then displayed on the user interfaces as a digitai map 424. The map can optionally be displayed in universal screen coordinates, which allows for additional functionality and features, also described in further detail below.
[0060] Figure 9 is a flowchart of a method for providing support for additional map formats. As shown in Figure 9, in step 430, the system is initiated, and the data abstraction layer is loaded, together with any data abstraction interfaces, in step 432, additional data abstraction interfaces can be added or "plugged in" as necessary to support additional map formats, In step 434, the digital map, or map information, is received in an input format. In step 436, the system recognizes the input format and users the corresponding data abstraction interface to retrieve the map items. In step 438, the system uses the semantic definition file to determine any linking between the map items, and convert the map data to a universal display format. In step 440, the digital map is displayed on the display screen or user interface.
[0061] in accordance with some embodiments, the system supports the PSi digital map format. The PSI format uses levels and tiles of map information, and is particularly suited for run-time access from local media (hard drive, CD, DVD, flash ROM), including storage and access on-board a vehicle or automobile. The PSi format is also designed to be particularly suitable for incremental data updates. For example, whenever there is a change in some portion of the map data, the entire map need not be changed, instead, only a tile (of some ievei or some content} need be replaced. The structure of the PSI map format is described in further detail below, but generally allows map information to be divided into "building blocks", levels, or layers, each of which levels contains some subset of the iotai information of the file, for example the basic map display, routing, name information block, guidance, positioning, POi information, advanced map dispiay (e.g. 3D imagery), and updated infrastructure, in accordance with an embodiment, the content of the PSi format is tiled into a pϊuraiity of levels, with the highest number level being the most detailed ievei with as much content and shape as is possible within that particuiar map (i.e. it is logicaily at the lowest level of the map hierarchy). Conversely the iowest-numbered level has iess detaii and is at the top of the hierarchy. Each level inciudes tiles of information that comprise the ievei, so that for example, Resolution decreases, but totai area size increases, with each successively Sower ievei in the map, in this manner, an appiication can use the iαwer ievei tiles for macroscopic mapping, and the higher ievei tiies for more detailed mapping, Furthermore, since different types of map data can be stored at the different levels, this aSiows for easier updating of those map Seveis and map data as necessary. [0062] Additionat information about the PSI map format is described in further detaii below, it wiii be evident that the system described herein can provide support for other input map formats, in addition to the GDF and PSl formats. The use of a DAL reduces the need for customized programming necessary to support different input map formats from M to a single input layer, where M is the number of different input map formats,
DSsptayable Map Information as Intermediary between ^ap Formats
[0063] in accordance with an embodiment, the system is abie to receive data into the viewer appiication in a first or originai map format (e.g. GDF) and then provide or output that data in a second or new map format (e.g. PSI). As described above, a pluraiity of different data abstraction layers can be used to allow different map formats to be interpreted and/or optionally viewed in a universal display format. Depending on the particular embodiment the univβrsa! dispiay format can inciude item coordinates, or higher ievei descriptions of geometry and topology in the map, in accordance with an embodiment, a map format iegend associated with a particular format can then be used to interpret the universal display format, and output the data into that output format. A piurality of different map iegends can be used to aSiow different map formats to be output. In this manner the system allows for easy and universal converting of map formats. The system aiso reduces the need for customized programming necessary to support those different formats from (IVTN) logical components to fvl+N logical components, where M and N are the numbers of different input formats and different output formats respectively, [0064] Sn accordance with an embodiment of the invention, the system can be used to access map formats of another type, or to convert between different map formats, for example between GDF and PSI, and other formats. Figure 10 illustrates a schematic of a system that can be used with an embodiment of the invention, in which the system allows for a variety of map formats to be retrieved, manipulated, viewed, edited, and converted into other formats by an operator or user. As shown in Figure 10, the system 404 again typically includes a memory, processor, and a storage or repository of some sort, together with a display device or monitor, including a graphical user interface or GUI operating thereon by which the system can display a digital map. in accordance with an embodiment the system includes one or a plurality of map legends 441, 443 that can be used by the system to interpret the hierarchy of objects within a particular map format as it is displayed on the screen, and relationships between those objects. As shown in Figure 10, a single semantic definition file can be used for several map formats. Alternatively, separate semantic definition files can be used for different map formats, including for exampie a semantic definition file for GDF, a semantic definition file for PSI, and so on.
[0065] In accordance with an embodiment, the system comprises a map legend crosstable 442 which, when combined with the map legends, aliows the system to interpret a map as it is displayed 426 on the graphical user interface, and then output 428 the map data to a new map format, A single map iegend can be used for several map formats. Alternatively, separate different map legends can be used for different map formats, inciuding for example a map legend for GDF display, a map legend for PSI display, and so on. Support for additional map formats can be added to the system by adding additional map legend information to an existing legend crosstable, and/or by adding additional map legends. [0066] In accordance with an embodiment, the system aliows map data of a first map format 'A" (for example a GDF format map) to be retrieved and viewed as a digital map on the display. Depending on the format to be retneved the system can use one or more of the map legends to interpret the map objects and display them 426 on the screen. Upon demand by the operator, the system can then interpret 428 the displayed digita! map objects, using the map legend, to determine appropriate information for the objects that are currently displayed in the map and, and convert or save those objects into a second or output map format IVC" (for exampie a PSI map). A selection of the displayed objects, or the entire map, can be converted in this manner. The second or output map format can then be saved to a disk, or used in another manner as implementations may require. [0067] Figure 11 illustrates a map iegend crosstabie in accordance with an embodiment. As shown in Figure 11, the legend crosstable is used to map item legend information from one map format legend (e.g. GDF), to another map format legend (e g. PSI). A plurality of entries 447 in the crosstabSe link the displayable (in screen coordinates) map item types of a first format, with corresponding displayable {in screen coordinates) map item types of a second format. Additional map formats and map iegends can be added by adding to the legend crosstabie. In this manner, a map of one format can be easily converted to one or several other map formats. As shown in Figure 11, in some instances a map item of one format may correspond to two or more map items in another format. Similarly, some map items of one format may have no corresponding map item in the other format. This information can be recorded in the legend crosstabie by means of an index or pointers, together with as necessary multiple pointers, or in some instance an absent or null pointer for certain map items.
[0068] Figure 12 illustrates a system that can be used with an embodiment of the invention, in which the system allows for a variety of map formats to be retrieved, manipulated, viewed, and edited by an operator or user according to the above description, As shown in Figure 12, the system first receives map data in a map format "A" (for example GDF). The system uses an input map legend and semantic definition file to determine objects in the map to clispiay. In accordance with an embodiment, if the map data is capable of being viewed at different Ie vets or different degrees of information, then the system displays the chosen level, and maintains an object tabie for the displayed map objects. The system then displays the map and the map objects on the screen. The displayed map is in universal screen coordinates and, subject to the differences between the map legends, is independent of the underlying map data. To convert the displayed map into an output format the system retrieves the map legend (or if several map legends exist then the map legend that corresponds to the output format). The system applies the map legend of the output format to the displayed map, and uses it to interpret those objects that are currently displayed. The system then prepares the currently displayed map objects for output, and saves the map info the desired format "C" (for example PSl).
[0089] When the map format is of a type that displays levels of information or sequential tiling (for example the PS! format), then the map data can be retrieved and displayed at those different levels. For example, the map data content within the PSI format can be tiled into a plurality of levels. In accordance with an embodiment, the system allows such data to be retrieved and displayed at the desired level. That level of information (corresponding to the currently displayed map) can then be output to the desired format. This allows map a desired level of map information to be output without requiring that the entire map be converted from one format to another format. Additional information about the PSI map format is described in further detail below. It will be evident that the system described herein can provide support for other input map formats, in addition to GDF and PSI. [0070] Figure 13 illustrates a system that can be used in accordance with an embodiment, in which the system allows for an input map format to be received, and a variety of map formats to be created, manipulated, yiewed, edited and output by an operator or user according to the above description. As shown in Figure 13, an input format, for example PS! or GDF, is received into the system. The system uses one of a plurality of map legends 449 to display the map data on the screen. The system then uses another one of the plurality of map iegends to interpret portions or the entire map as dispiayed, and to either edit the map, convert map information, or output the map or portions thereof in another or a proprietary map format. [0071] Figure 14 illustrates a flowchart that can be used with an embodiment of the invention, in which the system allows for a variety of map formats to be retrieved, manipulated, viewed, and edited by an operator or user according to the above description. As shown in Figure 14, in step 450 the system first receives map data in a particular map format, in step 452 the system uses a semantic definition file to determine objects in the map to display. If the map data is capable of being viewed at different levels or different degrees of information, then in step 454 the system displays the chosen ievel. In step 456 the system maintains an object fable for the displayed map objects. In step 457 the system retrieves a map legend for the input map format. In step 458 the system then displays the map and/or a selection of the map objects on the screen. To convert the displayed map or map items into another format, in step 460, the system retrieves the map legend for the output map format, in step 462 the system applies the map legend to the displayed map and uses it, together with the legend crosstable, to interpret those objects that are currently displayed, in step 464 the system then prepares the currently displayed map objects for output, and outputs the map into the desired format.
Viewing, Debugging and Converting Map Data
[0072] In accordance with an embodiment, the system can be used to view, edit, or debug map data, and perform conversions of map data. Techniques are also provided that assist in previewing and debugging the conversion of the map data from one map format to another format. Embodiments of the system allow for either alternately or concurrently presenting two or more digital maps in different map formats, and/or both a graphical map and textual information describing the objects or items within those maps. The system allows the user to compare the maps, and to preview conversions of maps, and to view or modify records within a map by either selecting items from a graphical map or from a text view. When the user wishes to view or modify a map, the user can display one or more digital maps on a computer screen, and display or preview another map format or a text view on the same or a different computer screen. As the user selects items within the map, for example a building, street, or park, typicaiSy by clicking on the item with a mouse or with some other form of pointing device, the map window and/or text window changes to reflect the properties of the map item currently selected. The operator can then navigate between map objects better from the graphical view or the text view Each map object or item is associated with a particular data record that describes the properties or attributes of that item. As used herein these properties may include, for example, a street name, or some relationship of this object to another object. The relationship may be. for example, how one street intersects another street to form a street corner or intersection, or that one street abuts a particular park. The system makes use of these relationships by extracting relationship information from the map itself and displaying it to the user in the text view format so that the user can then select from this text information to easily navigate between map objects, and to make changes to the information defining or associated with those objects. Modifying a text record to update an attribute associated with an object can be used to produce an immediate change in the graphical map itself. At the same time being able to view, display, and edit the record associated with an object provides an easy mechanism by which a map editor can change object attributes, in this way the map can be viewed in a more useable manner, and can be easily and quickly updated to reflect changes in the underlying objects. When the use is satisfied with the quality of the map data, the digital map can be stored, saved, or output, to one or more output map formats, using the techniques described above. [0073] Figure 15 iiSustrates an embodiment that ailows a preview of an output digitai map format, such as a PSi format map. to be compared to an input map format, for use in converting between map formats. This ailows for a digital map to be previewed, converted, and debugged against an input map source. As shown in Figure 15, a digital map tn an original input format 530 is received info the system. The input map format can be any format, for exampie GDF or another map format The input digital map 424, together with a preview of the output map data, can be displayed together or overiaid S32 on the same GUI 423 for an operator to review. This provides the operator with a preview of what the output map data or digital map wiiϊ look iike following conversion. For example, a GDF format map can be displayed on the same screen, or overiaid with, a PSi format map of the same map area. In the case of PSI output a PS! grid can be overlaid on the original map data to reflect the grid-like layout of the PSi format, and to show the operator what the eventual output PSI map would iook like. The additional map format data can be retneved, or generated from the original source using the techniques described above. Overlaying the two sets of data, or displaying the two sets in ciose proximity allows the operator to quickly review differences between the maps. The operator can also retrieve a text record 210 for any map item, to make changes directly into the data record for that item If the operator wishes, they can output the converted digital map data in a target map format, for exampie PSi. In accordance with an embodiment, the operator can also edit the converted digital map data as necessary.
|0074] Figure 16 illustrates another embodiment that allows for a preview of an output digital map format to be compared to an input map format, for use in converting between map formats. This allows for a digital map such as a PSI format map to be previewed, converted, and debugged against an input map source. As shown in Figure 16, the original version 540 of the digital map 424, together with a preview of the output map data 541. can be displayed together or side by side on the same GUS 423 for an operator to review. This provides the operator with a preview of what the output map data or digital map wiii look like following conversion. For example, a GDF format map can be displayed on the same screen side by side with a PSl format map of the same map area. In the case of PSI output a PSI grid can be overlaid on the preview to reflect the grid-like layout of the PSI format, and to show the operator what the eventual output PSI map wouid iook iike. As described above, the additional map format data can be retrieved, or generated from the original source, and the operator can also retrieve a text record for any map item to make changes directly into the data record or can output the converted digital map data in a target map format, for example PSI. Again, in accordance with an embodiment, the operator can also edit the converted digital map data as necessary. [0075] Figure 17 illustrates a flowchart that can be used with an embodiment, in which the system allows for an output digital map format, such as a PSi format map, to be compared to an input map format, for use in converting between map formats. This ailows for a digital map such as a PSI format map to be previewed, converted, and debugged against an input map. As shown in Figure 17, in step 550, the system receives map data in a first map format (e.g. GDF), In step 552, the system receives, creates, or converts the map data into a corresponding second map format (e.g. PSI). in step 554, the system displays the first map and second map in user interface on display screen, either superimposed or side-by- side. In step 556, the system allows the operator to view, edit, and debug map data in the second map format, including optional use of text record if desired, in step 558, when the operator is satisfied with map data, the system receives a command from the operator to save the map data, In step 560, the system prepares the currently displayed map data for output, and outputs the data to the desired format (e.g. PSI).
[0076] In accordance with an embodiment, the system also allows for debugging that includes an analysis of the target format in terms of data specification, rather than data content, in accordance with this embodiment, the operator can determine the extent to which the target or output map format is able to reflect the data content of the source or input map format. This may include aspects such as the flexibility of the attributes within the data (for example, whether a particular type of attribute can be represented in the output, and whether the representation handles unusual cases), and the efficiency of the data representation {for example, the size and the complexity of the data output representation). For example, an input map or source data may support area features with multiple faces in its map format; however, a particular choice of output map format might only support a single face per area, thus forcing multiple area features to capture the same content. An embodiment of the system can be used to visualize and detect such potential problems. [0077] By way of example, different map formats handle area features differently.
Normally, an area feature may consist of many faces. This is common in the GDF format when in feature mode: the various faces of the area are the regions enclosed by the road network that surround and sometimes bisect or intersect the area. In the PSI format there are three different methods of encoding an area. The RELATIVE and DIFF encoding methods support the notion of multiple faces in which the list of coordinates includes flags to mark the end of a face. However, if the attribute CoordCompression is set to COMPRESS1ON_NONE, then the RELATIVE and DiFF encodings are not allowed, and an area can instead have only one face. So if the original input GDF area has multiple faces and the operator selects an output option that cannot support those multiple faces, then the system must either (a) ignore the area, (b) signal an error condition, or (c) generate an area feature in the output for each face of the input area feature. [0078] For example, if one considers an input map that includes a rectangular shaped park (which is a commonly used area feature), the other lines on this map might be the roads, rivers, and other items that break up the park into other smaller elemental areas. In some data models, for example in GDF, the park area feature can be described as a composite area that is in turn comprised of smaller areas or faces. In PSI, under some circumstances it is considered "format illegal" to create a feature with multiple faces. Thus, in order to show the park using the PS! format it must be shown by creating separate park features for each of the elemental areas and by then designating those components as part of the overall park. This is redundant and also makes the process of map conversion more difficult since it has the potential to introduce unwanted effects, in accordance with an embodiment the viewer allows for viewing these effects or "discovering" unwanted effects by seeing how the rules of translation actually behave, As described above, this can be done by visualizing the data in, for example, GDF, and by then visualizing the same data in PSS in the viewer, with both its graphical and its textual outputs. Using either the overlay approach or the side-by-side approach described above with respect of Figures 18 and 17 allows the operator to quickly discern the differences between map features as presented or stored in the different source and target map formats, and to then edit or debug them accordingly.
[0079] Embodiments of the system can also be useful in debugging the translation process itself For example, if the output has missing or wrong attributes or geometry, then the issue may be the translation itself, rather than the data content of the source, or any restrictions imposed by the output map format.
Map Level and THe Features [0080] in accordance with an embodiment, techniques are provided that assist in reading, storing, and outputting data to various formats, and in particular to formats such as PSI that can include multtpie levels of tiled map information. Using the techniques described above, a digital map can be displayed on a display screen in a universai dispiay format that is independent of the original format The digital map as displayed can then be parsed using a map legend, and techniques can be used to output different map data based on the currently viewed map display, if a user modifies the map dispiay to display a greater (or iesser) detail of resoiution, then the set of map data that is output can also be varied accordingly. [0081] In accordance with an embodiment the system optionaiiy inciudes features for handling those map formats that include levels of information or sequential tiling (for example the PSi format). Figure 18 shows a screenshot 470 of an embodiment that can be integrated or used with a viewer apptication to aiiow viewing and editing of digital maps. Figure 19 shows another, close-up view 472 of the same map. As shown in Figures 18 and 19 the displayed map is a PSl format map. [0082] As described above, the PSI format is divided info "building blocks", levels, or layers, each of which ieveis contains some subset of the total information of the file; e.g., the basic map dispiay, routing, name information block, guidance, positioning, PO! information, advanced map display (e.g. 3D imagery), and updated infrastructure. Figure 20 illustrates multiple levels and tiies of information as stored in a multi-level map format such as PSI. As shown in Figure 20. the underlying digital map 480 can be represented as a piuraiity of levels 482, 484, 486. in the example of the PSI format the highest-numbered ievel 13 is the most defaiied ievei, with as much content and shape as is possible within that particular map, i.e. it is logically at the iowest level of the map hierarchy. Conversely the lowest-numbered level 0 is at the top of the map hierarchy. Each level inciudes tiles of information that comprise that ievel. so that for example each Ievei 13 tile is about 2 kilometers by 2 kilometers in area; whereas a ievei 12 tile loses some resolutions and is about 5 by 5 kilometers in tile area, it wiil be evident that PSi is described here by means of example, and that other multi-level map formats, having different arrangements of levels and tiies could be used). [0083] in accordance with an embodiment, selecting a particular level from the pull- down menu dispiays the tiles corresponding to that level. When the map is "zoomed out" to a iarge extent, then the system automatically hides the boundaries between the tiles [0084] In accordance with an embodiment, the boundaries between the tiies are not only used for display purposes. As described above, the system can aiso allow for an input map format to be received, and a variety of map formats to be created, manipulated, viewed, edited and output by an operator or user according to the above description, including where desired portions or the entire map as displayed. The system can aiso output the displayed map or portions thereof in another or a proprietary map format in accordance with an embodiment this technique is further used to interpret information from any map displayed on the screen (from any source and any original map format), and convert the information to corresponding PSI tiles (which can also be automatically clipped on tile boundaries, even across resolution differentials). When the number of tiles is too large to output to a single file (for example if the map covers an entire country), then the tiles can be collected automatically into an SQL database.
[0086] Figure 21 shows another screenshot 490 of an embodiment that can be integrated or used with a viewer application to allow viewing and editing of digital maps. A pull- down menu can be used to display selected PSI levels, if the operator desires then the system can be used to save map features to a particular PSI Sevei. Since different map formats may use different resolutions to store and display maps, the system must take this into account when saving data to a different format. For example, in the GDF format the resolution is at most 7 decimal points for iat long pairs in degrees. In the PSl format the resolution can be more precise (in the area of sub-centimeter accuracy), in accordance with an embodiment, when the system converts map data from GDF to PSI, the system deliberately leaves "tails" on each feature. A PSi conversion routine can then cut the tail to a proper size during output of the data. [00S7] Figure 22 shows another screenshot 492 of an embodiment that can be integrated or used with a viewer application to allow viewing and editing of digital maps. As shown in Figure 22, attributes for individual map objects can be edited before outputting them (to PSi or another format). This ensures that when saved, the data more accurately matches the operator's requirements. [0088] Figure 23 illustrates a flowchart that can be used with an embodiment to ailow for conversion of map data to PSI format. As shown in Figure 23t in step 500 the system first receives map data in a particular input map format (e.g. GDF). In step 502 the system uses a semantic definition file to determine objects in the map to display, in step S04 the system then uses the map legend for the input map format to display the map and the map objects on the screen, in step 506 the system allows the operator to specify a particular PSI ievei to which the system should save the map data. In step 508 the system applies the map legend of the output format to the specified ieve! of the displayed map (or to the ievei of the map that is currently specified and displayed) and uses it to interpret those objects that are currently displayed on the screen. In this manner the operator can either display a particuSar map level, and then export or output that level. Alternatively the operator can display a different map level, and uses a drop down menu or other device to choose a map level for output, in step SOS the system prepares the currently displayed map objects for output, and outputs the data to the desired format (e.g. PSi).
IViap Data Access using a Bit Stream Processor
[0089] In accordance with an embodiment, the system aiso includes features to aiiow efficient access and storage of map data. This is of particular use with some data formats, including PSi, which are designed to reduce overall data storage space in return for slightly longer access (reading and writing) times, in some map data formats each map item is not necessarily stored or encoded using a consistent byte-aligned number of bit length. For example the number of bits in a variable may not be byte-aligned such as 16, 32 or 64 bits, but could instead be 7 bits, 13 bits, or some other length. Instead, to save overaii storage requirements, the map items can be stored as different byte length variables. This necessitates additional processing during reading and writing the data. In accordance with an embodiment a bit stream processor provides a reader and/or a writer functionality, which ailows the system to read and/or write an arbitrary number of bits at any bit position in the data stream. In accordance with some embodiments the order of access can aiso be random.
[0090] Typical access to any data stream is byte oriented, so that reading or writing data normally requires the application to consider the nearby bits in the same byte being considered. For reading, this means that unwanted bits must be excluded and the remainder must be shifted to their proper position in the fina! result If the desired bits also span byte boundaries then there are additional complications in piecing together bits from multiple bytes to assemble the desired result. For writing, it is even more complicated, since the unreferenced bits in a byte must be preserved. This means bytes must be read, partially altered and written again. An additional issue is maintaining correct byte order when reading and writing values in environments in which the underlying machine byte order is different, such as big-endian and little-endian architectures, so that the same bit stream will work in ail environments.
[0091] in accordance with an embodiment, the bit stream processor, including a bit reader and/or writer addresses these problems by viewing the data stream as bit stream instead of a byte stream. As such there is the notion of a bit position in the stream. In accordance with an embodiment, access to the stream occurs at the current bit position. After reading or writing a number of bits at the current bit position, the current position is changed to the position after the last bit that was read or written. Numeric values that are retrieved from or written to such a data stream are viewed independently of their physical context in the bit stream, in particular there is no need to be concerned about ignoring or preserang neighboring bits in physical bytes. This is handled automatically by the reader/writer as needed. Furthermore, the bit position can be set to any desired position in the bit stream, so that random access is easy. Finally reading and writing can be mixed in any desired combination. This supports easy creation of data in which some parts of the stream content are not yet known, oniy its size and position. This might occur for example if a count of the number of items needs to be recorded, but the number will depend on processing that has not yet been done. The writer can then skip over this part of the data, write other data content, and then iater return to this position in the stream and compiete or update it.
[0092] To consider an example, in order to read a value A consisting of n bits from the current bit position of a bit stream, the reader must first determine which physical bytes of the data are involved. Assume for notation that the bytes are 81 , .,., Bm in this order. The bit stream is maintained in big-endian byte order, regardless of the byte order of the machine on which the reader is running. This means that A is broken up into biocks of bits, A1, .... Am. A1 contains the highest order bits of A that are in byte 81, while A2 contains the next biock of bits of A that are in byte B2, and so on, until finally Am contains the iowest order bits of A that are in byte Bm. Generally, A1 and Am will be partial bytes where A1 contains the low order bits of B1 starting at the current bit position, and Am contains the high order bits of Bm1 while aii other Ai wiii contain the full byte contents of the corresponding byte Bi. In accordance with an embodiment, the reader shifts the bits of each byte Bi, with appropriate masking of B1 and Bm1 and assembles the bytes into a final numeric vaiue A. [0093] In accordance with an embodiment, the writer can engage in a similar process, except that the masked bits in B1 and 8m will be added to the biocks A1 and Am to form a complete byte, and then the bytes A1 through Am will replace B1 through Bm in the bit stream.
[0094] In accordance with an embodiment, the bit reader and writer treat the data stream as a buffer in memory. This is convenient, since it allows any memory buffer to be managed by a bit stream reader or writer with virtually no overhead. Only the location and size of the buffer needs to be specified to initiaiize the reader or writer. This is also useful in a conventional database environment where binary content ts recorded as blob. Once the blob is retrieved it can be immediateiy attached to a reader and treated as a bit stream source. Conversely, when a buffer is created with a bit stream writer it can then be stored in a physical storage medium, such as a database or some other file system.
[0095] In accordance with an embodiment, the bit stream reader and writer includes the ability to resize the buffer as needed, without disturbing the reader/writer state. The current bit position can be retrieved and modified at any time, Reading and writing on a bit stream can foe mixed in any order,
|0096J Figure 24 illustrates a schematic of an embodiment that allows for map data to be read, edited, and stored into the system. As shown in Figure 24 , the system 570 comprises a disk storage 572, memory 574, cache 576, and a bit stream processor 578. The bit stream processor provides a staging area for efficient reading and writing of map data, and also provides security for adjoining data portions that use different byte length variables. An input map 580 including map data can be read into the system, and optionaiiy written to an output map 581. Input and output map formats include PSI and other map formats, As map data is read 583 into the system, instead of reading it directly from disk storage to the display screen, which takes time, the bit stream processor piaces the map data in memory and reads it from there. As map data is written 584 to the system for storage or output, which again takes time, the bit stream processor caches the map data in the cache, and writes it from there. [0097] In accordance with an embodiment, the bit stream processor can be used to read and write PSt format map data. The PSI format requires a stream of data items or various sizes (from 1 to 32 bits) that are packed with no unused space or data alignment assumptions. This means that at a low level all data must be converted to or from a bit stream. In accordance with an embodiment the map viewer application can inciude a PSl component which implements a bit stream reader and writer. This is used as the finai step on output to generate PSI data, and the first step on input to interpret and represent PSI data. In the context of PSI, the bit stream reader and writer allow the writing/reading of N bits of data to/from the memory buffer at any given bit position, without disturbing neighboring bits. Since data must be accessed in units of a byte {a minimum of 8 bits), the reader and writer must concern themselves with joining fractions of bytes of data, so that the process is invisible to the calling software.
[0098] In practical terms the bit stream is also a means of compressing the data.
Navigation systems that use digital maps typicaSSy have memory constraints (often moreso than processor constraints). As such a goal is often to balance memory and processor speed. Formats such as the PS! format use tiles, wherein the system may not know the number of points/iines/areas generated until it is compieted (a minimalist approach). After completion it must then go back and update the tile contents at particular positions to update these numbers. If the system performs a full unpacking of a tile, then it must place all of the content into unique variables which can be accessed directly and quickly. However, this approach requires the system to accept the cost of the fully unpacked data size within memory. If large tiles or many tiles are used then this approach might not be feasible. Alternatively, the system can choose to not unpack or store anything, except the information that is required to answer the current query. While this approach is minimal in terms of space usage, if requires rødigesting the tile bit stream every time the system must process a query that involves something in that tile. While this approach is smaller, it may also be slower. In accordance with an embodiment, the system digests the data as if is read, and 5 stores the bit locations of various "memory markers" in the bit stream. Such markers can include, for example, the start of an "Area Feature List" or the Start of a "Line Feature List", In PSi, the format aiiows the system to provide information about area features if it is known where the area feature iist starts. As such, in accordance with an embodiment the system does not then need to start digesting the bit stream from the beginning to again determine
10 where the area features start. This approach produces a much faster processing time for queries, at the cost of only a modest amount of memory, in accordance with an embodiment the system stores not just the beginning of the areas, but also the start of each area feature, in a iist in 1-1 correspondence with the area features. Then each feature is a direct lookup into the tile data.
I 5
Digital Map Viewer with Magnifying TUe Feature
[0099] Some or ali of the above features can be included in map viewers and other applications that include various embodiments of the invention. Fjgures 25-28 iiiustrate screenshots of a viewer for displaying previewing, and accessing levels of a muSti-level digital 0 map data. As shown in Figure 25, an input map 800 can be read into the viewer application. As shown in Figure 28, the map can be tilted 802 or displayed in three dimensional view. As shown in Figure 27, a magnifying glass 606 can be used to focus on a section of the map, or a level of map data. This can be used with the debugging features as described above to compare and debug map data. Similarly the magnifying glass can be used to view levels of 5 map information, such as in a PSI or other muiti-ievei format digital map, and then edit or output that level of the map. As shown in Figure 28, the operator can easily change the focus area 610 of the magnifying glass, to view a different portion of the map, or a different level of a multi-level map. Using this approach, different levels of map data can be accessed, viewed, edited, and stored as output. 0
[00100] The present invention includes a computer program product which is a storage medium (media) having instructions stored fhereon/in which can be used to program a computer to perform any of the processes of the present invention. The storage medium can include, but is not limited to. any type of disk including floppy disks, opticas discs, DVD, 5 CD-ROMs, microdrive, and magneto-optical disks, ROMs, RAIVIs, EPROIVIs, EEPROMs, DRAMs, VRAMs, flash memory devices, magnetic or optica! cards, πanosystems (including molecular memory ICs), or any type of media or device suitable for storing instructions and/or data.
|00101| Stored on any one of the computer readable medium (media), the present invention includes software for controlling both the hardware of the general purpose/specialized computer or microprocessor, and for enabling the computer or microprocessor to interact with a human user or other mechanism utilizing the results of the present invention. Such software may include, but is not limited to, device drivers, operating systems, and user applications. Ultimately, such computer readable media further includes software for performing the present invention, as described above, included in the programming (software) of the general/special ized computer or microprocessor are software modules for implementing the teachings of the present invention.
[001023 Appropriate software coding can readily be prepared by skilled programmers based on the teachings of the present disclosure, as will be apparent to those skilled in the software art. The invention may also be implemented by the preparation of application specific integrated circuits or by interconnecting an appropriate network of conventional component circuits, as will be readily apparent to those skilled in the art. [00103] The foregoing description of the present invention has been provided for the purposes of illustration and description. If is not intended to be exhaustive or to limit the invention to the precise forms disclosed. Many modifications and variations will be apparent to the practitioner skilled in the art. Particularly, it will be evident that the above described viewer and editor features can be incorporated into other types of software application beyond those described, and that a wide variety of map formats may be viewed and manipulated with the invention, in addition to the GDF and PS! formats described herein. The embodiments were chosen and described in order to best explain the principles of the invention and its practical application, thereby enabling others skilled in the art to understand the invention for various embodiments and with various modifications that are suited to the particular use contemplated. It is intended that the scope of the invention be defined by the following claims and their equivalence.

Claims

Cjajms;
What is claimed is:
5 1. A system for converting digital map information using displayabie map information as an intermediary, comprising: a set of map data that corresponds to a digital map., and having a first map format associated therewith; a first map legend that is associated with the first map format and that Sinks 10 displayabie map item types in the first map format to a universal display format; a second map legend that is associated with a second map format and that links displayabie map item types in the second map format to a universal display format; a legend index that links map item types defined by the first map legend with map item types defined by the second map legend;
J 5 a display device including a graphical window that can be optionaiiy used to display the digital map in a universal dispiay format; and a user interface that allows an operator to retrieve and display a digital map having the first map format into the system, and specify the second map format as an output format for some or all of the map data, wherein the system interprets the digital map displayed on 0 the display device in the universal display format, uses the first map legend to select all or a portion of the map as currently displayed on the display device, and uses the second map legend to output that portion of the map in the second map format,
2, The system of claim 1 wherein the first map format is Public Sector Information (PSI) 5 format.
3. The system of claim 1 wherein the first map format is Geographic Data File (GDF) format and the second map format is Public Sector Information (PSi) format. 0
4. The system of claim 3 wherein the first map format is GDF format and the second map format is PSI format, and wherein the system allows the operator to further select all or a portion of the map to be output to a particular level of PS! format
5 5. The system of claim 1 wherein the system further interprets the displayed digital map objects, using the map legend, to determine information for objects that are currently displayed within the digital map.
6. A method of map format and data conversion using displayabSe map information as an intermediary, comprising the steps of: providing a set of map data that corresponds to a digital map, and having a first map 5 format associated therewith; providing a first map legend that is associated with the first map format and that links displayabie map item types in the first map format to a universa! display format; providing a second map legend that is associated with a second map format and that links displayabie map item types in the second map format to a universal display format; 10 providing a legend index that links map item types defined by the first map legend with map item types defined by the second map legend; optionally displaying on a display device including a graphical window the digital map in a universa! display format; allowing an operator to retrieve and display a digital map having the first map format J 5 into the system, and specify the second map format as an output format for some or all of the map data; and interpreting the digital map displayed on the display device in the universa! display format, using the first map legend to select all or a portion of the map as currently displayed on the display device, and using the second map legend to output that portion of the map in 0 the second map format,
7. The method of claim 6 wherein the first map format is Public Sector Information (PS!) format. 5
8. The method of claim 6 wherein the first map format is Geographic Data File (GDF) format and the second map format is Public Sector Information (PS!) format.
9. The method of claim 8 wherein the first map format is GDF format and the second map format is PSI format, and wherein the system allows the operator to further select all or 0 a portion of the map to be output to a particular ieve! of PS! format.
10. The method of claim 6 wherein the system further interprets the displayed digital map objects, using the map legend, to determine information for objects that are currently displayed within the digital map. 5
11. A system for viewing and editing digita! maps using a plugin data abstraction layer for different digital map formats, comprising; a set of map data that corresponds to a digital map, and having a first map format associated therewith: a data abstraction layer, that allows one or a plurality of data abstraction interfaces to be plugged into the layer, and that inciudes an interface for the first map format that allows 5 the system to receive and display the map data; a semantic definition fiie that converts map items into a piuraiity of semanticaSiy linked items; a display device including a graphical window that is used to display the digital map in a universal display format together with the semantically linked items; and 10 a user interface that allows an operator to retrieve and display a digital map having the first map format into the system, wherein the system then uses the data abstraction interface and semantic definition file for that map format to receive and display the digital map on the display device in the universal display format.
J 5 12. A method for viewing and editing digital maps using a plugin data abstraction layer for different digital map formats, comprising the steps of. providing a set of map data that corresponds to a digital map, and having a first map format associated therewith; providing a data abstraction layer, that allows one or a plurality of data abstraction 0 interfaces to be plugged into the layer, and that includes an interface for the first map format that allows the system to receive and display the map data; providing a semantic definition file that converts map items into a plurality of semantically linked items; displaying on a display device including a graphical window the digital map in a 5 universal display format together with the semantically linked items; and allowing an operator to retrieve and display a digital map having the first map format into the system, and using the data abstraction interface and semantic definition fiie for that map format to receive and display the digital map on the display device in the universal display format. 0
13. A system for using layers and grids to access, view, edit and store digital map data, comprising: a set of map data that corresponds to a digital map, and having a first map format associated therewith, and multiple levels of map information stored therein; 5 a first map legend that is associated with the first map format and that links displayable map item types in the first map format to a universal display format; a display device including a graphica! window that is used to display the digital map in a universal display format; and a user interface that allows an operator to select a level of the map to be currently displayed on the display device, and wherein the system automatically uses the map legend 5 to interpret the features included therein, and output feature information for that level of the map.
14. A method for using layers and grids to access, view, edit and store digital map data, comprising the steps of:
10 providing a set of map data that corresponds to a digital map, and having a first map format associated therewith, and multiple ieveis of map information stored therein; providing a first map legend that is associated with the first map format and that links displayabSe map item types in the first map format to a universal display format; displaying on a display device including a graphical window the digital map in a J 5 universal display format; and allowing an operator to select a level of the map to be currently displayed on the display device, and wherein the system automatically uses the map legend to interpret the features included therein, and output feature information for that level of the map, 0 15. A system for providing efficient access to digital map data, comprising; a computer having a fixed disk or other non-volatile storage device for storage and archival of data; a memory or other software accessible medium for enabling retrieval and access to the data; 5 a cache for temporarily caching some of the data; a set of map data stored on the computer storage device, that corresponds to a digital map and that has a plurality of map items defined therein, wherein the digital map has a first map data format in which each map item is not necessarily stored or encoded using a consistent byte length; and 0 a bit stream processor that performs the steps of. while map data is being read by the system from the storage device to the memory, instead of reading it directly from disk storage to a display screen, places the map data in the memory and reads it from there, and while the map data is subsequently by from the system to the storage device 5 or another output, caches the map data in the cache and then writes it from the cache.
PCT/US2008/068829 2007-06-29 2008-06-30 System and method for accessing, viewing, editing and converting digital map information WO2009006427A1 (en)

Applications Claiming Priority (14)

Application Number Priority Date Filing Date Title
US94734407P 2007-06-29 2007-06-29
US94736907P 2007-06-29 2007-06-29
US60/947,369 2007-06-29
US60/947,344 2007-06-29
US94762607P 2007-07-02 2007-07-02
US60/947,626 2007-07-02
US12/163,816 US20090015595A1 (en) 2002-06-27 2008-06-27 System and method for converting digital map information using displayable map information as an intermediary
US12/163,824 US20090015596A1 (en) 2002-06-27 2008-06-27 System and method for viewing and editing digital maps using a plug-in data abstraction layer for different digital map formats
US12/163,840 2008-06-27
US12/163,824 2008-06-27
US12/163,833 2008-06-27
US12/163,840 US20090006480A1 (en) 2002-06-27 2008-06-27 System and method for providing efficient access to digital map data
US12/163,833 US20090013273A1 (en) 2002-06-27 2008-06-27 System and method for using layers and grids to access, view, edit and store digital map data
US12/163,816 2008-06-27

Publications (1)

Publication Number Publication Date
WO2009006427A1 true WO2009006427A1 (en) 2009-01-08

Family

ID=40226511

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2008/068829 WO2009006427A1 (en) 2007-06-29 2008-06-30 System and method for accessing, viewing, editing and converting digital map information

Country Status (1)

Country Link
WO (1) WO2009006427A1 (en)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102538801A (en) * 2010-12-16 2012-07-04 上海博泰悦臻电子设备制造有限公司 Method and device for processing road network data in navigation map
CN103021257A (en) * 2012-12-04 2013-04-03 北京世纪高通科技有限公司 Method and apparatus for generating electronic map
CN106940560A (en) * 2010-07-01 2017-07-11 德国福维克控股公司 Surveying and mapping with region division

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4407295A (en) * 1980-10-16 1983-10-04 Dna Medical, Inc. Miniature physiological monitor with interchangeable sensors
US5552989A (en) * 1991-10-30 1996-09-03 Bertrand; Georges Portable digital map reader
US5946615A (en) * 1996-10-08 1999-08-31 At&T Wireless Mobile network geographic address translation
US6505121B1 (en) * 2001-08-01 2003-01-07 Hewlett-Packard Company Onboard vehicle navigation system
US20050210445A1 (en) * 1996-05-10 2005-09-22 Apple Computer, Inc. Graphical editor for program files
US20070038962A1 (en) * 2002-06-27 2007-02-15 Tele Atlas North America, Inc. System and method for associating text and graphical views of map information
US20070130153A1 (en) * 2005-12-02 2007-06-07 Palm, Inc. Techniques to communicate and process location information from communications networks on a mobile computing device
US20070129885A1 (en) * 2005-11-09 2007-06-07 Harald Wellmann Optimum route determination with tiling

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4407295A (en) * 1980-10-16 1983-10-04 Dna Medical, Inc. Miniature physiological monitor with interchangeable sensors
US5552989A (en) * 1991-10-30 1996-09-03 Bertrand; Georges Portable digital map reader
US20050210445A1 (en) * 1996-05-10 2005-09-22 Apple Computer, Inc. Graphical editor for program files
US5946615A (en) * 1996-10-08 1999-08-31 At&T Wireless Mobile network geographic address translation
US6505121B1 (en) * 2001-08-01 2003-01-07 Hewlett-Packard Company Onboard vehicle navigation system
US20070038962A1 (en) * 2002-06-27 2007-02-15 Tele Atlas North America, Inc. System and method for associating text and graphical views of map information
US20070129885A1 (en) * 2005-11-09 2007-06-07 Harald Wellmann Optimum route determination with tiling
US20070130153A1 (en) * 2005-12-02 2007-06-07 Palm, Inc. Techniques to communicate and process location information from communications networks on a mobile computing device

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106940560A (en) * 2010-07-01 2017-07-11 德国福维克控股公司 Surveying and mapping with region division
CN102538801A (en) * 2010-12-16 2012-07-04 上海博泰悦臻电子设备制造有限公司 Method and device for processing road network data in navigation map
CN102538801B (en) * 2010-12-16 2016-03-30 上海博泰悦臻电子设备制造有限公司 A kind of disposal route of road network data in navigation map and device
CN103021257A (en) * 2012-12-04 2013-04-03 北京世纪高通科技有限公司 Method and apparatus for generating electronic map
CN103021257B (en) * 2012-12-04 2015-06-10 北京世纪高通科技有限公司 Method and apparatus for generating electronic map

Similar Documents

Publication Publication Date Title
US20090015596A1 (en) System and method for viewing and editing digital maps using a plug-in data abstraction layer for different digital map formats
US20090013273A1 (en) System and method for using layers and grids to access, view, edit and store digital map data
US20090006480A1 (en) System and method for providing efficient access to digital map data
US7103854B2 (en) System and method for associating text and graphical views of map information
JP5030411B2 (en) How to operate a navigation system to report the impact of updated parts of a geographic database
US7672779B2 (en) System and method for using universal location referencing objects to provide geographic item information
US8069412B2 (en) Methods, systems, and products for mapping facilities data
US6343301B1 (en) Method and system for collecting data for updating a geographic database
JP2619240B2 (en) Method of constructing database representing topology structure and search method thereof
CN102446177B (en) Collecting method, equipment, disposal route, system and base map processing method
EP1944702A1 (en) Updatable navigation database
MacDonald Building a geodatabase
WO2009006427A1 (en) System and method for accessing, viewing, editing and converting digital map information
CN101933015A (en) The system and method that is used for editing cartographic data
US20070106463A1 (en) Navigation apparatus, update data providing apparatus and update data providing method
US20090015595A1 (en) System and method for converting digital map information using displayable map information as an intermediary
US20090157635A1 (en) System and method for using universal location referencing objects to provide geographic information
WO1992002891A1 (en) Interactive automated mapping system
Chan DIGEST A primer for the International GIS Standard
US20100088014A1 (en) Computer process and program product for generating an archaeological map which can be consulted by means of navigation
CN105247322B (en) Information terminal device and map data creating method
Barnett et al. A “roads” data model: a necessary component for feature-based map generalization
JP2007188027A (en) System for updating map data using svg format
CN115292434A (en) GIS route visualization interaction method based on map engine
JP2003173138A (en) Device and method for generating road network

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 08781198

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: DE

122 Ep: pct application non-entry in european phase

Ref document number: 08781198

Country of ref document: EP

Kind code of ref document: A1