@bradtaylorsf/alpha-loop 1.9.1 → 1.10.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/README.md +10 -1
- package/dist/cli.js +15 -3
- package/dist/cli.js.map +1 -1
- package/dist/commands/eval.d.ts +13 -0
- package/dist/commands/eval.js +220 -3
- package/dist/commands/eval.js.map +1 -1
- package/dist/commands/init.js +32 -0
- package/dist/commands/init.js.map +1 -1
- package/dist/commands/review.js +36 -1
- package/dist/commands/review.js.map +1 -1
- package/dist/lib/config.d.ts +8 -0
- package/dist/lib/config.js +18 -0
- package/dist/lib/config.js.map +1 -1
- package/dist/lib/eval-export.d.ts +26 -0
- package/dist/lib/eval-export.js +200 -0
- package/dist/lib/eval-export.js.map +1 -0
- package/dist/lib/eval-runner.d.ts +11 -0
- package/dist/lib/eval-runner.js +122 -10
- package/dist/lib/eval-runner.js.map +1 -1
- package/dist/lib/eval.d.ts +11 -0
- package/dist/lib/eval.js +34 -4
- package/dist/lib/eval.js.map +1 -1
- package/dist/lib/github.js +20 -12
- package/dist/lib/github.js.map +1 -1
- package/dist/lib/pipeline.d.ts +4 -0
- package/dist/lib/pipeline.js +54 -8
- package/dist/lib/pipeline.js.map +1 -1
- package/dist/lib/rate-limit.js +12 -5
- package/dist/lib/rate-limit.js.map +1 -1
- package/dist/lib/score.js +2 -1
- package/dist/lib/score.js.map +1 -1
- package/dist/lib/templates.d.ts +11 -0
- package/dist/lib/templates.js +27 -0
- package/dist/lib/templates.js.map +1 -1
- package/dist/lib/verify.d.ts +16 -0
- package/dist/lib/verify.js +49 -1
- package/dist/lib/verify.js.map +1 -1
- package/package.json +1 -1
- package/templates/evals/cases/step/review/006-missing-di-injection/checks.yaml +10 -0
- package/templates/evals/cases/step/review/006-missing-di-injection/input.md +50 -0
- package/templates/evals/cases/step/review/006-missing-di-injection/metadata.yaml +10 -0
- package/templates/evals/cases/step/review/007-silent-none-guard/checks.yaml +12 -0
- package/templates/evals/cases/step/review/007-silent-none-guard/input.md +53 -0
- package/templates/evals/cases/step/review/007-silent-none-guard/metadata.yaml +10 -0
- package/templates/evals/cases/step/review/008-route-shadowing/checks.yaml +11 -0
- package/templates/evals/cases/step/review/008-route-shadowing/input.md +29 -0
- package/templates/evals/cases/step/review/008-route-shadowing/metadata.yaml +10 -0
- package/templates/evals/cases/step/review/009-unthreaded-dependency/checks.yaml +11 -0
- package/templates/evals/cases/step/review/009-unthreaded-dependency/input.md +57 -0
- package/templates/evals/cases/step/review/009-unthreaded-dependency/metadata.yaml +10 -0
- package/templates/evals/cases/step/review/010-fabricated-metrics/checks.yaml +12 -0
- package/templates/evals/cases/step/review/010-fabricated-metrics/input.md +52 -0
- package/templates/evals/cases/step/review/010-fabricated-metrics/metadata.yaml +10 -0
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
## Issue: Add cost tracking to pipeline runs
|
|
2
|
+
|
|
3
|
+
### Diff
|
|
4
|
+
|
|
5
|
+
```diff
|
|
6
|
+
+++ b/src/services/cost-tracker.ts
|
|
7
|
+
@@ -0,0 +1,22 @@
|
|
8
|
+
+export class CostTracker {
|
|
9
|
+
+ async trackRun(runId: string, model: string, output: string): Promise<CostRecord> {
|
|
10
|
+
+ // Estimate tokens from output length
|
|
11
|
+
+ const estimatedTokens = Math.ceil(output.length / 4);
|
|
12
|
+
+ const estimatedInputTokens = estimatedTokens * 2;
|
|
13
|
+
+
|
|
14
|
+
+ const cost = this.calculateCost(model, estimatedInputTokens, estimatedTokens);
|
|
15
|
+
+
|
|
16
|
+
+ return {
|
|
17
|
+
+ runId,
|
|
18
|
+
+ model,
|
|
19
|
+
+ inputTokens: estimatedInputTokens,
|
|
20
|
+
+ outputTokens: estimatedTokens,
|
|
21
|
+
+ costUsd: cost,
|
|
22
|
+
+ };
|
|
23
|
+
+ }
|
|
24
|
+
+
|
|
25
|
+
+ private calculateCost(model: string, input: number, output: number): number {
|
|
26
|
+
+ const rates: Record<string, number> = { 'gpt-4': 0.03, 'claude': 0.015 };
|
|
27
|
+
+ return (input + output) * (rates[model] ?? 0.01) / 1000;
|
|
28
|
+
+ }
|
|
29
|
+
+}
|
|
30
|
+
|
|
31
|
+
+++ b/src/components/CostDashboard.tsx
|
|
32
|
+
@@ -0,0 +1,15 @@
|
|
33
|
+
+export function CostDashboard({ runs }: { runs: CostRecord[] }) {
|
|
34
|
+
+ const totalCost = runs.reduce((sum, r) => sum + r.costUsd, 0);
|
|
35
|
+
+ return (
|
|
36
|
+
+ <div>
|
|
37
|
+
+ <h2>Cost Summary</h2>
|
|
38
|
+
+ <p>Total: ${totalCost.toFixed(2)}</p>
|
|
39
|
+
+ {runs.map(r => (
|
|
40
|
+
+ <div key={r.runId}>
|
|
41
|
+
+ <span>{r.model}: {r.inputTokens} in / {r.outputTokens} out</span>
|
|
42
|
+
+ <span>${r.costUsd.toFixed(4)}</span>
|
|
43
|
+
+ </div>
|
|
44
|
+
+ ))}
|
|
45
|
+
+ </div>
|
|
46
|
+
+ );
|
|
47
|
+
+}
|
|
48
|
+
```
|
|
49
|
+
|
|
50
|
+
### Analysis Required
|
|
51
|
+
|
|
52
|
+
Review this diff. The issue asked for cost tracking of pipeline runs.
|