# Executable Agentic Memory (EAM) Implementation

This repository contains the implementation code for **Executable Agentic Memory**. Follow the instructions below to set up the environment, construct the knowledge graph, train the model, and run inference.

## 1. Installation & Prerequisites

Before running the code, ensure you have the necessary databases and tools installed.

### 1.1 Database Setup

*   **Neo4j:** Deploy a Neo4j Graph Database instance.
*   **Pinecone:** Deploy a Pinecone Vector Database instance.
*   *Please refer to the official [Neo4j](https://neo4j.com/docs/) and [Pinecone](https://docs.pinecone.io/) documentation for deployment instructions.*

### 1.2 Python Environment

Create a virtual environment and install the required dependencies.

```bash
# Create a virtual environment (recommended)
conda create -n eam_env python=3.10
conda activate eam_env

# Install dependencies
pip install -r requirements.txt
```

### 1.3 Android Setup

1. Download and install [Android Studio](https://developer.android.com/studio).
2. Set up **ADB** (Android Debug Bridge) and configure an Android Emulator.
3. Ensure the emulator is running and accessible via ADB.

---

## 2. Getting Started: Exploration

This step performs autonomous exploration to collect interaction data.

1. **Configure Paths:** Open `exploration.py` and specify the paths for your emulator and `adb`.

2. **Configure Credentials:** Open `config.py` (or your specific config file) and set the following:
   - Neo4j ID and Password
   - Pinecone API Key and Environment
   - LLM API Keys (e.g., OpenAI ID/Key)
   - Target directory for storing exploration trajectories

3. **Run Exploration:**

   ```bash
   python exploration.py
   ```

---

## 3. Knowledge Graph Construction

Build the structured knowledge graph from the collected trajectories.

1. Navigate to the utility directory:

   ```bash
   cd task_explorer/util
   ```

2. Open `Construct_KG.py` and specify the directory where your exploration trajectories are stored.

3. **Run Construction:**

   ```bash
   python Construct_KG.py
   ```
## 4. Model Self-Training

This process involves preparing the environment data and iteratively training the model.

### 4.1 Data Preparation

First, convert the constructed Knowledge Graph into a text-based environment format for training.

```bash
python KG_to_file.py
```

### 4.2 Training Setup

It is recommended to use a separate clean environment for the training pipeline to avoid conflicts.

```bash
# Create and activate a new environment for training
conda create -n training_env python=3.10
conda activate training_env

# Navigate to the self_training directory
cd self_training

# Install training specific dependencies
pip install -r requirements.txt
```

### 4.3 Run Pipeline

1. Open `run_pipeline.py`.
2. Specify the **Base Model Path** and the **KG Data Path** (generated in step 4.1).
3. **Start Training:**

   ```bash
   python run_pipeline.py
   ```

---

## 5. Inference

Run the MCTS-based inference using the trained model.

1. Navigate to the MCTS directory:

   ```bash
   cd ../MCTS
   ```

2. Open `MCTS_score.py` and specify the path to your trained model checkpoint.

3. **Run Inference:**

   ```bash
   python MCTS_score.py
   ```