M1-Survey-Engine/tools/statistics/analyse/duration_per_age.py
2024-01-24 16:14:15 +01:00

40 lines
1,011 B
Python

from collections import defaultdict
import matplotlib.pyplot as plt
import numpy as np
from tools.statistics import extract
def analyse(datas: list[dict]):
ages_duration: dict[int, int] = defaultdict(lambda: 0)
ages_count: dict[int, int] = defaultdict(lambda: 0)
# TODO: faire des tranches d'âges ?
for data in datas:
age = extract.age.extract(data)
ages_count[age] += 1
for survey in data["surveys"].keys():
# only scan survey mission
if not survey.startswith("mission-"):
continue
ages_duration[age] += extract.mission_duration.extract(data, survey)
x = list(ages_duration.keys())
y = (
np.array(list(ages_duration.values()))
/ np.array(list(ages_count.values()))
)
# prepare plotting
figure: plt.Figure = plt.figure()
axes = figure.add_subplot(1, 1, 1)
axes.set_title("Temps moyen passé par âge")
# bar chart
axes.bar(x, y)
plt.show(block=True)