Skip to main content

OVOS intent pipeline plugin using Markov chain perplexity ensemble

Project description

ovos-markov-pipeline-plugin

An OVOS intent pipeline plugin that classifies utterances with an ensemble of per-intent Markov chains, scored by perplexity.

It trains one word-level Markov chain per intent from example utterances. At query time it computes the perplexity of the utterance under every model and picks the intent whose model is least "surprised" — lowest perplexity wins. Confidence is derived from perplexity, so the plugin slots cleanly into the OVOS high / medium / low confidence pipeline tiers.

Why a Markov pipeline?

Most OVOS intent matchers either pattern-match (Adapt, padacioso) or train a neural / SVM classifier (padatious, linha-fina). A Markov-chain language model sits in between: it is a lightweight statistical model that learns the word order of each intent's sample set, trains in milliseconds, needs no GPU, and degrades gracefully with very few samples. It is a practical baseline for small skill sets and a useful comparison point against the other matchers.

Install

pip install ovos-markov-pipeline-plugin

Optional stemming support (recommended for non-English use):

pip install ovos-markov-pipeline-plugin[stem]

Quick example

Enable the pipeline in mycroft.conf:

{
  "intents": {
    "pipeline": [
      "ovos-markov-pipeline-plugin-high",
      "ovos-markov-pipeline-plugin-medium",
      "ovos-markov-pipeline-plugin-low"
    ]
  }
}

Skills register their intents over the bus exactly as they do for padatious — no skill-side changes are required.

Documentation

Full documentation lives in docs/:

License

Apache-2.0

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

ovos_markov_pipeline_plugin-0.5.0a1.tar.gz (18.7 kB view details)

Uploaded Source

Built Distribution

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

ovos_markov_pipeline_plugin-0.5.0a1-py3-none-any.whl (19.9 kB view details)

Uploaded Python 3

File details

Details for the file ovos_markov_pipeline_plugin-0.5.0a1.tar.gz.

File metadata

File hashes

Hashes for ovos_markov_pipeline_plugin-0.5.0a1.tar.gz
Algorithm Hash digest
SHA256 ae27c93c40f0d70902a41a0887015bf84fae88e658da2844d9d30b15bda2b932
MD5 a49dd00656217a68f1bd4cbaa7556296
BLAKE2b-256 e5d1a74a839a27b691361dfd5b0956785c9eeb6de014caf03777a63dd61e6fe6

See more details on using hashes here.

File details

Details for the file ovos_markov_pipeline_plugin-0.5.0a1-py3-none-any.whl.

File metadata

File hashes

Hashes for ovos_markov_pipeline_plugin-0.5.0a1-py3-none-any.whl
Algorithm Hash digest
SHA256 f65076b0c3c674623b9736486d0094355f2bebf8725020bd2c6379288eccfdfe
MD5 adbc9c2f77eb4a7d70233ce96a02cd50
BLAKE2b-256 c5051380a6b37483476ed530d1fb39e6cafe37d913519847a44ce648fd22032a

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