Skip to content
This repository has been archived by the owner on Jan 16, 2025. It is now read-only.
/ OpenCoconut Public archive

OpenCoconut implements a latent reasoning paradigm where we generate thoughts before decoding.

License

Notifications You must be signed in to change notification settings

casper-hansen/OpenCoconut

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

12 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

arXiv

OpenCoconut

UPDATE: Meta has finally released their code! It was fun to try and reproduce Coconut, but I am archiving this repository now that the original implementation is up. https://github.com/facebookresearch/coconut

OpenCoconut intends to replicate the Chain of Continuous Thought (COCONUT) paper that implements a novel latent reasoning paradigm. The main idea is to generate thoughts in latent space by utilizing the hidden states during prefilling before we start decoding response. We build on the public dataset from the paper for math casperhansen/gsm8k_synthetic_cot.

Derivative/Similar Work

  1. Derivative: A clean demonstration of how a modified OpenCoconut using Gemma 2 leads to improved performance in translation tasks: https://github.com/vicksEmmanuel/latent-gemma
  2. Similar: LucidRains implements a custom Transformer from scratch with Coconut paradigm: https://github.com/lucidrains/coconut-pytorch

Getting started

Install the package and then go look in examples for how to run training and inference.

git clone https://github.com/casper-hansen/OpenCoconut.git
cd OpenCoconut
pip install -e .

If you want to see the thoughts during training or inference, you can run with DEBUG=1 python ....

Future Work

  1. Improve the loss function
    • Use a REINFORCE loss for thought tokens.
  2. Implement COCONUT for pretraining
    • Scaling through pretraining would be ideal due to data availability.
  3. Implement early exit with a classifier
    • Potentially as simple as training nn.Linear(X, 1).
  4. Improve the datasets
    • Find a good mix of step-by-step datasets for math, coding, and general domain.
  5. Adaptively switch between latent and language space during decoding.
    • This could help improve accuracy by allowing generation of more thoughts.
  6. Unit testing different parts of the code.
    • This should help with keeping bugs in check as code changes.

About

OpenCoconut implements a latent reasoning paradigm where we generate thoughts before decoding.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages