Skip to main content

dora-gradio

Project description

Dora Gradio UI Interface

A versatile UI interface for Dora-rs that provides text, audio, and video input capabilities using Gradio.

Features

  • Text Input: Direct text input through a chat-like interface
  • Audio Input: Real-time audio streaming in 16kHz format
  • Video Input: WebRTC camera streaming at 640x480
  • Multiple Output Channels:
    • text: For direct text messages
    • audio: For raw audio stream
    • image: For camera feed
  • Clean Interface: Simple and intuitive UI with tabbed sections
  • Auto Port Management: Automatically handles port conflicts

Installation

Using pip:

python -m venv .venv
source .venv/bin/activate
pip install -e .

Usage

1. Web Interface

The interface will be available at: http://localhost:7860

2. As a Dora Node

Create a YAML configuration:

nodes:
  - id: ui
    build: pip install -e .
    path: dora-gradio
    outputs:
      - text     # Text from chat interface
      - audio    # Raw audio stream
      - image    # Camera feed
    env:
      VIRTUAL_ENV: path to your venv   # comment this if not using venv

Run with Dora:

dora run demo.yml

3. Integration Examples

Video Processing Pipeline

nodes:
  - id: ui
    build: pip install -e .
    path: dora-gradio
    outputs:
      - image    # Camera feed

  - id: video_processor
    build: pip install -e path/to/processor
    path: video-processor
    inputs:
      video: ui/image

Audio Processing Pipeline

nodes:
  - id: ui
    build: pip install -e .
    path: dora-gradio
    outputs:
      - audio    # Raw audio stream

  - id: audio_processor
    build: pip install -e path/to/processor
    path: audio-processor
    inputs:
      audio: ui/audio

4. Demo Example

Here's a complete demo pipeline using the UI with visualization and audio processing:

nodes:
  - id: ui
    build: pip install -e .
    path: dora-gradio
    outputs:
      - text     # Text messages
      - audio    # Raw audio stream
      - image    # Camera feed

  - id: plot
    build: pip install dora-rerun
    path: dora-rerun
    inputs:
      text_input: ui/text
      audio: ui/audio
      image: ui/image

  - id: dora-vad
    build: pip install -e path/to/dora-vad
    path: dora-vad
    inputs:
      audio: ui/audio

  - id: dora-distil-whisper
    build: pip install -e path/to/dora-distil-whisper
    path: dora-distil-whisper
    inputs:
      audio: ui/audio

This demo showcases:

  • Real-time visualization with dora-rerun
  • Voice Activity Detection with dora-vad
  • Speech processing with dora-distil-whisper

Interface Features

Camera Tab

  • Real-time WebRTC video streaming
  • Fixed 640x480 resolution
  • BGR8 color format
  • Automatic timestamp synchronization

Audio and Text Input Tab

  • Chat-like interface for text input
  • Real-time audio streaming (16kHz, mono)
  • Status indicators for streaming state
  • Immediate output through respective channels

Controls

  • Send Text button for chat messages
  • Stop Server button for graceful shutdown

System Requirements

  • Python ≥ 3.10
  • Required ports:
    • 7860 (Gradio interface)

Known Limitations

  • Fixed video resolution (640x480)
  • Fixed audio sample rate (16kHz)
  • Requires port 7860 to be available

License

dora-gradio's code are released under the MIT License

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

dora_gradio-0.4.1.tar.gz (5.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

dora_gradio-0.4.1-py3-none-any.whl (5.5 kB view details)

Uploaded Python 3

File details

Details for the file dora_gradio-0.4.1.tar.gz.

File metadata

  • Download URL: dora_gradio-0.4.1.tar.gz
  • Upload date:
  • Size: 5.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for dora_gradio-0.4.1.tar.gz
Algorithm Hash digest
SHA256 64ea9949f0709eb1cc838f9e46581c8f0a5bba0b72e639fadf57763e87025ffa
MD5 0b1bfc08ffaec220691dbc3b03f81bff
BLAKE2b-256 b5c10f072348c78ce3f98d6060985761a3a818e92bee9c35f156d4a38d1b6d66

See more details on using hashes here.

File details

Details for the file dora_gradio-0.4.1-py3-none-any.whl.

File metadata

  • Download URL: dora_gradio-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 5.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for dora_gradio-0.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ab4ad89128079049e49a3891e7e68600c3e03ba11a2a6f6f25580fb30ca74c87
MD5 365c1415d3b2caf8abaff8b14af73ada
BLAKE2b-256 ff9e151e82a7e5b4f4b62077ee0e12b6be12ab1951b7cd95fbace5fa4cd55aa8

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page