From 7d5e0b03323ffe6e54a62cd1e2d9e7aeb744c26f Mon Sep 17 00:00:00 2001 From: Mike Bird Date: Tue, 12 Mar 2024 21:12:03 -0400 Subject: [PATCH 1/2] new docs structure --- docs/01os/01os-settings.mdx | 37 ------ docs/01os/environment-variables.mdx | 105 ------------------ docs/bodies/01-heavy.mdx | 6 + docs/bodies/01-light.mdx | 6 + docs/client/setup.mdx | 9 ++ docs/{ => getting-started}/introduction.mdx | 4 + docs/getting-started/setup.mdx | 6 + docs/guides/hardware.mdx | 16 --- docs/guides/software.mdx | 55 --------- docs/guides/teach.mdx | 24 ---- docs/mint.json | 27 +++-- docs/server/setup.mdx | 11 ++ docs/services/language-model.mdx | 9 ++ docs/services/speech-to-text.mdx | 8 ++ docs/services/text-to-speech.mdx | 8 ++ docs/setup.mdx | 19 ---- .../technical-instructions/build-hardware.mdx | 29 ----- docs/technical-instructions/development.mdx | 16 --- 18 files changed, 83 insertions(+), 312 deletions(-) delete mode 100644 docs/01os/01os-settings.mdx delete mode 100644 docs/01os/environment-variables.mdx create mode 100644 docs/bodies/01-heavy.mdx create mode 100644 docs/bodies/01-light.mdx create mode 100644 docs/client/setup.mdx rename docs/{ => getting-started}/introduction.mdx (83%) create mode 100644 docs/getting-started/setup.mdx delete mode 100644 docs/guides/hardware.mdx delete mode 100644 docs/guides/software.mdx delete mode 100644 docs/guides/teach.mdx create mode 100644 docs/server/setup.mdx create mode 100644 docs/services/language-model.mdx create mode 100644 docs/services/speech-to-text.mdx create mode 100644 docs/services/text-to-speech.mdx delete mode 100644 docs/setup.mdx delete mode 100644 docs/technical-instructions/build-hardware.mdx delete mode 100644 docs/technical-instructions/development.mdx diff --git a/docs/01os/01os-settings.mdx b/docs/01os/01os-settings.mdx deleted file mode 100644 index 0703984..0000000 --- a/docs/01os/01os-settings.mdx +++ /dev/null @@ -1,37 +0,0 @@ ---- -title: 01OS Settings -description: "Settings when running 01OS" ---- - -### Server - -Runs the server - -```bash Terminal -01 --server -``` - -### Expose - -Expose an 01 server publically - -```bash Terminal -01 --server --expose # This will print a URL that a client can point to. -``` - -### Client - -Runs a specific client - -```bash Terminal -01 --client macos # Options: macos, rpi -``` - -### Local - -The --local flag will install and run the whisper.cpp STT and Piper TTS models. - -```bash Terminal -01 --local # Local client and server -01 --local --server --expose # Expose a local server -``` diff --git a/docs/01os/environment-variables.mdx b/docs/01os/environment-variables.mdx deleted file mode 100644 index 53fa808..0000000 --- a/docs/01os/environment-variables.mdx +++ /dev/null @@ -1,105 +0,0 @@ ---- -title: "Environment Variables" -description: "Configure 01OS" ---- - -## ALL_LOCAL - -Default:`False` - -If `False`, we'll use OpenAI's services else we use whisper.cpp and piper local models - -## WHISPER_MODEL_NAME - -Default: `ggml-tiny.en.bin` - -## WHISPER_MODEL_URL - -Default: `https://huggingface.co/ggerganov/whisper.cpp/resolve/main/` - -## TEACH_MODE - -Default: `False` - -Teach mode is a mode that allows you to teach 01OS new things. Disclaimer: This is a Developer Preview. - -## OPENAI_API_KEY - -Set your OpenAI API key - -## PIPER_VOICE_URL - -Default: `https://huggingface.co/rhasspy/piper-voices/resolve/main/en/en_US/lessac/medium/` - -## PIPER_VOICE_NAME - -Default: `en_US-lessac-medium.onnx` - -For TTS, we use the `en_US-lessac-medium` voice model by default. Please change the voice URL and voice name if you wish to use another voice - -## NGROK_AUTHTOKEN - -Set to your [Ngrok auth token](https://dashboard.ngrok.com/get-started/your-authtoken) - -## SERVER_URL - -Default: `ws://0.0.0.0:8000/` - -## SERVER_START - -Default:`True` -This is where we'll serve the server - -## CLIENT_START - -Default: `True` -This is where the client expects the server to be. - -## CLIENT_TYPE - -Default: `auto` - -Can explicitly set the client type (macos, rpi) - -## CODE_RUNNER - -Default: `server` -Control where various operations happen. Can be `client` or `server`. - -## TTS_RUNNER - -Default: `server` -If client, audio will be sent over websocket. - -## STT_RUNNER - -Default: `client` -If server, audio will be sent over websocket. - -## SERVER_EXPOSE_PUBLICALLY - -Default: `False` - -Expose the server publically and display that URL. - -## CAMERA_ENABLED - -Default: `False` - -## CAMERA_DEVICE_INDEX - -Default: `0` - -Camera device selection (Typically 0 for built-in, 1 for USB) - -## CAMERA_WARMUP_SECONDS - -Default: `0.4` - -Camera warmup time is a workaround for some cameras that don't immediately return a properly exposed picture when they are first turned on - -## LOG_LEVEL - -Default: INFO - -Can be `INFO` or `DEBUG` diff --git a/docs/bodies/01-heavy.mdx b/docs/bodies/01-heavy.mdx new file mode 100644 index 0000000..cac5f1f --- /dev/null +++ b/docs/bodies/01-heavy.mdx @@ -0,0 +1,6 @@ +--- +title: "01 Heavy" +description: "Build your 01 Heavy" +--- + +runs fully locally + coming soon diff --git a/docs/bodies/01-light.mdx b/docs/bodies/01-light.mdx new file mode 100644 index 0000000..d669537 --- /dev/null +++ b/docs/bodies/01-light.mdx @@ -0,0 +1,6 @@ +--- +title: "01 Light" +description: "Build your 01 Light" +--- + +01 Light (one pager that points to the STL, wiring diagrams, and points to the ESP32 client setup page^) diff --git a/docs/client/setup.mdx b/docs/client/setup.mdx new file mode 100644 index 0000000..8e10b5e --- /dev/null +++ b/docs/client/setup.mdx @@ -0,0 +1,9 @@ +--- +title: "Setup" +description: "Get your 01 client up and running" +--- + +(lets you pick from a grid of avaliable clients) + +- ESP32 (instructions for flashing it) +- Desktop (basically says "just run start.py with no args, that will run the server with a client, or start.py --client to just run the client") diff --git a/docs/introduction.mdx b/docs/getting-started/introduction.mdx similarity index 83% rename from docs/introduction.mdx rename to docs/getting-started/introduction.mdx index 0a042c3..17f1332 100644 --- a/docs/introduction.mdx +++ b/docs/getting-started/introduction.mdx @@ -3,6 +3,10 @@ title: Introduction description: "The 01 is a Language Model Computer. 01OS is its operating system" --- +Introduction (the what, ripped from the github) — same as OI, I think should have a very basic setup on the bottom of that page, just about cloning the repo and running start.py. + +** PREVIOUS ** + thumbnail -- cd ../01/01OS/ (we reccomend starting a virtual environment [would it be good to link to info on setting up a venv?]) -- poetry run 01 --teach -- Enter the name of the skill you want to teach. -- Walk through the first step to show the 01OS what the action looks like. -- The 01OS will attempt to perform the first step. -- Confirm whether or not the 01OS successfully copied your action. -> - If it wasn't performed correctly, select "no" and adjust the prompt for the retrying. -> - If it was performed correctly, select "yes" and the code for that step will be added to the skill's python file -- Once you've finished all steps required to perform the skill, confirm that the skill is complete. -- The skill has been saved as a Python file, which the 01OS can now intelligently execute whenever your prompt would benefit from the skill. - -_Disclaimer:_ We caution against showing any sensitive information on your screen while Teach Mode is running. -The developer preview version of 01OS collects data during Teach Mode that is used to train the 01OS for future versions. -Reach out to partnerships@openinterpreter.com with any questions or concerns. [Thoughs Mike? would it be better to setup privacy@openinterpreter.com or something lol?] diff --git a/docs/mint.json b/docs/mint.json index 5bca41e..63bb7ea 100644 --- a/docs/mint.json +++ b/docs/mint.json @@ -21,7 +21,7 @@ "topbarLinks": [ { "name": "GitHub", - "url": "https://github.com/KillianLucas/01" + "url": "https://github.com/OpenInterpreter/01" } ], "topbarCtaButton": { @@ -34,22 +34,27 @@ "navigation": [ { "group": "Getting Started", - "pages": ["introduction", "setup"] + "pages": ["getting-started/introduction", "getting-started/setup"] }, { - "group": "Guides", - "pages": ["guides/hardware", "guides/software", "guides/teach"] + "group": "Server", + "pages": ["server/setup"] }, { - "group": "01OS", - "pages": ["01os/01os-settings", "01os/environment-variables"] - }, - { - "group": "Technical", + "group": "Services", "pages": [ - "technical-instructions/development", - "technical-instructions/build-hardware" + "services/language-model", + "services/speech-to-text", + "services/text-to-speech" ] + }, + { + "group": "Client", + "pages": ["client/setup"] + }, + { + "group": "Bodies", + "pages": ["bodies/01-light", "bodies/01-heavy"] } ], "feedback": { diff --git a/docs/server/setup.mdx b/docs/server/setup.mdx new file mode 100644 index 0000000..a5bdb20 --- /dev/null +++ b/docs/server/setup.mdx @@ -0,0 +1,11 @@ +--- +title: "Setup" +description: "Get your 01 server up and running" +--- + +Setup (just run start.py --server , explain the flags (revealed via start.py --help)) + +- Interpreter + - Open Interpreter (explains i.py, how you configure your interpreter, cover the basic settings of OI (that file is literally just modifying an interpreter from OI) + - Language Model (LLM setup via interpreter.model in i.py or from the command line via start.py --server --llm-service llamafile) +- Voice Interface (explains that you can run --tts-service and --stt-service to swap out for different services, which are in /Services/Speech-to-text and /Services/Text-to-text) diff --git a/docs/services/language-model.mdx b/docs/services/language-model.mdx new file mode 100644 index 0000000..1d199f9 --- /dev/null +++ b/docs/services/language-model.mdx @@ -0,0 +1,9 @@ +--- +title: "Language Model" +description: "The LLM that powers your 01" +--- + +- Llamafile (Local) +- Llamaedge (Local) +- Hosted Models (explains that we use litellm, you can pass in many different model flags to this) +- Add more (placeholder, we will add instructions soon) diff --git a/docs/services/speech-to-text.mdx b/docs/services/speech-to-text.mdx new file mode 100644 index 0000000..2b24828 --- /dev/null +++ b/docs/services/speech-to-text.mdx @@ -0,0 +1,8 @@ +--- +title: "Speech To Text" +description: "Converts your voice into text" +--- + +- Whisper (Local) +- Whisper (Hosted) +- Add more (placeholder, we will add instructions soon) diff --git a/docs/services/text-to-speech.mdx b/docs/services/text-to-speech.mdx new file mode 100644 index 0000000..9558c19 --- /dev/null +++ b/docs/services/text-to-speech.mdx @@ -0,0 +1,8 @@ +--- +title: "Text To Speech" +description: "Converts the text into audio" +--- + +- Piper (Local) +- OpenAI (Hosted) +- Add more (placeholder, we will add instructions soon) diff --git a/docs/setup.mdx b/docs/setup.mdx deleted file mode 100644 index 5c51acd..0000000 --- a/docs/setup.mdx +++ /dev/null @@ -1,19 +0,0 @@ ---- -title: "Setup" -description: "Get your 01 up and running" ---- - -## The 01 - -The 01 is a device that unleashes the power of controlling a Language Model Computer using only natural language. -Just connect it to the Internet and talk to it. - -It's more than just voice control. It's a new way to use computers. - -## One Click Installers - -To connect your 01, select your one click installer: - -- MacOS -- Linux -- Windows diff --git a/docs/technical-instructions/build-hardware.mdx b/docs/technical-instructions/build-hardware.mdx deleted file mode 100644 index cc6b7d9..0000000 --- a/docs/technical-instructions/build-hardware.mdx +++ /dev/null @@ -1,29 +0,0 @@ ---- -title: "Hardware Build Guide" -description: "How to build your Language Model Computer" ---- - -## 01 Light - -### Materials - -- ATOM Echo Smart Speaker Development Kit -- PowerBoost 1000 Charger -- Tactile Switches 12MM TACTILE PB SWITCH -- Slide Switches DPDT THRU HOLE .3A -- Lithium Ion Polymer Battery - 3.7v 500mAh -- Silicone Cover Stranded-Core Wire 26AWG - Black, Red, Yellow -- Premium Male/Male Jumper Wires - 20 x 3" (75mm) - -Optional - -- Adafruit Mono 2.5W Class D Audio Amplifier - PAM8302 - -### Assembly - -1. Gather Materials -2. Shove em together - -## 01 Heavy - -Coming soon diff --git a/docs/technical-instructions/development.mdx b/docs/technical-instructions/development.mdx deleted file mode 100644 index 6bbb753..0000000 --- a/docs/technical-instructions/development.mdx +++ /dev/null @@ -1,16 +0,0 @@ ---- -title: "Development" -description: "How to work on 01OS" ---- - -## Setup for development: - -```bash -# Clone the repo, cd into the 01OS directory -git clone https://github.com/KillianLucas/01.git -cd 01OS - -# Install dependencies, run the commands above -poetry install -poetry run 01 -``` From e7551438a829463684edb59662c684cfe4f2977f Mon Sep 17 00:00:00 2001 From: Mike Bird Date: Tue, 12 Mar 2024 21:45:20 -0400 Subject: [PATCH 2/2] getting start introduction draft --- docs/getting-started/introduction.mdx | 27 ++++++++++++++------------- 1 file changed, 14 insertions(+), 13 deletions(-) diff --git a/docs/getting-started/introduction.mdx b/docs/getting-started/introduction.mdx index 17f1332..ed1827c 100644 --- a/docs/getting-started/introduction.mdx +++ b/docs/getting-started/introduction.mdx @@ -1,29 +1,30 @@ --- title: Introduction -description: "The 01 is a Language Model Computer. 01OS is its operating system" +description: "The open-source language model computer." --- -Introduction (the what, ripped from the github) — same as OI, I think should have a very basic setup on the bottom of that page, just about cloning the repo and running start.py. - -** PREVIOUS ** - thumbnail -The 01 Operating System (01OS) is open source software that operates computers using language models, powered by Open Interpreter. -This allows computers to understand natural language requests, and execute tasks on your behalf. -These guides will cover the steps for installing, using, and teaching 01OS. +The 01 project is an open-source ecosystem for artificially intelligent devices. + +By combining code-interpreting language models ("interpreters") with speech recognition and voice synthesis, the 01’s flagship operating system ("01OS") can power conversational, computer-operating AI devices similar to the Rabbit R1 or the Humane Pin. -## Getting Started +We intend to become the “Linux” of this new space— open, modular, and free for personal or commercial use. -The 01 Light is the interface with 01OS. It connects to your computer or our hosted service via the Internet or directly to an 01 Heavy (coming soon). +## Quick Start -You can order a pre-made device or find instructions for building your own at openinterpreter.com/01OS/guides/hardware-guide. -You will always have the option to build your own device. +```bash +# Clone the repo, cd into the 01OS directory +git clone https://github.com/OpenInterpreter/01.git +cd 01OS -To connect to your device, use the one click installer. +# Install dependencies and run start.py +poetry install +poetry run 01 +``` _Disclaimer:_ The current version of 01OS is a developer preview.