Module: Braintrust::Contrib::Anthropic::Instrumentation::Common
- Defined in:
- lib/braintrust/contrib/anthropic/instrumentation/common.rb
Overview
Common utilities for Anthropic SDK instrumentation.
Class Method Summary collapse
-
.parse_usage_tokens(usage) ⇒ Hash<String, Integer>
Parse Anthropic SDK usage tokens into normalized Braintrust metrics.
Class Method Details
.parse_usage_tokens(usage) ⇒ Hash<String, Integer>
Parse Anthropic SDK usage tokens into normalized Braintrust metrics. Accumulates cache tokens into prompt_tokens and calculates total. Works with both Hash objects and SDK response objects (via to_h).
14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 |
# File 'lib/braintrust/contrib/anthropic/instrumentation/common.rb', line 14 def self.parse_usage_tokens(usage) metrics = {} return metrics unless usage usage_hash = usage.respond_to?(:to_h) ? usage.to_h : usage return metrics unless usage_hash.is_a?(Hash) # Anthropic SDK field mappings → Braintrust metrics field_map = { "input_tokens" => "prompt_tokens", "output_tokens" => "completion_tokens", "cache_read_input_tokens" => "prompt_cached_tokens", "cache_creation_input_tokens" => "prompt_cache_creation_tokens" } usage_hash.each do |key, value| next unless value.is_a?(Numeric) key_str = key.to_s target = field_map[key_str] metrics[target] = value.to_i if target end # Accumulate cache tokens into prompt_tokens (matching TS/Python SDKs) prompt_tokens = (metrics["prompt_tokens"] || 0) + (metrics["prompt_cached_tokens"] || 0) + (metrics["prompt_cache_creation_tokens"] || 0) metrics["prompt_tokens"] = prompt_tokens if prompt_tokens > 0 # Calculate total if metrics.key?("prompt_tokens") && metrics.key?("completion_tokens") metrics["tokens"] = metrics["prompt_tokens"] + metrics["completion_tokens"] end metrics end |