2017-05-11 17:54:02 +00:00
|
|
|
import copy
|
|
|
|
|
2017-05-17 21:54:14 +00:00
|
|
|
import logging
|
2017-05-23 17:04:10 +00:00
|
|
|
|
|
|
|
from . import parsing
|
|
|
|
from . import knowledge_evaluation
|
|
|
|
from .modifiable_property import is_modifiable_property
|
2017-05-11 17:54:02 +00:00
|
|
|
|
|
|
|
|
|
|
|
def diff_knowledge(before, after):
|
|
|
|
import jsondiff
|
|
|
|
return jsondiff.diff(before, after)
|
|
|
|
|
|
|
|
|
|
|
|
class KnowledgeBase(object):
|
|
|
|
def __init__(self, knowledge, examples=[], trained=[]):
|
|
|
|
self.knowledge = copy.copy(knowledge)
|
|
|
|
self.examples = copy.copy(examples)
|
|
|
|
self.trained = copy.copy(trained)
|
|
|
|
|
|
|
|
def train(self, examples):
|
|
|
|
knowledge_before = copy.deepcopy(self.knowledge)
|
|
|
|
|
|
|
|
# Parse everything
|
|
|
|
parsed_examples = []
|
|
|
|
for example in examples:
|
2017-05-22 20:06:49 +00:00
|
|
|
logging.info("\x1b[7;32m> {} \x1b[0m".format(example))
|
2017-05-11 17:54:02 +00:00
|
|
|
tokens, decomposition, inferred_tree = parsing.integrate_language(self, example)
|
2017-05-22 20:06:49 +00:00
|
|
|
logging.info(tokens)
|
2017-05-11 18:24:29 +00:00
|
|
|
result = knowledge_evaluation.integrate_information(self.knowledge, {
|
2017-05-11 17:54:02 +00:00
|
|
|
"elements": tokens,
|
|
|
|
"decomposition": decomposition,
|
|
|
|
"parsed": inferred_tree,
|
|
|
|
})
|
2017-05-15 14:51:39 +00:00
|
|
|
|
2017-05-22 20:06:49 +00:00
|
|
|
logging.info("\x1b[7;33m< {} \x1b[0m".format(self.get_value(result)))
|
2017-05-11 18:24:29 +00:00
|
|
|
self.act_upon(result)
|
2017-05-22 20:06:49 +00:00
|
|
|
logging.info("\x1b[7;34m> set: {} \x1b[0m".format(self.get_value(result)))
|
2017-05-13 18:28:11 +00:00
|
|
|
self.examples.append((decomposition, inferred_tree))
|
2017-05-11 17:54:02 +00:00
|
|
|
|
2017-05-13 18:28:11 +00:00
|
|
|
# Reduce values
|
|
|
|
self.trained = parsing.reprocess_language_knowledge(self, self.examples)
|
2017-05-11 17:54:02 +00:00
|
|
|
|
|
|
|
knowledge_after = copy.deepcopy(self.knowledge)
|
|
|
|
knowledge_diff_getter = lambda: diff_knowledge(knowledge_before,
|
|
|
|
knowledge_after)
|
|
|
|
|
|
|
|
return knowledge_diff_getter
|
|
|
|
|
|
|
|
|
|
|
|
def process(self, row):
|
|
|
|
knowledge_before = copy.deepcopy(self.knowledge)
|
2017-05-22 20:06:49 +00:00
|
|
|
logging.info("\x1b[7;32m> {} \x1b[0m".format(row))
|
2017-05-22 18:20:53 +00:00
|
|
|
tokens = parsing.to_tokens(row)
|
|
|
|
tokens, inferred_tree = parsing.get_fit(self, tokens)
|
2017-05-11 17:54:02 +00:00
|
|
|
result = knowledge_evaluation.integrate_information(self.knowledge,
|
|
|
|
{
|
2017-05-11 18:56:01 +00:00
|
|
|
"elements": tokens,
|
2017-05-11 17:54:02 +00:00
|
|
|
"parsed": inferred_tree,
|
|
|
|
})
|
2017-05-11 18:24:29 +00:00
|
|
|
self.act_upon(result)
|
|
|
|
|
2017-05-11 17:54:02 +00:00
|
|
|
knowledge_after = copy.deepcopy(self.knowledge)
|
|
|
|
knowledge_diff_getter = lambda: diff_knowledge(knowledge_before,
|
|
|
|
knowledge_after)
|
|
|
|
|
2017-05-11 19:13:27 +00:00
|
|
|
return result, inferred_tree, knowledge_diff_getter
|
2017-05-11 18:24:29 +00:00
|
|
|
|
2017-05-15 14:51:39 +00:00
|
|
|
def get_value(self, result):
|
2017-05-22 18:20:53 +00:00
|
|
|
if is_modifiable_property(result):
|
2017-05-15 14:51:39 +00:00
|
|
|
return result.getter()
|
|
|
|
else:
|
|
|
|
return result
|
|
|
|
|
2017-05-11 18:24:29 +00:00
|
|
|
def act_upon(self, result):
|
2017-05-22 18:20:53 +00:00
|
|
|
if is_modifiable_property(result):
|
2017-05-11 18:24:29 +00:00
|
|
|
result.setter()
|
|
|
|
else:
|
2017-05-22 20:06:49 +00:00
|
|
|
logging.warning("Cannot act upon: {}".format(result))
|