# LLM-Powered Preference Elicitation in Combinatorial Assignment

This repository contains the code, appendix, and experimental results for our work on **LLM-Powered Preference Elicitation in Combinatorial Assignment**, where we investigate how large language models (LLMs) can serve as proxies for humans to simplify the preference elicitation process.

The appendix is in this folder at Appendix.pdf

## 🚀 Key Features
- **LLM Proxy for Preference Elicitation**: Transforms **free-text** human preferences into structured inputs for combinatorial allocation mechanisms.
- **Machine Learning-Powered Allocation**: Enhances existing ML-based PE frameworks with **comparison queries (CQs) answered by LLMs**.
- **Chain-of-Thought Reasoning for LLMs**: Uses a structured prompting approach to improve LLM accuracy when answering preference queries.
- **Noise-Robust Training with Generalized Cross-Entropy (GCE)**: Mitigates the impact of noisy LLM responses, ensuring robust preference learning.

## 📂 Repository Structure
- `simulation_llm/` – Implementation of the LLM-powered preference elicitation framework. The main experiments are run with the files named real_xxx_cqs_training_hpo_{version}.py where xxx is the language model name, and the versions corresponds to the different experiments presented in the paper.
- `util/` – Code and data for experiments on course allocation and other ML components.
- `student_description/` – student description information generated by LLM.
- `simulation_noise/` – Simulation code.

## ⚙️ Installation & Usage
### Requirements
* Python 3.8 (or later) 
* numpy
* gurobi python API
* edsl

Prepare your python environment <name_of_your_environment> (whether you do that with `conda`, `virtualenv`, etc.) and activate this environment. Then install the required packages.

Using conda:
```bash
$ conda install -c anaconda numpy 
$ conda install -c gurobi gurobi 
$ conda install -c edsl

```

---

Let me know if you want to add any specific details! 🚀
