Idris2/tests/base/data_bits001/BitOps.idr
2021-03-04 20:59:56 +00:00

442 lines
11 KiB
Idris

import Data.Bits
import Data.DPair
import Data.List
import Data.Stream
import Decidable.Equality
--------------------------------------------------------------------------------
-- Utilities
--------------------------------------------------------------------------------
shl1 : Int -> Int
shl1 = prim__shl_Int 1
b8max : Bits8
b8max = 0xff
b16max : Bits16
b16max = 0xffff
b32max : Bits32
b32max = 0xffffffff
b64max : Bits64
b64max = 18446744073709551615
-- the only way to create -2^63
intmin : Int
intmin = shl1 63
intmax : Int
intmax = 0x7fffffffffffffff
powsOf2 : Num a => Nat -> List a
powsOf2 n = take n (iterate (*2) 1)
--------------------------------------------------------------------------------
-- shiftR
--------------------------------------------------------------------------------
shiftRBits8 : List Bits8
shiftRBits8 = map (`shiftR` fromNat 1) (powsOf2 8 ++ [b8max])
shiftRBits16 : List Bits16
shiftRBits16 = map (`shiftR` fromNat 1) (powsOf2 16 ++ [b16max])
shiftRBits32 : List Bits32
shiftRBits32 = map (`shiftR` fromNat 1) (powsOf2 32 ++ [b32max])
shiftRInt : List Int
shiftRInt = map (`shiftR` fromNat 1) (powsOf2 63 ++ [intmax])
shiftRNegativeInt : List Int
shiftRNegativeInt = map (`shiftR` fromNat 1) (map negate (powsOf2 63) ++ [intmin])
--------------------------------------------------------------------------------
-- shiftL
--------------------------------------------------------------------------------
shiftLBits8 : List Bits8
shiftLBits8 = map (`shiftL` fromNat 1) (0 :: powsOf2 7)
shiftLBits16 : List Bits16
shiftLBits16 = map (`shiftL` fromNat 1) (0 :: powsOf2 15)
shiftLBits32 : List Bits32
shiftLBits32 = map (`shiftL` fromNat 1) (0 :: powsOf2 31)
shiftLInt : List Int
shiftLInt = map (`shiftL` fromNat 1) (0 :: powsOf2 62)
shiftLNegativeInt : List Int
shiftLNegativeInt = map (`shiftL` fromNat 1) (map negate (powsOf2 62))
--------------------------------------------------------------------------------
-- Bitwise AND
--------------------------------------------------------------------------------
andBits8 : List Bits8
andBits8 = [ 11 .&. b8max
, 11 .&. 0
, 11 .&. 1
, 11 .&. 2
, 11 .&. 4
, 11 .&. 11
]
andBits16 : List Bits16
andBits16 = [ 11 .&. b16max
, 11 .&. 0
, 11 .&. 1
, 11 .&. 2
, 11 .&. 4
, 11 .&. 11
]
andBits32 : List Bits32
andBits32 = [ 11 .&. b32max
, 11 .&. 0
, 11 .&. 1
, 11 .&. 2
, 11 .&. 4
, 11 .&. 11
]
andInt : List Int
andInt = [ 11 .&. intmax
, 11 .&. 0
, 11 .&. 1
, 11 .&. 2
, 11 .&. 4
, 11 .&. 11
]
andNegativeInt : List Int
andNegativeInt = [ (-11) .&. intmax
, (-11) .&. 0
, (-11) .&. 1
, (-11) .&. 2
, (-11) .&. 4
, (-11) .&. 11
, (-11) .&. intmin
, (-11) .&. (-1)
, (-11) .&. (-2)
, (-11) .&. (-4)
, (-11) .&. (-11)
]
--------------------------------------------------------------------------------
-- Bitwise OR
--------------------------------------------------------------------------------
orBits8 : List Bits8
orBits8 = [ 11 .|. b8max
, 11 .|. 0
, 11 .|. 1
, 11 .|. 2
, 11 .|. 4
, 11 .|. 11
]
orBits16 : List Bits16
orBits16 = [ 11 .|. b16max
, 11 .|. 0
, 11 .|. 1
, 11 .|. 2
, 11 .|. 4
, 11 .|. 11
]
orBits32 : List Bits32
orBits32 = [ 11 .|. b32max
, 11 .|. 0
, 11 .|. 1
, 11 .|. 2
, 11 .|. 4
, 11 .|. 11
]
orInt : List Int
orInt = [ 11 .|. intmax
, 11 .|. 0
, 11 .|. 1
, 11 .|. 2
, 11 .|. 4
, 11 .|. 11
]
orNegativeInt : List Int
orNegativeInt = [ (-11) .|. intmax
, (-11) .|. 0
, (-11) .|. 1
, (-11) .|. 2
, (-11) .|. 4
, (-11) .|. 11
, (-11) .|. intmin
, (-11) .|. (-1)
, (-11) .|. (-2)
, (-11) .|. (-4)
, (-11) .|. (-11)
]
--------------------------------------------------------------------------------
-- Bitwise XOR
--------------------------------------------------------------------------------
xorBits8 : List Bits8
xorBits8 = [ 11 `xor` b8max
, 11 `xor` 0
, 11 `xor` 1
, 11 `xor` 2
, 11 `xor` 4
, 11 `xor` 11
]
xorBits16 : List Bits16
xorBits16 = [ 11 `xor` b16max
, 11 `xor` 0
, 11 `xor` 1
, 11 `xor` 2
, 11 `xor` 4
, 11 `xor` 11
]
xorBits32 : List Bits32
xorBits32 = [ 11 `xor` b32max
, 11 `xor` 0
, 11 `xor` 1
, 11 `xor` 2
, 11 `xor` 4
, 11 `xor` 11
]
xorInt : List Int
xorInt = [ 11 `xor` intmax
, 11 `xor` 0
, 11 `xor` 1
, 11 `xor` 2
, 11 `xor` 4
, 11 `xor` 11
]
xorNegativeInt : List Int
xorNegativeInt = [ (-11) `xor` intmax
, (-11) `xor` 0
, (-11) `xor` 1
, (-11) `xor` 2
, (-11) `xor` 4
, (-11) `xor` 11
, (-11) `xor` intmin
, (-11) `xor` (-1)
, (-11) `xor` (-2)
, (-11) `xor` (-4)
, (-11) `xor` (-11)
]
--------------------------------------------------------------------------------
-- bit
--------------------------------------------------------------------------------
fromNatMay : (n : Nat) -> (k : Nat) -> Maybe (Subset Nat (`Nat.LT` n))
fromNatMay n k with (decEq (lt k n) True)
fromNatMay n k | (Yes refl) = Just $ fromNat k
fromNatMay n k | (No _) = Nothing
bitBits8 : List Bits8
bitBits8 = map bit $ mapMaybe (fromNatMay 8) [0..7]
bitBits16 : List Bits16
bitBits16 = map bit $ mapMaybe (fromNatMay 16) [0..15]
bitBits32 : List Bits32
bitBits32 = map bit $ mapMaybe (fromNatMay 32) [0..31]
bitInt : List Int
bitInt = map bit $ mapMaybe (fromNatMay 64) [0..63]
--------------------------------------------------------------------------------
-- complementBit
--------------------------------------------------------------------------------
complementBitBits8 : List Bits8
complementBitBits8 = map (`complementBit` fromNat 1) bitBits8
complementBitBits16 : List Bits16
complementBitBits16 = map (`complementBit` fromNat 1) bitBits16
complementBitBits32 : List Bits32
complementBitBits32 = map (`complementBit` fromNat 1) bitBits32
complementBitInt : List Int
complementBitInt = map (`complementBit` fromNat 1) bitInt
--------------------------------------------------------------------------------
-- clearBit
--------------------------------------------------------------------------------
clearBitBits8 : List Bits8
clearBitBits8 = map (`clearBit` fromNat 5) bitBits8
clearBitBits16 : List Bits16
clearBitBits16 = map (`clearBit` fromNat 5) bitBits16
clearBitBits32 : List Bits32
clearBitBits32 = map (`clearBit` fromNat 5) bitBits32
clearBitInt : List Int
clearBitInt = map (`clearBit` fromNat 5) bitInt
--------------------------------------------------------------------------------
-- setBit
--------------------------------------------------------------------------------
setBitBits8 : List Bits8
setBitBits8 = map (`setBit` fromNat 1) bitBits8
setBitBits16 : List Bits16
setBitBits16 = map (`setBit` fromNat 1) bitBits16
setBitBits32 : List Bits32
setBitBits32 = map (`setBit` fromNat 1) bitBits32
setBitInt : List Int
setBitInt = map (`setBit` fromNat 1) bitInt
--------------------------------------------------------------------------------
-- testBit
--------------------------------------------------------------------------------
testBitBits8 : List Bool
testBitBits8 = map (testBit (the Bits8 0xaa))
$ mapMaybe (fromNatMay 8) [0..7]
testBitBits16 : List Bool
testBitBits16 = map (testBit (the Bits16 0xaaaa))
$ mapMaybe (fromNatMay 16) [0..15]
testBitBits32 : List Bool
testBitBits32 = map (testBit (the Bits32 0xaaaaaaaa))
$ mapMaybe (fromNatMay 32) [0..31]
testBitInt : List Bool
testBitInt = map (testBit (the Int 0xaaaaaaaaaaaaaaa))
$ mapMaybe (fromNatMay 64) [0..63]
testBitNegInt : List Bool
testBitNegInt = map (testBit (negate $ the Int 0xaaaaaaaaaaaaaaa))
$ mapMaybe (fromNatMay 64) [0..63]
--------------------------------------------------------------------------------
-- popCount
--------------------------------------------------------------------------------
popCountBits8 : List Nat
popCountBits8 = map popCount [the Bits8 0, 0xaa, 0xff]
popCountBits16 : List Nat
popCountBits16 = map popCount [the Bits16 0, 0xaaaa, 0xffff]
popCountBits32 : List Nat
popCountBits32 = map popCount [the Bits32 0, 0xaaaaaaaa, 0xffffffff]
popCountInt : List Nat
popCountInt = map popCount [ the Int 0
-- 0101 0101 ... 0101
-- => 32
, 0x5555555555555555
, -1
-- 1010 1010 ... 1011
-- => 33
, negate 0x5555555555555555
]
--------------------------------------------------------------------------------
-- Running Tests
--------------------------------------------------------------------------------
main : IO ()
main = do printLn shiftRBits8
printLn shiftRBits16
printLn shiftRBits32
printLn shiftRInt
printLn shiftRNegativeInt
putStrLn ""
printLn shiftLBits8
printLn shiftLBits16
printLn shiftLBits32
printLn shiftLInt
printLn shiftLNegativeInt
putStrLn ""
printLn andBits8
printLn andBits16
printLn andBits32
printLn andInt
printLn andNegativeInt
putStrLn ""
printLn orBits8
printLn orBits16
printLn orBits32
printLn orInt
printLn orNegativeInt
putStrLn ""
printLn xorBits8
printLn xorBits16
printLn xorBits32
printLn xorInt
printLn xorNegativeInt
putStrLn ""
printLn bitBits8
printLn bitBits16
printLn bitBits32
printLn bitInt
putStrLn ""
printLn complementBitBits8
printLn complementBitBits16
printLn complementBitBits32
printLn complementBitInt
putStrLn ""
printLn clearBitBits8
printLn clearBitBits16
printLn clearBitBits32
printLn clearBitInt
putStrLn ""
printLn setBitBits8
printLn setBitBits16
printLn setBitBits32
printLn setBitInt
putStrLn ""
printLn testBitBits8
printLn testBitBits16
printLn testBitBits32
printLn testBitInt
printLn testBitNegInt
putStrLn ""
printLn popCountBits8
printLn popCountBits16
printLn popCountBits32
printLn popCountInt