You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
In some cases projections can destroy let bindings in lsimp
#check
(fun i : Nat =>
let j := 42
let foo := ((i * j, i+j), (i ^ j, i / j))
foo.fst.snd)
rewrite_by
lsimp (config := {zeta:=false}) only
returns
(fun i : Nat =>
let j := 42
i + j)
which is undesirable. We want to split foo intor four let bindings
(fun i : Nat =>
let j := 42
let foo := ((i * j, i+j), (i ^ j, i / j))
foo.fst.snd)
==>
(fun i : Nat =>
let j := 42
let foo_fst_fst := (i * j)
let foo_fst_snd:= (i+j)
let foo_snd_fst := (i ^ j)
let foo_snd_snd := (i / j)
((foo_fst_fst, foo_fst_snd),(foo_snd_fst,foo_snd_snd)).fst.snd)
==>
(fun i : Nat =>
let j := 42
let foo_fst_snd:= (i+j)
foo_fst_snd)
Such transformation is currently part of let_normalize but should be an integral part of lsimp
The text was updated successfully, but these errors were encountered:
In some cases projections can destroy let bindings in
lsimp
returns
which is undesirable. We want to split
foo
intor four let bindingsSuch transformation is currently part of
let_normalize
but should be an integral part oflsimp
The text was updated successfully, but these errors were encountered: