Some checks failed
Tests / Go Tests (push) Has been cancelled
Tests / Python Tests (push) Has been cancelled
Tests / Integration Tests (push) Has been cancelled
Tests / Go Lint (push) Has been cancelled
Tests / Python Lint (push) Has been cancelled
Tests / Security Scan (push) Has been cancelled
Tests / All Checks Passed (push) Has been cancelled
Security Scanning / Secret Scanning (push) Has been cancelled
Security Scanning / Dependency Vulnerability Scan (push) Has been cancelled
Security Scanning / Go Security Scan (push) Has been cancelled
Security Scanning / Python Security Scan (push) Has been cancelled
Security Scanning / Node.js Security Scan (push) Has been cancelled
Security Scanning / Docker Image Security (push) Has been cancelled
Security Scanning / Security Summary (push) Has been cancelled
CI/CD Pipeline / Go Tests (push) Has been cancelled
CI/CD Pipeline / Python Tests (push) Has been cancelled
CI/CD Pipeline / Website Tests (push) Has been cancelled
CI/CD Pipeline / Linting (push) Has been cancelled
CI/CD Pipeline / Security Scan (push) Has been cancelled
CI/CD Pipeline / Docker Build & Push (push) Has been cancelled
CI/CD Pipeline / Integration Tests (push) Has been cancelled
CI/CD Pipeline / Deploy to Staging (push) Has been cancelled
CI/CD Pipeline / Deploy to Production (push) Has been cancelled
CI/CD Pipeline / CI Summary (push) Has been cancelled
ci/woodpecker/manual/build-ci-image Pipeline was successful
ci/woodpecker/manual/main Pipeline failed
All services: admin-v2, studio-v2, website, ai-compliance-sdk, consent-service, klausur-service, voice-service, and infrastructure. Large PDFs and compiled binaries excluded via .gitignore.
44 lines
1.0 KiB
Python
44 lines
1.0 KiB
Python
"""
|
|
Klausur-Service Grading Service
|
|
|
|
Functions for grade calculation.
|
|
"""
|
|
|
|
from typing import Dict
|
|
|
|
from models.grading import GRADE_THRESHOLDS, DEFAULT_CRITERIA
|
|
|
|
|
|
def calculate_grade_points(percentage: float) -> int:
|
|
"""
|
|
Calculate 15-point grade from percentage.
|
|
|
|
Args:
|
|
percentage: Score as percentage (0-100)
|
|
|
|
Returns:
|
|
Grade points (0-15)
|
|
"""
|
|
for points, threshold in sorted(GRADE_THRESHOLDS.items(), reverse=True):
|
|
if percentage >= threshold:
|
|
return points
|
|
return 0
|
|
|
|
|
|
def calculate_raw_points(criteria_scores: Dict[str, Dict]) -> int:
|
|
"""
|
|
Calculate weighted raw points from criteria scores.
|
|
|
|
Args:
|
|
criteria_scores: Dict mapping criterion name to score data
|
|
|
|
Returns:
|
|
Weighted raw points
|
|
"""
|
|
total = 0.0
|
|
for criterion, data in criteria_scores.items():
|
|
weight = DEFAULT_CRITERIA.get(criterion, {}).get("weight", 0.2)
|
|
score = data.get("score", 0)
|
|
total += score * weight
|
|
return int(total)
|