Agent Framework plugin for Speechmatics
Project description
Speechmatics STT plugin for LiveKit Agents
Support for Speechmatics STT.
See https://docs.livekit.io/agents/integrations/stt/speechmatics/ for more information.
Installation
pip install livekit-plugins-speechmatics
Diarization
Speechmatics STT engine can be configured to emit information about individual speakers in a conversation. This needs to be enabled using enable_diarization=True. The text output of the transcription can be configured to include this information using the macros speaker_id and text, as shown in the examples below.
<{speaker_id}>{text}</{speaker_id}>-><S1>Hello</S1>[Speaker {speaker_id}] {text}->[Speaker S1] Hello
You should adjust your system instructions to inform the LLM of this format for speaker identification.
Usage (Speechmatics end of utterance detection and speaker ID)
To use the Speechmatics end of utterance detection and speaker ID, you can use the following configuration.
Note: The turn_detection_mode parameter tells the plugin to control the end of turn detection. The default mode is ADAPTIVE, which means that the plugin will control the end of turn detection using the plugin's own VAD detection and the pace of speech. In the example below, we use the default ADAPTIVE mode. The turn_detection="stt" parameter tells the plugin to use the STT engine's end of turn detection.
from livekit.agents import AgentSession
from livekit.plugins import speechmatics
agent = AgentSession(
stt=speechmatics.STT(
speaker_active_format="[Speaker {speaker_id}] {text}",
speaker_passive_format="[Speaker {speaker_id} *PASSIVE*] {text}",
additional_vocab=[
speechmatics.AdditionalVocabEntry(
content="LiveKit",
sounds_like=["live kit"],
),
],
),
turn_detection="stt",
...
)
Usage (LiveKit Turn Detection)
To use the LiveKit end of turn detection, the format for the output text needs to be adjusted to not include any extra content at the end of the utterance. Using [Speaker S1] ... as the speaker_active_format should work well. You may need to adjust your system instructions to inform the LLM of this format for speaker identification. You must also include the listener for when the VAD has detected the end of speech.
The end_of_utterance_silence_trigger parameter controls the amount of silence before the end of turn detection is triggered. The default is 0.5 seconds.
Usage:
from livekit.agents import AgentSession
from livekit.plugins.turn_detector.multilingual import MultilingualModel
from livekit.plugins import speechmatics, silero
agent = AgentSession(
stt=speechmatics.STT(
end_of_utterance_silence_trigger=0.2,
speaker_active_format="[Speaker {speaker_id}] {text}",
speaker_passive_format="[Speaker {speaker_id} *PASSIVE*] {text}",
),
vad=silero.VAD.load(),
turn_detection=MultilingualModel(),
min_endpointing_delay=0.3,
max_endpointing_delay=5.0,
...
)
Pre-requisites
You'll need to specify a Speechmatics API Key. It can be set as environment variable SPEECHMATICS_API_KEY or .env.local file.
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 livekit_plugins_speechmatics-1.5.8.tar.gz.
File metadata
- Download URL: livekit_plugins_speechmatics-1.5.8.tar.gz
- Upload date:
- Size: 14.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f6a1443c71c1f92c0fbf70fbc17f1c050a271fc8aded6d2ac5dfddee045cb0f5
|
|
| MD5 |
bfdb5417cfd051fe387489c9a728c159
|
|
| BLAKE2b-256 |
04090592f149f7f1e40772be63dd85bff4f3e1c1dcb69b076147f0a2f8c683f7
|
Provenance
The following attestation bundles were made for livekit_plugins_speechmatics-1.5.8.tar.gz:
Publisher:
publish.yml on livekit/agents
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
livekit_plugins_speechmatics-1.5.8.tar.gz -
Subject digest:
f6a1443c71c1f92c0fbf70fbc17f1c050a271fc8aded6d2ac5dfddee045cb0f5 - Sigstore transparency entry: 1441141940
- Sigstore integration time:
-
Permalink:
livekit/agents@d28d1a1af816651fb757659de1e171e073919c08 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/livekit
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@d28d1a1af816651fb757659de1e171e073919c08 -
Trigger Event:
pull_request
-
Statement type:
File details
Details for the file livekit_plugins_speechmatics-1.5.8-py3-none-any.whl.
File metadata
- Download URL: livekit_plugins_speechmatics-1.5.8-py3-none-any.whl
- Upload date:
- Size: 15.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
39484d48879fe3786095129e12ccdd8303eebae16439e3e8547b76c80ba25430
|
|
| MD5 |
33a9e7881994d366f914312e46ee617b
|
|
| BLAKE2b-256 |
db58c79a418d937f994731bd6063f3115bb6f91a37c0bb1635b8882cc96cac24
|
Provenance
The following attestation bundles were made for livekit_plugins_speechmatics-1.5.8-py3-none-any.whl:
Publisher:
publish.yml on livekit/agents
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
livekit_plugins_speechmatics-1.5.8-py3-none-any.whl -
Subject digest:
39484d48879fe3786095129e12ccdd8303eebae16439e3e8547b76c80ba25430 - Sigstore transparency entry: 1441142049
- Sigstore integration time:
-
Permalink:
livekit/agents@d28d1a1af816651fb757659de1e171e073919c08 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/livekit
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@d28d1a1af816651fb757659de1e171e073919c08 -
Trigger Event:
pull_request
-
Statement type: