samsja / tabby

Self-hosted AI coding assistant

Home Page:https://tabby.tabbyml.com/

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

🐾 Tabby

build status Docker pulls License Slack Community

Tabby is a self-hosted AI coding assistant, offering an open-source and on-premises alternative to GitHub Copilot. It boasts several key features:

  • Self-contained, with no need for a DBMS or cloud service.
  • OpenAPI interface, easy to integrate with existing infrastructure (e.g Cloud IDE).
  • Supports consumer-grade GPUs.

Open in Playground

Demo

πŸ‘€ What's New

  • 09/12/2023 Apple's M1/M2 Metal inference support has landed in v0.1.0!
  • 08/31/2023 tabby's first stable release v0.0.1 πŸ₯³.
  • 08/28/2023 Experimental support for the CodeLlama 7B.
  • 08/24/2023 Tabby is now on JetBrains Marketplace!

πŸ‘‹ Getting Started

The easiest way to start a Tabby server is by using the following Docker command:

docker run -it \
  --gpus all -p 8080:8080 -v $HOME/.tabby:/data \
  tabbyml/tabby \
  serve --model TabbyML/SantaCoder-1B --device cuda

For additional options (e.g inference type, parallelism), please refer to the documentation at https://tabbyml.github.io/tabby.

🀝 Contributing

Get the Code

git clone --recurse-submodules https://github.com/TabbyML/tabby
cd tabby

Build

  1. Set up the Rust environment by following this tutorial.

  2. Install the required dependencies:

# For MacOS
brew install protobuf

# For Ubuntu / Debian
apt-get install protobuf-compiler libopenblas-dev
  1. Now, you can build Tabby by running the command cargo build.

Start Hacking!

... and don't forget to submit a Pull Request

🌟 Star History

Star History Chart

About

Self-hosted AI coding assistant

https://tabby.tabbyml.com/

License:Apache License 2.0


Languages

Language:TypeScript 31.6%Language:Rust 25.8%Language:Kotlin 13.5%Language:Python 13.0%Language:Vim Script 5.9%Language:JavaScript 4.4%Language:C++ 2.5%Language:CMake 1.1%Language:MDX 0.9%Language:CSS 0.5%Language:Shell 0.4%Language:Dockerfile 0.4%Language:Makefile 0.0%