forked from trueagi-io/hyperon-experimental
-
Notifications
You must be signed in to change notification settings - Fork 0
/
test_atom.py
172 lines (133 loc) · 6.55 KB
/
test_atom.py
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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
import unittest
from hyperon import *
class AtomTest(unittest.TestCase):
def test_symbol_equals(self):
self.assertEqual(S("a"), S("a"))
self.assertNotEqual(S("a"), S("b"))
def test_symbol_str(self):
self.assertEqual(str(S("a")), "a")
def test_symbol_type(self):
self.assertEqual(S("a").get_metatype(), AtomKind.SYMBOL)
def test_symbol_get_symbol(self):
self.assertEqual(S("a").get_name(), "a")
def test_symbol_get_symbol_utf8(self):
self.assertEqual(S("здравствуйте").get_name(), "здравствуйте")
def test_variable_equals(self):
self.assertEqual(V("x"), V("x"))
self.assertNotEqual(V("x"), V("y"))
def test_variable_str(self):
self.assertEqual(str(V("x")), "$x")
def test_variable_type(self):
self.assertEqual(V("x").get_metatype(), AtomKind.VARIABLE)
def test_variable_get_name(self):
self.assertEqual(V("x").get_name(), "x")
def test_grounded_equals(self):
self.assertEqual(ValueAtom(1.0), ValueAtom(1.0))
self.assertNotEqual(ValueAtom(1.0), ValueAtom(2.0))
def test_grounded_str(self):
self.assertEqual(str(ValueAtom(1.0)), "1.0")
self.assertEqual(str(ValueAtom("1.0")), '"1.0"')
def test_grounded_type(self):
self.assertEqual(ValueAtom(1.0).get_metatype(), AtomKind.GROUNDED)
def test_grounded_grounded_type(self):
atom = G(GroundedObject(None), S("Float"))
self.assertEqual(atom.get_grounded_type(), S("Float"))
def test_grounded_no_copy(self):
with self.assertRaises(AssertionError) as context:
atom = G(GroundedNoCopy(), S("GroundedNoCopy"))
self.assertTrue(str(context.exception)
.startswith("Method copy should be implemented by grounded object"))
# def test_grounded_execute_default(self):
# self.assertEqual(ValueAtom(1.0).get_object().execute(VecAtom(),
# VecAtom()), "1.0 is not executable")
def test_grounded_execute(self):
res = x2Atom.get_object().execute(ValueAtom(1.0))
self.assertEqual(res, [ValueAtom(2.0)])
def test_expr_equals(self):
self.assertEqual(E(S("+"), S("1"), S("2")),
E(S("+"), S("1"), S("2")))
def test_expr_equals_grounded(self):
self.assertEqual(E(x2Atom, ValueAtom(1.0)),
E(x2Atom, ValueAtom(1.0)))
def test_expr_str(self):
self.assertEqual(str(E(x2Atom, ValueAtom(1.0))), "(*2 1.0)")
def test_expr_type(self):
self.assertEqual(E(x2Atom, ValueAtom(1.0)).get_metatype(), AtomKind.EXPR)
def test_expr_get_children(self):
self.assertEqual(E(x2Atom, ValueAtom(1.0)).get_children(),
[x2Atom, ValueAtom(1.0)])
def test_groundingspace_equals(self):
kb_a = GroundingSpaceRef()
kb_a.add_atom(E(S("+"), S("1"), S("2")))
kb_b = GroundingSpaceRef()
kb_b.add_atom(E(S("+"), S("1"), S("2")))
kb_c = kb_a
self.assertEqual(kb_a.get_atoms(), kb_b.get_atoms())
self.assertEqual(kb_a, kb_c)
self.assertNotEqual(kb_a, kb_b)
def test_interpret(self):
space = GroundingSpaceRef()
x2 = E(Atoms.METTA, E(x2Atom, ValueAtom(1)), AtomType.UNDEFINED, G(space))
self.assertEqual(interpret(space, x2), [ValueAtom(2)])
def test_grounded_returns_python_value_unwrap_false(self):
def x2_op(atom):
return [2 * atom.get_object().value]
x2Atom = OperationAtom('*2', x2_op, type_names=["Number", "Number"], unwrap=False)
expr = E(x2Atom, ValueAtom(1))
space = GroundingSpaceRef()
self.assertEqual(interpret(space, E(Atoms.METTA, expr, AtomType.UNDEFINED, G(space))),
[E(S('Error'), expr, S('Grounded operation which is defined using unwrap=False should return atom instead of Python type'))])
def test_grounded_no_return(self):
space = GroundingSpaceRef()
def print_op(input):
print(input)
printExpr = E(OperationAtom('print', print_op, type_names=["Atom", "->"], unwrap=False), S("test"))
printExpr = E(Atoms.METTA, printExpr, AtomType.UNDEFINED, G(space))
self.assertTrue(atom_is_error(interpret(space, printExpr)[0]))
printExpr = E(OperationAtom('print', print_op, type_names=["Atom", "->"], unwrap=True), ValueAtom("test"))
printExpr = E(Atoms.METTA, printExpr, AtomType.UNDEFINED, G(space))
self.assertEqual(interpret(space, printExpr), [E()])
def test_no_reduce(self):
space = GroundingSpaceRef()
expr = E(Atoms.METTA, E(noReduceAtom, ValueAtom(1)),
AtomType.UNDEFINED, G(space))
self.assertEqual(interpret(space, expr),
[E(noReduceAtom, ValueAtom(1))])
def test_incorrect_argument(self):
space = GroundingSpaceRef()
expr = E(Atoms.METTA, E(incorrectArgumentAtom, ValueAtom(1)),
AtomType.UNDEFINED, G(space))
self.assertEqual(interpret(space, expr),
[E(incorrectArgumentAtom, ValueAtom(1))])
def test_match_(self):
space = GroundingSpaceRef()
match_atom = MatchableAtomTest(S("MatchableAtom"), type_name=None, atom_id=None)
space.add_atom(match_atom)
result = space.query(E(S('symbol_atom'), V('atom_type')))
self.assertEqual(AtomKind.SYMBOL.name, str(result[0]['atom_type']))
result = space.query(E(E(S("+"), S("1"), S("2")), V('atom_type')))
self.assertEqual(AtomKind.EXPR.name, str(result[0]['atom_type']))
atom = E(G(GroundedObject(None), S("Float")), V('atom_type'))
result = space.query(atom)
self.assertEqual(AtomKind.GROUNDED.name, str(result[0]['atom_type']))
result = space.query(V("Z"))
self.assertEqual(S("MatchableAtom").get_name(), str(result[0]['Z']))
# No unwrap
def x2_op(atom):
return [ValueAtom(2 * atom.get_object().value)]
x2Atom = OperationAtom('*2', x2_op, type_names=["Number", "Number"], unwrap=False)
def no_reduce_op(atom):
raise NoReduceError()
noReduceAtom = OperationAtom('no-reduce', no_reduce_op, unwrap=False)
def incorrect_argument_op(atom):
raise IncorrectArgumentError()
incorrectArgumentAtom = OperationAtom('incorrect-argument', incorrect_argument_op, unwrap=False)
class GroundedNoCopy:
pass
class MatchableObjectTest(MatchableObject):
def match_(self, atom):
return [{'atom_type': S(atom.get_children()[0].get_metatype().name)}]
def MatchableAtomTest(value, type_name=None, atom_id=None):
return G(MatchableObjectTest(value, atom_id), AtomType.UNDEFINED)
if __name__ == "__main__":
unittest.main()