Exemple #1
0
 def test_identity(self):
     function = BoolFunction(examples.identity)
     function.simulate_all()
     self.assertEqual(function.num_inputs(), 1)
     self.assertEqual(function.num_outputs(), 1)
     self.assertEqual(function.num_input_bits(), 1)
     self.assertEqual(function.num_output_bits(), 1)
     self.assertEqual(str(function.truth_table(output_bit=0)), '10')
     
     result = function.simulate(BitVec(1, '0'))
     self.assertEqual(result, BitVec(1, '0'))
     result = function.simulate(BitVec(1, '1'))
     self.assertEqual(result, BitVec(1, '1'))
Exemple #2
0
    def test_identity(self):
        function = BoolFunction(identity)
        function.simulate_all()
        assert function.num_inputs() == 1
        assert function.num_outputs() == 1
        assert function.num_input_bits() == 1
        assert function.num_output_bits() == 1
        assert str(function.truth_table(output_bit=0)) == "10"

        result = function.simulate(BitVec(1, "0"))
        assert result == BitVec(1, "0")
        result = function.simulate(BitVec(1, "1"))
        assert result == BitVec(1, "1")
Exemple #3
0
 def test_bool_and(self):
     function = BoolFunction(bool_and)
     for a in range(2):
         for b in range(2):
             result = function.simulate(BitVec(1, a), BitVec(1, b))
             tmp = BitVec(1, a) and BitVec(1, b)
             assert result == tmp
Exemple #4
0
 def test_bit_xor_2bit(self):
     function = BoolFunction(bit_xor_2bit)
     for a in range(4):
         for b in range(4):
             result = function.simulate(BitVec(2, a), BitVec(2, b))
             tmp = BitVec(2, a) ^ BitVec(2, b)
             assert result == tmp
Exemple #5
0
 def test_bit_xor_2bit(self):
     function = BoolFunction(examples.bit_xor_2bit)
     for a in range(4):
         for b in range(4):
             result = function.simulate(BitVec(2, a), BitVec(2, b))
             tmp = BitVec(2, a) ^ BitVec(2, b)
             self.assertEqual(result, tmp)
Exemple #6
0
 def test_bit_or(self):
     function = BoolFunction(examples.bit_or)
     for a in range(2):
         for b in range(2):
             result = function.simulate(BitVec(1, a), BitVec(1, b))
             tmp = BitVec(1, a) | BitVec(1, b)
             self.assertEqual(result, tmp)
Exemple #7
0
 def test_bit_or(self):
     function = BoolFunction(bit_or)
     for a in range(2):
         for b in range(2):
             result = function.simulate(BitVec(1, a), BitVec(1, b))
             tmp = BitVec(1, a) | BitVec(1, b)
             assert result == tmp
Exemple #8
0
 def test_bit_ne_2bit(self):
     function = BoolFunction(examples.ne_2bit)
     self.assertEqual(function._parameters_signature,
                      [(type(BitVec(2)), 2), (type(BitVec(2)), 2)])
     for a in range(4):
         for b in range(4):
             result = function.simulate(BitVec(2, a), BitVec(2, b))
             tmp = BitVec(2, a) != BitVec(2, b)
             self.assertEqual(result, tmp)
Exemple #9
0
 def test_ne(self):
     function = BoolFunction(examples.ne)
     self.assertEqual(function._parameters_signature,
                      [(type(BitVec(1)), 1), (type(BitVec(1)), 1)])
     for a in range(2):
         for b in range(2):
             result = function.simulate(BitVec(1, a), BitVec(1, b))
             tmp = BitVec(1, a) != BitVec(1, b)
             self.assertEqual(result, tmp)
Exemple #10
0
 def test_ne(self):
     function = BoolFunction(ne)
     assert function._parameters_signature == [
         (type(BitVec(1)), 1),
         (type(BitVec(1)), 1),
     ]
     for a in range(2):
         for b in range(2):
             result = function.simulate(BitVec(1, a), BitVec(1, b))
             tmp = BitVec(1, a) != BitVec(1, b)
             assert result == tmp
Exemple #11
0
 def test_bit_ne_2bit(self):
     function = BoolFunction(ne_2bit)
     assert function._parameters_signature == [
         (type(BitVec(2)), 2),
         (type(BitVec(2)), 2),
     ]
     for a in range(4):
         for b in range(4):
             result = function.simulate(BitVec(2, a), BitVec(2, b))
             tmp = BitVec(2, a) != BitVec(2, b)
             assert result == tmp
Exemple #12
0
 def test_xor(self):
     function = BoolFunction(examples.bool_and)
     function = BoolFunction.from_truth_table('0110')
     self.assertEqual(function.num_inputs(), 2)
     self.assertEqual(function.num_outputs(), 1)
     self.assertEqual(function.num_input_bits(), 2)
     self.assertEqual(function.num_output_bits(), 1)
     for a in range(2):
         for b in range(2):
             result = function.simulate(BitVec(1, a), BitVec(1, b))
             tmp = BitVec(1, a) ^ BitVec(1, b)
             self.assertEqual(result, tmp)
Exemple #13
0
 def test_not(self):
     function = BoolFunction(bool_not)
     function.simulate_all()
     assert function.num_inputs() == 1
     assert function.num_outputs() == 1
     assert function.num_input_bits() == 1
     assert function.num_output_bits() == 1
     assert str(function.truth_table(output_bit=0)) == "01"
     for a in range(2):
         tmp = BitVec(1, a)
         result = function.simulate(tmp)
         assert result == ~tmp
Exemple #14
0
 def test_not(self):
     function = BoolFunction(examples.bool_not)
     function.simulate_all()
     self.assertEqual(function.num_inputs(), 1)
     self.assertEqual(function.num_outputs(), 1)
     self.assertEqual(function.num_input_bits(), 1)
     self.assertEqual(function.num_output_bits(), 1)
     self.assertEqual(str(function.truth_table(output_bit=0)), '01')
     for a in range(2):
         tmp = BitVec(1, a)
         result = function.simulate(tmp)
         self.assertEqual(result, ~tmp)
Exemple #15
0
 def test_xor(self):
     function = BoolFunction(bool_and)
     function = BoolFunction.from_truth_table("0110")
     assert function.num_inputs() == 2
     assert function.num_outputs() == 1
     assert function.num_input_bits() == 2
     assert function.num_output_bits() == 1
     for a in range(2):
         for b in range(2):
             result = function.simulate(BitVec(1, a), BitVec(1, b))
             tmp = BitVec(1, a) ^ BitVec(1, b)
             assert result == tmp
Exemple #16
0
 def test_identity_2bit(self):
     function = BoolFunction(examples.identity_2bit)
     function.simulate_all()
     self.assertEqual(function.num_inputs(), 1)
     self.assertEqual(function.num_outputs(), 1)
     self.assertEqual(function.num_input_bits(), 2)
     self.assertEqual(function.num_output_bits(), 2)
     self.assertEqual(str(function.truth_table(output_bit=0)), '1010')
     self.assertEqual(str(function.truth_table(output_bit=1)), '1100')
     for a in range(4):
         tmp = BitVec(2, a)
         result = function.simulate(tmp)
         self.assertEqual(result, tmp)
Exemple #17
0
 def test_or(self):
     function = BoolFunction(examples.bool_or)
     function.simulate_all()
     self.assertEqual(function.num_inputs(), 2)
     self.assertEqual(function.num_outputs(), 1)
     self.assertEqual(function.num_input_bits(), 2)
     self.assertEqual(function.num_output_bits(), 1)
     self.assertEqual(str(function.truth_table(output_bit=0)), '1110')
     for a in range(2):
         for b in range(2):
             result = function.simulate(BitVec(1, a), BitVec(1, b))
             tmp = BitVec(1, a) or BitVec(1, b)
             self.assertEqual(result, tmp)
Exemple #18
0
 def test_or(self):
     function = BoolFunction(bool_or)
     function.simulate_all()
     assert function.num_inputs() == 2
     assert function.num_outputs() == 1
     assert function.num_input_bits() == 2
     assert function.num_output_bits() == 1
     assert str(function.truth_table(output_bit=0)) == "1110"
     for a in range(2):
         for b in range(2):
             result = function.simulate(BitVec(1, a), BitVec(1, b))
             tmp = BitVec(1, a) or BitVec(1, b)
             assert result == tmp
Exemple #19
0
 def test_identity_2bit(self):
     function = BoolFunction(identity_2bit)
     function.simulate_all()
     assert function.num_inputs() == 1
     assert function.num_outputs() == 1
     assert function.num_input_bits() == 2
     assert function.num_output_bits() == 2
     assert str(function.truth_table(output_bit=0)) == "1010"
     assert str(function.truth_table(output_bit=1)) == "1100"
     for a in range(4):
         tmp = BitVec(2, a)
         result = function.simulate(tmp)
         assert result == tmp
Exemple #20
0
 def test_not_2bit(self):
     function = BoolFunction(bit_not_2bit)
     function.simulate_all()
     assert function.num_inputs() == 1
     assert function.num_outputs() == 1
     assert function.num_input_bits() == 2
     assert function.num_output_bits() == 2
     assert str(function.truth_table(output_bit=0)) == "0101"
     assert str(function.truth_table(output_bit=1)) == "0011"
     for a in range(4):
         tmp = BitVec(2, a)
         result = function.simulate(tmp)
         assert result == ~tmp
Exemple #21
0
 def test_xor_2bit(self):
     function = BoolFunction(examples.bit_xor_2bit)
     function.simulate_all()
     self.assertEqual(function.num_inputs(), 2)
     self.assertEqual(function.num_outputs(), 1)
     self.assertEqual(function.num_input_bits(), 4)
     self.assertEqual(function.num_output_bits(), 2)
     output0 = BitVec(16, 0xaaaa) ^ BitVec(16, 0xf0f0)
     output1 = BitVec(16, 0xcccc) ^ BitVec(16, 0xff00)
     self.assertEqual(str(function.truth_table(output_bit=0)), str(output0))
     self.assertEqual(str(function.truth_table(output_bit=1)), str(output1))
     for a in range(4):
         for b in range(4):
             result = function.simulate(BitVec(2, a), BitVec(2, b))
             tmp = BitVec(2, a) ^ BitVec(2, b)
             self.assertEqual(result, tmp)
Exemple #22
0
 def test_xor_2bit(self):
     function = BoolFunction(bit_xor_2bit)
     function.simulate_all()
     assert function.num_inputs() == 2
     assert function.num_outputs() == 1
     assert function.num_input_bits() == 4
     assert function.num_output_bits() == 2
     output0 = BitVec(16, 0xAAAA) ^ BitVec(16, 0xF0F0)
     output1 = BitVec(16, 0xCCCC) ^ BitVec(16, 0xFF00)
     assert str(function.truth_table(output_bit=0)) == str(output0)
     assert str(function.truth_table(output_bit=1)) == str(output1)
     for a in range(4):
         for b in range(4):
             result = function.simulate(BitVec(2, a), BitVec(2, b))
             tmp = BitVec(2, a) ^ BitVec(2, b)
             assert result == tmp
Exemple #23
0
 def test_identity(self):
     function = BoolFunction(identity)
     result = function.simulate(BitVec(1, "0"))
     assert result == BitVec(1, "0")
     result = function.simulate(BitVec(1, "1"))
     assert result == BitVec(1, "1")
Exemple #24
0
 def test_constant(self):
     function = BoolFunction(constant)
     result = function.simulate()
     assert result == BitVec(1, "1")
Exemple #25
0
 def test_constant_4bit(self):
     function = BoolFunction(constant_4bit)
     result = function.simulate()
     assert result == BitVec("0000")
Exemple #26
0
 def test_bit_not_2bit(self):
     function = BoolFunction(examples.bit_not_2bit)
     for a in range(4):
         tmp = BitVec(2, a)
         result = function.simulate(tmp)
         self.assertEqual(result, ~tmp)
Exemple #27
0
 def test_bool_not(self):
     function = BoolFunction(bool_not)
     for a in range(2):
         tmp = BitVec(1, a)
         result = function.simulate(tmp)
         assert result == ~tmp
Exemple #28
0
 def test_bit_not_2bit(self):
     function = BoolFunction(bit_not_2bit)
     for a in range(4):
         tmp = BitVec(2, a)
         result = function.simulate(tmp)
         assert result == ~tmp
Exemple #29
0
 def test_identity_not(self):
     function = BoolFunction(identity_not)
     for a in range(4):
         tmp = BitVec(2, a)
         result = function.simulate(tmp)
         assert result == (tmp, ~tmp)
Exemple #30
0
 def test_bool_not(self):
     function = BoolFunction(examples.bool_not)
     for a in range(2):
         tmp = BitVec(1, a)
         result = function.simulate(tmp)
         self.assertEqual(result, ~tmp)