/* * Copyright (C) 2018 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef LIBTEXTCLASSIFIER_ACTIONS_TYPES_H_ #define LIBTEXTCLASSIFIER_ACTIONS_TYPES_H_ #include <map> #include <string> #include <vector> #include "actions/actions-entity-data_generated.h" #include "annotator/types.h" #include "utils/flatbuffers.h" namespace libtextclassifier3 { // A text span in the conversation. struct MessageTextSpan { // The referenced message. // -1 if not referencing a particular message in the provided input. int message_index; // The span within the reference message. // (-1, -1) if not referencing a particular location. CodepointSpan span; // The span text. std::string text; explicit MessageTextSpan() : message_index(kInvalidIndex), span({kInvalidIndex, kInvalidIndex}) {} MessageTextSpan(const int message_index, const CodepointSpan span, const std::string& text) : message_index(message_index), span(span), text(text) {} }; // An entity associated with an action. struct ActionSuggestionAnnotation { MessageTextSpan span; ClassificationResult entity; // Optional annotation name. std::string name; }; // Action suggestion that contains a response text and the type of the response. struct ActionSuggestion { // Text of the action suggestion. std::string response_text; // Type of the action suggestion. std::string type; // Score. float score; // Priority score for internal conflict resolution. float priority_score; // The associated annotations. std::vector<ActionSuggestionAnnotation> annotations; // Extras information. std::string serialized_entity_data; const ActionsEntityData* entity_data() { return LoadAndVerifyFlatbuffer<ActionsEntityData>( serialized_entity_data.data(), serialized_entity_data.size()); } }; // Actions suggestions result containing meta - information and the suggested // actions. struct ActionsSuggestionsResponse { ActionsSuggestionsResponse() : sensitivity_score(-1), triggering_score(-1), output_filtered_sensitivity(false), output_filtered_min_triggering_score(false), output_filtered_low_confidence(false), output_filtered_locale_mismatch(false) {} // The sensitivity assessment. float sensitivity_score; float triggering_score; // Whether the output was suppressed by the sensitivity threshold. bool output_filtered_sensitivity; // Whether the output was suppressed by the triggering score threshold. bool output_filtered_min_triggering_score; // Whether the output was suppressed by the low confidence patterns. bool output_filtered_low_confidence; // Whether the output was suppressed due to locale mismatch. bool output_filtered_locale_mismatch; // The suggested actions. std::vector<ActionSuggestion> actions; }; // Represents a single message in the conversation. struct ConversationMessage { // User ID distinguishing the user from other users in the conversation. int user_id; // Text of the message. std::string text; // Reference time of this message. int64 reference_time_ms_utc; // Timezone in which the input text was written (format as accepted by ICU). std::string reference_timezone; // Annotations on the text. std::vector<AnnotatedSpan> annotations; // Comma-separated list of BCP 47 language tags of the message. std::string detected_text_language_tags; }; // Conversation between multiple users. struct Conversation { // Sequence of messages that were exchanged in the conversation. std::vector<ConversationMessage> messages; }; } // namespace libtextclassifier3 #endif // LIBTEXTCLASSIFIER_ACTIONS_TYPES_H_