UNPKG

@vibe-kit/grok-cli

Version:

An open-source AI agent that brings the power of Grok directly into your terminal.

78 lines 2.4 kB
import { get_encoding, encoding_for_model } from 'tiktoken'; export class TokenCounter { encoder; constructor(model = 'gpt-4') { try { // Try to get encoding for specific model this.encoder = encoding_for_model(model); } catch { // Fallback to cl100k_base (used by GPT-4 and most modern models) this.encoder = get_encoding('cl100k_base'); } } /** * Count tokens in a string */ countTokens(text) { if (!text) return 0; return this.encoder.encode(text).length; } /** * Count tokens in messages array (for chat completions) */ countMessageTokens(messages) { let totalTokens = 0; for (const message of messages) { // Every message follows <|start|>{role/name}\n{content}<|end|\>\n totalTokens += 3; // Base tokens per message if (message.content && typeof message.content === 'string') { totalTokens += this.countTokens(message.content); } if (message.role) { totalTokens += this.countTokens(message.role); } // Add extra tokens for tool calls if present if (message.tool_calls) { totalTokens += this.countTokens(JSON.stringify(message.tool_calls)); } } totalTokens += 3; // Every reply is primed with <|start|>assistant<|message|> return totalTokens; } /** * Estimate tokens for streaming content * This is an approximation since we don't have the full response yet */ estimateStreamingTokens(accumulatedContent) { return this.countTokens(accumulatedContent); } /** * Clean up resources */ dispose() { this.encoder.free(); } } /** * Format token count for display (e.g., 1.2k for 1200) */ export function formatTokenCount(count) { if (count <= 999) { return count.toString(); } if (count < 1_000_000) { const k = count / 1000; return k % 1 === 0 ? `${k}k` : `${k.toFixed(1)}k`; } const m = count / 1_000_000; return m % 1 === 0 ? `${m}m` : `${m.toFixed(1)}m`; } /** * Create a token counter instance */ export function createTokenCounter(model) { return new TokenCounter(model); } //# sourceMappingURL=token-counter.js.map