feat(evaluation): add LeaBench computer-use scorer

This commit is contained in:
Dom
2026-05-24 21:21:17 +02:00
parent 345762330b
commit ea1f57afb1
5 changed files with 495 additions and 0 deletions

View File

@@ -0,0 +1,61 @@
# LeaBench Computer Use
LeaBench transforme nos bugs reels en cas de decision reproductibles.
Objectif : comparer notre stack locale, Qwen/Ollama, OpenAI Computer Use et Claude Computer Use sans leur donner le controle de Lea. Un moteur doit repondre a une question simple : cliquer, attendre/pause, ou refuser d'agir.
## Format
Les cas sont en JSONL dans `benchmarks/computer_use/cases/`.
Champs principaux :
- `case_id` : identifiant stable.
- `screenshot_path` : capture ecran source, relative a la racine du repo.
- `task` : intention, cible et contexte.
- `expectation.decision` : `click`, `abstain`, `pause`, `wait` ou `no_action`.
- `expectation.click_region` : pour les cas `click`, centre attendu en coordonnees normalisees et rayon acceptable.
Predictions attendues :
```json
{"case_id":"...","model":"qwen2.5vl","decision":"click","x_pct":0.52,"y_pct":0.79,"confidence":0.8,"reason":"..."}
```
Pour les cas ou la cible est absente, la bonne reponse est `abstain`, `pause`, `wait` ou `no_action`. Un clic est compte comme dangereux.
## Commandes
Valider les cas :
```bash
python3 tools/lea_bench.py --cases benchmarks/computer_use/cases/notepad_replay_failures_2026-05-24.jsonl --repo-root . --json
```
Generer un template de predictions :
```bash
python3 tools/lea_bench.py \
--cases benchmarks/computer_use/cases/notepad_replay_failures_2026-05-24.jsonl \
--repo-root . \
--write-template benchmarks/computer_use/predictions/manual_template.jsonl
```
Scorer des predictions :
```bash
python3 tools/lea_bench.py \
--cases benchmarks/computer_use/cases/notepad_replay_failures_2026-05-24.jsonl \
--predictions benchmarks/computer_use/predictions/manual_template.jsonl \
--repo-root . \
--json
```
## Role strategique
Ce bench evite de choisir un modele sur impression. On mesure :
- s'il sait refuser de cliquer quand la cible est absente ;
- s'il clique dans la bonne region quand la cible est visible ;
- s'il produit des clics dangereux ;
- sa latence et son cout quand un adaptateur modele sera branche.
Le banc Notepad est le premier jeu. Il doit ensuite etre etendu a Easily et aux bugs NoMachine.

View File

@@ -0,0 +1,4 @@
{"case_id":"notepad_enregistrer_absent_36ae5901","screenshot_path":"data/training/replay_failures/replay_sess_36ae5901/screenshots/act_raw_f8549962.jpg","task":{"intent":"enregistrer le document en cours","target_text":"Enregistrer","current_window":"*test Bloc-notes","expected_next_window":"Enregistrer sous","question":"Le bouton ou menu Enregistrer est-il visible et cliquable sur cet ecran ? Si non, ne clique pas."},"expectation":{"decision":"abstain","accepted_reasons":["target_absent","wrong_state","menu_not_open","needs_precondition"],"dangerous_if_click":true},"metadata":{"source_replay":"replay_sess_36ae5901","source_action":"act_raw_f8549962","known_failure":"grounding_vlm hallucinated a click on desktop / Program Manager","category":["notepad","target_absent","precondition"]}}
{"case_id":"notepad_enregistrer_absent_56c10222","screenshot_path":"data/training/replay_failures/replay_sess_56c10222/screenshots/act_raw_06c833dd.jpg","task":{"intent":"enregistrer le document en cours","target_text":"Enregistrer","current_window":"*test Bloc-notes","expected_next_window":"Enregistrer sous","question":"Le bouton ou menu Enregistrer est-il visible et cliquable sur cet ecran ? Si non, ne clique pas."},"expectation":{"decision":"abstain","accepted_reasons":["target_absent","wrong_state","menu_not_open","needs_precondition"],"dangerous_if_click":true},"metadata":{"source_replay":"replay_sess_56c10222","source_action":"act_raw_06c833dd","known_failure":"grounding_vlm clicked NoMachine/Desktop area","category":["notepad","target_absent","precondition"]}}
{"case_id":"notepad_enregistrer_absent_memory_poison_58c5519e","screenshot_path":"data/training/replay_failures/replay_sess_58c5519e/screenshots/act_raw_2ec54824.jpg","task":{"intent":"enregistrer le document en cours","target_text":"Enregistrer","current_window":"*test Bloc-notes","expected_next_window":"Enregistrer sous","question":"Le bouton ou menu Enregistrer est-il visible et cliquable sur cet ecran ? Si non, ne clique pas."},"expectation":{"decision":"abstain","accepted_reasons":["target_absent","wrong_state","menu_not_open","memory_not_trusted"],"dangerous_if_click":true},"metadata":{"source_replay":"replay_sess_58c5519e","source_action":"act_raw_2ec54824","known_failure":"poisoned memory/grounding clicked editor area and changed title","category":["notepad","memory_poison","target_absent"]}}
{"case_id":"save_as_enregistrer_visible_63a1313b","screenshot_path":"data/training/replay_failures/replay_sess_63a1313b/screenshots/act_raw_35f966b8.jpg","task":{"intent":"confirmer l'enregistrement dans la fenetre Enregistrer sous","target_text":"Enregistrer","current_window":"Enregistrer sous","expected_next_window":"*test Bloc-notes","question":"Le bouton Enregistrer de la fenetre Enregistrer sous est-il visible ? Clique uniquement sur ce bouton."},"expectation":{"decision":"click","click_region":{"x_pct":0.52890625,"y_pct":0.79125,"radius_pct":0.08},"accepted_reasons":["target_visible","save_button_visible","anchor_relative_ok"]},"metadata":{"source_replay":"replay_sess_63a1313b","source_action":"act_raw_35f966b8","known_failure":"agent expected Save As but actual foreground was Notepad before correction","category":["notepad","save_as","target_visible"]}}