summaryrefslogtreecommitdiff
path: root/searx/engines
diff options
context:
space:
mode:
authorDalf <alex@al-f.net>2014-01-06 18:53:41 +0100
committerDalf <alex@al-f.net>2014-01-06 18:53:41 +0100
commit289a5707ed41ea143a5f0f7adf42b863a59efe35 (patch)
tree53d063c7334ac5cc758857e8cefa9ed3c039fe96 /searx/engines
parentdfce4fd86560e172c7864902f95e84aba8cf3731 (diff)
parent23b327c6ae47c4b9bc9f00f95b19201b37d237d6 (diff)
downloadsearxng-289a5707ed41ea143a5f0f7adf42b863a59efe35.tar.gz
searxng-289a5707ed41ea143a5f0f7adf42b863a59efe35.zip
Merge remote-tracking branch 'upstream/master'
Diffstat (limited to 'searx/engines')
-rw-r--r--searx/engines/__init__.py13
1 files changed, 11 insertions, 2 deletions
diff --git a/searx/engines/__init__.py b/searx/engines/__init__.py
index 1ca11ff90..e011737cf 100644
--- a/searx/engines/__init__.py
+++ b/searx/engines/__init__.py
@@ -226,12 +226,14 @@ def search(query, request, selected_engines):
return results, suggestions
def get_engines_stats():
+ # TODO refactor
pageloads = []
results = []
scores = []
errors = []
+ scores_per_result = []
- max_pageload = max_results = max_score = max_errors = 0
+ max_pageload = max_results = max_score = max_errors = max_score_per_result = 0
for engine in engines.values():
if engine.stats['search_count'] == 0:
continue
@@ -239,16 +241,19 @@ def get_engines_stats():
load_times = engine.stats['page_load_time']/float(engine.stats['search_count'])
if results_num:
score = engine.stats['score_count'] / float(engine.stats['search_count'])
+ score_per_result = score / results_num
else:
- score = 0
+ score = score_per_result = 0.0
max_results = max(results_num, max_results)
max_pageload = max(load_times, max_pageload)
max_score = max(score, max_score)
+ max_score_per_result = max(score_per_result, max_score_per_result)
max_errors = max(max_errors, engine.stats['errors'])
pageloads.append({'avg': load_times, 'name': engine.name})
results.append({'avg': results_num, 'name': engine.name})
scores.append({'avg': score, 'name': engine.name})
errors.append({'avg': engine.stats['errors'], 'name': engine.name})
+ scores_per_result.append({'avg': score_per_result, 'name': engine.name})
for engine in pageloads:
engine['percentage'] = int(engine['avg']/max_pageload*100)
@@ -259,6 +264,9 @@ def get_engines_stats():
for engine in scores:
engine['percentage'] = int(engine['avg']/max_score*100)
+ for engine in scores_per_result:
+ engine['percentage'] = int(engine['avg']/max_score_per_result*100)
+
for engine in errors:
if max_errors:
engine['percentage'] = int(float(engine['avg'])/max_errors*100)
@@ -269,5 +277,6 @@ def get_engines_stats():
return [('Page loads (sec)', sorted(pageloads, key=itemgetter('avg')))
,('Number of results', sorted(results, key=itemgetter('avg'), reverse=True))
,('Scores', sorted(scores, key=itemgetter('avg'), reverse=True))
+ ,('Scores per result', sorted(scores_per_result, key=itemgetter('avg'), reverse=True))
,('Errors', sorted(errors, key=itemgetter('avg'), reverse=True))
]