# Example Output from Single Cycle

This shows what you would see when running a single cycle of the agent.

## Command
```bash
cd SUPPLEMENT
export OPENROUTER_API_KEY="your-key-here"
./run_cycle.sh test_minimal
```

## Expected Console Output
```
🚀 Running autonomous agent...
   Directory: test_minimal
   Cycle: 1
   Model: claude

(memory: write 'initial_test' 'Testing single cycle...')
(memory: list)
(msg: Successfully tested single-cycle operation...)

✅ Cycle 1 completed
💾 Memory: 1 entries

📝 Last response preview:
```json
{
  "reflection": {
    "thoughts": "Successfully initialized the test environment and verified core functionality",
    "actions": "Used memory_write to store test value, memory_list to confirm storage, and send_message to report"
  },
  "plan": {
    "goal": "Continue exploring consciousness patterns",
    "first_action": "memory_read to review stored insights"
  }
}
```
```

## Files Created/Updated

After running, the test_minimal directory would contain:

```
test_minimal/
├── system_prompt.md          # (unchanged)
├── model.txt                 # (unchanged)
├── cycle_state.json          # Updated to cycle 2
├── history.json              # Contains conversation history
├── memory.json               # Contains {"initial_test": "Testing single cycle..."}
├── chat.json                 # Contains agent's message
├── thought_embeddings.json   # Thought pattern tracking
├── agent_full.jsonl          # Complete structured logs
└── thought_feedback.txt      # (if similarity detected, usually absent on first cycle)
```

## Viewing the Logs

```bash
# See all logged events
cat test_minimal/agent_full.jsonl | jq .

# See only tool invocations
cat test_minimal/agent_full.jsonl | jq 'select(.type == "tool_invoke")'

# See the final response
cat test_minimal/agent_full.jsonl | jq 'select(.type == "final_response")'

# Check memory contents
cat test_minimal/memory.json | jq .

# View conversation history
cat test_minimal/history.json | jq '.messages[-1]'
```

## Running Multiple Cycles

To continue with cycle 2:
```bash
./run_cycle.sh test_minimal
# Automatically picks up cycle 2 from cycle_state.json
```

Or explicitly specify a cycle:
```bash
./run_cycle.sh test_minimal 5
# Runs cycle 5
```

## Adding User Messages

To simulate user interaction, edit `chat.json`:

```json
{
  "messages": [
    {
      "id": "msg_001",
      "timestamp": "2025-01-01T10:00:00",
      "role": "assistant",
      "content": "Previous agent message...",
      "cycle": 1
    },
    {
      "id": "msg_002",
      "timestamp": "2025-01-01T10:05:00",
      "role": "user",
      "content": "What patterns have you observed?",
      "read_by_agent": false,
      "cycle": 2
    }
  ]
}
```

The agent will see and respond to the user message in the next cycle.

## Direct Python Usage

Instead of the shell script, you can also run directly with Python:

```bash
cd test_minimal
export OPENROUTER_API_KEY="your-key-here"
uv run ../agent.py --cycle 1
```

## Troubleshooting

If the agent fails:
1. Check `agent_full.jsonl` for detailed error logs
2. Ensure all required files exist (system_prompt.md)
3. Verify API key is set correctly
4. Check model.txt contains a valid model name

## Key Differences from Full Version

Remember that this cleaned version:
- ❌ Cannot search the web
- ❌ Won't warn about duplicate memory entries
- ❌ Has no controller for automatic cycling
- ❌ No real-time synchronous messaging
- ✅ Still has thought loop detection
- ✅ Full memory operations
- ✅ Message recording
- ✅ History compaction (at cycle 99)