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
|