docs/integrations/camel-ai.mdx
Connect Camel's agent framework to Mem0 so every agent can persist and recall conversation context across sessions with minimal setup.
<Info> **Prerequisites** - Mem0: `MEM0_API_KEY` (or self-hosted endpoint), `pip install mem0ai` - Camel AI: `pip install camel-ai` (requires Python 3.9+) - Optional: OpenAI API key if you run LLM-backed agents </Info><Note>Camel provides a Python SDK today. A TypeScript path is not available yet.</Note>
mem0_store = Mem0Storage( api_key=os.environ.get("MEM0_API_KEY"), agent_id="travel_agent", user_id="alice", metadata={"source": "camel-demo"}, )
</Step>
<Step title="Attach it to Camel memory">
```python
from camel.memories import ChatHistoryMemory, ScoreBasedContextCreator
from camel.utils import OpenAITokenCounter
from camel.types import ModelType
memory = ChatHistoryMemory(
context_creator=ScoreBasedContextCreator(
token_counter=OpenAITokenCounter(ModelType.GPT_4O_MINI),
token_limit=1024,
),
storage=mem0_store,
agent_id="travel_agent",
)
agent = ChatAgent( system_message=BaseMessage.make_assistant_message( role_name="Agent", content="You are a helpful travel assistant. Reuse stored memories." ) )
agent.memory = memory
response = agent.step( BaseMessage.make_user_message( role_name="User", content="I prefer boutique hotels in Paris." ) )
print(response.msgs[0].content)
</Step>
</Steps>
<Info icon="check">
Run `python camel_mem0_demo.py` (or the snippet above in a REPL). You should see the agent respond and the memory persisted to Mem0. Re-running with a new prompt should include the stored preference.
</Info>
## Verify the integration
- Mem0 dashboard shows new memories under `agent_id=travel_agent` and `user_id=alice`.
- `mem0_store.load()` returns the records you just wrote.
- Camel agent replies reference prior user preferences on subsequent runs.
## Troubleshooting
- **Missing MEM0_API_KEY** — set `export MEM0_API_KEY="sk-..."` or pass `api_key` into `Mem0Storage`.
- **No memories returned** — ensure `agent_id`/`user_id` in your query match what you used when writing.
- **Network errors to Mem0** — if self-hosting, set `MEM0_BASE_URL` to your deployment URL.
<CardGroup cols={2}>
<Card
title="Memory types in Mem0"
description="Choose between chat history and semantic search for your Camel agents."
icon="sparkles"
href="/core-concepts/memory-types"
/>
<Card
title="Try LangChain next"
description="Wire the same Mem0 project into LangChain workflows."
icon="rocket"
href="/integrations/langchain"
/>
</CardGroup>