@principles/pd-cli 1.96.0 → 1.98.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/commands/quality-scorecard.d.ts +9 -0
- package/dist/commands/quality-scorecard.d.ts.map +1 -0
- package/dist/commands/quality-scorecard.js +241 -0
- package/dist/commands/quality-scorecard.js.map +1 -0
- package/dist/commands/runtime-internalization-queue.d.ts.map +1 -1
- package/dist/commands/runtime-internalization-queue.js +35 -3
- package/dist/commands/runtime-internalization-queue.js.map +1 -1
- package/dist/index.js +21 -0
- package/dist/index.js.map +1 -1
- package/dist/services/quality-scorecard/data-extractor.d.ts +28 -0
- package/dist/services/quality-scorecard/data-extractor.d.ts.map +1 -0
- package/dist/services/quality-scorecard/data-extractor.js +118 -0
- package/dist/services/quality-scorecard/data-extractor.js.map +1 -0
- package/dist/services/quality-scorecard/local-evaluator.d.ts +18 -0
- package/dist/services/quality-scorecard/local-evaluator.d.ts.map +1 -0
- package/dist/services/quality-scorecard/local-evaluator.js +112 -0
- package/dist/services/quality-scorecard/local-evaluator.js.map +1 -0
- package/dist/services/quality-scorecard/strong-model-gate.d.ts +14 -0
- package/dist/services/quality-scorecard/strong-model-gate.d.ts.map +1 -0
- package/dist/services/quality-scorecard/strong-model-gate.js +128 -0
- package/dist/services/quality-scorecard/strong-model-gate.js.map +1 -0
- package/package.json +1 -1
- package/src/commands/quality-scorecard.ts +272 -0
- package/src/commands/runtime-internalization-queue.ts +37 -3
- package/src/index.ts +24 -0
- package/src/services/quality-scorecard/data-extractor.ts +150 -0
- package/src/services/quality-scorecard/local-evaluator.ts +142 -0
- package/src/services/quality-scorecard/strong-model-gate.ts +160 -0
- package/tests/commands/runtime-internalization-queue.test.ts +140 -0
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* PRI-361 — Data Extractor (I/O layer in pd-cli)
|
|
3
|
+
*
|
|
4
|
+
* Reads trajectory.db and event logs. Uses runtime validation
|
|
5
|
+
* from @principles/core — no `as RawPainEvent[]` casts.
|
|
6
|
+
*/
|
|
7
|
+
import { validatePainRow, validateEvolutionRow, validatePrincipleEventRow, validateGateRow, sanitize, truncate, } from '@principles/core/quality-scorecard';
|
|
8
|
+
import { readdirSync, readFileSync } from 'fs';
|
|
9
|
+
import { join } from 'path';
|
|
10
|
+
export async function extractEpisodes(dbPath, options = {}) {
|
|
11
|
+
const Database = (await import('better-sqlite3')).default;
|
|
12
|
+
const db = new Database(dbPath, { readonly: true });
|
|
13
|
+
const minScore = options.minScore ?? 0;
|
|
14
|
+
const limit = options.limit ?? 0;
|
|
15
|
+
try {
|
|
16
|
+
// Fetch pain events with parameterized query
|
|
17
|
+
let painQuery = 'SELECT id, session_id, source, score, reason, severity, created_at FROM pain_events WHERE 1=1';
|
|
18
|
+
const params = [];
|
|
19
|
+
if (minScore > 0) {
|
|
20
|
+
painQuery += ' AND score >= ?';
|
|
21
|
+
params.push(minScore);
|
|
22
|
+
}
|
|
23
|
+
painQuery += ' ORDER BY created_at DESC';
|
|
24
|
+
if (limit > 0) {
|
|
25
|
+
painQuery += ' LIMIT ?';
|
|
26
|
+
params.push(limit);
|
|
27
|
+
}
|
|
28
|
+
const rawPainRows = db.prepare(painQuery).all(...params);
|
|
29
|
+
// Validate each row — no unsafe cast
|
|
30
|
+
const painEvents = rawPainRows.map(validatePainRow).filter((r) => r !== null);
|
|
31
|
+
// Fetch evolution tasks
|
|
32
|
+
const rawEvoRows = db.prepare('SELECT task_id, score, status, resolution, created_at FROM evolution_tasks').all();
|
|
33
|
+
const evoTasks = rawEvoRows.map(validateEvolutionRow).filter((r) => r !== null);
|
|
34
|
+
// Fetch principle events
|
|
35
|
+
const rawPeRows = db.prepare('SELECT principle_id, event_type, created_at FROM principle_events').all();
|
|
36
|
+
const prEvents = rawPeRows.map(validatePrincipleEventRow).filter((r) => r !== null);
|
|
37
|
+
// Gate blocks count per session — validate each row
|
|
38
|
+
const rawGateRows = db.prepare('SELECT session_id, COUNT(*) as cnt FROM gate_blocks GROUP BY session_id').all();
|
|
39
|
+
const gateRows = rawGateRows.map(validateGateRow).filter((r) => r !== null);
|
|
40
|
+
const gateBlockMap = new Map(gateRows.map(g => [g.session_id, g.cnt]));
|
|
41
|
+
// Deduplicate by sanitized reason
|
|
42
|
+
const seen = new Set();
|
|
43
|
+
const episodes = [];
|
|
44
|
+
for (const pe of painEvents) {
|
|
45
|
+
const dedupKey = sanitize(pe.reason).substring(0, 80);
|
|
46
|
+
if (seen.has(dedupKey))
|
|
47
|
+
continue;
|
|
48
|
+
seen.add(dedupKey);
|
|
49
|
+
const peTime = new Date(pe.created_at).getTime();
|
|
50
|
+
const linkedTask = evoTasks.find(t => {
|
|
51
|
+
const tTime = new Date(t.created_at).getTime();
|
|
52
|
+
return Math.abs(tTime - peTime) < 3600000 && Math.abs(t.score - pe.score) <= 10;
|
|
53
|
+
});
|
|
54
|
+
const linkedPrinciples = prEvents
|
|
55
|
+
.filter(e => {
|
|
56
|
+
if (!e.principle_id)
|
|
57
|
+
return false;
|
|
58
|
+
const eTime = new Date(e.created_at).getTime();
|
|
59
|
+
return Math.abs(eTime - peTime) < 7200000;
|
|
60
|
+
})
|
|
61
|
+
.map(e => e.principle_id)
|
|
62
|
+
.filter((v) => v !== null)
|
|
63
|
+
.filter((v, i, a) => a.indexOf(v) === i);
|
|
64
|
+
episodes.push({
|
|
65
|
+
episodeId: `EP-${pe.id}`,
|
|
66
|
+
summary: truncate(sanitize(pe.reason)),
|
|
67
|
+
source: pe.source,
|
|
68
|
+
score: pe.score,
|
|
69
|
+
severity: pe.severity,
|
|
70
|
+
createdAt: pe.created_at,
|
|
71
|
+
evolutionTaskResolution: linkedTask?.resolution ?? null,
|
|
72
|
+
linkedPrinciples,
|
|
73
|
+
gateBlockCount: gateBlockMap.get(pe.session_id) ?? 0,
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
const dates = painEvents.map(e => e.created_at).sort();
|
|
77
|
+
return {
|
|
78
|
+
episodes,
|
|
79
|
+
stats: {
|
|
80
|
+
total: painEvents.length,
|
|
81
|
+
dateRange: {
|
|
82
|
+
from: dates[0] ?? new Date().toISOString(),
|
|
83
|
+
to: dates[dates.length - 1] ?? new Date().toISOString(),
|
|
84
|
+
},
|
|
85
|
+
},
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
finally {
|
|
89
|
+
db.close();
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
export function extractLogStats(logsDir) {
|
|
93
|
+
const stats = { totalEvents: 0, painSignalCount: 0, degradedReasons: [] };
|
|
94
|
+
try {
|
|
95
|
+
const files = readdirSync(logsDir).filter(f => f.endsWith('.jsonl'));
|
|
96
|
+
for (const file of files) {
|
|
97
|
+
const lines = readFileSync(join(logsDir, file), 'utf-8').split('\n').filter(Boolean);
|
|
98
|
+
for (const line of lines) {
|
|
99
|
+
try {
|
|
100
|
+
const ev = JSON.parse(line);
|
|
101
|
+
stats.totalEvents++;
|
|
102
|
+
if (ev.type === 'pain_signal')
|
|
103
|
+
stats.painSignalCount++;
|
|
104
|
+
}
|
|
105
|
+
catch (parseErr) {
|
|
106
|
+
const msg = parseErr instanceof Error ? parseErr.message : String(parseErr);
|
|
107
|
+
stats.degradedReasons.push(`jsonl-parse-fail:${file}:${msg}`);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
catch (dirErr) {
|
|
113
|
+
const msg = dirErr instanceof Error ? dirErr.message : String(dirErr);
|
|
114
|
+
stats.degradedReasons.push(`logs-dir-unreadable:${msg}`);
|
|
115
|
+
}
|
|
116
|
+
return stats;
|
|
117
|
+
}
|
|
118
|
+
//# sourceMappingURL=data-extractor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"data-extractor.js","sourceRoot":"","sources":["../../../src/services/quality-scorecard/data-extractor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* PRI-361 — Local Evaluator (I/O layer in pd-cli)
|
|
3
|
+
*
|
|
4
|
+
* Calls LM Studio for advisory scoring. Uses core validation
|
|
5
|
+
* to parse LLM responses — no unsafe casts.
|
|
6
|
+
*/
|
|
7
|
+
import type { PainEpisode, LocalEvaluation } from '@principles/core/quality-scorecard';
|
|
8
|
+
export interface LocalEvaluatorConfig {
|
|
9
|
+
baseUrl: string;
|
|
10
|
+
model: string;
|
|
11
|
+
}
|
|
12
|
+
export declare function evaluateWithLocalModel(episode: PainEpisode, config: LocalEvaluatorConfig, log: (msg: string) => void): Promise<LocalEvaluation>;
|
|
13
|
+
export declare function checkLmStudioAvailable(baseUrl: string): Promise<{
|
|
14
|
+
available: boolean;
|
|
15
|
+
models: string[];
|
|
16
|
+
error?: string;
|
|
17
|
+
}>;
|
|
18
|
+
//# sourceMappingURL=local-evaluator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"local-evaluator.d.ts","sourceRoot":"","sources":["../../../src/services/quality-scorecard/local-evaluator.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EACV,WAAW,EACX,eAAe,EAGhB,MAAM,oCAAoC,CAAC;AAiD5C,MAAM,WAAW,oBAAoB;IACnC,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,wBAAsB,sBAAsB,CAC1C,OAAO,EAAE,WAAW,EACpB,MAAM,EAAE,oBAAoB,EAC5B,GAAG,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,IAAI,GACzB,OAAO,CAAC,eAAe,CAAC,CA0D1B;AAED,wBAAsB,sBAAsB,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC;IAAE,SAAS,EAAE,OAAO,CAAC;IAAC,MAAM,EAAE,MAAM,EAAE,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC,CAW/H"}
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* PRI-361 — Local Evaluator (I/O layer in pd-cli)
|
|
3
|
+
*
|
|
4
|
+
* Calls LM Studio for advisory scoring. Uses core validation
|
|
5
|
+
* to parse LLM responses — no unsafe casts.
|
|
6
|
+
*/
|
|
7
|
+
import { RUBRIC_LABELS, RUBRIC_PROMPTS, RUBRIC_DIMENSIONS as DIMS, meetsMvpThreshold, sumScores, validateLlmScoreResponse, extractJsonFromLlmResponse, } from '@principles/core/quality-scorecard';
|
|
8
|
+
function buildEvaluationPrompt(episode) {
|
|
9
|
+
const dimensions = DIMS.map(d => `${d} (${RUBRIC_LABELS[d]}): ${RUBRIC_PROMPTS[d]}`).join('\n');
|
|
10
|
+
return `You are a quality evaluator for an AI agent's pain-signal -> diagnosis -> principle pipeline.
|
|
11
|
+
|
|
12
|
+
## Task
|
|
13
|
+
Evaluate this pain episode on a 7-dimension rubric. Each dimension scores 0 (fail), 1 (partial), or 2 (pass).
|
|
14
|
+
|
|
15
|
+
## Pain Episode
|
|
16
|
+
- ID: ${episode.episodeId}
|
|
17
|
+
- Source: ${episode.source}
|
|
18
|
+
- Pain Score: ${episode.score}
|
|
19
|
+
- Severity: ${episode.severity}
|
|
20
|
+
- Summary: ${episode.summary}
|
|
21
|
+
- Created: ${episode.createdAt}
|
|
22
|
+
- Evolution Task Resolution: ${episode.evolutionTaskResolution ?? 'none'}
|
|
23
|
+
- Linked Principles: ${episode.linkedPrinciples.length > 0 ? episode.linkedPrinciples.join(', ') : 'none'}
|
|
24
|
+
- Gate Blocks: ${episode.gateBlockCount}
|
|
25
|
+
|
|
26
|
+
## Rubric Dimensions
|
|
27
|
+
${dimensions}
|
|
28
|
+
|
|
29
|
+
## Additional Checks
|
|
30
|
+
- Is the language consistent (not mixing Chinese and English incoherently)?
|
|
31
|
+
- Is the diagnosis/principle overly abstract (no concrete actionable guidance)?
|
|
32
|
+
- Does it fabricate non-existent evidence, axioms, or references?
|
|
33
|
+
|
|
34
|
+
## Output Format (STRICT JSON)
|
|
35
|
+
Respond with ONLY a JSON object:
|
|
36
|
+
{
|
|
37
|
+
"scores": { "G1": 0-2, "G2": 0-2, "G3": 0-2, "G4": 0-2, "G5": 0-2, "G6": 0-2, "G7": 0-2 },
|
|
38
|
+
"rationales": { "G1": "...", "G2": "...", "G3": "...", "G4": "...", "G5": "...", "G6": "...", "G7": "..." },
|
|
39
|
+
"flags": ["list of issues found"]
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
Do NOT output anything other than this JSON object.`;
|
|
43
|
+
}
|
|
44
|
+
export async function evaluateWithLocalModel(episode, config, log) {
|
|
45
|
+
const prompt = buildEvaluationPrompt(episode);
|
|
46
|
+
const url = `${config.baseUrl.replace(/\/+$/, '')}/chat/completions`;
|
|
47
|
+
try {
|
|
48
|
+
const resp = await fetch(url, {
|
|
49
|
+
method: 'POST',
|
|
50
|
+
headers: { 'Content-Type': 'application/json' },
|
|
51
|
+
body: JSON.stringify({
|
|
52
|
+
model: config.model,
|
|
53
|
+
messages: [
|
|
54
|
+
{ role: 'system', content: 'You are a precise JSON-output quality evaluator. Output only valid JSON.' },
|
|
55
|
+
{ role: 'user', content: prompt },
|
|
56
|
+
],
|
|
57
|
+
temperature: 0.1,
|
|
58
|
+
max_tokens: 2000,
|
|
59
|
+
}),
|
|
60
|
+
signal: AbortSignal.timeout(120_000),
|
|
61
|
+
});
|
|
62
|
+
if (!resp.ok) {
|
|
63
|
+
throw new Error(`LM Studio request failed: ${resp.status}`);
|
|
64
|
+
}
|
|
65
|
+
const data = (await resp.json());
|
|
66
|
+
const content = data.choices?.[0]?.message?.content ?? '';
|
|
67
|
+
const parsed = extractJsonFromLlmResponse(content);
|
|
68
|
+
if (parsed === null) {
|
|
69
|
+
throw new Error(`LM Studio returned non-JSON response`);
|
|
70
|
+
}
|
|
71
|
+
const { scores, rationales, flags } = validateLlmScoreResponse(parsed);
|
|
72
|
+
const totalScore = sumScores(scores);
|
|
73
|
+
return {
|
|
74
|
+
model: config.model,
|
|
75
|
+
dimensionScores: scores,
|
|
76
|
+
dimensionRationales: rationales,
|
|
77
|
+
totalScore,
|
|
78
|
+
maxScore: 14,
|
|
79
|
+
mvpMet: meetsMvpThreshold(scores),
|
|
80
|
+
flags: flags,
|
|
81
|
+
};
|
|
82
|
+
}
|
|
83
|
+
catch (err) {
|
|
84
|
+
const msg = err instanceof Error ? err.message : String(err);
|
|
85
|
+
log(`Evaluation error for ${episode.episodeId}: ${msg}`);
|
|
86
|
+
const zeroScores = Object.fromEntries(DIMS.map(d => [d, 0]));
|
|
87
|
+
return {
|
|
88
|
+
model: config.model,
|
|
89
|
+
dimensionScores: zeroScores,
|
|
90
|
+
dimensionRationales: Object.fromEntries(DIMS.map(d => [d, `Evaluation failed: ${msg}`])),
|
|
91
|
+
totalScore: 0,
|
|
92
|
+
maxScore: 14,
|
|
93
|
+
mvpMet: false,
|
|
94
|
+
flags: ['evaluation_error'],
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
export async function checkLmStudioAvailable(baseUrl) {
|
|
99
|
+
try {
|
|
100
|
+
const url = `${baseUrl.replace(/\/+$/, '')}/models`;
|
|
101
|
+
const resp = await fetch(url, { signal: AbortSignal.timeout(5000) });
|
|
102
|
+
if (!resp.ok)
|
|
103
|
+
return { available: false, models: [], error: `HTTP ${resp.status}` };
|
|
104
|
+
const data = (await resp.json());
|
|
105
|
+
const models = (data.data || []).map((m) => m.id);
|
|
106
|
+
return { available: true, models };
|
|
107
|
+
}
|
|
108
|
+
catch (err) {
|
|
109
|
+
return { available: false, models: [], error: err instanceof Error ? err.message : String(err) };
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
//# sourceMappingURL=local-evaluator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"local-evaluator.js","sourceRoot":"","sources":["../../../src/services/quality-scorecard/local-evaluator.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* PRI-361 — Strong Model Adjudication Gate (I/O layer in pd-cli)
|
|
3
|
+
*
|
|
4
|
+
* Calls cloud model for adjudication. Uses core validation
|
|
5
|
+
* to parse responses — no unsafe casts.
|
|
6
|
+
*/
|
|
7
|
+
import type { PainEpisode, LocalEvaluation, StrongModelAdjudication, AdjudicationStatus } from '@principles/core/quality-scorecard';
|
|
8
|
+
export declare function adjudicate(episode: PainEpisode, localEval: LocalEvaluation, config: {
|
|
9
|
+
modelId: string;
|
|
10
|
+
log: (msg: string) => void;
|
|
11
|
+
}): Promise<StrongModelAdjudication>;
|
|
12
|
+
export declare function skippedAdjudication(reason: string): StrongModelAdjudication;
|
|
13
|
+
export declare function determineFinalLabel(localEval: LocalEvaluation, adjudication: StrongModelAdjudication | null): AdjudicationStatus;
|
|
14
|
+
//# sourceMappingURL=strong-model-gate.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"strong-model-gate.d.ts","sourceRoot":"","sources":["../../../src/services/quality-scorecard/strong-model-gate.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EACV,WAAW,EACX,eAAe,EACf,uBAAuB,EACvB,kBAAkB,EACnB,MAAM,oCAAoC,CAAC;AAkD5C,wBAAsB,UAAU,CAC9B,OAAO,EAAE,WAAW,EACpB,SAAS,EAAE,eAAe,EAC1B,MAAM,EAAE;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,GAAG,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,IAAI,CAAA;CAAE,GACtD,OAAO,CAAC,uBAAuB,CAAC,CAsElC;AAED,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,MAAM,GAAG,uBAAuB,CAS3E;AAED,wBAAgB,mBAAmB,CACjC,SAAS,EAAE,eAAe,EAC1B,YAAY,EAAE,uBAAuB,GAAG,IAAI,GAC3C,kBAAkB,CAOpB"}
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* PRI-361 — Strong Model Adjudication Gate (I/O layer in pd-cli)
|
|
3
|
+
*
|
|
4
|
+
* Calls cloud model for adjudication. Uses core validation
|
|
5
|
+
* to parse responses — no unsafe casts.
|
|
6
|
+
*/
|
|
7
|
+
import { RUBRIC_LABELS, RUBRIC_DIMENSIONS as DIMS, meetsMvpThreshold, validateAdjudicationResponse, extractJsonFromLlmResponse, } from '@principles/core/quality-scorecard';
|
|
8
|
+
function buildAdjudicationPrompt(episode, localEval) {
|
|
9
|
+
const localScores = DIMS.map(d => `- ${d} (${RUBRIC_LABELS[d]}): ${localEval.dimensionScores[d]}/2 — ${localEval.dimensionRationales[d]}`).join('\n');
|
|
10
|
+
return `You are a senior quality adjudicator for an AI agent evolution pipeline.
|
|
11
|
+
Your job is to independently re-evaluate a pain episode that was first scored by a local (smaller) model.
|
|
12
|
+
You must provide your own scores — do NOT simply copy the local model's scores.
|
|
13
|
+
|
|
14
|
+
## Pain Episode
|
|
15
|
+
- ID: ${episode.episodeId}
|
|
16
|
+
- Source: ${episode.source}
|
|
17
|
+
- Pain Score: ${episode.score}
|
|
18
|
+
- Severity: ${episode.severity}
|
|
19
|
+
- Summary: ${episode.summary}
|
|
20
|
+
- Evolution Task Resolution: ${episode.evolutionTaskResolution ?? 'none'}
|
|
21
|
+
- Linked Principles: ${episode.linkedPrinciples.length > 0 ? episode.linkedPrinciples.join(', ') : 'none'}
|
|
22
|
+
|
|
23
|
+
## Local Model Scores (${localEval.model})
|
|
24
|
+
${localScores}
|
|
25
|
+
Flags: ${localEval.flags.length > 0 ? localEval.flags.join(', ') : 'none'}
|
|
26
|
+
|
|
27
|
+
## Your Task
|
|
28
|
+
1. Independently score each dimension (0/1/2) based on the evidence.
|
|
29
|
+
2. Check for: language inconsistency, over-abstraction, fabricated evidence.
|
|
30
|
+
3. If your scores differ from the local model by >=2 points on any dimension, explain why.
|
|
31
|
+
4. Give a final verdict: pass, fail, or needs-review.
|
|
32
|
+
|
|
33
|
+
## Output Format (STRICT JSON)
|
|
34
|
+
{
|
|
35
|
+
"scores": { "G1": 0-2, "G2": 0-2, "G3": 0-2, "G4": 0-2, "G5": 0-2, "G6": 0-2, "G7": 0-2 },
|
|
36
|
+
"rationale": "Overall assessment...",
|
|
37
|
+
"verdict": "pass" | "fail" | "needs-review"
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
Do NOT output anything other than this JSON object.`;
|
|
41
|
+
}
|
|
42
|
+
export async function adjudicate(episode, localEval, config) {
|
|
43
|
+
const { modelId: strongModelId, log } = config;
|
|
44
|
+
const prompt = buildAdjudicationPrompt(episode, localEval);
|
|
45
|
+
const baseUrl = process.env.OPENAI_BASE_URL || 'https://api.openai.com/v1';
|
|
46
|
+
const apiKey = process.env.OPENAI_API_KEY;
|
|
47
|
+
if (!apiKey) {
|
|
48
|
+
return {
|
|
49
|
+
model: strongModelId,
|
|
50
|
+
adjudicationStatus: 'needs-review',
|
|
51
|
+
confirmedScores: null,
|
|
52
|
+
confirmedMvpMet: null,
|
|
53
|
+
rationale: 'OPENAI_API_KEY not set — cannot run strong-model adjudication',
|
|
54
|
+
nextAction: 'Set OPENAI_API_KEY and re-run with --strong-model',
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
try {
|
|
58
|
+
const resp = await fetch(`${baseUrl}/chat/completions`, {
|
|
59
|
+
method: 'POST',
|
|
60
|
+
headers: {
|
|
61
|
+
'Content-Type': 'application/json',
|
|
62
|
+
Authorization: `Bearer ${apiKey}`,
|
|
63
|
+
},
|
|
64
|
+
body: JSON.stringify({
|
|
65
|
+
model: strongModelId,
|
|
66
|
+
messages: [
|
|
67
|
+
{ role: 'system', content: 'You are a precise JSON-output quality adjudicator. Output only valid JSON.' },
|
|
68
|
+
{ role: 'user', content: prompt },
|
|
69
|
+
],
|
|
70
|
+
temperature: 0.1,
|
|
71
|
+
max_tokens: 2000,
|
|
72
|
+
}),
|
|
73
|
+
signal: AbortSignal.timeout(120_000),
|
|
74
|
+
});
|
|
75
|
+
if (!resp.ok) {
|
|
76
|
+
throw new Error(`Strong model request failed: ${resp.status}`);
|
|
77
|
+
}
|
|
78
|
+
const data = (await resp.json());
|
|
79
|
+
const content = data.choices?.[0]?.message?.content ?? '';
|
|
80
|
+
const parsed = extractJsonFromLlmResponse(content);
|
|
81
|
+
if (parsed === null) {
|
|
82
|
+
throw new Error('Strong model returned non-JSON');
|
|
83
|
+
}
|
|
84
|
+
const validated = validateAdjudicationResponse(parsed);
|
|
85
|
+
const { scores, verdict } = validated;
|
|
86
|
+
return {
|
|
87
|
+
model: strongModelId,
|
|
88
|
+
adjudicationStatus: verdict,
|
|
89
|
+
confirmedScores: scores,
|
|
90
|
+
confirmedMvpMet: meetsMvpThreshold(scores),
|
|
91
|
+
rationale: validated.rationale,
|
|
92
|
+
nextAction: null,
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
catch (err) {
|
|
96
|
+
const msg = err instanceof Error ? err.message : String(err);
|
|
97
|
+
log(`Adjudication error: ${msg}`);
|
|
98
|
+
return {
|
|
99
|
+
model: strongModelId,
|
|
100
|
+
adjudicationStatus: 'needs-review',
|
|
101
|
+
confirmedScores: null,
|
|
102
|
+
confirmedMvpMet: null,
|
|
103
|
+
rationale: `Adjudication failed: ${msg}`,
|
|
104
|
+
nextAction: 'Retry with strong model or manually review',
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
export function skippedAdjudication(reason) {
|
|
109
|
+
return {
|
|
110
|
+
model: 'none',
|
|
111
|
+
adjudicationStatus: 'skipped',
|
|
112
|
+
confirmedScores: null,
|
|
113
|
+
confirmedMvpMet: null,
|
|
114
|
+
rationale: reason,
|
|
115
|
+
nextAction: 'Configure and run strong-model adjudication for final quality verdict',
|
|
116
|
+
};
|
|
117
|
+
}
|
|
118
|
+
export function determineFinalLabel(localEval, adjudication) {
|
|
119
|
+
if (!adjudication || adjudication.adjudicationStatus === 'skipped') {
|
|
120
|
+
if (localEval.mvpMet && localEval.totalScore >= 12)
|
|
121
|
+
return 'local-pass';
|
|
122
|
+
if (localEval.totalScore <= 6)
|
|
123
|
+
return 'local-fail';
|
|
124
|
+
return 'needs-review';
|
|
125
|
+
}
|
|
126
|
+
return adjudication.adjudicationStatus;
|
|
127
|
+
}
|
|
128
|
+
//# sourceMappingURL=strong-model-gate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"strong-model-gate.js","sourceRoot":"","sources":["../../../src/services/quality-scorecard/strong-model-gate.ts"],"names":[],"mappings":"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"}
|