dustalov commited on
Commit
3c5d33d
·
verified ·
1 Parent(s): f7f2122

Add Markov Clustering

Browse files
Files changed (2) hide show
  1. app.py +19 -0
  2. 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