Giter VIP home page Giter VIP logo

vita-group / ms-poe Goto Github PK

View Code? Open in Web Editor NEW
13.0 10.0 1.0 7.71 MB

"Found in the Middle: How Language Models Use Long Contexts Better via Plug-and-Play Positional Encoding" Zhenyu Zhang, Runjin Chen, Shiwei Liu, Zhewei Yao, Olatunji Ruwase, Beidi Chen, Xiaoxia Wu, Zhangyang Wang.

License: MIT License

Python 87.49% Shell 12.51%
large-language-models long-context positional-encoding lost-in-the-middle

ms-poe's Introduction

Found in the Middle: How Language Models Use Long Contexts Better via Plug-and-Play Positional Encoding

License: MIT

Codes for this paper "Found in the Middle: How Language Models Use Long Contexts Better via Plug-and-Play Positional Encoding"

Zhenyu Zhang, Runjin Chen, Shiwei Liu, Zhewei Yao, Olatunji Ruwase, Beidi Chen, Xiaoxia Wu, Zhangyang Wang

Overview

This paper aims to overcome the "lost-in-the-middle" challenge of large language models (LLMs). While recent advancements have successfully enabled LLMs to perform stable language modeling with up to 4 million tokens, the persistent difficulty faced by most LLMs in identifying relevant information situated in the middle of the context has not been adequately tackled. To address this problem, this paper introduces Multi-scale Positional Encoding (Ms-PoE) which is a simple yet effective plug-and-play approach to enhance the capacity of LLMs to handle the relevant information located in the middle of the context, without fine-tuning or introducing any additional overhead. Ms-PoE leverages the position indice rescaling to relieve the long-term decay effect introduced by RoPE, while meticulously assigning distinct scaling ratios to different attention heads to preserve essential knowledge learned during the pre-training step, forming a multi-scale context fusion from short to long distance. Extensive experiments with a wide range of LLMs demonstrate the efficacy of our approach. Notably, Ms-PoE achieves an average accuracy gain of up to 3.8 on the Zero-SCROLLS benchmark over the original LLMs.

1709612009228

Prerequisites

Pytorch
Transformers

Usage

Baseline

# evaluation on multi-document QA
bash src/baseline.sh

Ours

# evaluation on multi-document QA
base src/ms_poe.sh

Citation

@article{zhang2024found,
  title={Found in the Middle: How Language Models Use Long Contexts Better via Plug-and-Play Positional Encoding},
  author={Zhang, Zhenyu and Chen, Runjin and Liu, Shiwei and Yao, Zhewei and Ruwase, Olatunji and Chen, Beidi and Wu, Xiaoxia and Wang, Zhangyang},
  journal={arXiv preprint arXiv:2403.04797},
  year={2024}
}

ms-poe's People

Contributors

kyriection avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

ms-poe's Issues

some questions when generating

Hi, thanks for your work and posting it! I have some following questions about your work and look forward to your replies.

  1. For the model, does it need to re-adapt the coefficients of the head every time it generates a sentence?
  2. According to my understanding of the paper, when assigning the coefficient of the header, the query of the last id and the entire sentence are used as k. But when I look at the code, it seems that it is the first query and k when generating, so the calculated attention is all 1 (the softmax range is only 1), and the coefficients of the head are linearly allocated in order.

Looking forward to your reply

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.