https://github.com/jcallinan/lit-llama

Implementation of the LLaMA language model based on nanoGPT. Supports flash attention, Int8 and GPTQ 4bit quantization, LoRA and LLaMA-Adapter fine-tuning, pre-training. Apache 2.0-licensed.

https://github.com/jcallinan/lit-llama

Science Score: 10.0%

This score indicates how likely this project is to be science-related based on various indicators:

  • CITATION.cff file
  • codemeta.json file
  • .zenodo.json file
  • DOI references
  • Academic publication links
    Links to: arxiv.org
  • Academic email domains
  • Institutional organization owner
  • JOSS paper metadata
  • Scientific vocabulary similarity
    Low similarity (13.1%) to scientific vocabulary
Last synced: 8 months ago · JSON representation

Repository

Implementation of the LLaMA language model based on nanoGPT. Supports flash attention, Int8 and GPTQ 4bit quantization, LoRA and LLaMA-Adapter fine-tuning, pre-training. Apache 2.0-licensed.

Basic Info
  • Host: GitHub
  • Owner: jcallinan
  • License: apache-2.0
  • Default Branch: main
  • Homepage:
  • Size: 1.54 MB
Statistics
  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • Open Issues: 0
  • Releases: 0
Fork of Lightning-AI/lit-llama
Created over 2 years ago · Last pushed over 2 years ago

https://github.com/jcallinan/lit-llama/blob/main/

Lit-LLaMA # Lit-LLaMA ![cpu-tests](https://github.com/lightning-AI/lit-llama/actions/workflows/cpu-tests.yml/badge.svg) [![Build Status](https://dev.azure.com/Lightning-AI/lit%20Models/_apis/build/status%2FLightning-AI.lit-LLaMA?branchName=main)](https://dev.azure.com/Lightning-AI/lit%20Models/_build/latest?definitionId=49&branchName=main) [![license](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](https://github.com/Lightning-AI/lit-llama/blob/master/LICENSE) [![Discord](https://img.shields.io/discord/1077906959069626439?style=plastic)](https://discord.gg/VptPCZkGNa) Lit-LLaMA and pineapple pizza
# Lit-LLaMA Independent implementation of [LLaMA]() pretraining, finetuning, and inference code that is fully open source under the **Apache 2.0 license.** This implementation builds on [nanoGPT](). The open-source code in this repository works with the original LLaMA weights that are distributed by Meta under a [research-only license](https://github.com/facebookresearch/llama/blob/main/MODEL_CARD.md#model-details). ## Looking for LLaMA 2? Meta AI has since released LLaMA 2. Additionally, new Apache 2.0 licensed weights are being released as part of the [Open LLaMA project](https://github.com/openlm-research/open_llama). To run LLaMA 2 weights, Open LLaMA weights, or Vicuna weights (among other LLaMA-like checkpoints), **check out the [Lit-GPT repository](https://github.com/Lightning-AI/lit-gpt)**. ## Why? We believe that AI should be fully open source and part of the collective knowledge. The original [LLaMA code](https://github.com/facebookresearch/llama) is [GPL licensed](https://github.com/facebookresearch/llama/blob/main/LICENSE) which means any project using it must also be released under GPL. This "taints" any other code and prevents integration with the rest of the ecosystem. **Lit-LLaMA solves that for good.**   ## Design principles **Lit-LLaMA** is: - **Simple:** Single-file implementation without boilerplate. - **Correct:** Numerically equivalent to the original model. - **Optimized:** Runs on consumer hardware or at scale. - **Open-source:** No strings attached. ## Get involved! [Join our Discord](https://discord.gg/VptPCZkGNa) to build high-performance, truly open-source models for the common benefit of the community.   ## Setup Clone the repo ```bash git clone https://github.com/Lightning-AI/lit-llama cd lit-llama ``` install dependencies ```bash pip install -r requirements.txt ``` You are all set!   ## Use the model To generate text predictions, you need to download the model weights. **If you don't have them, check out our [guide](howto/download_weights.md).** Run inference: ```bash python generate.py --prompt "Hello, my name is" ``` This will run the 7B model and require ~26 GB of GPU memory (A100 GPU). [Full guide for generating samples from the model](howto/inference.md). ### Run Lit-LLaMA on consumer devices On GPUs with `bfloat16` support, the `generate.py` script will automatically convert the weights and consume about ~14 GB. For GPUs with less memory, or ones that don't support `bfloat16`, enable quantization (`--quantize llm.int8`): ```bash python generate.py --quantize llm.int8 --prompt "Hello, my name is" ``` See `python generate.py --help` for more options. You can also use GPTQ-style int4 quantization, but this needs conversions of the weights first: ```bash python quantize/gptq.py --output_path checkpoints/lit-llama/7B/llama-gptq.4bit.pth --dtype bfloat16 --quantize gptq.int4 ``` GPTQ-style int4 quantization brings GPU usage down to about ~5GB. As only the weights of the Linear layers are quantized, it is useful to also use `--dtype bfloat16` even with the quantization enabled. With the generated quantized checkpoint generation quantization then works as usual with `--quantize gptq.int4` and the newly generated checkpoint file: ```bash python generate.py --quantize gptq.int4 --checkpoint_path checkpoints/lit-llama/7B/llama-gptq.4bit.pth ``` [Full guide for generating samples from the model](howto/inference.md). ## Finetune the model We provide a simple training scripts in `finetune/lora.py` and `finetune/adapter.py` that instruction-tunes a pretrained model on the [Alpaca](https://github.com/tatsu-lab/stanford_alpaca) dataset using the techniques of [LoRA](https://arxiv.org/abs/2106.09685) and [Adapter](https://arxiv.org/abs/2303.16199). 1. Download the data and generate a instruction tuning dataset: ```bash python scripts/prepare_alpaca.py ``` 2. Run the finetuning script ```bash python finetune/lora.py ``` or ```bash python finetune/adapter.py ``` It is expected that you have downloaded the pretrained weights as described above. The finetuning requires at least one GPU with ~24 GB memory (RTX 3090). Follow the instructions in the script to efficiently fit your GPU memory. Note: For some GPU models you might need to set `torch.backends.cuda.enable_flash_sdp(False)` (see comments at the top of the script). More details about each finetuning method and how you can apply it to your own data can be found in our technical how-to guides. ### Finetuning How-To Guides These technical tutorials illustrate how to run the finetuning code. - [Finetune with LoRA](howto/finetune_lora.md) - [Finetune with Adapters](howto/finetune_adapter.md) ### Understanding Finetuning -- Conceptual Tutorials Looking for conceptual tutorials and explanations? We have some additional articles below: - [Understanding Parameter-Efficient Finetuning of Large Language Models: From Prefix Tuning to LLaMA-Adapters](https://lightning.ai/pages/community/article/understanding-llama-adapters/) ## Pre-training We provide a simple training script based on Fabric if you want to venture into pre-training on RedPajama, a reproduction of the original LLaMA dataset. Conversion scripts for our optimized streaming `PackedDataset` are included. Follow this guide to start pre-training on the RedPajama dataset: - [Pretrain on RedPajama](howto/train_redpajama.md) ## Get involved! We are on a quest towards fully open source AI. Lit-LLaMA Join us and start contributing, especially on the following areas: - [ ] [Pre-training](https://github.com/Lightning-AI/lit-llama/labels/pre-training) - [ ] [Fine-tuning (full and LoRA)](https://github.com/Lightning-AI/lit-llama/labels/fine-tuning) - [ ] [Quantization](https://github.com/Lightning-AI/lit-llama/labels/quantization) - [ ] [Sparsification](https://github.com/Lightning-AI/lit-llama/labels/sparsification) Look at `train.py` for a starting point towards pre-training / fine-tuning using [Lightning Fabric](https://lightning.ai/docs/fabric/stable/). We welcome all individual contributors, regardless of their level of experience or hardware. Your contributions are valuable, and we are excited to see what you can accomplish in this collaborative and supportive environment. Unsure about contributing? Check out our [Contributing to Lit-LLaMA: A Hitchhikers Guide to the Quest for Fully Open-Source AI](https://lightning.ai/pages/community/tutorial/contributing-to-lit-llama-a-hitchhikers-guide-to-the-quest-for-fully-open-source-ai/) guide. Don't forget to [join our Discord](https://discord.gg/VptPCZkGNa)! ## Acknowledgements - [@karpathy](https://github.com/karpathy) for [nanoGPT](https://github.com/karpathy/nanoGPT) - [@FacebookResearch](https://github.com/facebookresearch) for the original [LLaMA implementation](https://github.com/facebookresearch/llama) - [@TimDettmers](https://github.com/TimDettmers) for [bitsandbytes](https://github.com/TimDettmers/bitsandbytes) - [@Microsoft](https://github.com/microsoft) for [LoRA](https://github.com/microsoft/LoRA) - [@IST-DASLab](https://github.com/IST-DASLab) for [GPTQ](https://github.com/IST-DASLab/gptq) ## License Lit-LLaMA is released under the [Apache 2.0](https://github.com/Lightning-AI/lightning-llama/blob/main/LICENSE) license.

Owner

  • Name: Jeremy Callinan
  • Login: jcallinan
  • Kind: user
  • Location: Bradford, PA 16701

Developer, Consultant, Contractor, Adjunct Instructor at the University of Pittsburgh at Bradford.

GitHub Events

Total
Last Year