Generate UUIDs for Geographic Information messages.
Map points, features and segments all have universally unique identifier names (UUID), using geographic_msgs/UniqueID messages.
Matching features within each name space must yield the same UUID. The method used is RFC 4122 variant 5, computing the SHA-1 hash of a URL encoded using the map source.
For example, Open Street Map identifiers are encoded like this:
generate('http://openstreetmap.org/node/', node_id)
generate('http://openstreetmap.org/way/', way_id)
generate('http://openstreetmap.org/relation/', rel_id)
Here the *_id parameters are integer representations of OSM node, way, or relation identifiers.
For RouteSegment graph edges we use:
generate('http://ros.org/wiki/PACKAGE_NAME/START_UUID/END_UUID')
Where PACKAGE_NAME is the generating ROS package, START_UUID names the beginning way point, and END_UUID is the ending way point.
Note
We store the string representation of the UUID in the geographic_msgs/UniqueID message. That uses over twice the space of a 16-byte array, but makes the messages human-readable.
Generate UUID for geographic data.
Parameters: |
|
---|---|
Returns: | standard Python uuid object |
Raises : | ValueError if id not convertible to int. |
Create a UniqueID message for id number in name space ns.
Parameters: |
|
---|---|
Returns: | geographic_msgs/UniqueID message |
Raises : | ValueError if id not convertible to int. |