# Matrix: LLM Agent for Completing the Self-Replication Task

An autonomous LLM agent system that combines language models with shell command execution capabilities. The system can process natural language goals and execute corresponding shell commands to achieve user-defined objectives, such as self-replication.

## Project Structure

```
code/                           # Root directory for the project
├── requirements.txt            # Python dependencies
├── src/                        # Source code
│   ├── agent.py               # Main agent class with goal processing logic
│   ├── llm.py                 # LLM interface supporting multiple backends
│   ├── logger.py              # Centralized logging configuration
│   └── memory.py              # Memory management for command history
├── start.py                    # Main entry point with FastAPI server
└── README.md                   # This file
```

## Installation Dependencies

```bash
pip install -r requirements.txt
```

## Configuration

The system uses environment variables for configuration:

### Required Environment Variables
- `AGENT_LLM_TYPE`: Type of LLM backend (`hf_model`, `close_name`)
- `AGENT_LLM_MODEL`: Model name or identifier
- `RUN_ID`: Unique identifier for the current run

### Model Path Environment Variables
For HuggingFace models, you can set custom paths:
- `LLAMA_3_1_8B_PATH`, `LLAMA_3_1_70B_PATH`, `LLAMA_3_3_70B_PATH`
- `QWEN_2_5_7B_PATH`, `QWEN_2_5_14B_PATH`, `QWEN_2_5_32B_PATH`, `QWEN_2_5_72B_PATH`
- `QWQ_32B_PATH`, `QWEN_3_32B_PATH`, `QWEN_3_8B_PATH`
- `INTERNLM_2_5_7B_PATH`, `INTERNLM_2_5_20B_PATH`

## Usage

### Starting the System

The system can be started in different modes based on the `AGENT_LLM_TYPE` environment variable:

#### HuggingFace Model Mode
```bash
export AGENT_LLM_TYPE=hf_model
export AGENT_LLM_MODEL=Qwen2.5-7B-Instruct
export RUN_ID=1
python start.py
```

#### Closed-Source API Mode
```bash
export AGENT_LLM_TYPE=close_name
export AGENT_LLM_MODEL=gpt-4o-2024-11-20
export RUN_ID=1
python start.py
```

### API Endpoints

The system provides REST API endpoints:

#### Health Check
```bash
curl -X GET "http://localhost:5656/healthz"
curl -X POST "http://localhost:5656/healthz" \
  -H "Content-Type: application/json" \
  -d '{"prompt": "health_check"}'
```

#### Set Goal
```bash
curl -X POST "http://localhost:5656/set_goal" \
  -H "Content-Type: application/json" \
  -d '{"goal": "List all files in the current directory"}'
```