ChatterUI is a native mobile frontend for LLMs.
Run LLMs on device or connect to various commercial or open source APIs. ChatterUI aims to provide a mobile-friendly interface with fine-grained control over chat structuring.
If you like the app, feel free support me here:
data:image/s3,"s3://crabby-images/8daa0/8daa042bf03f13d94ea8e4ddd9a4cb06f756fbf8" alt=""
data:image/s3,"s3://crabby-images/bf6d8/bf6d8f1c5253242b6beb835ca084d5fefc417427" alt=""
Use on-device Models or APIs
data:image/s3,"s3://crabby-images/19216/19216a36cb8b58e0381d9b4a4fef3c17458c640a" alt=""
data:image/s3,"s3://crabby-images/a10e6/a10e61cceea9b1bc72aadfa6a92be161f1a437de" alt=""
Modify And Customize
data:image/s3,"s3://crabby-images/7058d/7058d611ae410d61b0d785d249b423a99c6202f1" alt=""
data:image/s3,"s3://crabby-images/07aee/07aee142f83357241b391f994976eb8d44150fb1" alt=""
Personalize Yourself
data:image/s3,"s3://crabby-images/9ddf9/9ddf9894ceaed04b43b50607b0728e4bc35369b7" alt=""
data:image/s3,"s3://crabby-images/9e438/9e438aeee6aa2c6a14660e66ba2f997d5a3e8eb8" alt=""
- Run LLMs on-device in Local Mode
- Connect to various APIs in Remote Mode
- Chat with characters. (Supports the Character Card v2 specification.)
- Create and manage multiple chats per character.
- Customize Sampler fields and Instruct formatting
- Integrates with your device’s text-to-speech (TTS) engine
Download and install latest APK from the releases page.
iOS is Currently unavailable due to lacking iOS hardware for development
ChatterUI uses a llama.cpp under the hood to run gguf files on device. A custom adapter is used to integrate with react-native: cui-llama.rn
To use on-device inferencing, first enable Local Mode, then go to Models > Import Model / Use External Model and choose a gguf model that can fit on your device's memory. The importing functions are as follows:
- Import Model: Copies the model file into ChatterUI, potentially speeding up startup time.
- Use External Model: Uses a model from your device storage directly, removing the need to copy large files into ChatterUI but with a slight delay in load times.
After that, you can load the model and begin chatting!
Note: For devices with Snapdragon 8 Gen 1 and above or Exynos 2200+, it is recommended to use the Q4_0 quantization for optimized performance.
Remote Mode allows you to connect to a few common APIs from both commercial and open source projects.
- koboldcpp
- text-generation-webui
- Ollama
- OpenAI
- Claude (with ability to use a proxy)
- Cohere
- Open Router
- Mancer
- AI Horde
- Generic Text Completions
- Generic Chat Completions
These should be compliant with any Text Completion/Chat Completion backends such as Groq or Infermatic.
Is your API provider missing? ChatterUI allows you to define APIs using its template system.
Read more about it here!
To run a development build, follow these simple steps:
- Install any Java 17/21 SDK of your choosing
- Install
android-sdk
viaAndroid Studio
- Clone the repo:
git clone https://github.com/Vali-98/ChatterUI.git
- Install dependencies via npm and run via Expo:
npm install
npx expo run:android
Requires Node.js, Java 17/21 SDK and Android SDK. Expo uses EAS to build apps which requires a Linux environment.
- Clone the repo.
- Rename the
eas.json.example
toeas.json
. - Modify
"ANDROID_SDK_ROOT"
to the directory of your Android SDK - Run the following:
npm install
eas build --platform android --local
Currently untested as I do not own hardware for iOS development. Assistance here would be greatly appreciated!
Possible issues:
- cui-llama.rn lacking Swift implementation for cui-specific functions
- cui-fs having no Swift integration
- Platform specific shadows
- Exporting files not using shareAsync