Files
rose-ash/lib/ocaml/baseline/bfs_grid.ml
giles 4761d41a0d
Some checks failed
Test, Build, and Deploy / test-build-deploy (push) Failing after 22s
ocaml: && / || short-circuit fix + bfs_grid.ml baseline (5x5 grid, dist 8)
Before: `:op` handler always evaluated both operands before dispatching
to ocaml-eval-op. For pure binops that's fine, but `&&` / `||` MUST
short-circuit:

  if nr >= 0 && grid.(nr).(nc) = 0 then ...

When nr = -1, real OCaml never evaluates `grid.(-1)`. Our evaluator
did, and crashed with "nth: list/string and number".

Fix: special-case `&&` and `||` in :op dispatch, mirroring the same
pattern already used for `:=` and `<-`. Evaluate lhs, branch on it,
and only evaluate rhs when needed.

Latent since baseline 1 — earlier programs never triggered it because
the rhs was unconditionally safe.

bfs_grid.ml: shortest path through a 5x5 grid with walls. Standard
BFS using Queue.{push,pop,is_empty} + Array.init for the 2D distance
matrix. Path 0,0 -> ... -> 4,4 has length 8. 155 baseline programs
total.
2026-05-10 21:37:41 +00:00

43 lines
935 B
OCaml

let h = 5
let w = 5
let grid = [|
[| 0; 0; 1; 0; 0 |];
[| 1; 0; 1; 0; 1 |];
[| 0; 0; 0; 0; 0 |];
[| 0; 1; 1; 1; 0 |];
[| 0; 0; 0; 0; 0 |]
|]
let step dist q r c nr nc =
if nr >= 0 && nr < h && nc >= 0 && nc < w
&& grid.(nr).(nc) = 0 && dist.(nr).(nc) = -1 then begin
dist.(nr).(nc) <- dist.(r).(c) + 1;
Queue.push (nr * 10 + nc) q
end
let bfs sr sc tr tc =
let dist = Array.init h (fun _ -> Array.make w (-1)) in
let q = Queue.create () in
dist.(sr).(sc) <- 0;
Queue.push (sr * 10 + sc) q;
let go = ref true in
while !go do
if Queue.is_empty q then go := false
else if dist.(tr).(tc) <> -1 then go := false
else begin
let rc = Queue.pop q in
let r = rc / 10 in
let c = rc mod 10 in
step dist q r c (r - 1) c;
step dist q r c (r + 1) c;
step dist q r c r (c - 1);
step dist q r c r (c + 1)
end
done;
dist.(tr).(tc)
;;
bfs 0 0 4 4