• Top
    • Documentation
    • Books
    • Boolean-reasoning
    • Projects
    • Debugging
    • Std
    • Proof-automation
    • Macro-libraries
    • ACL2
    • Interfacing-tools
    • Hardware-verification
    • Software-verification
    • Math
      • 100-theorems
      • Arithmetic
      • Bit-vectors
        • Sparseint
        • Bitops
        • Bv
        • Ihs
          • Logops-definitions
          • Math-lemmas
          • Ihs-theories
          • Ihs-init
          • Logops
            • Logops-lemmas
              • Logops-recursive-definitions-theory
              • Ihs/logbitp-lemmas
              • Ihs/logtail-lemmas
              • Ihs/loghead-lemmas
              • Ihs/logrpl-lemmas
                • Ihs/logand-lemmas
                • Ihs/logapp-lemmas
                • Ihs/logcar-lemmas
                • Ihs/integer-length-lemmas
                • Ihs/unsigned-byte-p-lemmas
                • Ihs/logcons-lemmas
                • Signed-byte-p-logops
                • Ihs/logxor-lemmas
                • Ihs/logior-lemmas
                • Ihs/logext-lemmas
                • Ihs/logextu-lemmas
                • Ihs/signed-byte-p-lemmas
                • Ihs/lognotu-lemmas
                • Ihs/lognot-lemmas
                • Ihs/logmaskp-lemmas
                • Ihs/ash-lemmas
                • Logops-lemmas-theory
                • Ihs/wrb-lemmas
                • Ihs/logite-lemmas
          • Rtl
        • Algebra
      • Testing-utilities
    • Logrpl
    • Logops-lemmas

    Ihs/logrpl-lemmas

    Lemmas about logrpl from the logops-lemmas book.

    Definitions and Theorems

    Theorem: logrpl-0

    (defthm logrpl-0
      (and (implies (logrpl-guard 0 i j)
                    (equal (logrpl 0 i j) j))
           (implies (logrpl-guard size i 0)
                    (equal (logrpl size i 0)
                           (loghead size i)))
           (implies (and (unsigned-byte-p size j)
                         (integerp i))
                    (equal (logrpl size i j)
                           (loghead size i)))))

    Theorem: unsigned-byte-p-logrpl

    (defthm unsigned-byte-p-logrpl
      (implies (and (<= size1 size)
                    (>= j 0)
                    (logrpl-guard size1 i j)
                    (force (integerp size))
                    (force (>= size 0)))
               (equal (unsigned-byte-p size (logrpl size1 i j))
                      (unsigned-byte-p size j))))

    Theorem: logrpl-i-i

    (defthm logrpl-i-i
      (implies (logrpl-guard size i i)
               (equal (logrpl size i i) i)))

    Theorem: logrpl-loghead-i-i

    (defthm logrpl-loghead-i-i
      (implies (and (<= size size1)
                    (loghead-guard size1 i)
                    (force (integerp size))
                    (force (>= size 0)))
               (equal (logrpl size (loghead size1 i) i)
                      i)))

    Theorem: logrpl-logrpl-right

    (defthm logrpl-logrpl-right
      (implies (and (logrpl-guard size1 j k)
                    (logrpl-guard size i (logrpl size1 j k))
                    (<= size1 size))
               (equal (logrpl size i (logrpl size1 j k))
                      (logrpl size i k))))

    Theorem: logrpl-logrpl-left

    (defthm logrpl-logrpl-left
      (implies (and (logrpl-guard size1 i j)
                    (logrpl-guard size (logrpl size1 i j) k)
                    (<= size size1))
               (equal (logrpl size (logrpl size1 i j) k)
                      (logrpl size i k))))