Skip to content

Latest commit

 

History

History
86 lines (54 loc) · 2.75 KB

README.md

File metadata and controls

86 lines (54 loc) · 2.75 KB

SemiEvol

This repository contains the official implementation of the paper: SemiEvol: Semi-supervised Fine-tuning for LLM Adaptation.

TLDR

We have developed SemiEvol, which leverages labeled data to enhance inference on unlabeled data, thereby improving the reasoning capabilities of Large Language Models (LLMs). This process is characterized as a bi-level knowledge propagation and selection mechanism.

BibTex

If our work has been helpful to you, please consider citing it. Your citation serves as encouragement for our research.

@misc{luo2024semievol,
    title={SemiEvol: Semi-supervised Fine-tuning for LLM Adaptation}, 
    author={Junyu Luo and Xiao Luo and Xiusi Chen and Zhiping Xiao and Wei Ju and Ming Zhang},
    year={2024},
    eprint={2410.14745},
    archivePrefix={arXiv},
    primaryClass={cs.CL},
    url={https://arxiv.org/abs/2410.14745}, 
}

You can also find the paper at HuggingFace.

Framework

SemiEvol

SemiEvol maximizes the utility of labeled data through a bi-level knowledge propagation-and-selection framework, while leveraging collaborative learning among multiple LLMs to exploit unlabeled data, unleashing the full data potential.

Installation

Install dependencies using the requirements.txt file:

pip install -r requirements.txt

Dataset and Released Model Weights

We have released model weights for two tasks to facilitate testing:

Usage

  • For evaluation, execute:
python eval.py

You can modify relevant parameters, including task and model, in eval.py.

  • To run the SemiEvol process, use:
python semievol.py

You can adjust parameters such as task, model, and other hyperparameters in semievol.py.

  • For evaluation of RAG methods, run:
python rag-eval.py
  • To convert data for fine-tuning, use:
python utils/convert_data.py

Please modify the parameters in the code before execution.