3. Pipeline dict with services (basic)#
The following tutorial shows pipeline
creation from dict and most important pipeline components.
Here, Service class, that can be used for pre- and postprocessing of messages is shown.
Pipeline’s from_dict static method is used for pipeline creation (from dictionary).
[1]:
# installing dependencies
%pip install -q dff
Note: you may need to restart the kernel to use updated packages.
[2]:
import logging
from dff.pipeline import Service, Pipeline, ACTOR
from dff.utils.testing.common import (
check_happy_path,
is_interactive_mode,
run_interactive_mode,
)
from dff.utils.testing.toy_script import HAPPY_PATH, TOY_SCRIPT
logger = logging.getLogger(__name__)
When Pipeline is created using from_dict
method, pipeline should be defined as a dictionary. It should contain services
- a ServiceGroupBuilder
object, basically a list of ServiceBuilder
or ServiceGroupBuilder
objects, see tutorial 4.
On pipeline execution services from services
list are run without difference between pre- and postprocessors. Actor constant “ACTOR” is required to be passed as one of the services. ServiceBuilder object can be defined either with callable (see tutorial 2) or with dict / object. It should contain handler
- a ServiceBuilder object.
Not only Pipeline can be run using __call__
method, for most cases run
method should be used. It starts pipeline asynchronously and connects to provided messenger interface.
Here, the pipeline contains 4 services, defined in 4 different ways with different signatures.
[3]:
def prepreprocess(_):
logger.info(
"preprocession intent-detection Service running (defined as a dict)"
)
def preprocess(_):
logger.info(
"another preprocession web-based annotator Service "
"(defined as a callable)"
)
def postprocess(_):
logger.info("postprocession Service (defined as an object)")
[4]:
pipeline_dict = {
"script": TOY_SCRIPT,
"start_label": ("greeting_flow", "start_node"),
"fallback_label": ("greeting_flow", "fallback_node"),
"components": [
{
"handler": prepreprocess,
},
preprocess,
ACTOR,
Service(
handler=postprocess,
),
],
}
[5]:
pipeline = Pipeline.from_dict(pipeline_dict)
if __name__ == "__main__":
check_happy_path(pipeline, HAPPY_PATH)
if is_interactive_mode():
run_interactive_mode(pipeline) # This runs tutorial in interactive mode
(user) >>> text='Hi'
(bot) <<< text='Hi, how are you?'
(user) >>> text='i'm fine, how are you?'
(bot) <<< text='Good. What do you want to talk about?'
(user) >>> text='Let's talk about music.'
(bot) <<< text='Sorry, I can not talk about music now.'
(user) >>> text='Ok, goodbye.'
(bot) <<< text='bye'
(user) >>> text='Hi'
(bot) <<< text='Hi, how are you?'