• Top
    • Documentation
    • Books
    • Boolean-reasoning
    • Projects
    • Debugging
    • Community
    • Std
    • Proof-automation
    • Macro-libraries
      • B*
      • Defunc
      • Fty
      • Apt
        • Isodata
          • Isodata-implementation
            • Isodata-event-generation
              • Isodata-gen-everything
              • Isodata-gen-thm-instances-to-terms-back
              • Isodata-gen-new-fn
              • Isodata-gen-new-fn-body-nonpred
              • Isodata-gen-new-fn-verify-guards
                • Isodata-gen-new-fn-verify-guards-hints-nonpred-rec-1res/mres
                • Isodata-gen-new-to-list-of-mv-nth
                • Isodata-gen-new-to-old-lemma
                • Isodata-gen-forth-image-instances-to-terms-back
                • Isodata-gen-forth-guard-instances-to-terms-back
                • Isodata-gen-back-of-forth-instances-to-terms-back
                • Isodata-gen-new-fn-verify-guards-hints-nonpred-nonrec-1res/mres
                • Isodata-gen-defiso
                • Isodata-gen-new-to-old-lemma-hints
                • Isodata-gen-old-to-new-lemma
                • Isodata-gen-new-to-old-thm-hints-1res
                • Isodata-gen-lemma-instances-var-to-new-forth-rec-call-args-back
                • Isodata-gen-new-to-old-thm
                • Isodata-gen-lemma-instances-x1...xn-to-forth-rec-call-args-back
                • Isodata-gen-thm-instances-to-x1...xn
                • Isodata-gen-old-to-new-thm
                • Isodata-gen-new-fn-verify-guards-hints-pred-rec
                • Isodata-gen-all-back-guard-instances-to-mv-nth
                • Isodata-gen-newp-of-new-thm-hints
                • Isodata-gen-lemma-instances-x1...xn-to-rec-call-args-back
                • Isodata-gen-result-vars
                • Isodata-gen-old-to-new-lemma-hints
                • Isodata-gen-newp-of-new-thm
                • Isodata-gen-new-to-old-thm-hints-0res
                • Isodata-gen-new-to-old-thm-hints
                • Isodata-gen-new-fn-verify-guards-hints-nonpred-rec-0res
                • Isodata-gen-lemma-instances-var-to-rec-calls-back
                • Isodata-gen-new-fn-body-pred
                • Isodata-gen-all-back-of-forth-instances-to-mv-nth
                • Isodata-gen-new-fn-verify-guards-hints-nonpred
                • Isodata-gen-new-fn-verify-guards-hints
                • Isodata-gen-all-back-of-forth-instances-to-terms-back
                • Isodata-gen-old-to-new-thm-hints-1res
                • Isodata-gen-all-forth-image-instances-to-terms-back
                • Isodata-gen-all-forth-guard-instances-to-terms-back
                • Isodata-gen-old-to-new-thm-hints
                • Isodata-gen-old-to-list-of-mv-nth
                • Isodata-gen-new-fn-verify-guards-hints-pred-nonrec
                • Isodata-gen-appconds
                • Isodata-gen-forth-image-instances-to-mv-nth
                • Isodata-gen-forth-guard-instances-to-mv-nth
                • Isodata-gen-back-of-forth-instances-to-mv-nth
                • Isodata-gen-back-guard-instances-to-mv-nth
                • Isodata-xform-rec-calls
                • Isodata-gen-old-to-new-thm-formula
                • Isodata-gen-new-fn-verify-guards-hints-nonpred-nonrec-0res
                • Isodata-gen-lemma-instance-x1...xn-to-forth-of-x1...xn
                • Isodata-gen-lemma-instance-x1...xn-to-back-of-x1...xn
                • Isodata-gen-forth-image-instances-to-x1...xn
                • Isodata-gen-forth-guard-instances-to-x1...xn
                • Isodata-gen-back-of-forth-instances-to-x1...xn
                • Isodata-gen-old-to-new-lemma-formula
                • Isodata-gen-newp-of-new-thm-formula
                • Isodata-gen-newp-guard-instances-to-x1...xn
                • Isodata-gen-new-to-old-lemma-formula
                • Isodata-gen-fn-of-terms
                • Isodata-gen-back-image-instances-to-x1...xn
                • Isodata-gen-back-guard-instances-to-x1...xn
                • Isodata-gen-oldp-of-rec-call-args-under-contexts
                • Isodata-gen-new-to-old-thm-formula
                • Isodata-gen-new-fn-termination-hints
                • Isodata-gen-new-fn-body
                • Isodata-gen-lemma-instance-x1...xn-to-fn-of-x1...xn
                • Isodata-gen-old-to-new-thm-hints-0res
                • Isodata-gen-new-fn-verify-guards-hints-pred
                • Isodata-gen-new-fn-guard
                • Isodata-gen-subst-x1...xn-with-back-of-x1...xn
                • Isodata-gen-oldp-of-terms
                • Isodata-gen-newp-of-terms
                • Isodata-gen-forth-of-terms
                • Isodata-gen-defisos
                • Isodata-gen-back-of-terms
                • Isodata-gen-old-to-new-thm-hints-mres
                • Isodata-gen-new-to-old-thm-hints-mres
                • Isodata-gen-new-fn-measure
                • Isodata-formal-of-newp
                • Isodata-formal-of-forth
                • Isodata-formal-of-back
                • Isodata-formal-of-unary
              • Isodata-fn
              • Isodata-input-processing
              • Isodata-macro-definition
          • Simplify-defun
          • Tailrec
          • Schemalg
          • Restrict
          • Expdata
          • Casesplit
          • Simplify-term
          • Simplify-defun-sk
          • Parteval
          • Solve
          • Wrap-output
          • Propagate-iso
          • Simplify
          • Finite-difference
          • Drop-irrelevant-params
          • Copy-function
          • Lift-iso
          • Rename-params
          • Utilities
          • Simplify-term-programmatic
          • Simplify-defun-sk-programmatic
          • Simplify-defun-programmatic
          • Simplify-defun+
          • Common-options
          • Common-concepts
        • Std/util
        • Defdata
        • Defrstobj
        • Seq
        • Match-tree
        • Defrstobj
        • With-supporters
        • Def-partial-measure
        • Template-subst
        • Soft
        • Defthm-domain
        • Event-macros
        • Def-universal-equiv
        • Def-saved-obligs
        • With-supporters-after
        • Definec
        • Sig
        • Outer-local
        • Data-structures
      • ACL2
      • Interfacing-tools
      • Hardware-verification
      • Software-verification
      • Math
      • Testing-utilities
    • Isodata-event-generation

    Isodata-gen-new-fn-verify-guards

    Generate the event to verify the guards of the new function.

    Signature
    (isodata-gen-new-fn-verify-guards 
         appcond-thm-names 
         old$ arg-isomaps res-isomaps 
         predicate$ new$ new-to-old$ old-to-new$ 
         old-fn-unnorm-name newp-of-new$ wrld) 
     
      → 
    new-fn-verify-guards-event
    Arguments
    appcond-thm-names — Guard (symbol-symbol-alistp appcond-thm-names).
    old$ — Guard (symbolp old$).
    arg-isomaps — Guard (isodata-symbol-isomap-alistp arg-isomaps).
    res-isomaps — Guard (isodata-pos-isomap-alistp res-isomaps).
    predicate$ — Guard (booleanp predicate$).
    new$ — Guard (symbolp new$).
    new-to-old$ — Guard (symbolp new-to-old$).
    old-to-new$ — Guard (symbolp old-to-new$).
    old-fn-unnorm-name — Guard (symbolp old-fn-unnorm-name).
    newp-of-new$ — Guard (symbolp newp-of-new$).
    wrld — Guard (plist-worldp wrld).
    Returns
    new-fn-verify-guards-event — A pseudo-event-formp.

    As mentioned elsewhere, the verification of the guards of the new function, when it has to take place, is deferred when the function is introduced. The reason is that, as shown in the design notes, the guard verification proof for the recursive case uses the theorem that relates the old and new functions: thus, the theorem must be proved before guard verification, and the new function must be introduced before proving the theorem. In the non-recursive case, we could avoid deferring guard verification, but we defer it anyhow for uniformity.

    The guard verification event is local to the encapsulate generated by the transformation. This keeps the event history after the transformation ``clean'', without implementation-specific proof hints that may refer to local events of the encapsulate that do not exist in the history after the transformation.

    Definitions and Theorems

    Function: isodata-gen-new-fn-verify-guards

    (defun isodata-gen-new-fn-verify-guards
           (appcond-thm-names old$ arg-isomaps res-isomaps
                              predicate$ new$ new-to-old$ old-to-new$
                              old-fn-unnorm-name newp-of-new$ wrld)
     (declare
          (xargs :guard (and (symbol-symbol-alistp appcond-thm-names)
                             (symbolp old$)
                             (isodata-symbol-isomap-alistp arg-isomaps)
                             (isodata-pos-isomap-alistp res-isomaps)
                             (booleanp predicate$)
                             (symbolp new$)
                             (symbolp new-to-old$)
                             (symbolp old-to-new$)
                             (symbolp old-fn-unnorm-name)
                             (symbolp newp-of-new$)
                             (plist-worldp wrld))))
     (let ((__function__ 'isodata-gen-new-fn-verify-guards))
      (declare (ignorable __function__))
      (b*
       ((hints (isodata-gen-new-fn-verify-guards-hints
                    appcond-thm-names
                    old$ arg-isomaps res-isomaps
                    predicate$ new-to-old$ new$ old-to-new$
                    old-fn-unnorm-name newp-of-new$ wrld))
        (event
         (cons
          'local
          (cons
           (cons 'verify-guards
                 (cons new$
                       (cons ':hints
                             (cons hints '(:guard-simplify :limited)))))
           'nil))))
       event)))