• Top
    • Documentation
    • Books
    • Boolean-reasoning
    • Projects
      • Apt
      • Zfc
      • Acre
      • Milawa
      • Smtlink
      • Abnf
        • Deftreeops
        • Defdefparse
          • Defdefparse-implementation
            • Defdefparse-event-generation
              • Defdefparse-gen-function-for-rulename
              • Defdefparse-gen-code-for-alternation
              • Defdefparse-gen-code-for-repetition
              • Defdefparse-gen-function-for-group
              • Defdefparse-function-spec
                • Defdefparse-function-spec-fix
                • Defdefparse-function-spec-case
                • Defdefparse-function-spec-equiv
                  • Defdefparse-function-spec-p
                  • Defdefparse-function-spec-rulename
                  • Defdefparse-function-spec-option
                  • Defdefparse-function-spec-group
                  • Defdefparse-function-spec-repetition
                  • Defdefparse-function-spec-kind
                • Defdefparse-gen-code-for-element
                • Defdefparse-gen-*-group-macro
                • Defdefparse-gen-function-for-option
                • Defdefparse-gen-option-macro
                • Defdefparse-gen-group-macro
                • Defdefparse-gen-function-for-repetition
                • Defdefparse-gen-code-for-concatenation
                • Defdefparse-gen-*-rulename-macro
                • Defdefparse-gen-rulename-macro
                • Defdefparse-gen-repetition-alist
                • Defdefparse-gen-option-alist
                • Defdefparse-gen-group-alist
                • Defdefparse-gen-everything
                • Defdefparse-gen-repetition-table-macro
                • Defdefparse-gen-option-table-macro
                • Defdefparse-gen-group-table-macro
                • Defdefparse-gen-function-for-spec
                • Defdefparse-gen-repetition-table
                • Defdefparse-gen-option-table
                • Defdefparse-gen-group-table
                • Defdefparse-reorder-alternation
                • Defdefparse-order-permutationp
                • Defdefparse-gen-repetition-table-name
                • Defdefparse-gen-option-table-name
                • Defdefparse-gen-group-table-name
                • Defdefparse-alt-symbol-alist
                • Defdefparse-rep-symbol-alist
              • Defdefparse-fn
              • Defdefparse-input-processing
              • Defdefparse-table
              • Defdefparse-macro-definition
          • Defgrammar
          • Tree-utilities
          • Notation
          • Grammar-parser
          • Meta-circular-validation
          • Parsing-primitives-defresult
          • Parsing-primitives-seq
          • Operations
          • Examples
          • Differences-with-paper
          • Constructor-utilities
          • Grammar-printer
          • Parsing-tools
        • Vwsim
        • Isar
        • Wp-gen
        • Dimacs-reader
        • Pfcs
        • Legacy-defrstobj
        • C
        • Proof-checker-array
        • Soft
        • Farray
        • Rp-rewriter
        • Instant-runoff-voting
        • Imp-language
        • Sidekick
        • Ethereum
        • Leftist-trees
        • Java
        • Riscv
        • Taspi
        • Bitcoin
        • Zcash
        • Des
        • X86isa
        • Sha-2
        • Yul
        • Proof-checker-itp13
        • Regex
        • ACL2-programming-language
        • Json
        • Jfkr
        • Equational
        • Cryptography
        • Axe
        • Poseidon
        • Where-do-i-place-my-book
        • Aleo
        • Bigmems
        • Builtins
        • Execloader
        • Solidity
        • Paco
        • Concurrent-programs
        • Bls12-377-curves
      • Debugging
      • Community
      • Std
      • Proof-automation
      • Macro-libraries
      • ACL2
      • Interfacing-tools
      • Hardware-verification
      • Software-verification
      • Math
      • Testing-utilities
    • Defdefparse-function-spec

    Defdefparse-function-spec-equiv

    Basic equivalence relation for defdefparse-function-spec structures.

    Definitions and Theorems

    Function: defdefparse-function-spec-equiv$inline

    (defun defdefparse-function-spec-equiv$inline (acl2::x acl2::y)
      (declare
           (xargs :guard (and (defdefparse-function-spec-p acl2::x)
                              (defdefparse-function-spec-p acl2::y))))
      (equal (defdefparse-function-spec-fix acl2::x)
             (defdefparse-function-spec-fix acl2::y)))

    Theorem: defdefparse-function-spec-equiv-is-an-equivalence

    (defthm defdefparse-function-spec-equiv-is-an-equivalence
      (and (booleanp (defdefparse-function-spec-equiv x y))
           (defdefparse-function-spec-equiv x x)
           (implies (defdefparse-function-spec-equiv x y)
                    (defdefparse-function-spec-equiv y x))
           (implies (and (defdefparse-function-spec-equiv x y)
                         (defdefparse-function-spec-equiv y z))
                    (defdefparse-function-spec-equiv x z)))
      :rule-classes (:equivalence))

    Theorem: defdefparse-function-spec-equiv-implies-equal-defdefparse-function-spec-fix-1

    (defthm
     defdefparse-function-spec-equiv-implies-equal-defdefparse-function-spec-fix-1
     (implies (defdefparse-function-spec-equiv acl2::x x-equiv)
              (equal (defdefparse-function-spec-fix acl2::x)
                     (defdefparse-function-spec-fix x-equiv)))
     :rule-classes (:congruence))

    Theorem: defdefparse-function-spec-fix-under-defdefparse-function-spec-equiv

    (defthm
     defdefparse-function-spec-fix-under-defdefparse-function-spec-equiv
     (defdefparse-function-spec-equiv
          (defdefparse-function-spec-fix acl2::x)
          acl2::x)
     :rule-classes (:rewrite :rewrite-quoted-constant))

    Theorem: equal-of-defdefparse-function-spec-fix-1-forward-to-defdefparse-function-spec-equiv

    (defthm
     equal-of-defdefparse-function-spec-fix-1-forward-to-defdefparse-function-spec-equiv
     (implies (equal (defdefparse-function-spec-fix acl2::x)
                     acl2::y)
              (defdefparse-function-spec-equiv acl2::x acl2::y))
     :rule-classes :forward-chaining)

    Theorem: equal-of-defdefparse-function-spec-fix-2-forward-to-defdefparse-function-spec-equiv

    (defthm
     equal-of-defdefparse-function-spec-fix-2-forward-to-defdefparse-function-spec-equiv
     (implies (equal acl2::x
                     (defdefparse-function-spec-fix acl2::y))
              (defdefparse-function-spec-equiv acl2::x acl2::y))
     :rule-classes :forward-chaining)

    Theorem: defdefparse-function-spec-equiv-of-defdefparse-function-spec-fix-1-forward

    (defthm
     defdefparse-function-spec-equiv-of-defdefparse-function-spec-fix-1-forward
     (implies (defdefparse-function-spec-equiv
                   (defdefparse-function-spec-fix acl2::x)
                   acl2::y)
              (defdefparse-function-spec-equiv acl2::x acl2::y))
     :rule-classes :forward-chaining)

    Theorem: defdefparse-function-spec-equiv-of-defdefparse-function-spec-fix-2-forward

    (defthm
     defdefparse-function-spec-equiv-of-defdefparse-function-spec-fix-2-forward
     (implies (defdefparse-function-spec-equiv
                   acl2::x
                   (defdefparse-function-spec-fix acl2::y))
              (defdefparse-function-spec-equiv acl2::x acl2::y))
     :rule-classes :forward-chaining)