# Secure LLM Obfuscation and Inference Framework

This repository contains code for secure LLM obfuscation and inference experiments. The project is organized into two main directories, each focusing on different aspects of secure LLM deployment.

## Repository Structure

```
github_repo/
├── obf_llm/          # Security experiment code and hyperparameters
├── inference/        # Secure inference implementation
└── README.md         # This file
```

## Hardware Environment Requirements

We conduct inference and security analysis experiments on different devices:

- **Inference**:
    - **CPU**: 2 * 4th Gen Intel Xeon Scalable Processors 4410Y
    - **GPU**: 1 * Nvidia A100 80G PCIe
    - **RAM**: 512GB
- **Security**:
    - **CPU**: 56vCPU
    - **GPU**: 4 * Nvidia RTX 5090 32G
    - **RAM**: 480GB
    - **OS**: Ubuntu 24.04

## Python Environment Requirements

The following Python packages are required to run the code:

### Core Dependencies
- Python 3.10 or higher
- numpy
- torch
- transformers
- vllm
- scikit-learn

### SGX-Related Dependencies
- intel-sgx-sdk (for SGX enclave development)

### Installation Commands

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

## Directory Overview

### obf_llm

The `obf_llm` directory contains code and hyperparameters for security experiments. This includes:

- Implementation of various obfuscation techniques for LLMs
- Experiment configurations and hyperparameters
- Scripts for evaluating obfuscation effectiveness
- Security analysis tools

### inference

The `inference` directory contains code for secure inference using SGX technology. This includes:

- SGX enclave implementations for different obfuscation approaches
- Python wrappers for SGX enclave APIs
- Test scripts for evaluating inference performance and security
- Model implementations optimized for secure execution

## Getting Started

1. **Set up the hardware environment** with SGX support enabled
2. **Install the required Python packages** as listed above
3. **Install the Intel SGX SDK** following official documentation
4. **Build the SGX dynamic libraries** in the `inference/sgx` directory
5. **Run the security experiments** in the `obf_llm` directory
6. **Test the secure inference** using the scripts in the `inference/python` directory
