Skip to content

Commit

Permalink
docs: add entity mapping example for OpenTelemetry concepts
Browse files Browse the repository at this point in the history
  • Loading branch information
teocns committed Jan 5, 2025
1 parent c5ff75c commit 9b36d7a
Showing 1 changed file with 74 additions and 0 deletions.
74 changes: 74 additions & 0 deletions docs/dev/OTEL/entity_mapping.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,74 @@
An example of how AgentOps components could map to OpenTelemetry concepts:

1. **Core Mapping**
```mermaid
graph LR
subgraph AgentOps
A[Session] --> B[Events]
B --> C[LLMEvent]
B --> D[ActionEvent]
B --> E[ToolEvent]
end
subgraph OpenTelemetry
F[Trace] --> G[Spans]
G --> H[LLM Spans]
G --> I[Action Spans]
G --> J[Tool Spans]
K[Metrics] --> L[LLM Metrics]
end
A -.->|Maps to| F
C -.->|Maps to| H
D -.->|Maps to| I
E -.->|Maps to| J
```

Let's look at specific examples:

1. **Session to Trace**
````python
# When AgentOps starts a session:
class Session:
def __init__(self):
# Create root span for the session
self.trace = tracer.start_span(
name="agentops.session",
attributes={
"session.id": self.session_id,
"agent.id": self.agent_id
}
)
````

2. **LLMEvent to Span**
````python
# When AgentOps records an LLM event:
class LLMEvent:
def to_span(self):
return tracer.start_span(
name="llm.completion",
attributes={
"llm.model": self.model,
"llm.tokens.prompt": self.prompt_tokens,
"llm.tokens.completion": self.completion_tokens,
"llm.cost": self.cost
}
)
````

3. **LLM Metrics**
````python
# In LlmTracker:
class LlmTracker:
def __init__(self):
self.calls_counter = meter.create_counter(
name="llm.calls",
description="Number of LLM API calls"
)

self.token_histogram = meter.create_histogram(
name="llm.tokens",
description="Distribution of token usage"
)
````

0 comments on commit 9b36d7a

Please sign in to comment.