Add Markov Clustering
Browse files- app.py +19 -0
- packages.txt +1 -0
app.py
CHANGED
@@ -16,6 +16,7 @@ __author__ = 'Dmitry Ustalov'
|
|
16 |
__license__ = 'Apache 2.0'
|
17 |
|
18 |
import csv
|
|
|
19 |
import re
|
20 |
import subprocess
|
21 |
from dataclasses import dataclass
|
@@ -36,6 +37,7 @@ class Algorithm:
|
|
36 |
local_params: Optional[str] = None
|
37 |
global_name: Optional[str] = None
|
38 |
global_params: Optional[str] = None
|
|
|
39 |
|
40 |
def args_clustering(self) -> List[str]:
|
41 |
args = [self.name]
|
@@ -51,6 +53,9 @@ class Algorithm:
|
|
51 |
if self.global_params:
|
52 |
args.extend(['--global-params', self.global_params])
|
53 |
|
|
|
|
|
|
|
54 |
return args
|
55 |
|
56 |
def args_graph(self) -> List[str]:
|
@@ -65,6 +70,11 @@ class Algorithm:
|
|
65 |
return args
|
66 |
|
67 |
|
|
|
|
|
|
|
|
|
|
|
68 |
ALGORITHMS: Dict[str, Algorithm] = {
|
69 |
'Watset[CW_top, CW_top]': Algorithm('watset', None, 'cw', 'mode=top', 'cw', 'mode=top'),
|
70 |
'Watset[CW_lin, CW_top]': Algorithm('watset', None, 'cw', 'mode=lin', 'cw', 'mode=top'),
|
@@ -84,6 +94,15 @@ ALGORITHMS: Dict[str, Algorithm] = {
|
|
84 |
'MaxMax': Algorithm('maxmax')
|
85 |
}
|
86 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
87 |
SENSE = re.compile(r'^(?P<item>\d+)#(?P<sense>\d+)$')
|
88 |
|
89 |
|
|
|
16 |
__license__ = 'Apache 2.0'
|
17 |
|
18 |
import csv
|
19 |
+
import os
|
20 |
import re
|
21 |
import subprocess
|
22 |
from dataclasses import dataclass
|
|
|
37 |
local_params: Optional[str] = None
|
38 |
global_name: Optional[str] = None
|
39 |
global_params: Optional[str] = None
|
40 |
+
mcl_bin: Optional[str] = None
|
41 |
|
42 |
def args_clustering(self) -> List[str]:
|
43 |
args = [self.name]
|
|
|
53 |
if self.global_params:
|
54 |
args.extend(['--global-params', self.global_params])
|
55 |
|
56 |
+
if self.mcl_bin:
|
57 |
+
args.extend(['--mcl-bin', self.mcl_bin])
|
58 |
+
|
59 |
return args
|
60 |
|
61 |
def args_graph(self) -> List[str]:
|
|
|
70 |
return args
|
71 |
|
72 |
|
73 |
+
if 'MCL_BIN' in os.environ and os.path.isfile(os.environ['MCL_BIN']) and os.access(os.environ['MCL_BIN'], os.X_OK):
|
74 |
+
mcl: Optional[str] = os.environ['MCL_BIN']
|
75 |
+
else:
|
76 |
+
mcl = None
|
77 |
+
|
78 |
ALGORITHMS: Dict[str, Algorithm] = {
|
79 |
'Watset[CW_top, CW_top]': Algorithm('watset', None, 'cw', 'mode=top', 'cw', 'mode=top'),
|
80 |
'Watset[CW_lin, CW_top]': Algorithm('watset', None, 'cw', 'mode=lin', 'cw', 'mode=top'),
|
|
|
94 |
'MaxMax': Algorithm('maxmax')
|
95 |
}
|
96 |
|
97 |
+
if mcl:
|
98 |
+
ALGORITHMS.update({
|
99 |
+
'Watset[CW_top, MCL]': Algorithm('watset', None, 'cw', 'mode=top', 'mcl', 'mcl-bin=' + mcl),
|
100 |
+
'Watset[CW_lin, MCL]': Algorithm('watset', None, 'cw', 'mode=lin', 'mcl', 'mcl-bin=' + mcl),
|
101 |
+
'Watset[CW_log, MCL]': Algorithm('watset', None, 'cw', 'mode=log', 'mcl', 'mcl-bin=' + mcl),
|
102 |
+
'Watset[MCL, MCL]': Algorithm('watset', None, 'mcl', None, 'mcl', 'mcl-bin=' + mcl),
|
103 |
+
'MCL': Algorithm('mcl')
|
104 |
+
})
|
105 |
+
|
106 |
SENSE = re.compile(r'^(?P<item>\d+)#(?P<sense>\d+)$')
|
107 |
|
108 |
|
packages.txt
CHANGED
@@ -1 +1,2 @@
|
|
1 |
default-jre
|
|
|
|
1 |
default-jre
|
2 |
+
mcl
|