summaryrefslogtreecommitdiff
path: root/packages/cli/src/ui/utils/computeStats.ts
diff options
context:
space:
mode:
authorAbhi <[email protected]>2025-06-29 20:44:33 -0400
committerGitHub <[email protected]>2025-06-30 00:44:33 +0000
commit770f862832dfef477705bee69bd2a84397d105a8 (patch)
tree8cb647cf789f05458ff491b461aa531a6932ad3d /packages/cli/src/ui/utils/computeStats.ts
parent0fd602eb43eea7abca980dc2ae3fd7bf2ba76a2a (diff)
feat: Change /stats to include more detailed breakdowns (#2615)
Diffstat (limited to 'packages/cli/src/ui/utils/computeStats.ts')
-rw-r--r--packages/cli/src/ui/utils/computeStats.ts84
1 files changed, 84 insertions, 0 deletions
diff --git a/packages/cli/src/ui/utils/computeStats.ts b/packages/cli/src/ui/utils/computeStats.ts
new file mode 100644
index 00000000..e0483c3b
--- /dev/null
+++ b/packages/cli/src/ui/utils/computeStats.ts
@@ -0,0 +1,84 @@
+/**
+ * @license
+ * Copyright 2025 Google LLC
+ * SPDX-License-Identifier: Apache-2.0
+ */
+
+import {
+ SessionMetrics,
+ ComputedSessionStats,
+ ModelMetrics,
+} from '../contexts/SessionContext.js';
+
+export function calculateErrorRate(metrics: ModelMetrics): number {
+ if (metrics.api.totalRequests === 0) {
+ return 0;
+ }
+ return (metrics.api.totalErrors / metrics.api.totalRequests) * 100;
+}
+
+export function calculateAverageLatency(metrics: ModelMetrics): number {
+ if (metrics.api.totalRequests === 0) {
+ return 0;
+ }
+ return metrics.api.totalLatencyMs / metrics.api.totalRequests;
+}
+
+export function calculateCacheHitRate(metrics: ModelMetrics): number {
+ if (metrics.tokens.prompt === 0) {
+ return 0;
+ }
+ return (metrics.tokens.cached / metrics.tokens.prompt) * 100;
+}
+
+export const computeSessionStats = (
+ metrics: SessionMetrics,
+): ComputedSessionStats => {
+ const { models, tools } = metrics;
+ const totalApiTime = Object.values(models).reduce(
+ (acc, model) => acc + model.api.totalLatencyMs,
+ 0,
+ );
+ const totalToolTime = tools.totalDurationMs;
+ const agentActiveTime = totalApiTime + totalToolTime;
+ const apiTimePercent =
+ agentActiveTime > 0 ? (totalApiTime / agentActiveTime) * 100 : 0;
+ const toolTimePercent =
+ agentActiveTime > 0 ? (totalToolTime / agentActiveTime) * 100 : 0;
+
+ const totalCachedTokens = Object.values(models).reduce(
+ (acc, model) => acc + model.tokens.cached,
+ 0,
+ );
+ const totalPromptTokens = Object.values(models).reduce(
+ (acc, model) => acc + model.tokens.prompt,
+ 0,
+ );
+ const cacheEfficiency =
+ totalPromptTokens > 0 ? (totalCachedTokens / totalPromptTokens) * 100 : 0;
+
+ const totalDecisions =
+ tools.totalDecisions.accept +
+ tools.totalDecisions.reject +
+ tools.totalDecisions.modify;
+ const successRate =
+ tools.totalCalls > 0 ? (tools.totalSuccess / tools.totalCalls) * 100 : 0;
+ const agreementRate =
+ totalDecisions > 0
+ ? (tools.totalDecisions.accept / totalDecisions) * 100
+ : 0;
+
+ return {
+ totalApiTime,
+ totalToolTime,
+ agentActiveTime,
+ apiTimePercent,
+ toolTimePercent,
+ cacheEfficiency,
+ totalDecisions,
+ successRate,
+ agreementRate,
+ totalCachedTokens,
+ totalPromptTokens,
+ };
+};