forked from thanhnguyen-aws/plausible
-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy pathFunctionCallsTest.lean
More file actions
32 lines (29 loc) · 1.13 KB
/
FunctionCallsTest.lean
File metadata and controls
32 lines (29 loc) · 1.13 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
import Plausible.Chamelean.DecOpt
import Plausible.Chamelean.Enumerators
import Plausible.Chamelean.DeriveChecker
import Plausible.Chamelean.EnumeratorCombinators
import Test.CommonDefinitions.FunctionCallInConclusion
open DecOpt
set_option guard_msgs.diff true
/--
info: Try this checker: instance : DecOpt (square_of n_1 m_1) where
decOpt :=
let rec aux_dec (initSize : Nat) (size : Nat) (n_1 : Nat) (m_1 : Nat) : Option Bool :=
match size with
| Nat.zero =>
DecOpt.checkerBacktrack
[fun _ =>
EnumeratorCombinators.enumeratingOpt
(EnumSizedSuchThat.enumSizedST (fun m_1 => Eq m_1 (HMul.hMul n_1 n_1)) initSize)
(fun m_1 => Option.some Bool.true) (min 2 initSize)]
| Nat.succ size' =>
DecOpt.checkerBacktrack
[fun _ =>
EnumeratorCombinators.enumeratingOpt
(EnumSizedSuchThat.enumSizedST (fun m_1 => Eq m_1 (HMul.hMul n_1 n_1)) initSize)
(fun m_1 => Option.some Bool.true) (min 2 initSize),
]
fun size => aux_dec size size n_1 m_1
-/
#guard_msgs(info, drop warning) in
#derive_checker (square_of n m)