All notable changes to this project will be documented in this file.
0.8.2 - 2025-06-06
This minor release fixes several bugs, adds two new algorithms, slightly improves the performance of maximum_matching,
adds a tool for parsing graphs from Dot/Graphviz files, and improves the documentation, making it more complete and uniform, as well as clarifying several points.
- Ford Fulkerson sometimes Panics on StableGraphs (#793)
- Run Maximal Cliques Quickcheck only on Digraphs which are symmetrical (#800)
- Run Steiner Tree Quickcheck on the connected components to properly support disconnected graphs (#801)
- Quickcheck random01 function only outputs 0 (#798)
- Specify that Acyclic::try_udpate_edge may add an edge (#770)
- Update remove_node doc comment in graphmap.rs (#663)
- Add examples to minimum spanning tree functions (#808)
- Minimal typo fix in comments (#803)
- Update docs.rs (#807)
- Add note about
StableGraph::edge_indicesbehaviour (#812) - Clarification of references to nodes and V (refresh #358) (#814)
- Fix link and mention Dfs and Bfs as special case in examples (#816)
- Unify algo docs (#815)
- (parser) allow parsing graphs from Dot/Graphviz files (#653)
- Implement
DataMapforGraphMapgraphs (#776) - Add Johnson's algorithm (#741)
- Add algorithm to find bridge edges (#590)
- Reuse queue allocation in
maximum_matchingmain loop (#817)
- Fix new clippy warnings (#791)
0.8.1 - 2025-04-07
This patch release re-adds a missing VisitMap implementation that was dropped in the 0.8.0 release,
improves error messaging in panicking functions, and adds capacity management methods to UnionFind.
- Bring back
VisitMapimpl for stdHashSet(#764)
0.8.0 - 2025-04-05
- Add
no_stdSupport (#747) - Add
VisitMap::unvisitas proposed in #610 (#611) - Add support for specifying rankdir on dot plots. (#728)
- Make
dot::Confignon_exhaustive (#756) - Add
from_f32/64methods forFloat,Unit, andBoundedmeasures (#733)
- Add articulation points implementation (#681)
- Add Prim's Algorithm for Minimum Spanning Tree (#625)
- Add Kou's algorithm for finding a MST (#682)
- Add Bron-Kerbosch algorithm for maximal cliques (#662)
- Add Shortest Path Faster Algorithm Implementation (#686)
- Add
UnionFind::new_set(#684) - Implement
Csr::try_add_edge(#719) - Add checked
UnionFindmethods (#730) - Add
MatrixGraphmethods with recoverable errors (#720) - Add methods with recoverable errors for
GraphandStableGraph(#718)
- Fix all clippy lints and check them on CI (#726)
- Pin once_cell version for MSRV builds (#750)
- Require conventional commits tag in PR titles (#734)
- Fix wrong trigger for pr-title check (#751)
- Solve clippy warnings (#749)
- Fix github token in pr-title action (#752)
- Add new triggers for semver-checks (#754)
- Add some missed features into crate-lvl doc (#758)
0.7.1 - 2025-01-08
0.7.0 - 2024-12-31
- Re-released version 0.6.6 with the correct version number, as it included a major update to an exposed crate (#664).
0.6.6 - 2024-12-31
- Add graph6 format encoder and decoder (#658)
- Dynamic Topological Sort algorithm support (#675)
- Add
UndirectedAdaptor(#695) - Add
LowerHexandUpperHeximplementations forDot(#687) - Make
serdesupport more complete (#550) - Process multiple edges in the Floyd-Warshall implementation (#685)
- Update
fixedbitsetto 0.5.7 (#664) - Fix
immediately_dominated_byfunction called on root of graph returns root itself (#670) - Fix adjacency matrix for
CsrandList(#648) - Fix clippy warnings (#701)
- Add performance note to the
all_simple_pathsfunction documentation (#693)
0.6.5 - 2024-05-06
- Add rayon support for
GraphMap(#573, #615) - Add
Topo::with_initialsmethod (#585) - Add logo to the project (#598)
- Add Ford-Fulkerson algorithm (#640)
- Update
itertoolsto 0.12.1 (#628) - Update
GraphMapto allow custom hash functions (#622) - Fix documentation (#630)
- Fix clippy warnings (#627)
- (internal) Fix remove old
copyclonemacro (#601) - (internal) Move minimum spanning tree into own module (#624)
0.6.4 - 2023-08-21
0.6.3 - 2023-02-07
- Added an iterator over subgraph isomorphisms (#500)
- Added serde support on
GraphMap(#496) - Added
reversemethod forStableGraph(#533) - Added
edges_connectingiterator forStableGraph(#521) - Fix Floyd-Warshall algorithm behaviour on undirected graphs (
487_) - Fix IntoEdgesDirected implementation for NodeFiltered when direction is Incoming (
476_) - Fix cardinality check in subgraph isomorphism (
472_) - Fix UB in
MatrixGraph(#505)
0.6.2 - 2022-05-28
- Loosed the strict version dependency set in
493, to allow users to use newer versions of indexmap (495).
0.6.1 - 2022-05-22
- Added clarifications on Graph docs (
491_). - Fix build errors on rust 1.41 (
493_).
0.6.0 - 2021-07-04
- MSRV is now 1.41 (#444).
- Removed the
NodeCompactIndexabletrait impl forMatrixGraph(#429). - The
IntoEdges::edgesimplementations are now required return edges with the passed node as source (#433).
- Multiple documentation improvements (#360, #383, #426, #433, #437, #443, #450).
- Added an
immediately_dominated_bymethod to the dominators result (#337). - Added
adj::List, a new append-only graph type using a simple adjacency list with no node-weights (#263). - Added
dag_to_toposorted_adjacency_listanddag_transitive_reduction_closurealgorithms to transitively reduce an acyclic graph (#263). - Made the
is_isomorphicalgorithm generic on both graph types (#369). - Implement Debug and Clone for all the iterators (#418).
- Implement multiple mising traits on graph implementations and adapters (#405, #429).
- Add an EdgeIndexable public trait (#402).
- Added immutable
node_weightsandedge_weightsmethods forGraphandStableGraph(#363).
- Added a k-shortest-path implementation (#328).
- Added a generic graph complement implementation (#371).
- Added a maximum matching implementation (#400).
- Added a Floyd-Warshall shortest path algorithm (#377).
- Added a greedy feedback arc set algorithm (#386).
- Added a
find_negative_cyclealgorithm (#434).
- Reuse the internal state in
tarjan_scc(#313) - Reduce memory usage in
tarjan_scc(#413). - Added tighter size hints to all iterators (#380).
- Optimized
petgraph::dota bit (#424). - Optimized StableGraph de-serialization with holes (#395).
- Fixed A* not producing optimal solutions with inconsistent heuristics (#379).
- Fixed a stacked borrow violation (#404).
- Fixed a panic in
StableGraph::extend_with_edges(#415). - Fixed multiple bugs in the matrix graph implementation (#427).
- Fixed
GraphMap::remove_nodenot removing some edges (#432). - Fixed all clippy warnings (#440, #449).
- Now using github actions as CI (#391).
- Replace matchs on
Option<T>withmap(#381). - Added benchmarks for
tarjan_scc(#421).
0.5.1 - 2020-05-23
- Implement
Defaultfor traversals. - Export
EdgesConnectingpublicly. - Implement
is_bipartite_graph. - Add
FilterNodeimplementation forFixedBitSetandHashSet. - Implement
node_weights_mutandedge_weights_mutforStableGraph. - Add configurable functions for adding attributes to dotfile features.
0.5.0 - 2019-12-25
- The iterative DFS implementation,
Dfs, now marks nodes visited when they are pushed onto the stack, not when they're popped off. This may require changes to callers that useDfs::from_partsor manipulate its internals. - The
IntoEdgesDirectedtrait now has a stricter contract for undirected graphs. Custom implementations of this trait may have to be updated. See thetrait documentation__ for more.
- Upgrade to Rust 2018 edition
- Fix clippy warnings and unify code formatting
- Improved and enhanced documentation
- Update dependencies including modern quickcheck
- Numerous bugfixes and refactorings
- Added
MatrixGraphimplementation
__ https://docs.rs/petgraph/0.5/petgraph/visit/trait.IntoEdgesDirected.html
0.4.13 - 2018-08-26
- Fix clippy warnings by @jonasbb
- Add docs for
Csrby @ksadorf - Fix conflict with new stable method
find_mapin new Rust
0.4.12 - 2018-03-26
- Newtype
Timenow also implementsHash - Documentation updates for
Frozen.
0.4.11 - 2018-01-07
- Fix
petgraph::graph::NodeReferencesto be publicly visible - Small doc typo and code style files by @shepmaster and @waywardmonkeys
- Fix a future compat warning with pointer casts
0.4.10 - 2017-08-15
- Add graph trait
IntoEdgesDirected - Update dependencies
0.4.9 - 2017-10-02
- Fix
bellman_fordto work correctly with undirected graphs (#152) by @carrutstick - Performance improvements for
Graph, Stablegraph's.map().
0.4.8 - 2017-09-20
-
StableGraphlearned new methods nearing parity withGraph. Note that theStableGraphmethods preserve index stability even in the batch removal methods likefilter_mapandretain_edges.- Added
.filter_map(), which maps associated node and edge data - Added
.retain_edges(),.edge_indices()and.clear_edges()
- Added
-
Existing
Graphiterators gained some trait impls:.node_indices(), .edge_indices()areExactSizeIterator.node_references()is nowDoubleEndedIterator + ExactSizeIterator..edge_references()is nowExactSizeIterator.
-
Implemented
From<StableGraph>forGraph.
0.4.7 - 2017-09-16
- New algorithm by @jmcomets: A* search algorithm in
petgraph::algo::astar - One
StableGraphbug fix whose patch was supposed to be in the previous version:add_edge(m, n, _)now properly always panics if nodes m or n don't exist in the graph.
0.4.6 - 2017-09-12
-
New optional crate feature:
"serde-1", which enables serialization forGraphandStableGraphusing serde. -
Add methods
new,add_nodetoCsrby @jmcomets -
Add indexing with
[]by node index,NodeCompactIndexableforCsrby @jmcomets -
Amend doc for
GraphMap::into_graph(it has a case where it can panic) -
Add implementation of
From<Graph>forStableGraph. -
Add implementation of
IntoNodeReferencesfor&StableGraph. -
Add method
StableGraph::mapthat maps associated data -
Add method
StableGraph::find_edge_undirected -
Many
StableGraphbug fixes involving node vacancies (holes left by deletions):neighbors(n)and similar neighbor and edge iterator methods now handle n being a vacancy properly. (This produces an empty iterator.)find_edge(m, n)now handles m being a vacancy correctly tooStableGraph::node_boundwas fixed for empty graphs and returns 0
-
Add implementation of
DoubleEndedIteratortoGraph, StableGraph's edge references iterators. -
Debug output for
Graphnow shows node and edge count.Graph, StableGraphshow nothing for the edges list if it's empty (no label). -
Arbitraryimplementation forStableGraphnow can produce graphs with vacancies (used by quickcheck)
0.4.5 - 2017-06-16
- Fix
maxambiguity error with current rust nightly by @daboross (#153)
0.4.4 - 2017-03-14
- Add
GraphMap::all_edges_mut()iterator by @Binero - Add
StableGraph::retain_nodesby @Rupsbant - Add
StableGraph::index_twice_mutby @christolliday
0.4.3 - 2017-01-21
- Add crate categories
0.4.2 - 2017-01-06
- Move the
visit.rsfile due to changed rules for a module’s directory ownership in Rust, resolving a future compat warning. - The error types
Cycle, NegativeCyclenow implementPartialEq.
0.4.1 - 2016-10-26
- Add new algorithm
simple_fastfor computing dominators in a control-flow graph.
0.4.0 - 2016-10-17
Graph::edgesand the other edges methods now return an iterator of edge references
toposortnow returns an error if the graph had a cycle.is_cyclic_directedno longer takes a dfs space argument. It is now recursive.sccwas renamed tokosaraju_scc.min_spanning_treenow returns an iterator that needs to be made into a specific graph type deliberately.dijkstranow uses theIntoEdgestrait.NodeIndexablechanged its method signatures.IntoExternalswas removed, and many other smaller adjustments in graph traits.NodeIdmust now implementPartialEq, for example.DfsIter, BfsIterwere removed in favour of a more general approach with theWalkertrait and its iterator conversion.
- New graph traits, for example
IntoEdgeswhich returns an iterator of edge references. Everything implements the graph traits much more consistently. - Traits for associated data access and building graphs:
DataMap,Build, Create, FromElements. - Graph adaptors:
EdgeFiltered.Filteredwas renamed toNodeFiltered. - New algorithms: bellman-ford
- New graph: compressed sparse row (
Csr). GraphMapimplementsNodeIndexable.Dotwas generalized
0.3.2 - 2016-10-11
- Add
depth_first_search, a recursive dfs visitor that emits discovery, finishing and edge classification events. - Add graph adaptor
Filtered. - impl
Debug, NodeIndexableforReversed.
0.3.1 - 2016-10-05
- Add
.edges(), .edges_directed()toStableGraph. Note that these differ fromGraph, because this is the signature they will all use in the future. - Add
.update_edge()toStableGraph. - Add reexports of common items in
stable_graphmodule (for exampleNodeIndex). - Minor performance improvements to graph iteration
- Improved docs for
visitmodule.
0.3.0 - 2016-10-03
-
Overhaul all graph visitor traits so that they use the
IntoIteratorstyle. This makes them composable.- Multiple graph algorithms use new visitor traits.
- Help is welcome to port more algorithms (and create new graph traits in the process)!
-
GraphMapcan now have directed edges.GraphMap::newis now generic in the edge type.DiGraphMapandUnGraphMapare new type aliases. -
Add type aliases
DiGraph, UnGraph, StableDiGraph, StableUnGraph -
GraphMapis based on the indexmap crate. Deterministic iteration order, faster iteration, no side tables needed to convert toGraph. -
Improved docs for a lot of types and functions.
-
Add graph visitor
DfsPostOrder -
Dfsgained new methodsfrom_partsandreset. -
New algo
has_path_connecting. -
New algo
tarjan_scc, a second scc implementation. -
Document traversal order in
Dfs, DfsPostOrder, scc, tarjan_scc. -
Optional graph visitor workspace reuse in
has_path_connecting,is_cyclic_directed, toposort. -
Improved
Debugformatting forGraph, StableGraph. -
Add a prelude module
-
GraphMapnow has a method.into_graph()that makes aGraph. -
Graph::retain_nodes, retain_edgesnow expose the self graph only as wrapped inFrozen, so that weights can be mutated but the graph structure not. -
Enable
StableGraphby default -
Add method
Graph::contains_edge. -
Renamed
EdgeDirection→Direction. -
Remove
SubTopo. -
Require Rust 1.12 or later
0.2.10 - 2016-07-27
- Fix compilation with rust nightly
0.2.9 - 2016-10-01
- Fix a bug in SubTopo (#81)
0.2.8 - 2016-09-12
- Add Graph methods reserve_nodes, reserve_edges, reserve_exact_nodes, reserve_exact_edges, shrink_to_fit_edges, shrink_to_fit_nodes, shrink_to_fit
0.2.7 - 2016-04-22
- Update URLs
0.2.6 - 2016-04-20
- Fix warning about type parameter defaults (no functional change)
0.2.5 - 2016-04-10
- Add SubTopo, a topo walker for the subgraph reachable from a starting point.
- Add condensation, which forms the graph of a graph’s strongly connected components.
0.2.4 - 2016-04-05
- Fix an algorithm error in scc (#61). This time we have a test that crosschecks the result of the algorithm vs another implementation, for greater confidence in its correctness.
0.2.3 - 2016-02-22
- Require Rust 1.6: Due to changes in how rust uses type parameter defaults.
- Implement Graph::clone_from.
0.2.2 - 2015-12-14
- Require Rust 1.5
Dotpasses on the alternate flag to node and edge label formatting- Add
Cloneimpl for some iterators - Document edge iteration order for
Graph::neighbors - Add experimental feature
StableGraph, using feature flagstable_graph
0.2.1 - 2015-12-06
- Add algorithm
is_isomorphic_matching
0.2.0 - 2015-12-03
- Add Graph::neighbors().detach() to step edges without borrowing. This is more general than, and replaces now deprecated walk_edges_directed. (#39)
- Implement Default for Graph, GraphMap
- Add method EdgeDirection::opposite()
- Graph::neighbors() for undirected graphs and Graph::neighbors_undirected for any graph now visit self loop edges once, not twice. (#31)
- Renamed Graph::without_edges to Graph::externals
- Removed Graph::edges_both
- GraphMap::add_edge now returns
Option<E> - Element type of
GraphMap<N, E>::all_edges()changed to(N, N, &E)
- IntoWeightedEdge changed a type parameter to associated type
- IndexType is now an unsafe trait
- Removed IndexType::{one, zero}, use method new instead.
- Removed MinScored
- Ptr moved to the graphmap module.
- Directed, Undirected are now void enums.
- Fields of graphmap::Edges are now private (#19)
0.1.18 - 2015-11-30
- Fix bug on calling GraphMap::add_edge with existing edge (#35)
0.1.17 - 2015-11-25
- Add Graph::capacity(), GraphMap::capacity()
- Fix bug in Graph::reverse()
- Graph and GraphMap have
quickcheck::Arbitraryimplementations, if optional featurecheckis enabled.
0.1.16 - 2015-11-25
- Add Graph::node_indices(), Graph::edge_indices()
- Add Graph::retain_nodes(), Graph::retain_edges()
- Add Graph::extend_with_edges(), Graph::from_edges()
- Add functions petgraph::graph::{edge_index, node_index};
- Add GraphMap::extend(), GraphMap::from_edges()
- Add petgraph::dot::Dot for simple graphviz dot output
0.1.15 - 2015-11-20
- Add Graph::clear_edges()
- Add Graph::edge_endpoints()
- Add Graph::map() and Graph::filter_map()
0.1.14 - 2015-11-19
- Add new topological order visitor Topo
- New graph traits NeighborsDirected, Externals, Revisitable
0.1.13 - 2015-11-11
- Add iterator GraphMap::all_edges
0.1.12 - 2015-11-07
- Fix an algorithm error in scc (#14)
0.1.11 - 2015-08-16
- Update for well-formedness warnings (Rust RFC 1214), adding new lifetime bounds on NeighborIter and Dfs, impact should be minimal.
0.1.10 - 2015-06-22
- Fix bug in WalkEdges::next_neighbor()
0.1.9 - 2015-06-17
- Fix Dfs/Bfs for a rustc bugfix that disallowed them
- Add method next_neighbor() to WalkEdges
0.1.8 - 2015-06-08
- Add Graph::walk_edges_directed()
- Add Graph::index_twice_mut()
0.1.7 - 2015-06-08
- Add Graph::edges_directed()
0.1.6 - 2015-06-04
- Add Graph::node_weights_mut and Graph::edge_weights_mut
0.1.4 - 2015-05-20
- Add back DfsIter, BfsIter