-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathoperators.py
More file actions
98 lines (68 loc) · 1.62 KB
/
operators.py
File metadata and controls
98 lines (68 loc) · 1.62 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
# logical connectives
def _negate(truth_value):
if truth_value == "T":
return "F"
else:
return "T"
def _and(p, q):
if p == "T" and q == "T":
return "T"
else:
return "F"
def _or(p, q):
if p == "F" and q == "F":
return "F"
else:
return "T"
def _xor(p, q):
if (p == "T" and q == "T") or (p == "F" and q == "F"):
return "F"
else:
return "T"
def _implies(p, q):
if p == "T" and q == "F":
return "F"
else:
return "T"
def _iff(p, q):
if (p == "T" and q == "T") or (p == "F" and q == "F"):
return "T"
else:
return "F"
# operators to generate truth values
def op_negate(p):
truth_values = []
for x in range(len(p)):
t_v = _negate(p[x])
truth_values.append(t_v)
return truth_values
def op_and(p, q):
truth_values = []
for x in range(len(p)):
t_v = _and(p[x], q[x])
truth_values.append(t_v)
return truth_values
def op_or(p, q):
truth_values = []
for x in range(len(p)):
t_v = _or(p[x], q[x])
truth_values.append(t_v)
return truth_values
def op_xor(p, q):
truth_values = []
for x in range(len(p)):
t_v = _xor(p[x], q[x])
truth_values.append(t_v)
return truth_values
def op_implies(p, q):
truth_values = []
for x in range(len(p)):
t_v = _implies(p[x], q[x])
truth_values.append(t_v)
return truth_values
def op_iff(p, q):
truth_values = []
for x in range(len(p)):
t_v = _iff(p[x], q[x])
truth_values.append(t_v)
return truth_values