Modern Speech Recognition with both active and ambient listening and keyboard
Project description
HoloSTT
Overview
HoloSTT is a modern, thread-safe speech recognition and input manager for Python applications. It unifies active speech, ambient listening, and keyboard input into a single, production-ready interface for any AI-driven project.
Highlights:
- Multi-modal input: Seamlessly combine voice (active/ambient) and keyboard input.
- No vendor lock-in: Works with any skill set, AI stack, or backend logic.
- Advanced audio handling: Adaptive noise management, energy thresholds, platform-aware volume support.
- Thread-safe singleton: Designed for multi-threaded and interactive desktop, assistant, and automation apps.
- Real-time text processing: Built-in cleaning, comparison, and input filtering utilities.
Why HoloSTT?
Typical speech recognition modules often come with limitations:
- Limited to just microphone input, or just keyboard.
- Lack of fallback modes, or forced use of a single speech engine.
- Not suitable for multi-threaded apps, or lacking input state management.
HoloSTT solves these problems by:
- Offering both active (“push-to-talk”) and ambient (always-on) listening, with instant keyboard fallback.
- Providing a centralized, extensible interface for all input and recognition events.
- Supporting robust error handling, state tracking, and dynamic configuration—ready for modern AI workflows.
Key Features
-
Flexible Audio Capture: Toggle between active/ambient listening or switch to keyboard input instantly.
-
Dynamic Noise and Volume Handling: Automatically adapts to background noise and adjusts thresholds for clear, accurate recognition.
-
Centralized State & Properties: Track commands, input modes, timeouts, and all key settings in one place.
-
Customizable Input Processing: Clean and filter input text, apply replacements, compare similarity, and trigger actions.
-
Robust Error Handling: Handles microphone, audio, and network exceptions gracefully.
-
Production-Ready: Built for real-world, scalable AI systems.
How It Works
- Call the HoloSTT manager in your application.
- Select input mode: active voice, ambient voice, or keyboard.
- Process and clean recognized text automatically.
- Use output directly for commands, automations, or AI skills.
FAQ
Q: Does HoloSTT require a specific folder or class naming? A: No. Organize your project and input logic as you see fit.
Q: Can I use my own text cleaning or filtering? A: Yes. HoloSTT exposes all processing utilities and is easy to extend.
Q: Is it production-ready and thread-safe? A: Yes. The singleton implementation ensures safe multi-threaded operation.
Code Examples
You can find code examples on my GitHub repository.
License
This project is licensed under the Apache License, Version 2.0. Copyright 2025 Tristan McBride Sr.
Authors
- Tristan McBride Sr.
- Sybil
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file holostt-0.2.4.tar.gz.
File metadata
- Download URL: holostt-0.2.4.tar.gz
- Upload date:
- Size: 11.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b1e222b3f019425dcfcaa6ac85a86a8d7b0a4b5c1788f16da29bdc4b71b71a5c
|
|
| MD5 |
3666b2fb1f86d24808e2c34425f876a5
|
|
| BLAKE2b-256 |
1bd40926eead92fe3629a55b36cb8be88e9bfd7ab940787f5ba1959f3b2deded
|
File details
Details for the file holostt-0.2.4-py3-none-any.whl.
File metadata
- Download URL: holostt-0.2.4-py3-none-any.whl
- Upload date:
- Size: 11.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2a3234435509827ebee2b4d01268c03519b67da670fdb3c2d21128821165d205
|
|
| MD5 |
029f02ddba3ed1695aa0728e2c32e303
|
|
| BLAKE2b-256 |
d0be6061120591384591aa3507ebb6ab4e1c47c40e835bd0a2ede97b1ef9a80c
|