lean4-htt/tests/elab/do_for_loop_levenstein_compiler_test.lean
Garmelon 08eb78a5b2
chore: switch to new test/bench suite (#12590)
This PR sets up the new integrated test/bench suite. It then migrates
all benchmarks and some related tests to the new suite. There's also
some documentation and some linting.

For now, a lot of the old tests are left alone so this PR doesn't become
even larger than it already is. Eventually, all tests should be migrated
to the new suite though so there isn't a confusing mix of two systems.
2026-02-25 13:51:53 +00:00

256 lines
11 KiB
Text
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

@[inline] unsafe def Array.forInNew'Unsafe {α : Type u} {σ β : Type v} {m : Type v → Type w}
(as : Array α) (s : σ) (kcons : (a : α) → (h : a ∈ as) → (σ → m β) → σ → m β) (knil : σ → m β) : m β :=
let sz := as.usize
let rec @[specialize] loop (i : USize) (s : σ) : m β :=
if i < sz then
let a := as.uget i lcProof
kcons a lcProof (loop (i+1)) s
else
knil s
loop 0 s
@[inline] protected def Std.Legacy.Range.forInNew' {m : Type u → Type v} {σ β} (range : Range) (init : σ)
(kcons : (i : Nat) → i ∈ range → (σ → m β) → σ → m β) (knil : σ → m β) : m β :=
have := range.step_pos
let rec @[specialize] loop (i : Nat)
(hs : (i - range.start) % range.step = 0) (hl : range.start ≤ i := by omega) : σ → m β :=
if h : i < range.stop then
kcons i ⟨hl, by omega, hs⟩ (loop (i + range.step) (by rwa [Nat.add_comm, Nat.add_sub_assoc hl, Nat.add_mod_left]))
else
knil
loop range.start (by simp) (by simp) init
/--
trace: [Compiler.saveMono] size: 13
def _private.Init.Data.Array.Basic.0.Array.anyMUnsafe.any._at_.Array.contains._at_.deletions.spec_0.spec_0 a as i stop : Bool :=
let _x.1 := USize.decEq i stop;
cases _x.1 : Bool
| Bool.false =>
let _x.2 := Array.uget ◾ as i ◾;
let _x.3 := String.decEq a _x.2;
cases _x.3 : Bool
| Bool.false =>
let _x.4 := 1;
let _x.5 := USize.add i _x.4;
let _x.6 := _private.Init.Data.Array.Basic.0.Array.anyMUnsafe.any._at_.Array.contains._at_.deletions.spec_0.spec_0 a as _x.5 stop;
return _x.6
| Bool.true =>
return _x.3
| Bool.true =>
let _x.7 := false;
return _x.7
[Compiler.saveMono] size: 12
def Array.contains._at_.deletions.spec_0 as a : Bool :=
let _x.1 := 0;
let _x.2 := Array.size ◾ as;
let _x.3 := Nat.decLt _x.1 _x.2;
cases _x.3 : Bool
| Bool.false =>
return _x.3
| Bool.true =>
cases _x.3 : Bool
| Bool.false =>
return _x.3
| Bool.true =>
let _x.4 := 0;
let _x.5 := USize.ofNat _x.2;
let _x.6 := _private.Init.Data.Array.Basic.0.Array.anyMUnsafe.any._at_.Array.contains._at_.deletions.spec_0.spec_0 a as _x.4 _x.5;
return _x.6
[Compiler.saveMono] size: 19
def Array.forInNew'Unsafe.loop._at_.deletions.spec_2 as sz i s : Array String :=
let _x.1 := USize.decLt i sz;
cases _x.1 : Array String
| Bool.false =>
let _x.2 := Array.reverse._redArg s;
return _x.2
| Bool.true =>
let a := Array.uget ◾ as i ◾;
let _x.3 := String.utf8ByteSize a;
let _x.4 := 0;
let _x.5 := Nat.decEq _x.3 _x.4;
cases _x.5 : Array String
| Bool.false =>
let _x.6 := 1;
let _x.7 := USize.add i _x.6;
let _x.8 := String.length a;
let _x.9 := 1;
let _x.10 := Std.Legacy.Range.mk _x.4 _x.8 _x.9 ◾;
let _x.11 := Std.Legacy.Range.forInNew'.loop._at_.deletions.spec_1._at_.Array.forInNew'Unsafe.loop._at_.deletions.spec_2.spec_4._redArg as sz _x.7 a _x.3 _x.10 _x.4 s;
return _x.11
| Bool.true =>
let _x.12 := Array.reverse._redArg s;
return _x.12
[Compiler.saveMono] size: 31
def Std.Legacy.Range.forInNew'.loop._at_.Std.Legacy.Range.forInNew'.loop._at_.deletions.spec_1._at_.Array.forInNew'Unsafe.loop._at_.deletions.spec_2.spec_4.spec_4._redArg s' _x.1 as sz _x.2 range i a.3 : Array
String :=
cases range : Array String
| Std.Legacy.Range.mk start stop step step_pos =>
let _x.4 := Nat.decLt i stop;
cases _x.4 : Array String
| Bool.false =>
let _x.5 := Array.forInNew'Unsafe.loop._at_.deletions.spec_2 as sz _x.2 a.3;
return _x.5
| Bool.true =>
let _x.6 := 1;
let _x.7 := 0;
let _x.8 := Nat.decEq _x.1 _x.7;
let _x.9 := Nat.add i step;
let _x.10 := String.utf8ByteSize s';
let _x.11 := String.Slice.mk s' _x.7 _x.10 ◾;
let _x.12 := @String.Slice.Pos.nextn _x.11 _x.7 i;
let _x.13 := @String.extract s' _x.7 _x.12;
let _x.14 := Nat.add i _x.6;
let _x.15 := @String.Slice.Pos.nextn _x.11 _x.7 _x.14;
let _x.16 := @String.extract s' _x.15 _x.10;
let d := String.append _x.13 _x.16;
jp _jp.17 : Array String :=
let out := Array.push ◾ a.3 d;
let _x.18 := Std.Legacy.Range.forInNew'.loop._at_.Std.Legacy.Range.forInNew'.loop._at_.deletions.spec_1._at_.Array.forInNew'Unsafe.loop._at_.deletions.spec_2.spec_4.spec_4._redArg s' _x.1 as sz _x.2 range _x.9 out;
return _x.18;
let _x.19 := Array.contains._at_.deletions.spec_0 a.3 d;
cases _x.19 : Array String
| Bool.false =>
goto _jp.17
| Bool.true =>
cases _x.8 : Array String
| Bool.false =>
let _x.20 := Std.Legacy.Range.forInNew'.loop._at_.Std.Legacy.Range.forInNew'.loop._at_.deletions.spec_1._at_.Array.forInNew'Unsafe.loop._at_.deletions.spec_2.spec_4.spec_4._redArg s' _x.1 as sz _x.2 range _x.9 a.3;
return _x.20
| Bool.true =>
goto _jp.17
[Compiler.saveMono] size: 31
def Std.Legacy.Range.forInNew'.loop._at_.deletions.spec_1._at_.Array.forInNew'Unsafe.loop._at_.deletions.spec_2.spec_4._redArg as sz _x.1 s' _x.2 range i a.3 : Array
String :=
cases range : Array String
| Std.Legacy.Range.mk start stop step step_pos =>
let _x.4 := Nat.decLt i stop;
cases _x.4 : Array String
| Bool.false =>
let _x.5 := Array.forInNew'Unsafe.loop._at_.deletions.spec_2 as sz _x.1 a.3;
return _x.5
| Bool.true =>
let _x.6 := 1;
let _x.7 := 0;
let _x.8 := Nat.decEq _x.2 _x.7;
let _x.9 := Nat.add i step;
let _x.10 := String.utf8ByteSize s';
let _x.11 := String.Slice.mk s' _x.7 _x.10 ◾;
let _x.12 := @String.Slice.Pos.nextn _x.11 _x.7 i;
let _x.13 := @String.extract s' _x.7 _x.12;
let _x.14 := Nat.add i _x.6;
let _x.15 := @String.Slice.Pos.nextn _x.11 _x.7 _x.14;
let _x.16 := @String.extract s' _x.15 _x.10;
let d := String.append _x.13 _x.16;
jp _jp.17 : Array String :=
let out := Array.push ◾ a.3 d;
let _x.18 := Std.Legacy.Range.forInNew'.loop._at_.Std.Legacy.Range.forInNew'.loop._at_.deletions.spec_1._at_.Array.forInNew'Unsafe.loop._at_.deletions.spec_2.spec_4.spec_4._redArg s' _x.2 as sz _x.1 range _x.9 out;
return _x.18;
let _x.19 := Array.contains._at_.deletions.spec_0 a.3 d;
cases _x.19 : Array String
| Bool.false =>
goto _jp.17
| Bool.true =>
cases _x.8 : Array String
| Bool.false =>
let _x.20 := Std.Legacy.Range.forInNew'.loop._at_.Std.Legacy.Range.forInNew'.loop._at_.deletions.spec_1._at_.Array.forInNew'Unsafe.loop._at_.deletions.spec_2.spec_4.spec_4._redArg s' _x.2 as sz _x.1 range _x.9 a.3;
return _x.20
| Bool.true =>
goto _jp.17
[Compiler.saveMono] size: 15
def deletions n s : Array String :=
let zero := 0;
let isZero := Nat.decEq n zero;
cases isZero : Array String
| Bool.true =>
let _x.1 := 1;
let _x.2 := Array.mkEmpty ◾ _x.1;
let _x.3 := Array.push ◾ _x.2 s;
return _x.3
| Bool.false =>
let one := 1;
let n.4 := Nat.sub n one;
let out := Array.mkEmpty ◾ zero;
let _x.5 := deletions n.4 s;
let sz := Array.usize ◾ _x.5;
let _x.6 := 0;
let _x.7 := Array.forInNew'Unsafe.loop._at_.deletions.spec_2 _x.5 sz _x.6 out;
return _x.7
[Compiler.saveMono] size: 31
def Std.Legacy.Range.forInNew'.loop._at_.deletions.spec_1._redArg s' _x.1 kcontinue range i a.2 : Array String :=
cases range : Array String
| Std.Legacy.Range.mk start stop step step_pos =>
let _x.3 := Nat.decLt i stop;
cases _x.3 : Array String
| Bool.false =>
let _x.4 := kcontinue a.2;
return _x.4
| Bool.true =>
let _x.5 := 1;
let _x.6 := 0;
let _x.7 := Nat.decEq _x.1 _x.6;
let _x.8 := Nat.add i step;
let _x.9 := String.utf8ByteSize s';
let _x.10 := String.Slice.mk s' _x.6 _x.9 ◾;
let _x.11 := @String.Slice.Pos.nextn _x.10 _x.6 i;
let _x.12 := @String.extract s' _x.6 _x.11;
let _x.13 := Nat.add i _x.5;
let _x.14 := @String.Slice.Pos.nextn _x.10 _x.6 _x.13;
let _x.15 := @String.extract s' _x.14 _x.9;
let d := String.append _x.12 _x.15;
jp _jp.16 : Array String :=
let out := Array.push ◾ a.2 d;
let _x.17 := Std.Legacy.Range.forInNew'.loop._at_.deletions.spec_1._redArg s' _x.1 kcontinue range _x.8 out;
return _x.17;
let _x.18 := Array.contains._at_.deletions.spec_0 a.2 d;
cases _x.18 : Array String
| Bool.false =>
goto _jp.16
| Bool.true =>
cases _x.7 : Array String
| Bool.false =>
let _x.19 := Std.Legacy.Range.forInNew'.loop._at_.deletions.spec_1._redArg s' _x.1 kcontinue range _x.8 a.2;
return _x.19
| Bool.true =>
goto _jp.16
[Compiler.saveMono] size: 1
def Std.Legacy.Range.forInNew'.loop._at_.deletions.spec_1 s' _x.1 kcontinue range this i hs hl a.2 : Array String :=
let _x.3 := Std.Legacy.Range.forInNew'.loop._at_.deletions.spec_1._redArg s' _x.1 kcontinue range i a.2;
return _x.3
[Compiler.saveMono] size: 1
def Std.Legacy.Range.forInNew'.loop._at_.deletions.spec_1._at_.Array.forInNew'Unsafe.loop._at_.deletions.spec_2.spec_4 as sz _x.1 s' _x.2 range this i hs hl a.3 : Array
String :=
let _x.4 := Std.Legacy.Range.forInNew'.loop._at_.deletions.spec_1._at_.Array.forInNew'Unsafe.loop._at_.deletions.spec_2.spec_4._redArg as sz _x.1 s' _x.2 range i a.3;
return _x.4
[Compiler.saveMono] size: 1
def Std.Legacy.Range.forInNew'.loop._at_.Std.Legacy.Range.forInNew'.loop._at_.deletions.spec_1._at_.Array.forInNew'Unsafe.loop._at_.deletions.spec_2.spec_4.spec_4 s' _x.1 as sz _x.2 range this i hs hl a.3 : Array
String :=
let _x.4 := Std.Legacy.Range.forInNew'.loop._at_.Std.Legacy.Range.forInNew'.loop._at_.deletions.spec_1._at_.Array.forInNew'Unsafe.loop._at_.deletions.spec_2.spec_4.spec_4._redArg s' _x.1 as sz _x.2 range i a.3;
return _x.4
-/
#guard_msgs in
set_option trace.Compiler.saveMono true in
unsafe def deletions (n : Nat) (s : String) : Array String :=
match n with
| 0 => #[s]
| n' + 1 => Id.run do
let out := #[];
have kbreak := fun (s : Array String) =>
let out := s;
pure out.reverse;
(deletions n' s).forInNew'Unsafe out
(fun s' _ kcontinue s =>
let out := s;
if s'.isEmpty = true then kbreak out
else
[:s'.length].forInNew' out
(fun i _ kcontinue s =>
let out := s;
let d := (s'.take i).copy ++ s'.drop (i + 1);
if (!out.contains d) = true then
let out := out.push d;
kcontinue out
else kcontinue out)
fun s =>
let out := s;
kcontinue out)
kbreak