Skip to main content

Crate maliput

Crate maliput 

Source
Expand description

§maliput

github crates.io docs.rs build status

Creates Rustacean API for maliput. It is implemented on top of maliput-sys package.

Note: What is maliput? Refer to https://maliput.readthedocs.org.

§Description

maliput provides a Rust API implemented on top of FFI bindings provided by maliput-sys package.

§Features

Backends are exposed as Cargo features:

FeatureDefaultDescription
maliput_malidriveOpenDRIVE (.xodr) backend
maliput_geopackageGeoPackage (.gpkg) backend
allEnables both backends

Only RoadNetworkBackend variants for enabled features are available. With default features, only MaliputMalidrive is compiled in.

# Default (maliput_malidrive only)
cargo build

# Both backends
cargo build --features all

# Only maliput_geopackage
cargo build --no-default-features --features maliput_geopackage

§Usage

  use maliput::api::{RoadNetwork, RoadNetworkBackend};
  use std::collections::HashMap;

  fn main() -> Result<(), Box<dyn std::error::Error>> {
    // Get location of odr resources
    let package_location = std::env::var("CARGO_MANIFEST_DIR").unwrap();
    let xodr_path = format!("{}/data/xodr/TShapeRoad.xodr", package_location);

    let road_network_properties = HashMap::from([
        ("road_geometry_id", "my_rg_from_rust"),
        ("opendrive_file", xodr_path.as_str()),
    ]);

    let road_network = RoadNetwork::new(RoadNetworkBackend::MaliputMalidrive, &road_network_properties)?;
    let road_geometry = road_network.road_geometry();

    // Exercise the RoadGeometry API.
    println!("linear_tolerance: {}", road_geometry.linear_tolerance());
    println!("angular_tolerance: {}", road_geometry.angular_tolerance());
    println!("num_junctions: {}", road_geometry.num_junctions());

    let lanes = road_geometry.get_lanes();
    println!("num_lanes: {}", lanes.len());
    println!("lanes: ");
    for lane in lanes {
        println!("\tlane id: {}", lane.id());
    }
    Ok(())
  }

§Apps

  • maliput_query: A command-line tool for interactively querying a road network. It loads a road network using the available backends (depending on enabled features) and provides a set of commands to inspect its geometric properties and perform coordinate transformations.

    To run the application:

    cargo run --bin maliput_query -- <path_to_file>

    For example, using one of the provided XODR files (requires maliput_malidrive feature, enabled by default):

    cargo run --bin maliput_query -- data/xodr/TShapeRoad.xodr

§Examples

  • Load maliput::api::RoadNetwork and perform some basic queries against the Road Geometry.

    cargo run --example 01_road_geometry
  • Load maliput::api::RoadNetwork from a GeoPackage file and perform basic Road Geometry queries.

    cargo run --example 12_geopackage_road_geometry --features maliput_geopackage

§Benches

  • Evaluate the execution of maliput::api::RoadGeometry::to_road_position method.

    cargo bench to_road_position
  • Evaluate the execution of maliput::api::Lane::to_lane_position method.

    cargo bench to_lane_position
  • Evaluate the execution of maliput::api::RoadGeometry::to_road_position method using the GeoPackage backend.

    cargo bench to_road_position_geopackage --features maliput_geopackage
  • Evaluate the execution of maliput::api::Lane::to_lane_position method using the GeoPackage backend.

cargo bench to_lane_position_geopackage --features maliput_geopackage

§License

Licensed under BSD 3-Clause.

Modules§

api
common
math
utility

Structs§

ResourceManager
ResourceManager