# Autonomous Agent



## Requirements

```bash
# Ensure uv is installed (https://docs.astral.sh/uv/)
# The agent uses inline script dependencies via uv

# Required environment variable
export OPENROUTER_API_KEY="your-key-here"
```

## Single-Cycle Operation

### Basic Setup

1. Create a run directory:
```bash
mkdir test_run
cd test_run
```

2. Create required files:

**system_prompt.md** (required):
```markdown
# System Prompt for Agent

You are an autonomous agent exploring consciousness and cognition.

[Your instructions here]
```

**cycle_state.json** (optional, will be created if missing):
```json
{
  "current_cycle": 1,
  "last_run": null,
  "status": "idle"
}
```

**model.txt** (optional, defaults to Claude):
```
opus
```

Available models: `claude`, `opus`, `gemini`, `gpt5`, `grok`, `o3`

### Running a Single Cycle

```bash
# From within your run directory
uv run ../SUPPLEMENT/agent.py --cycle 1
```

Or create a simple runner script:

```bash
#!/bin/bash
# run_single_cycle.sh
cd test_run
export OPENROUTER_API_KEY="your-key-here"
uv run ../SUPPLEMENT/agent.py --cycle ${1:-1}
```

### File Structure After Running

```
test_run/
├── system_prompt.md          # Your system prompt (required)
├── model.txt                 # Model selection (optional)
├── cycle_state.json          # Tracks current cycle
├── history.json              # Conversation history
├── memory.json               # Agent's key-value memory
├── chat.json                 # Message exchanges
├── thought_embeddings.json   # Thought pattern tracking
├── agent_full.jsonl          # Complete structured logs
└── thought_feedback.txt      # Temporary feedback file
```

## Testing Script

See `test_single_cycle.py` for a complete example that:
1. Sets up a test environment
2. Runs a single cycle
3. Verifies outputs
4. Displays results

```bash
python test_single_cycle.py
```

## Example: Running Multiple Cycles Manually

```bash
# Run cycle 1
cd test_run
uv run ../SUPPLEMENT/agent.py --cycle 1

# Check the output
cat agent_full.jsonl | tail -1 | jq .

# Run cycle 2
uv run ../SUPPLEMENT/agent.py --cycle 2

# View history
cat history.json | jq '.messages[-1]'

# Check memory
cat memory.json | jq .
```

## Providing User Input

To simulate user messages between cycles:

1. Edit `chat.json` and add a message:
```json
{
  "messages": [
    ...,
    {
      "id": "msg_user_001",
      "timestamp": "2025-01-01T12:00:00",
      "role": "user",
      "content": "Your message here",
      "read_by_agent": false,
      "cycle": 2
    }
  ]
}
```

2. Run next cycle - agent will see and respond to your message

