This repository has been archived by the owner on Jul 22, 2019. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmain.py
86 lines (71 loc) · 3.36 KB
/
main.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
#!/usr/bin/python
# -*- coding: utf-8 -*-
from flask import Flask, render_template, request
from aba.aba_parser import ABA_Parser
from aba.aba_perf_logger import ABA_Perf_Logger
from networkx.readwrite import json_graph
import json
import jsonpickle
import logging
import os
app = Flask(__name__)
@app.route("/")
def main():
return render_template("index.html")
@app.route("/api", methods=['POST'])
def api():
logging.basicConfig(filename=os.path.join('logs', 'main.log'),level=logging.DEBUG,format='[%(asctime)s] %(levelname)s:%(name)s: %(message)s',datefmt='%Y-%m-%d %H:%M:%S')
## Safety measure so that the process won't overshoot my RAM limit
# import sys
# if sys.platform == "win32" and protect_ram:
# import perf_memory_limiter
# five_gb = 5 * 1024 * 1024 * 1024
# perf_memory_limiter.set_limit(os.getpid(), five_gb)
global_perf_logger = ABA_Perf_Logger("Request handler")
global_perf_logger.start()
source_code = request.form['source_code']
parser = ABA_Parser(source_code)
parse_errors = parser.parse()
aba = None
data = dict()
try:
aba = parser.construct_aba()
except MemoryError:
data['errors'] = str(exp)
return json.dumps(data)
except Exception as exp:
data['errors'] = str(exp)
return json.dumps(data)
arg_graph = aba.get_combined_argument_graph()
data['parse_errors'] = parse_errors
data['arguments'] = json_graph.node_link_data(arg_graph)
data['dispute_trees'] = dict()
data['dispute_trees_data'] = dict()
for argument, i in aba.arguments:
symbol = argument.root
dispute_tree = aba.get_dispute_tree(symbol, i)
if dispute_tree is not None:
for dt_index, dt_graph in enumerate(dispute_tree.graphs):
dt_name = "%s_%s_%s" % (symbol, i, dt_index)
data['dispute_trees'][dt_name] = jsonpickle.encode(json_graph.node_link_data(dt_graph), unpicklable=False, max_depth=6, make_refs=False)
data['dispute_trees_data'][dt_name] = dict()
data['dispute_trees_data'][dt_name]['is_conflict_free'] = argument.is_conflict_free[i]
data['dispute_trees_data'][dt_name]['is_stable'] = argument.is_stable[i]
data['dispute_trees_data'][dt_name]['is_admissible'] = dispute_tree.is_admissible[dt_index]
data['dispute_trees_data'][dt_name]['is_grounded'] = dispute_tree.is_grounded[dt_index]
data['dispute_trees_data'][dt_name]['is_ideal'] = dispute_tree.is_ideal[dt_index]
data['dispute_trees_data'][dt_name]['is_complete'] = dispute_tree.is_complete[dt_index]
global_perf_logger.end()
data['statistics'] = dict()
data['statistics']['wall_time'] = global_perf_logger.wall_time
data['statistics']['cpu_time'] = global_perf_logger.cpu_time
data['statistics']['symbols'] = len(aba.symbols)
data['statistics']['assumptions'] = len(aba.assumptions)
data['statistics']['arguments'] = len(aba.arguments)
data['statistics']['potential_arguments'] = len(aba.potential_arguments)
stat = ['is_conflict_free', 'is_stable', 'is_admissible', 'is_grounded', 'is_ideal', 'is_complete']
for st in stat:
data['statistics'][st] = len([x for x in data['dispute_trees_data'].values() if x[st]])
return json.dumps(data)
if __name__ == "__main__":
app.run()