@relayplane/proxy 1.9.24 → 1.9.25

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.
@@ -0,0 +1,11 @@
1
+ import type { RoutingLogEntry } from './routing-log.js';
2
+ export interface SaveRecommendation {
3
+ opusCount: number;
4
+ avgComplexityScore: number;
5
+ sonnetThresholdScore: number;
6
+ estimatedDailySavings: number;
7
+ windowSize: number;
8
+ }
9
+ export declare function computeSaveRecommendation(entries: RoutingLogEntry[]): SaveRecommendation | null;
10
+ export declare function formatSaveRecommendationTip(rec: SaveRecommendation): string;
11
+ //# sourceMappingURL=save-recommendation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"save-recommendation.d.ts","sourceRoot":"","sources":["../src/save-recommendation.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAExD,MAAM,WAAW,kBAAkB;IACjC,SAAS,EAAE,MAAM,CAAC;IAClB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,oBAAoB,EAAE,MAAM,CAAC;IAC7B,qBAAqB,EAAE,MAAM,CAAC;IAC9B,UAAU,EAAE,MAAM,CAAC;CACpB;AAkBD,wBAAgB,yBAAyB,CACvC,OAAO,EAAE,eAAe,EAAE,GACzB,kBAAkB,GAAG,IAAI,CAiC3B;AAED,wBAAgB,2BAA2B,CAAC,GAAG,EAAE,kBAAkB,GAAG,MAAM,CAO3E"}
@@ -0,0 +1,53 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.computeSaveRecommendation = computeSaveRecommendation;
4
+ exports.formatSaveRecommendationTip = formatSaveRecommendationTip;
5
+ const WINDOW_SIZE = 20;
6
+ const MIN_ENTRIES = 10;
7
+ const SONNET_THRESHOLD = 0.5;
8
+ // $/token pricing: Opus vs Sonnet
9
+ const OPUS_INPUT_PRICE = 15 / 1_000_000;
10
+ const OPUS_OUTPUT_PRICE = 75 / 1_000_000;
11
+ const SONNET_INPUT_PRICE = 3 / 1_000_000;
12
+ const SONNET_OUTPUT_PRICE = 15 / 1_000_000;
13
+ function complexityToScore(complexity) {
14
+ if (complexity === 'simple')
15
+ return 0.2;
16
+ if (complexity === 'moderate')
17
+ return 0.35;
18
+ return 0.7; // complex or unknown
19
+ }
20
+ function computeSaveRecommendation(entries) {
21
+ if (entries.length < MIN_ENTRIES)
22
+ return null;
23
+ const window = entries.slice(-WINDOW_SIZE);
24
+ const opusCalls = window.filter(e => e.resolvedModel.toLowerCase().includes('opus'));
25
+ if (opusCalls.length === 0)
26
+ return null;
27
+ const avgComplexityScore = opusCalls.reduce((sum, e) => sum + complexityToScore(e.complexity), 0) /
28
+ opusCalls.length;
29
+ if (avgComplexityScore >= SONNET_THRESHOLD)
30
+ return null;
31
+ const avgInput = opusCalls.reduce((sum, e) => sum + (e.inputTokens ?? 0), 0) / opusCalls.length;
32
+ const avgOutput = opusCalls.reduce((sum, e) => sum + (e.outputTokens ?? 0), 0) / opusCalls.length;
33
+ let estimatedDailySavings = 0;
34
+ if (avgInput > 0 || avgOutput > 0) {
35
+ const savingsPerRequest = (OPUS_INPUT_PRICE - SONNET_INPUT_PRICE) * avgInput +
36
+ (OPUS_OUTPUT_PRICE - SONNET_OUTPUT_PRICE) * avgOutput;
37
+ estimatedDailySavings = savingsPerRequest * opusCalls.length;
38
+ }
39
+ return {
40
+ opusCount: opusCalls.length,
41
+ avgComplexityScore,
42
+ sonnetThresholdScore: SONNET_THRESHOLD,
43
+ estimatedDailySavings,
44
+ windowSize: window.length,
45
+ };
46
+ }
47
+ function formatSaveRecommendationTip(rec) {
48
+ const savings = `$${rec.estimatedDailySavings.toFixed(2)}/day`;
49
+ return (`TIP: Last ${rec.opusCount} Opus requests averaged complexity ` +
50
+ `${rec.avgComplexityScore} (Sonnet threshold: ${rec.sonnetThresholdScore}). ` +
51
+ `Estimated savings if routed to Sonnet: ${savings}.`);
52
+ }
53
+ //# sourceMappingURL=save-recommendation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"save-recommendation.js","sourceRoot":"","sources":["../src/save-recommendation.ts"],"names":[],"mappings":";;AA0BA,8DAmCC;AAED,kEAOC;AA5DD,MAAM,WAAW,GAAG,EAAE,CAAC;AACvB,MAAM,WAAW,GAAG,EAAE,CAAC;AACvB,MAAM,gBAAgB,GAAG,GAAG,CAAC;AAE7B,kCAAkC;AAClC,MAAM,gBAAgB,GAAG,EAAE,GAAG,SAAS,CAAC;AACxC,MAAM,iBAAiB,GAAG,EAAE,GAAG,SAAS,CAAC;AACzC,MAAM,kBAAkB,GAAG,CAAC,GAAG,SAAS,CAAC;AACzC,MAAM,mBAAmB,GAAG,EAAE,GAAG,SAAS,CAAC;AAE3C,SAAS,iBAAiB,CAAC,UAAkB;IAC3C,IAAI,UAAU,KAAK,QAAQ;QAAE,OAAO,GAAG,CAAC;IACxC,IAAI,UAAU,KAAK,UAAU;QAAE,OAAO,IAAI,CAAC;IAC3C,OAAO,GAAG,CAAC,CAAC,qBAAqB;AACnC,CAAC;AAED,SAAgB,yBAAyB,CACvC,OAA0B;IAE1B,IAAI,OAAO,CAAC,MAAM,GAAG,WAAW;QAAE,OAAO,IAAI,CAAC;IAE9C,MAAM,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,WAAW,CAAC,CAAC;IAC3C,MAAM,SAAS,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC;IACrF,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,IAAI,CAAC;IAExC,MAAM,kBAAkB,GACtB,SAAS,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,iBAAiB,CAAC,CAAC,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;QACtE,SAAS,CAAC,MAAM,CAAC;IAEnB,IAAI,kBAAkB,IAAI,gBAAgB;QAAE,OAAO,IAAI,CAAC;IAExD,MAAM,QAAQ,GACZ,SAAS,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,WAAW,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,SAAS,CAAC,MAAM,CAAC;IACjF,MAAM,SAAS,GACb,SAAS,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,YAAY,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,SAAS,CAAC,MAAM,CAAC;IAElF,IAAI,qBAAqB,GAAG,CAAC,CAAC;IAC9B,IAAI,QAAQ,GAAG,CAAC,IAAI,SAAS,GAAG,CAAC,EAAE,CAAC;QAClC,MAAM,iBAAiB,GACrB,CAAC,gBAAgB,GAAG,kBAAkB,CAAC,GAAG,QAAQ;YAClD,CAAC,iBAAiB,GAAG,mBAAmB,CAAC,GAAG,SAAS,CAAC;QACxD,qBAAqB,GAAG,iBAAiB,GAAG,SAAS,CAAC,MAAM,CAAC;IAC/D,CAAC;IAED,OAAO;QACL,SAAS,EAAE,SAAS,CAAC,MAAM;QAC3B,kBAAkB;QAClB,oBAAoB,EAAE,gBAAgB;QACtC,qBAAqB;QACrB,UAAU,EAAE,MAAM,CAAC,MAAM;KAC1B,CAAC;AACJ,CAAC;AAED,SAAgB,2BAA2B,CAAC,GAAuB;IACjE,MAAM,OAAO,GAAG,IAAI,GAAG,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC;IAC/D,OAAO,CACL,aAAa,GAAG,CAAC,SAAS,qCAAqC;QAC/D,GAAG,GAAG,CAAC,kBAAkB,uBAAuB,GAAG,CAAC,oBAAoB,KAAK;QAC7E,0CAA0C,OAAO,GAAG,CACrD,CAAC;AACJ,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@relayplane/proxy",
3
- "version": "1.9.24",
3
+ "version": "1.9.25",
4
4
  "description": "Open source cost intelligence proxy for AI agents. Cut LLM costs ~80% with smart model routing. Dashboard, policy engine, 11 providers. MIT licensed.",
5
5
  "homepage": "https://relayplane.com",
6
6
  "repository": {