(vl-lucid-dissect st) → (mv reportcard typos)
Function:
(defun vl-lucid-dissect (st) (declare (xargs :guard (vl-lucidstate-p st))) (let ((__function__ 'vl-lucid-dissect)) (declare (ignorable __function__)) (b* (((vl-lucidstate st)) (copy (fast-alist-fork st.db nil)) (- (fast-alist-free copy))) (vl-lucid-dissect-database copy nil st nil))))
Theorem:
(defthm vl-reportcard-p-of-vl-lucid-dissect.reportcard (b* (((mv ?reportcard ?typos) (vl-lucid-dissect st))) (vl-reportcard-p reportcard)) :rule-classes :rewrite)
Theorem:
(defthm vl-typocandidates-p-of-vl-lucid-dissect.typos (b* (((mv ?reportcard ?typos) (vl-lucid-dissect st))) (vl-typocandidates-p typos)) :rule-classes :rewrite)
Theorem:
(defthm vl-lucid-dissect-of-vl-lucidstate-fix-st (equal (vl-lucid-dissect (vl-lucidstate-fix st)) (vl-lucid-dissect st)))
Theorem:
(defthm vl-lucid-dissect-vl-lucidstate-equiv-congruence-on-st (implies (vl-lucidstate-equiv st st-equiv) (equal (vl-lucid-dissect st) (vl-lucid-dissect st-equiv))) :rule-classes :congruence)