aboutsummaryrefslogtreecommitdiff
path: root/.venv/lib/python3.12/site-packages/networkx/algorithms/traversal/tests/test_beamsearch.py
diff options
context:
space:
mode:
authorS. Solomon Darnell2025-03-28 21:52:21 -0500
committerS. Solomon Darnell2025-03-28 21:52:21 -0500
commit4a52a71956a8d46fcb7294ac71734504bb09bcc2 (patch)
treeee3dc5af3b6313e921cd920906356f5d4febc4ed /.venv/lib/python3.12/site-packages/networkx/algorithms/traversal/tests/test_beamsearch.py
parentcc961e04ba734dd72309fb548a2f97d67d578813 (diff)
downloadgn-ai-master.tar.gz
two version of R2R are hereHEADmaster
Diffstat (limited to '.venv/lib/python3.12/site-packages/networkx/algorithms/traversal/tests/test_beamsearch.py')
-rw-r--r--.venv/lib/python3.12/site-packages/networkx/algorithms/traversal/tests/test_beamsearch.py25
1 files changed, 25 insertions, 0 deletions
diff --git a/.venv/lib/python3.12/site-packages/networkx/algorithms/traversal/tests/test_beamsearch.py b/.venv/lib/python3.12/site-packages/networkx/algorithms/traversal/tests/test_beamsearch.py
new file mode 100644
index 00000000..049f116b
--- /dev/null
+++ b/.venv/lib/python3.12/site-packages/networkx/algorithms/traversal/tests/test_beamsearch.py
@@ -0,0 +1,25 @@
+"""Unit tests for the beam search functions."""
+
+import pytest
+
+import networkx as nx
+
+
+def test_narrow():
+ """Tests that a narrow beam width may cause an incomplete search."""
+ # In this search, we enqueue only the neighbor 3 at the first
+ # step, then only the neighbor 2 at the second step. Once at
+ # node 2, the search chooses node 3, since it has a higher value
+ # than node 1, but node 3 has already been visited, so the
+ # search terminates.
+ G = nx.cycle_graph(4)
+ edges = nx.bfs_beam_edges(G, source=0, value=lambda n: n, width=1)
+ assert list(edges) == [(0, 3), (3, 2)]
+
+
+@pytest.mark.parametrize("width", (2, None))
+def test_wide(width):
+ """All nodes are searched when `width` is None or >= max degree"""
+ G = nx.cycle_graph(4)
+ edges = nx.bfs_beam_edges(G, source=0, value=lambda n: n, width=width)
+ assert list(edges) == [(0, 3), (0, 1), (3, 2)]