Version: 3.x

rasa.core.trackers

EventVerbosity Objects

class EventVerbosity(Enum)

Filter on which events to include in tracker dumps.

AnySlotDict Objects

class AnySlotDict(dict)

A slot dictionary that pretends every slot exists, by creating slots on demand.

This only uses the generic slot type! This means certain functionality wont work, e.g. properly featurizing the slot.

DialogueStateTracker Objects

class DialogueStateTracker()

Maintains the state of a conversation.

The field max_event_history will only give you these last events, it can be set in the tracker_store

from_dict

| @classmethod
| from_dict(cls, sender_id: Text, events_as_dict: List[Dict[Text, Any]], slots: Optional[List[Slot]] = None, max_event_history: Optional[int] = None) -> "DialogueStateTracker"

Create a tracker from dump.

The dump should be an array of dumped events. When restoring the tracker, these events will be replayed to recreate the state.

__init__

| __init__(sender_id: Text, slots: Optional[Iterable[Slot]], max_event_history: Optional[int] = None, sender_source: Optional[Text] = None, is_rule_tracker: bool = False) -> None

Initialize the tracker.

A set of events can be stored externally, and we will run through all of them to get the current state. The tracker will represent all the information we captured while processing messages of the dialogue.

current_state

| current_state(event_verbosity: EventVerbosity = EventVerbosity.NONE) -> Dict[Text, Any]

Return the current tracker state as an object.

past_states

| past_states(domain: Domain) -> List[State]

Generate the past states of this tracker based on the history.

Arguments:

  • domain - a :class:rasa.core.domain.Domain

Returns:

a list of states

change_loop_to

| change_loop_to(loop_name: Text) -> None

Set the currently active loop.

Arguments:

  • loop_name - The name of loop which should be marked as active.

set_form_validation

| set_form_validation(validate: bool) -> None

Toggle form validation

reject_action

| reject_action(action_name: Text) -> None

Notify active loop that it was rejected

set_latest_action

| set_latest_action(action: Dict[Text, Text]) -> None

Set latest action name and reset form validation and rejection parameters

current_slot_values

| current_slot_values() -> Dict[Text, Any]

Return the currently set values of the slots

get_slot

| get_slot(key: Text) -> Optional[Any]

Retrieves the value of a slot.

get_latest_entity_values

| get_latest_entity_values(entity_type: Text, entity_role: Optional[Text] = None, entity_group: Optional[Text] = None) -> Iterator[Text]

Get entity values found for the passed entity type and optional role and group in latest message.

If you are only interested in the first entity of a given type use next(tracker.get_latest_entity_values("my_entity_name"), None). If no entity is found None is the default result.

Arguments:

  • entity_type - the entity type of interest
  • entity_role - optional entity role of interest
  • entity_group - optional entity group of interest

Returns:

Entity values.

get_latest_input_channel

| get_latest_input_channel() -> Optional[Text]

Get the name of the input_channel of the latest UserUttered event

is_paused

| is_paused() -> bool

State whether the tracker is currently paused.

idx_after_latest_restart

| idx_after_latest_restart() -> int

Return the idx of the most recent restart in the list of events.

If the conversation has not been restarted, 0 is returned.

events_after_latest_restart

| events_after_latest_restart() -> List[Event]

Return a list of events after the most recent restart.

init_copy

| init_copy() -> "DialogueStateTracker"

Creates a new state tracker with the same initial values.

generate_all_prior_trackers

| generate_all_prior_trackers() -> Generator["DialogueStateTracker", None, None]

Returns a generator of the previous trackers of this tracker.

The resulting array is representing the trackers before each action.

applied_events

| applied_events() -> List[Event]

Returns all actions that should be applied - w/o reverted events.

replay_events

| replay_events() -> None

Update the tracker based on a list of events.

recreate_from_dialogue

| recreate_from_dialogue(dialogue: Dialogue) -> None

Use a serialised Dialogue to update the trackers state.

This uses the state as is persisted in a TrackerStore. If the tracker is blank before calling this method, the final state will be identical to the tracker from which the dialogue was created.

copy

| copy() -> "DialogueStateTracker"

Creates a duplicate of this tracker

travel_back_in_time

| travel_back_in_time(target_time: float) -> "DialogueStateTracker"

Creates a new tracker with a state at a specific timestamp.

A new tracker will be created and all events previous to the passed time stamp will be replayed. Events that occur exactly at the target time will be included.

as_dialogue

| as_dialogue() -> Dialogue

Return a Dialogue object containing all of the turns.

This can be serialised and later used to recover the state of this tracker exactly.

update

| update(event: Event, domain: Optional[Domain] = None) -> None

Modify the state of the tracker according to an Event.

as_story

| as_story(include_source: bool = False) -> "Story"

Dump the tracker as a story in the Rasa Core story format.

Returns the dumped tracker as a string.

export_stories

| export_stories(e2e: bool = False, include_source: bool = False) -> Text

Dump the tracker as a story in the Rasa Core story format.

Returns:

The dumped tracker as a string.

export_stories_to_file

| export_stories_to_file(export_path: Text = "debug.md") -> None

Dump the tracker as a story to a file.

get_last_event_for

| get_last_event_for(event_type: Type[Event], action_names_to_exclude: List[Text] = None, skip: int = 0, event_verbosity: EventVerbosity = EventVerbosity.APPLIED) -> Optional[Event]

Gets the last event of a given type which was actually applied.

Arguments:

  • event_type - The type of event you want to find.
  • action_names_to_exclude - Events of type ActionExecuted which should be excluded from the results. Can be used to skip action_listen events.
  • skip - Skips n possible results before return an event.
  • event_verbosity - Which EventVerbosity should be used to search for events.

Returns:

event which matched the query or None if no event matched.

last_executed_action_has

| last_executed_action_has(name: Text, skip: int = 0) -> bool

Returns whether last ActionExecuted event had a specific name.

Arguments:

  • name - Name of the event which should be matched.
  • skip - Skips n possible results in between.

Returns:

True if last executed action had name name, otherwise False.

trigger_followup_action

| trigger_followup_action(action: Text) -> None

Triggers another action following the execution of the current.

clear_followup_action

| clear_followup_action() -> None

Clears follow up action when it was executed.

active_loop_name

| @property
| active_loop_name() -> Optional[Text]

Get the name of the currently active loop.

Returns: None if no active loop or the name of the currently active loop.

latest_action_name

| @property
| latest_action_name() -> Optional[Text]

Get the name of the previously executed action or text of e2e action.

Returns: name of the previously executed action or text of e2e action

get_active_loop_name

get_active_loop_name(state: State) -> Optional[Text]

Get the name of current active loop.

Arguments:

  • state - The state from which the name of active loop should be extracted

Returns:

the name of active loop or None

is_prev_action_listen_in_state

is_prev_action_listen_in_state(state: State) -> bool

Check if action_listen is the previous executed action.

Arguments:

  • state - The state for which the check should be performed

Returns:

boolean value indicating whether action_listen is previous action