Snips Natural Language Understanding library
Project description
Snips NLU (Natural Language Understanding) is a Python library that allows to parse sentences written in natural language and extracts structured information.
Check out our blog post to get more details about why we built Snips NLU and how it works under the hood.
Installation
pip install snips-nlu
We currently have pre-built binaries (wheels) for snips-nlu and its dependencies for MacOS and Linux x86_64. If you use a different architecture/os you will need to build these dependencies from sources which means you will need to install setuptools_rust and Rust before running the pip install snips-nlu command.
A simple example
Let’s take an example to illustrate the main purpose of this lib, and consider the following sentence:
"What will be the weather in paris at 9pm?"
Properly trained, the Snips NLU engine will be able to extract structured data such as:
{
"intent": {
"intentName": "searchWeatherForecast",
"probability": 0.95
},
"slots": [
{
"value": "paris",
"entity": "locality",
"slotName": "forecast_locality"
},
{
"value": {
"kind": "InstantTime",
"value": "2018-02-08 20:00:00 +00:00"
},
"entity": "snips/datetime",
"slotName": "forecast_start_datetime"
}
]
}
Sample code
Here is a sample code that you can run on your machine after having installed snips-nlu and downloaded this sample dataset:
from __future__ import unicode_literals, print_function
import io
import json
from snips_nlu import SnipsNLUEngine, load_resources
from snips_nlu.default_configs import CONFIG_EN
with io.open("sample_dataset.json") as f:
sample_dataset = json.load(f)
load_resources("en")
nlu_engine = SnipsNLUEngine(config=CONFIG_EN)
nlu_engine.fit(sample_dataset)
text = "What will be the weather in San Francisco next week?"
parsing = nlu_engine.parse(text)
print(json.dumps(parsing, indent=2))
What it does is training an NLU engine on a sample weather dataset and parsing a weather query.
Documentation
To find out how to use Snips NLU please refer to our documentation, it will provide you with a step-by-step guide on how to use and setup our library.
FAQ
Please join our Discord channel to ask your questions and get feedback from the community.
Links
Snips NLU Open sourcing blog post
Snips NLU Rust: Rust inference pipeline implementation and bindings (C, Swift, Kotlin, Python)
Rustling: Snips NLU builtin entities parser
How do I contribute ?
Please see the Contribution Guidelines.
Licence
This library is provided by Snips as Open Source software. See LICENSE for more information.
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
Hashes for snips_nlu-0.13.3-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 31511d29c416c5d8edf15583d86b22957b6d5e9a9a3f090738e1173b4b6a6a03 |
|
MD5 | a85306f8a4f9f134d0b9f249f774dc16 |
|
BLAKE2b-256 | 46f11b7753eddd986ee23915a75522d84857c8bc16b5e497506adbf0cb91d6fd |