summaryrefslogtreecommitdiff
path: root/routes/analyse.py
diff options
context:
space:
mode:
authorLilian Teronen <lteronen@local>2023-11-27 01:37:03 +0200
committerLilian Teronen <lteronen@local>2023-11-27 01:37:03 +0200
commit03b031ea793e91ce2f87cf28c73cefc8ce69a7b5 (patch)
tree882919559651e1b18904404ccc7c5106d167f1fd /routes/analyse.py
parentd2de3ae10b6f5314bd4b8243218212d2004f35b0 (diff)
More rework on routes. Best and worst matches. More visuals.
Diffstat (limited to 'routes/analyse.py')
-rw-r--r--routes/analyse.py60
1 files changed, 55 insertions, 5 deletions
diff --git a/routes/analyse.py b/routes/analyse.py
index b333e70..3076d99 100644
--- a/routes/analyse.py
+++ b/routes/analyse.py
@@ -1,19 +1,66 @@
+from itertools import combinations
from app import app
from flask import render_template,session,request,redirect
import db_actions as D
from routes.tools import rows2dicts, get_alert, get_nick, red
+def find_best_and_worst(aid, uid):
+ answers=D.get_all_answers_for_quiz(aid)
+ alist=rows2dicts( answers, ['q','u','a'] )
+ questions = set(x['q'] for x in alist)
+ users = set(x['u'] for x in alist)
+ data = {}
+ for q in questions:
+ data[q]={}
+ for i in alist:
+ data[i['q']][i['u']]=i['a']
+ match = {}
+ comb = list(combinations(users,2))
+ if len(comb)<1:
+ comb=[(uid,uid)]
+ min, minme, max, maxme = 101, 101, -1, -1
+ for pair in comb:
+ sum=0
+ for q in questions:
+ sum += 1000 - abs(data[q][pair[0]]-data[q][pair[1]])
+ match[pair]=int(sum / len(questions) / 10 + 0.5)
+ if match[pair] < min:
+ min = match[pair]
+ min_pair = pair
+ if match[pair] > max:
+ max = match[pair]
+ max_pair = pair
+ if pair[0]==uid or pair[1]==uid:
+ if match[pair] < minme:
+ minme = match[pair]
+ minme_pair = pair
+ if match[pair] > maxme:
+ maxme = match[pair]
+ maxme_pair = pair
+ return ( {
+ 'min': min, 'min_u1': min_pair[0], 'min_u2': min_pair[1],
+ 'max': max, 'max_u1': max_pair[0], 'max_u2': max_pair[1],
+ 'minme': minme, 'minme_u1': minme_pair[0], 'minme_u2': minme_pair[1],
+ 'maxme': maxme, 'maxme_u1': maxme_pair[0], 'maxme_u2': maxme_pair[1] })
+
+
@app.route("/pages/analyse.html")
def analyse():
if "id" in session:
sid = session["id"]
else:
- return red["nick"]
+ return render_template(
+ "analyse.html",
+ caller="analyse",
+ alert=get_alert()
+ )
if "answer_id" in session and D.is_user_answered(session["answer_id"],sid):
aid = session["answer_id"]
else:
- return render_template("analyse.html",
+ return render_template(
+ "analyse.html",
+ caller="analyse",
alert=get_alert(),
nick=get_nick()
)
@@ -24,14 +71,16 @@ def analyse():
uid2 = session["anal_user2"] if "anal_user2" in session else sid
uid2 = sid if uid2 != sid and not D.is_user_answered(aid,uid2) else uid2
+
comparable = D.get_comparable( aid, uid1, uid2 )
avg=0
for i in range(len(comparable)):
avg += comparable[i][5]
avg//=len(comparable)
-
- return render_template("analyse.html",
+ return render_template(
+ "analyse.html",
+ caller="analyse",
alert=get_alert(),
nick=get_nick(),
code=D.get_quiz_link(aid),
@@ -39,7 +88,8 @@ def analyse():
users = rows2dicts( D.get_users_answered(aid), ['id','nick'] ),
user1=int(uid1),
user2=int(uid2),
- avg = avg
+ avg = avg,
+ best = find_best_and_worst(aid, sid)
)
@app.route("/set/compare",methods=["POST"])