Merge pull request #299 from OpenInterpreter/livekit-docs-update

Docs Update - Livekit and Light Server
pull/300/head
killian 4 months ago committed by GitHub
commit 575754ed7f
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

@ -15,12 +15,24 @@ To run the 01 on your computer, you will need to install a few essential package
To install poetry, follow the official guide here. To install poetry, follow the official guide here.
</Card> </Card>
## What is Poetry?
Poetry is a tool for dependency management and packaging in Python. It allows you to declare the libraries your project depends on and it will manage (install/update) them for you. We use Poetry to ensure that everyone running 01 has the same environment and dependencies.
### MacOS ### MacOS
On MacOS, we use Homebrew (a package manager) to install the required dependencies. Run the following command in your terminal:
```bash ```bash
brew install portaudio ffmpeg cmake brew install portaudio ffmpeg cmake
``` ```
This command installs:
- PortAudio: A cross-platform audio I/O library
- FFmpeg: A complete, cross-platform solution for recording, converting, and streaming audio and video
- CMake: An open-source, cross-platform family of tools designed to build, test and package software
### Ubuntu ### Ubuntu
<Note>Wayland not supported, only Ubuntu 20.04 and below</Note> <Note>Wayland not supported, only Ubuntu 20.04 and below</Note>
@ -29,6 +41,12 @@ brew install portaudio ffmpeg cmake
sudo apt-get install portaudio19-dev ffmpeg cmake sudo apt-get install portaudio19-dev ffmpeg cmake
``` ```
This command installs:
- PortAudio: A cross-platform audio I/O library
- FFmpeg: A complete solution for recording, converting, and streaming audio and video
- CMake: An open-source, cross-platform family of tools designed to build, test and package software
### Windows ### Windows
- [Git for Windows](https://git-scm.com/download/win). - [Git for Windows](https://git-scm.com/download/win).

@ -9,7 +9,7 @@ description: "The open-source language model computer"
style={{ transform: "translateY(-1.25rem)" }} style={{ transform: "translateY(-1.25rem)" }}
/> />
The **01** is an open-source platform for conversational devices, inspired by the *Star Trek* computer. The **01** is an open-source platform for conversational devices, inspired by the _Star Trek_ computer.
With [Open Interpreter](https://github.com/OpenInterpreter/open-interpreter) at its core, the **01** is more natural, flexible, and capable than its predecessors. Assistants built on **01** can: With [Open Interpreter](https://github.com/OpenInterpreter/open-interpreter) at its core, the **01** is more natural, flexible, and capable than its predecessors. Assistants built on **01** can:
@ -19,7 +19,7 @@ With [Open Interpreter](https://github.com/OpenInterpreter/open-interpreter) at
- Control third-party software - Control third-party software
- ... - ...
<br> <br></br>
We intend to become the GNU/Linux of this space by staying open, modular, and free. We intend to become the GNU/Linux of this space by staying open, modular, and free.

@ -6,5 +6,3 @@ description: "The 01 light"
The 01 light is an open-source voice interface. The 01 light is an open-source voice interface.
The first body was designed to be push-to-talk and handheld, but the core chip can be built into standalone bodies with hardcoded wifi credentials. The first body was designed to be push-to-talk and handheld, but the core chip can be built into standalone bodies with hardcoded wifi credentials.
[MORE COMING SOON]

@ -44,7 +44,14 @@
"pages": [ "pages": [
"software/introduction", "software/introduction",
"software/installation", "software/installation",
"software/run", {
"group": "Server",
"pages": [
"software/server/introduction",
"software/server/livekit-server",
"software/server/light-server"
]
},
"software/configure", "software/configure",
"software/flags" "software/flags"
] ]
@ -55,6 +62,7 @@
{ {
"group": "01 Light", "group": "01 Light",
"pages": [ "pages": [
"hardware/01-light/introduction",
"hardware/01-light/materials", "hardware/01-light/materials",
"hardware/01-light/case", "hardware/01-light/case",
"hardware/01-light/assembly", "hardware/01-light/assembly",
@ -66,17 +74,25 @@
"hardware/desktop", "hardware/desktop",
{ {
"group": "Mobile", "group": "Mobile",
"pages": ["hardware/mobile/ios", "hardware/mobile/android", "hardware/mobile/privacy"] "pages": [
"hardware/mobile/ios",
"hardware/mobile/android",
"hardware/mobile/privacy"
]
} }
] ]
}, },
{ {
"group": "Troubleshooting", "group": "Troubleshooting",
"pages": ["troubleshooting/faq"] "pages": [
"troubleshooting/faq"
]
}, },
{ {
"group": "Legal", "group": "Legal",
"pages": ["legal/fulfillment-policy"] "pages": [
"legal/fulfillment-policy"
]
} }
], ],
"feedback": { "feedback": {

@ -133,3 +133,11 @@ For local TTS, Coqui is used.
# Set your profile with a local TTS service # Set your profile with a local TTS service
interpreter.tts = "coqui" interpreter.tts = "coqui"
``` ```
<Note>
When using the Livekit server, the interpreter.tts setting in your profile
will be ignored. The Livekit server currently only works with Deepgram for
speech recognition and Eleven Labs for text-to-speech. We are working on
introducing all-local functionality for the Livekit server as soon as
possible.
</Note>

@ -7,10 +7,12 @@ description: "Customize the behaviour of your 01 from the CLI"
### Server ### Server
Runs the server. Specify the server to run.
Valid arguments are either [livekit](/software/livekit-server) or [light](/software/light-server)
``` ```
poetry run 01 --server poetry run 01 --server light
``` ```
### Server Host ### Server Host
@ -33,19 +35,6 @@ Default: `10001`.
poetry run 01 --server-port 10001 poetry run 01 --server-port 10001
``` ```
### Tunnel Service
Specify the tunnel service.
Default: `ngrok`.
```
poetry run 01 --tunnel-service ngrok
```
Specify the tunnel service.
Default: `ngrok`.
### Expose ### Expose
Expose server to internet. Expose server to internet.
@ -56,10 +45,12 @@ poetry run 01 --expose
### Client ### Client
Run client. Specify the client.
Valid argument is `light-python`
``` ```
poetry run 01 --client poetry run 01 --client light-python
``` ```
### Server URL ### Server URL
@ -73,18 +64,6 @@ Default: `None`.
poetry run 01 --server-url http://0.0.0.0:10001 poetry run 01 --server-url http://0.0.0.0:10001
``` ```
### Client Type
Specify the client type.
Default: `auto`.
```
poetry run 01 --client-type auto
```
Default: `auto`.
### QR ### QR
Display QR code to scan to connect to the server. Display QR code to scan to connect to the server.

@ -43,7 +43,7 @@ One of the key features of the 01 ecosystem is its modularity. You can:
To begin using 01: To begin using 01:
1. [Install](/software/installation) the software 1. [Install](/software/installation) the software
2. [Run](/software/run) the Server 2. [Run](/software/server/introduction) the Server
3. [Connect](/hardware/01-light/connect) the Client 3. [Connect](/hardware/01-light/connect) the Client
For more advanced usage, check out our guides on [configuration](/software/configure). For more advanced usage, check out our guides on [configuration](/software/configure).

@ -1,18 +0,0 @@
---
title: "Run"
description: "Run your 01"
---
<Info> Make sure that you have navigated to the `software` directory. </Info>
To run the server and the client:
```bash
poetry run 01
```
To run the 01 server:
```bash
poetry run 01 --server
```

@ -0,0 +1,19 @@
---
title: "Choosing a server"
description: "The servers that powers 01"
---
<CardGroup cols={2}>
<Card title="Light" href="/software/server/light-server">
Light Server
</Card>
<Card title="Livekit" href="/software/server/livekit">
Livekit Server
</Card>
</CardGroup>
## Livekit vs. Light Server
- **Livekit Server**: Designed for devices with higher processing power, such as phones, web browsers, and more capable hardware. It offers a full range of features and robust performance.
- **Light Server**: We have another lightweight server called the Light server, specifically designed for ESP32 devices. It's optimized for low-power, constrained environments.

@ -0,0 +1,28 @@
---
title: "Light Server"
description: "A lightweight voice server for your 0"
---
## Overview
The Light server streams bytes of audio to an ESP32 and the Light Python client.
### Key Features
- Lightweight
- Works with ESP32
- Can use local options for Speech-to-Text and Text-to-Speech
## Getting Started
### Prerequisites
Make sure you have navigated to the `software` directory before proceeding.
### Starting the Server
To start the Light server, run the following command:
```bash
poetry run 01 --server light
```

@ -0,0 +1,99 @@
---
title: "Livekit Server"
description: "A robust, feature-rich voice server for your 01"
---
## Overview
[Livekit](https://livekit.io/) is a powerful, open-source WebRTC server and client SDK that enables real-time audio communication. It's designed for applications that require robust, scalable real-time features.
### Key Features
- Scalable architecture
- Extensive documentation and community support
- SDKs for various languages and platforms (web, mobile, desktop)
## Getting Started
### Prerequisites
Make sure you have navigated to the `software` directory before proceeding.
### Installing Livekit
Before setting up the environment, you need to install Livekit. Follow the instructions for your operating system:
- **macOS**:
```bash
brew install livekit
```
- **Linux**:
```bash
curl -sSL https://get.livekit.io | bash
```
- **Windows**:
Download the latest release from: [Livekit Releases](https://github.com/livekit/livekit/releases/tag/v1.7.2)
### Environment Setup
1. Create a `.env` file in the `/software` directory with the following content:
```env
ELEVEN_API_KEY=your_eleven_labs_api_key
DEEPGRAM_API_KEY=your_deepgram_api_key
NGROK_AUTHTOKEN=your_ngrok_auth_token
```
Replace the placeholders with your actual API keys.
<CardGroup cols={3}>
<Card title="Eleven Labs" icon="microphone" href="https://beta.elevenlabs.io">
Get your Eleven Labs API key for text-to-speech
</Card>
<Card title="Deepgram" icon="waveform-lines" href="https://console.deepgram.com">
Obtain your Deepgram API key for speech recognition
</Card>
<Card title="Ngrok" icon="wifi" href="https://dashboard.ngrok.com">
Sign up for Ngrok and get your auth token
</Card>
</CardGroup>
### Starting the Server
To start the Livekit server, run the following command:
```bash
poetry run 01 --server livekit
```
<Note>
Currently, our Livekit server only works with Deepgram and Eleven Labs. We are working to introduce all-local functionality as soon as possible. By setting your profile (see [Configure Your Profile](/software/configure)), you can still change your LLM to be a local LLM, but the `interpreter.tts` value will be ignored for the Livekit server.
</Note>
## Livekit vs. Light Server
- **Livekit Server**: Designed for devices with higher processing power, such as phones, web browsers, and more capable hardware. It offers a full range of features and robust performance.
- **Light Server**: We have another lightweight server called the Light server, specifically designed for ESP32 devices. It's optimized for low-power, constrained environments.
## SDK Integration
Livekit provides SDKs for various programming languages and platforms, allowing you to easily integrate real-time communication features into your applications.
### Available SDKs
- JavaScript/TypeScript
- React
- React Native
- iOS (Swift)
- Android (Kotlin)
- Flutter
- Unity
<Card
title="Explore Livekit SDKs"
icon="code"
href="https://docs.livekit.io/client-sdk-js/"
>
Find documentation and integration guides for all Livekit SDKs.
</Card>
Loading…
Cancel
Save