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.2.0a3.tar.gz (13.8 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.2.0a3-py3-none-any.whl (14.7 kB view details)

Uploaded Python 3

File details

Details for the file ovos_markov_pipeline_plugin-0.2.0a3.tar.gz.

File metadata

File hashes

Hashes for ovos_markov_pipeline_plugin-0.2.0a3.tar.gz
Algorithm Hash digest
SHA256 7ece188faf4a6c22cc8354d0df967c97bc2a733a544854291fde2573a5dabb94
MD5 d58f1cef9dd6b30f013f99f1474fb526
BLAKE2b-256 667267f758784822d0d35abb2aa563893ba0309f9752053b142d395744eff4ae

See more details on using hashes here.

File details

Details for the file ovos_markov_pipeline_plugin-0.2.0a3-py3-none-any.whl.

File metadata

File hashes

Hashes for ovos_markov_pipeline_plugin-0.2.0a3-py3-none-any.whl
Algorithm Hash digest
SHA256 95cf5bbc6043074ddbac20d2f16a7f164e16e2956f4e02ada149961408f45d7e
MD5 84afa16631d2c4381c64ff53f3ffa686
BLAKE2b-256 09b32262cd8e11420a2c8db5adf7ab3a25d876de48e8ebcdf9745dfe12a7b67e

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