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