It provides access to a generator of virtual assistants extensions.
Project description
Virtual Assistant extensions Generator
It provides a Generator of Virtual Assistant extensions to reply Natural Language (NL) questions by querying SPARQL endpoints. In its actual version (v. 1.0), our generator enables the generation of Alexa skills. The implemented mechanism to move from NL to SPARQL queries is KG-independent. Thus, it can be applied to any SPARQL endpoint that enables GET requests and returns JSON results. It simplifies the skill generation both for technical and lay-users. The effort is strictly related to the provision of queriable entities and predicates, while the generation of the Alexa skill is as simple as the call of a command.
The generator is maintained by the ISISLab of the University of Salerno.
Generator structure and extension points
Our generator can create a VA extension according to the configuration file provided by the user. It takes as input a conf.json file, checks its syntax correctness and semantic validity and, finally, creates the VA extension. Each phase is kept separate by satisfying the modularity requirement, and it is implemented as an abstract module. The architecture of our general-purpose and multi speaking languages VA extension generator is reported in the figure below.
The Vocal Assistant Generator module takes as input a configuration file to personalize the generated VA extension and conducts the entire generation workflow, i.e., it 1) checks the syntactical correctness of the configuration file by the Syntax checker; 2) validates the semantic correctness of the configuration by the Validator; 3) creates the interaction_model.json by the Interaction Model Generator containing configured intents, its utterances and the slot values personalized by the user; iv) generates the back-end code by the Back-end generator and it produces the zip file containing the intent implementation.
While the syntax checker and the validator strictly depend on the configuration file, the interaction model and the back-end generator depend on the API provided by the VA to extend its features. We require a JSON configuration file. Therefore, the JSON Syntax Checker has to verify that the file is a valid JSON file, while the Validator checks if all the mandatory fields are provided, and the configuration is consistent, e.g., we verify that entities and properties are provided if there is at least one intent that uses them as a slot. Once validated the configuration file, the Alexa skills components (the JSON interaction model and the zip file implementing the skill back-end that can be upload on Amazon AWS) can be created. Thanks to the architecture modularity, it is easy to develop new VA providers support and extend the supported languages (English and Italian at the moment).
Due to the modularity of the implementation, the extensions point are:
- the supported languages (by affecting the instance of Interaction Model Generator and by providing the interaction model components according to the desired language);
- the Vocal Assistant (by providing a dedicated implementation of the Abstract Interaction Model and Abstract Back-end).
Repository structure
-
src contains
- pa_generator.py containing both the Abstract PersonalAssistantGenerator and the Alexa implementation,
- syntax_checker.py containing both the AbstractSyntaxChecker and the JSONSyntaxChecker,
- validator.py containing both the AbstracValidator and the actual Validator,
- interaction_model_generator.py containing both the InteractionModel abstract class and the AlexaInteractionModel,
- en_interaction_model_components.json and it_interaction_model_components.py containing the interaction model components for the English and the Italian languages,
- back_end_generator.py containing both the Abstract BackEndGenerator and the Alexa instance. It exploits the content of the back_end folder,
- back_end folder, containing
- index.js contains the back_end code in JavaScript;
- custom_functions.js contains the functions that the user may need to modify to personalize the entities and properties look-up (for instance, by exploiting API instead on pre-defined dictionaries),
- package-lock.json and package.json to manage Node.js packages,
- node_modules folder, containing all the required Node.js packages,
- conf.json an exemplerary configuration file,
- main.py that starts the VA extension generation according to the configuration file.
-
use cases contains
- the configuration file and the Alexa skill components (interaction model and back end) for DBpedia and Wikidata and general-purpose Knowledge Graphs (KGs), the UNESCO Thesaurus, the WarSampo and WordNet as special-purpose KGs. Each skill is provided in an individual folder.
- the evaluation of the Wikidata and DBpedia Alexa skills against QLAD-7 and QALD-9 (respectively). We report the used datasets, the skill replies, the code used to compare gold standard and actual results, and the achieved results.
-
SPARQL_endpoint_analysis contains
- analysis_queries.md the used SPARQL queries to retrieve classes, properties and resources from KGs,
- conf_generator.md the code to estimate the SPARQL endpoint readiness in being queried by Vocal Assistants. In calculating the VA_readiness_score, we took into account the coverage of labels, the readability of labels and the uniqueness of URLs attached to the same label,
- conf_generator_and_va_readiness_score.ipynb provides a Jupyter Notebbok to test conf_generator.py on the UNESCO Thesaurus KG,
- analysis_results.md contains the VA_readiness of 30 available SPARQL endpoints.
Generator details
Supported intents
The implemented intents, an example of provided utterance and the queried triples can be summarized as follows:
Intent name | Utterance | Triple |
---|---|---|
getPropertyObject | What is the {p} of {e}? | <e> <p> ? |
getDescription | What/Who is {e}? | <e> <definition> ? |
getLocation | Where is {e}? | <e> <location> ? |
getImg | Show me <e> | <e> <img> ? |
getPropertyObjectByClass | Which {c} is the {p} of {e}? | <e> <p> ?. ? <instanceof> <c> |
getPropertySubject | What has {e} as {p}? | ? <p> <e> |
getClassInstances | What are the instances of {e}? | ? <instanceof> <e> |
getPropertySubjectByClass | Which {c} has {e} as {p}? | ? <instanceof> <c>.<br>? <p> <e>. |
getNumericFilter | What has {p} {symbol} {val}? | ? <p> ?o. <br> FILTER(?o <symbol> <val>) |
getNumeriFilterByClass | Which {c} has {p} {symbol} {val}? | ? <instanceof> <c>.? <p> ?o. <br> FILTER(?o <symbol> <val>) |
getSuperlative | What is the {c} with {sup} {p}? | ? <p> ?o.<br> ORDER BY (?o).<br> LIMIT 1 |
getTripleVerification | {s} has {o} as {p} | ASK <s> <p> <o> |
getAllResultsPreviousQuery | Give me all the results | - |
Configuration file format
In its actual implementation, we require a JSON file with the following format:
{ "invocation_name" : INVOCATION NAME, "endpoint" : SPARQL endpoint, "intents" : LIST OF THE DESIRED INTENTS, "lang" : EN|IT, "entities" : {...}, "properties" : {...} }
Entities and properties are modelled as dictionaries with the following format:
LABEL : { "urls" : LIST OF URLs [, "synonyms" : LIST OF SYNONYMS] }
Running details
To generate the Alexa skill, you have:
- provide the configuration file (e.g., conf.json),
- create an instance of the generator (i.e., AlexaSkillGenerator()),
- call the generate_personal_assistant function on the generator by providing the configuration file (e.g., generator.generate_personal_assistant("conf.json")).
Results storage
The Alexa skill will be stored on the local path. The generator will create:
- a folder named as the <INVOCATION_NAME> provided in the configuration file, containing
- generated_interaction_model.json that is the interaction model as expected by the Alexa Developer Console
- a back_end.zip file containing the back end (implemented in JavaScript) that can be directly uploaded on Amazon AWS.
Dependencies
The generator is implemented in Python 3.0
License
The code is Open-Source the MIT License applies to the provided source code.
Permanent URI
A permanent version of this repository is provided on Zenodo.
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
File details
Details for the file virtual_assistant_generator-0.1.0.tar.gz
.
File metadata
- Download URL: virtual_assistant_generator-0.1.0.tar.gz
- Upload date:
- Size: 57.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/47.1.1 requests-toolbelt/0.9.1 tqdm/4.46.1 CPython/3.7.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 504e89c487ddaa94ee09d62b9a086ba0b8278b8bff39a0eddab0592ee8838716 |
|
MD5 | e781e8a4ab2191608c7b81420e84f948 |
|
BLAKE2b-256 | a394d13099011c20646ee97b7b3d83bbcdd6dfca7bbfb4047603a0dd53e9e3f5 |
File details
Details for the file virtual_assistant_generator-0.1.0-py3-none-any.whl
.
File metadata
- Download URL: virtual_assistant_generator-0.1.0-py3-none-any.whl
- Upload date:
- Size: 7.2 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/47.1.1 requests-toolbelt/0.9.1 tqdm/4.46.1 CPython/3.7.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f7cf47471f98035de8d8f3670dea307a9d00a06d2d2d2b2e1c83fcf9dead2aa4 |
|
MD5 | 3033a50771d9f7ad5418e3179f8b42af |
|
BLAKE2b-256 | d20cd05cf9691e292ea66fe44708d623be4df54d147200f6c9fd020525cf2f8e |