# Implementation of Secure Inference

## Project Structure

This project implements secure inference using SGX (Software Guard Extensions) technology. The project structure is organized as follows:

```
inference/
├── python/                # Python implementation and test scripts
│   ├── sgx_api/           # SGX API wrappers for different implementations
│   │   ├── sgx_arrowcloak.py
│   │   ├── sgx_groupcover.py
│   │   └── sgx_ours.py
│   ├── model_arrowcloak.py  # Model implementation for ArrowCloak
│   ├── model_groupcover.py  # Model implementation for GroupCover
│   ├── model_ours.py        # Model implementation for our approach
│   ├── obf_arrowcloak.py    # Obfuscation implementation for ArrowCloak
│   ├── obf_groupcover.py    # Obfuscation implementation for GroupCover
│   ├── obf_ours.py          # Obfuscation implementation for our approach
│   ├── test_infer.py        # Inference test script
│   ├── test_throughput.py   # Throughput test script
│   └── test_token_acc.py    # Token accuracy test script
├── sgx/                    # SGX enclave implementations
│   ├── arrowcloak/          # ArrowCloak implementation
│   │   ├── app/             # Untrusted application code
│   │   │   ├── App.cpp
│   │   │   └── ocalls.cpp
│   │   ├── enclave/         # Trusted enclave code
│   │   │   ├── Compute.cpp
│   │   │   ├── Compute_multi_threads.cpp
│   │   │   ├── Data.cpp
│   │   │   ├── DataStructure.h
│   │   │   ├── Enclave.config.xml
│   │   │   ├── Enclave.cpp
│   │   │   ├── Enclave.edl
│   │   │   ├── Enclave.h
│   │   │   └── Enclave_private.pem
│   │   └── Makefile         # Build file for ArrowCloak
│   ├── groupcover/          # GroupCover implementation
│   │   ├── app/             # Untrusted application code
│   │   │   ├── App.cpp
│   │   │   └── ocalls.cpp
│   │   ├── enclave/         # Trusted enclave code
│   │   │   ├── Compute.cpp
│   │   │   ├── Compute_bak.cpp
│   │   │   ├── Compute_multi_threads.cpp
│   │   │   ├── Data.cpp
│   │   │   ├── DataStructure.h
│   │   │   ├── Enclave.config.xml
│   │   │   ├── Enclave.cpp
│   │   │   ├── Enclave.edl
│   │   │   ├── Enclave.h
│   │   │   └── Enclave_private.pem
│   │   └── Makefile         # Build file for GroupCover
│   ├── ours/                # Our approach implementation
│   │   ├── app/             # Untrusted application code
│   │   │   ├── App.cpp
│   │   │   └── ocalls.cpp
│   │   ├── enclave/         # Trusted enclave code
│   │   │   ├── Enclave.config.xml
│   │   │   ├── Enclave.cpp
│   │   │   ├── Enclave.edl
│   │   │   ├── Enclave.h
│   │   │   ├── Enclave.lds
│   │   │   ├── Enclave_private.pem
│   │   │   ├── Internal.h
│   │   │   ├── Obfuscation.cpp
│   │   │   ├── Obfuscation.h
│   │   │   ├── Otp.cpp
│   │   │   └── Otp.h
│   │   └── Makefile         # Build file for our approach
│   └── third_party/         # Third-party libraries
│       ├── FastMemcpy_Avx.h
│       └── fmath.hpp
└── README.md                # This file
```

## Building SGX Dynamic Libraries

To build the SGX dynamic libraries for each implementation, follow these steps:

### Prerequisites
- Intel SGX SDK installed
- Appropriate build tools (gcc, make, etc.)

### Building ArrowCloak SGX Library

Before building the SGX libraries, modified the sgx sdk path in Makefile to your own path.

```bash
cd inference/sgx/arrowcloak
make clean
make all
```

### Building GroupCover SGX Library

```bash
cd inference/sgx/groupcover
make clean
make all
```

### Building Our Approach SGX Library

```bash
cd inference/sgx/ours
make clean
make all
```

After successful compilation, the SGX dynamic libraries will be generated in their respective directories.

## Running Python Files

To run the Python test scripts, follow these steps:

### Running Inference Test

```bash
cd inference/python
export LD_LIBRARY_PATH=/path/to/your/sgxsdk/lib64:$LD_LIBRARY_PATH && python test_infer.py --model_path ${model_path} --method ours
```

### Running Throughput Test

```bash
cd inference/python
export LD_LIBRARY_PATH=/path/to/your/sgxsdk/lib64:$LD_LIBRARY_PATH && python test_throughput.py --model_path ${model_path} --method ours
```

### Running Token Accuracy Test

```bash
cd inference/python
export LD_LIBRARY_PATH=/path/to/your/sgxsdk/lib64:$LD_LIBRARY_PATH && python test_token_acc.py --model_path ${model_path} --method ours
```

### Using the Models and Obfuscation

The Python directory contains model implementations and obfuscation techniques for each approach:

- `model_*.py` files: Implement the models for each approach
- `obf_*.py` files: Implement obfuscation techniques for each approach
- `sgx_api/sgx_*.py` files: Provide Python wrappers for the SGX enclave APIs

These files are used by the test scripts to perform secure inference with different obfuscation techniques.

