<!DOCTYPE html><htmllang="en"><head><metacharset="utf-8"><metaname="viewport"content="width=device-width, initial-scale=1.0"><metaname="generator"content="rustdoc"><metaname="description"content="API documentation for the Rust `pathfind` mod in crate `map_model`."><metaname="keywords"content="rust, rustlang, rust-lang, pathfind"><title>map_model::pathfind - Rust</title><linkrel="stylesheet"type="text/css"href="../../normalize.css"><linkrel="stylesheet"type="text/css"href="../../rustdoc.css"id="mainThemeStyle"><linkrel="stylesheet"type="text/css"href="../../light.css"id="themeStyle"><linkrel="stylesheet"type="text/css"href="../../dark.css"disabled><linkrel="stylesheet"type="text/css"href="../../ayu.css"disabled><scriptid="default-settings"></script><scriptsrc="../../storage.js"></script><noscript><linkrel="stylesheet"href="../../noscript.css"></noscript><linkrel="icon"type="image/svg+xml"href="../../favicon.svg">
<linkrel="alternate icon"type="image/png"href="../../favicon-32x32.png"><styletype="text/css">#crate-search{background-image:url("../../down-arrow.svg");}</style></head><bodyclass="rustdoc mod"><!--[if lte IE 8]><div class="warning">This old browser is unsupported and will most likely display funky things.</div><![endif]--><navclass="sidebar"><divclass="sidebar-menu">☰</div><ahref='../../map_model/index.html'><divclass='logo-container rust-logo'><imgsrc='../../rust-logo.png'alt='logo'></div></a><pclass="location">Module pathfind</p><divclass="sidebar-elems"><divclass="block items"><ul><li><ahref="#reexports">Re-exports</a></li><li><ahref="#modules">Modules</a></li><li><ahref="#structs">Structs</a></li><li><ahref="#enums">Enums</a></li><li><ahref="#functions">Functions</a></li></ul></div><pclass="location"><ahref="../index.html">map_model</a></p><script>window.sidebarCurrent={name:"pathfind",ty:"mod",relpath:"../"};</script><scriptdefersrc="../sidebar-items.js"></script></div></nav><divclass="theme-picker"><buttonid="theme-picker"aria-label="Pick another theme!"aria-haspopup="menu"><imgsrc="../../brush.svg"width="18"alt="Pick another theme!"></button><divid="theme-choices"role="menu"></div></div><scriptsrc="../../theme.js"></script><navclass="sub"><formclass="search-form"><divclass="search-container"><div><selectid="crate-search"><optionvalue="All crates">All crates</option></select><inputclass="search-input"name="search"disabledautocomplete="off"spellcheck="false"placeholder="Click or press ‘S’ to search, ‘?’ for more options…"type="search"></div><buttontype="button"class="help-button">?</button>
<aid="settings-menu"href="../../settings.html"><imgsrc="../../wheel.svg"width="18"alt="Change settings"></a></div></form></nav><sectionid="main"class="content"><h1class="fqn"><spanclass="out-of-band"><spanid="render-detail"><aid="toggle-all-docs"href="javascript:void(0)"title="collapse all docs">[<spanclass="inner">−</span>]</a></span><aclass="srclink"href="../../src/map_model/pathfind/mod.rs.html#1-670"title="goto source code">[src]</a></span><spanclass="in-band">Module <ahref="../index.html">map_model</a>::<wbr><aclass="mod"href="">pathfind</a></span></h1><divclass="docblock"><p>Everything related to pathfinding through a map for different types of agents.</p>
<table><tr><td><code>pub use self::ch::<aclass="struct"href="../../map_model/pathfind/ch/struct.ContractionHierarchyPathfinder.html"title="struct map_model::pathfind::ch::ContractionHierarchyPathfinder">ContractionHierarchyPathfinder</a>;</code></td></tr><tr><td><code>pub use self::dijkstra::<aclass="fn"href="../../map_model/pathfind/dijkstra/fn.build_graph_for_pedestrians.html"title="fn map_model::pathfind::dijkstra::build_graph_for_pedestrians">build_graph_for_pedestrians</a>;</code></td></tr><tr><td><code>pub use self::dijkstra::<aclass="fn"href="../../map_model/pathfind/dijkstra/fn.build_graph_for_vehicles.html"title="fn map_model::pathfind::dijkstra::build_graph_for_vehicles">build_graph_for_vehicles</a>;</code></td></tr><tr><td><code>pub use self::driving::<aclass="fn"href="../../map_model/connectivity/fn.driving_cost.html"title="fn map_model::connectivity::driving_cost">driving_cost</a>;</code></td></tr><tr><td><code>pub use self::pathfinder::<aclass="enum"href="../../map_model/pathfind/pathfinder/enum.Pathfinder.html"title="enum map_model::pathfind::pathfinder::Pathfinder">Pathfinder</a>;</code></td></tr><tr><td><code>pub use self::walking::<aclass="fn"href="../../map_model/pathfind/walking/fn.walking_cost.html"title="fn map_model::pathfind::walking::walking_cost">walking_cost</a>;</code></td></tr><tr><td><code>pub use self::walking::<aclass="enum"href="../../map_model/connectivity/enum.WalkingNode.html"title="enum map_model::connectivity::WalkingNode">WalkingNode</a>;</code></td></tr></table><h2id="modules"class="section-header"><ahref="#modules">Modules</a></h2>
<table><trclass="module-item"><td><aclass="mod"href="ch/index.html"title="map_model::pathfind::ch mod">ch</a></td><tdclass="docblock-short"><p>Uses https://github.com/easbar/fast_paths. Slower creation during map importing, but very fast
</td></tr><trclass="module-item"><td><aclass="mod"href="dijkstra/index.html"title="map_model::pathfind::dijkstra mod">dijkstra</a></td><tdclass="docblock-short"><p>Pathfinding without needing to build a separate contraction hierarchy.</p>
</td></tr><trclass="module-item"><td><aclass="mod"href="driving/index.html"title="map_model::pathfind::driving mod">driving</a></td><tdclass="docblock-short"><p>Pathfinding for cars, bikes, buses, and trains using contraction hierarchies</p>
</td></tr><trclass="module-item"><td><aclass="mod"href="node_map/index.html"title="map_model::pathfind::node_map mod">node_map</a></td><tdclass="docblock-short"><p>Some helpers for working with fast_paths.</p>
</td></tr><trclass="module-item"><td><aclass="mod"href="pathfinder/index.html"title="map_model::pathfind::pathfinder mod">pathfinder</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="mod"href="uber_turns/index.html"title="map_model::pathfind::uber_turns mod">uber_turns</a></td><tdclass="docblock-short"><p>To deal with complicated intersections and short roads in OSM, cluster intersections close
</td></tr><trclass="module-item"><td><aclass="mod"href="walking/index.html"title="map_model::pathfind::walking mod">walking</a></td><tdclass="docblock-short"><p>Pathfinding for pedestrians using contraction hierarchies, as well as figuring out if somebody
<table><trclass="module-item"><td><aclass="struct"href="struct.Path.html"title="map_model::pathfind::Path struct">Path</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="struct"href="struct.PathRequest.html"title="map_model::pathfind::PathRequest struct">PathRequest</a></td><tdclass="docblock-short"></td></tr><trclass="module-item"><td><aclass="struct"href="struct.RoutingParams.html"title="map_model::pathfind::RoutingParams struct">RoutingParams</a></td><tdclass="docblock-short"><p>Tuneable parameters for all types of routing.</p>
<table><trclass="module-item"><td><aclass="enum"href="enum.PathConstraints.html"title="map_model::pathfind::PathConstraints enum">PathConstraints</a></td><tdclass="docblock-short"><p>Who's asking for a path?</p>