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.
256 lines
11 KiB
Text
256 lines
11 KiB
Text
@[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
|