Our new X account is live! Follow @wizwand_team for updates
WorkDL logo mark

FreeCtrl: Constructing Control Centers with Feedforward Layers for Learning-Free Controllable Text Generation

About

Controllable text generation (CTG) seeks to craft texts adhering to specific attributes, traditionally employing learning-based techniques such as training, fine-tuning, or prefix-tuning with attribute-specific datasets. These approaches, while effective, demand extensive computational and data resources. In contrast, some proposed learning-free alternatives circumvent learning but often yield inferior results, exemplifying the fundamental machine learning trade-off between computational expense and model efficacy. To overcome these limitations, we propose FreeCtrl, a learning-free approach that dynamically adjusts the weights of selected feedforward neural network (FFN) vectors to steer the outputs of large language models (LLMs). FreeCtrl hinges on the principle that the weights of different FFN vectors influence the likelihood of different tokens appearing in the output. By identifying and adaptively adjusting the weights of attribute-related FFN vectors, FreeCtrl can control the output likelihood of attribute keywords in the generated content. Extensive experiments on single- and multi-attribute control reveal that the learning-free FreeCtrl outperforms other learning-free and learning-based methods, successfully resolving the dilemma between learning costs and model performance.

Zijian Feng, Hanzhang Zhou, Zixiao Zhu, Kezhi Mao• 2024

Related benchmarks

TaskDatasetResultRank
Multi-attribute Controllable Text GenerationMulti-attribute Control GPT-2 medium (evaluation set)
Average Score0.934
7
Single-attribute Controllable Text GenerationPPLM 35 Neutral Prompts GPT2-medium base (test)
Sentiment (Avg)97.7
7
Multi-attribute Controlled Text GenerationHuman Evaluation Set
Quality Score3.8
3
Single-Attribute Controlled Text GenerationHuman Evaluation Set
Quality Score4.1
3
Showing 4 of 4 rows

Other info

Code

Follow for update