• 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
          • Bitops/merge
          • Bitops-compatibility
          • Bitops-books
          • Logbitp-reasoning
          • Bitops/signed-byte-p
          • Fast-part-select
          • Bitops/integer-length
          • Bitops/extra-defs
          • Install-bit
          • Trailing-0-count
          • Bitops/defaults
          • Logbitp-mismatch
          • Trailing-1-count
          • Bitops/rotate
          • Bitops/equal-by-logbitp
          • Bitops/ash-bounds
          • Bitops/fast-logrev
          • Limited-shifts
          • Bitops/part-select
          • Bitops/parity
          • Bitops/saturate
          • Bitops/part-install
          • Bitops/logbitp-bounds
          • Bitops/ihsext-basics
          • Bitops/fast-rotate
          • Bitops/fast-logext
            • Fast-logext
              • Fast-logext-exec
                • Fast-logext64
                • Fast-logext16
                • Fast-logext8
                • Fast-logext32
                • Fast-logext-fn
            • Bitops/ihs-extensions
          • Bv
          • Ihs
          • Rtl
        • Algebra
      • Testing-utilities
    • Fast-logext

    Fast-logext-exec

    Executable definition of fast-logext in the general case.

    Signature
    (fast-logext-exec b x) → *
    Arguments
    b — Guard (posp b).
    x — Guard (integerp x).

    Definitions and Theorems

    Function: fast-logext-exec$inline

    (defun fast-logext-exec$inline (b x)
      (declare (xargs :guard (and (posp b) (integerp x))))
      (let ((__function__ 'fast-logext-exec))
        (declare (ignorable __function__))
        (b* ((x1 (logand (1- (ash 1 b)) x))
             (m (ash 1 (- b 1))))
          (- (logxor x1 m) m))))

    Theorem: fast-logext-exec-is-logext

    (defthm fast-logext-exec-is-logext
      (implies (posp b)
               (equal (fast-logext-exec b x)
                      (logext b x))))