KR20220155957A - Method and apparatus for providing chatbot service based on slot filling - Google Patents

Method and apparatus for providing chatbot service based on slot filling Download PDF

Info

Publication number
KR20220155957A
KR20220155957A KR1020220148686A KR20220148686A KR20220155957A KR 20220155957 A KR20220155957 A KR 20220155957A KR 1020220148686 A KR1020220148686 A KR 1020220148686A KR 20220148686 A KR20220148686 A KR 20220148686A KR 20220155957 A KR20220155957 A KR 20220155957A
Authority
KR
South Korea
Prior art keywords
intent
slot
block
chatbot
intents
Prior art date
Application number
KR1020220148686A
Other languages
Korean (ko)
Inventor
배용주
조은주
Original Assignee
에스케이플래닛 주식회사
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 에스케이플래닛 주식회사 filed Critical 에스케이플래닛 주식회사
Priority to KR1020220148686A priority Critical patent/KR20220155957A/en
Publication of KR20220155957A publication Critical patent/KR20220155957A/en

Links

Images

Classifications

    • G06Q50/50
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q50/00Systems or methods specially adapted for specific business sectors, e.g. utilities or tourism
    • G06Q50/30Transportation; Communications
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/30Information retrieval; Database structures therefor; File system structures therefor of unstructured textual data
    • G06F16/33Querying
    • G06F16/332Query formulation
    • G06F16/3329Natural language query formulation or dialogue systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/20Natural language analysis
    • G06F40/237Lexical tools
    • G06F40/247Thesauruses; Synonyms
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/20Natural language analysis
    • G06F40/258Heading extraction; Automatic titling; Numbering
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/20Natural language analysis
    • G06F40/279Recognition of textual entities
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L51/00User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail
    • H04L51/02User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail using automatic reactions or user delegation, e.g. automatic replies or chatbot-generated messages
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L51/00User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail
    • H04L51/21Monitoring or handling of messages

Abstract

Disclosed are a method and an apparatus for providing a chatbot service based on slot filling. The chatbot service providing method according to one embodiment of the present invention comprises the steps of: determining intent corresponding to user conversation; using an intent mapping list to select an execution block corresponding to the intent; performing slot filling corresponding to the execution block; and based on the slot filling, performing a conversation process corresponding to the intent. The intent mapping list is provided for each execution block and corresponds to at least one intent. Accordingly, a chatbot can effectively respond to various user conversation patterns.

Description

슬롯 필링 기반의 챗봇 서비스 제공 방법 및 장치 {METHOD AND APPARATUS FOR PROVIDING CHATBOT SERVICE BASED ON SLOT FILLING}Method and apparatus for providing chatbot service based on slot filling {METHOD AND APPARATUS FOR PROVIDING CHATBOT SERVICE BASED ON SLOT FILLING}

본 발명은 챗봇(chatbot) 서비스 제공 방법 및 장치에 관한 것으로, 특히 사용자가 처음부터 말하기 어려운 정보나 사용자와 대화를 진행하면서 추가된 정보들에 대해서도 슬롯 필링이 가능한 슬롯 필링 기반의 챗봇 서비스 제공 기술에 관한 것이다.The present invention relates to a method and apparatus for providing a chatbot service, and in particular, to a slot filling-based chatbot service providing technology capable of slot filling information that is difficult for a user to say from the beginning or information added while having a conversation with a user. it's about

본 명세서에서 달리 표시되지 않는 한, 이 섹션에 설명되는 내용들은 이 출원의 청구항들에 대한 종래 기술이 아니며, 이 섹션에 포함된다고 하여 종래 기술이라고 인정되는 것은 아니다.Unless otherwise indicated herein, material described in this section is not prior art to the claims in this application, and inclusion in this section is not an admission that it is prior art.

챗봇(chatbot)은 문자나 음성으로 대화하는 기능이 구비된 컴퓨터 프로그램이나 인공지능을 말하며, 사람처럼 자연스러운 대화를 진행하기 위해 단어나 구(句)의 매칭만을 이용하는 단순한 챗봇부터 복잡하고 정교한 자연어 처리 기술을 적용한 챗봇까지 다양한 수준의 챗봇들이 존재한다.A chatbot refers to a computer program or artificial intelligence equipped with the ability to communicate by text or voice. It ranges from simple chatbots that use only word or phrase matching to complex and sophisticated natural language processing technology to conduct natural conversations like humans. There are various levels of chatbots, including chatbots that apply .

챗봇을 이용한 대화형 AI 에이전트 시스템은 사용자의 입력에 대해 사용자가 원하는 서비스가 어떤 것인지를 파악하고 그 응답을 제공한다. 이 때, 사용자가 자연스러운 문장을 통하여 입력을 제공한 경우, 입력에 처리를 위해 자연어 처리 기술이 적용될 수 있다. 이를 위해, 사용자의 의도(intent)가 동일한 발화 예시 문장들 여러 개를 모아서 하나의 인텐트로 분류한다. 이렇게 분류된 인텐트들 각각에 대응하는 봇 응답을 매핑(mapping)하거나 서비스 API 호출 등의 동작을 정의함으로써 사용자의 다양한 자연 발화를 처리할 수 있는 챗봇 서비스 제공이 가능하다.A conversational AI agent system using a chatbot identifies the service the user wants in response to the user's input and provides a response. In this case, when the user provides an input through a natural sentence, natural language processing technology may be applied to the input for processing. To this end, several utterance example sentences with the same user intent are collected and classified into one intent. It is possible to provide a chatbot service capable of handling various spontaneous speeches of users by mapping bot responses corresponding to each of the thus classified intents or defining operations such as service API calls.

하나의 사용자의 발화 단위(인텐트)별로 하나의 봇 응답 단위(실행블록)를 매핑하는 경우, 서비스 기능이 늘어날수록 봇 응답들과 이에 대응하는 인텐트들도 늘어나게 된다. 인텐트들에 할당되게 되고, 의도 분류시 복수의 근소한 스코어(score) 차이를 가지는 인텐트들이 발생하게 되어 의도 분류에서 오류가 발생할 가능성이 높아진다. When one bot response unit (execution block) is mapped for each user's utterance unit (intent), bot responses and corresponding intents increase as service functions increase. It is assigned to intents, and when intent is classified, a plurality of intents having a slight score difference are generated, which increases the possibility of error in intent classification.

인텐트의 개수가 늘어나지 않더라도, 사용자의 자연스러운 다양한 발화를 인식하기 위해 인텐트에 다양한 발화 패턴을 등록하게 되면, 유사한 패턴이 여러 인텐트에 등록되게 되므로 자연어 처리기에서 서로 다른 인텐트간에 유사한 발화를 정확히 처리하기 어려워서 의도 분류에 오류가 발생하기 쉽다. Even if the number of intents does not increase, if various utterance patterns are registered in the intent to recognize the user's various natural utterances, similar patterns are registered in multiple intents, so that the natural language processor accurately identifies similar utterances between different intents. Difficult to process, prone to errors in intent classification.

즉, 인텐트와 봇 응답 단위가 1:1로 매핑되는 상황에 맞추어 발화를 분류하게 되면 인텐트 개수가 늘어나거나 인텐트에 등록된 예시 발화 문장의 개수가 늘어날수록 자연어 처리기의 성능이 떨어지는 문제가 발생하고, 자연어 처리기의 성능을 보장하기 위해 발화를 분류하게 되면 인텐트 하나에 유사한 발화 패턴을 모두 정의하게 되어 해당 인텐트에 매핑되는 블록의 구현이 매우 복잡해지고 실제 제공되는 여러 기능이 블록 하나에 매핑되는 상황이 되어 관리상의 어려움이 불가피하다.That is, if utterances are classified according to the situation in which intents and bot response units are mapped 1:1, the performance of the natural language processor decreases as the number of intents increases or the number of example utterances registered in the intent increases. occurrence, and when utterances are classified to ensure the performance of the natural language processor, all similar utterance patterns are defined in one intent, which makes the implementation of blocks mapped to the intent very complicated, and many actually provided functions are included in one block. As it becomes a mapping situation, difficulties in management are inevitable.

또한, 대부분의 챗봇은 사용자 발화시 모든 인텐트를 대상으로 서치(search)하여 봇의 동작을 프로세싱하는데, 이와 같이 모든 인텐트를 대상으로 서치하는 경우에는 자연어 처리기의 결과 처리 문제와 봇 응답 및 액션 구성이 복잡해지는 문제가 발생한다.In addition, most chatbots process bot actions by searching for all intents when the user utters them. In the case of searching for all intents in this way, the problem of processing results of natural language processors and bot responses and actions There is a problem that complicates the configuration.

따라서, 인텐트와 봇 응답 단위를 보다 자유롭게 매핑할 수 있는 새로운 챗봇 서비스 제공 기술의 필요성이 절실하게 대두된다.Therefore, there is an urgent need for a new chatbot service providing technology that can more freely map intents and bot response units.

한국 공개 특허 제10-2019-0006403호, 2019년 1월 18일 공개 (명칭: 음성 처리 방법 및 이를 지원하는 시스템)Korean Patent Publication No. 10-2019-0006403, published on January 18, 2019 (Name: Voice processing method and system supporting it)

본 발명의 목적은, 동일한 인텐트가 서로 다른 실행블록에서 사용되는 경우에 실행블록에 정의된 슬롯 필링을 기반으로 다르게 동작하도록 설정함으로써 다양한 사용자 대화 패턴에 대해 챗봇이 효과적으로 대응하도록 하는 것이다.An object of the present invention is to enable a chatbot to effectively respond to various user conversation patterns by setting the same intent to operate differently based on slot filling defined in the execution block when the same intent is used in different execution blocks.

또한, 본 발명의 목적은, 하나의 슬롯에 매핑된 여러 개의 엔티티들을 이용하여 인텐트에 존재하는 슬롯뿐만 아니라 전혀 새로운 슬롯에 대한 슬롯 필링을 수행할 수 있고, 이를 통해 사용자가 처음부터 말하기 어려운 정보나 대화를 진행하면서 추가된 정보들에 대해서도 슬롯 필링이 가능하게 하는 것이다. In addition, an object of the present invention is to perform slot filling for a completely new slot as well as a slot existing in an intent using several entities mapped to one slot, through which information that is difficult for a user to speak from the beginning. It is to enable slot filling for information added during the conversation.

또한, 본 발명의 목적은, 슬롯 재사용 기능을 제공함으로써 컨텍스트 흐름을 유지하기 위한 과정을 간소화하고, 컨텍스트 흐름 유지를 위해 설정되는 슬롯 값들을 보다 효과적으로 관리하는 것이다.Also, an object of the present invention is to simplify a process for maintaining a context flow by providing a slot reuse function, and to more effectively manage slot values set for maintaining a context flow.

또한, 본 발명의 목적은, 자연어 처리기에 적합하게 분류된 인텐트들과 인텐트들을 처리하는 실행블록들 사이의 N: N(N은 자연수) 매핑이 가능하도록 하여, 여러가지 다른 발화들로 하나의 기능을 실행할 수 있고, 반대로 유사한 발화들로 전혀 다른 기능을 수행할 수 있도록 하는 것이다.In addition, an object of the present invention is to enable N:N (N is a natural number) mapping between intents classified as suitable for a natural language processor and execution blocks processing the intents, so that a single It is to be able to execute a function, and conversely, to be able to perform a completely different function with similar utterances.

또한, 본 발명의 목적은 하나 이상의 인텐트별로 인텐트 식별자와 슬롯 조건을 포함하는 인텐트 매핑 리스트를 이용하여 다양한 인텐트-실행블록 매핑 관계가 가능해지도록 하는 것이다.Also, an object of the present invention is to enable various intent-execution block mapping relationships by using an intent mapping list including an intent identifier and a slot condition for each one or more intents.

또한, 본 발명의 목적은 상술한 바와 같은 목적들로 한정되지 않으며, 이하의 설명으로부터 또 다른 목적이 도출될 수도 있음은 자명하다.In addition, the object of the present invention is not limited to the objects as described above, and it is obvious that another object may be derived from the following description.

상기한 목적을 달성하기 위한 본 발명의 일실시예에 따른 슬롯 필링 기반의 챗봇 서비스 제공 방법은 사용자 대화에 상응하는 인텐트를 결정하는 단계; 인텐트 매핑 리스트를 이용하여 상기 인텐트에 상응하는 실행블록을 선택하는 단계; 상기 실행블록에 상응하는 슬롯 필링을 수행하는 단계; 상기 슬롯 필링에 기반하여 상기 인텐트에 상응하는 대화 처리를 수행하는 단계를 포함하고, 상기 인텐트 매핑 리스트는 실행블록들 각각을 위하여 구비되고, 적어도 하나 이상의 인텐트에 상응한다.To achieve the above object, a method for providing a chatbot service based on slot filling according to an embodiment of the present invention includes determining an intent corresponding to a user conversation; selecting an execution block corresponding to the intent using an intent mapping list; performing slot filling corresponding to the execution block; and performing conversation processing corresponding to the intent based on the slot filling, wherein the intent mapping list is provided for each execution block and corresponds to at least one intent.

이 때, 슬롯 필링을 수행하는 단계는 슬롯에 매핑된 엔티티, 상기 실행블록에 상응하는 슬롯들 및 슬롯의 인텐트 매핑 정보 중 적어도 하나를 기반으로 슬롯 필링을 수행할 수 있다.In this case, performing slot filling may perform slot filling based on at least one of an entity mapped to a slot, slots corresponding to the execution block, and intent mapping information of the slot.

이 때, 인텐트 매핑 정보는 슬롯에 매핑된 인텐트 이름, 슬롯에 매핑된 인텐트의 슬롯 이름, 슬롯에 매핑된 인텐트의 슬롯 값 및 슬롯에 매핑된 인텐트의 슬롯 값에 의한 결과 값 중 적어도 하나를 포함할 수 있다.In this case, the intent mapping information is selected from among result values of the intent name mapped to the slot, the slot name of the intent mapped to the slot, the slot value of the intent mapped to the slot, and the slot value of the intent mapped to the slot. may contain at least one.

이 때, 실행블록에 상응하는 슬롯들은 상기 인텐트 매핑 리스트를 통해 상기 실행블록과 연결된 인텐트들의 슬롯들을 포함할 수 있다.In this case, slots corresponding to the execution block may include slots of intents connected to the execution block through the intent mapping list.

이 때, 슬롯 필링을 수행하는 단계는 상기 슬롯에 매핑된 엔티티에 대한 동의어 매칭을 수행하여 슬롯 값을 추출할 수 있다.In this case, in the step of performing slot filling, a slot value may be extracted by performing synonym matching on an entity mapped to the slot.

이 때, 하나의 슬롯은 복수개의 엔티티들과 매핑 가능할 수 있다.In this case, one slot may be mappable with a plurality of entities.

이 때, 실행블록이 포함되는 시나리오를 고려하여 슬롯 컨텍스트를 유지하기 위한 슬롯 재사용 설정을 수행하는 단계를 더 포함할 수 있다.At this time, the step of performing slot reuse configuration for maintaining a slot context in consideration of a scenario including an execution block may be further included.

이 때, 슬롯 재사용 설정이 수행된 실행블록과 연결된 인텐트들의 슬롯들은 상기 시나리오가 종료된 후 다시 실행했을 때에도 슬롯 값이 삭제되지 않을 수 있다.In this case, the slot values of the intents connected to the execution block for which the slot reuse setting is performed may not be deleted even when the scenario is executed again after the end of the scenario.

이 때, 인텐트 매핑 리스트는 인텐트별로 인텐트 식별자 및 슬롯 조건을 포함할 수 있다.In this case, the intent mapping list may include an intent identifier and a slot condition for each intent.

또한, 본 발명의 일실시예에 따른 슬롯 필링 기반의 챗봇 서비스 제공 장치는, 하나 이상의 프로세서; 및 상기 하나 이상의 프로세서에 의해 실행되는 적어도 하나 이상의 프로그램을 저장하는 실행메모리; 를 포함하고, 상기 적어도 하나 이상의 프로그램은, 사용자 대화에 상응하는 인텐트를 결정하고, 인텐트 매핑 리스트를 이용하여 상기 인텐트에 상응하는 실행블록을 선택하고, 상기 실행블록에 상응하는 슬롯 필링을 수행하고, 상기 슬롯 필링에 기반하여 상기 인텐트에 상응하는 대화 처리를 수행하되, 상기 인텐트 매핑 리스트는 실행블록들 각각을 위하여 구비되고, 적어도 하나 이상의 인텐트에 상응한다.In addition, an apparatus for providing a chatbot service based on slot filling according to an embodiment of the present invention includes one or more processors; and an execution memory storing one or more programs executed by the one or more processors. The at least one program determines an intent corresponding to a user conversation, selects an execution block corresponding to the intent using an intent mapping list, and performs slot filling corresponding to the execution block. and performs conversation processing corresponding to the intent based on the slot filling, wherein the intent mapping list is provided for each execution block and corresponds to at least one intent.

이 때, 상기 적어도 하나 이상의 프로그램은 슬롯에 매핑된 엔티티, 상기 실행블록에 상응하는 슬롯들 및 슬롯의 인텐트 매핑 정보 중 적어도 하나를 기반으로 슬롯 필링을 수행할 수 있다.In this case, the at least one program may perform slot filling based on at least one of an entity mapped to a slot, slots corresponding to the execution block, and intent mapping information of the slot.

이 때, 인텐트 매핑 정보는 슬롯에 매핑된 인텐트 이름, 슬롯에 매핑된 인텐트의 슬롯 이름, 슬롯에 매핑된 인텐트의 슬롯 값 및 슬롯에 매핑된 인텐트의 슬롯 값에 의한 결과 값 중 적어도 하나를 포함할 수 있다.In this case, the intent mapping information is selected from among result values of the intent name mapped to the slot, the slot name of the intent mapped to the slot, the slot value of the intent mapped to the slot, and the slot value of the intent mapped to the slot. may contain at least one.

이 때, 실행블록에 상응하는 슬롯들은 상기 인텐트 매핑 리스트를 통해 상기 실행블록과 연결된 인텐트들의 슬롯들을 포함할 수 있다.In this case, slots corresponding to the execution block may include slots of intents connected to the execution block through the intent mapping list.

이 때, 상기 적어도 하나 이상의 프로그램은 상기 슬롯에 매핑된 엔티티에 대한 동의어 매칭을 수행하여 슬롯 값을 추출할 수 있다.In this case, the at least one program may extract a slot value by performing synonym matching on an entity mapped to the slot.

이 때, 하나의 슬롯은 복수개의 엔티티들과 매핑 가능할 수 있다.In this case, one slot may be mappable with a plurality of entities.

이 때, 상기 적어도 하나 이상의 프로그램은 실행블록이 포함되는 시나리오를 고려하여 슬롯 컨텍스트를 유지하기 위한 슬롯 재사용 설정을 수행할 수 있다.At this time, the at least one or more programs may perform slot reuse configuration for maintaining a slot context in consideration of a scenario including an execution block.

이 때, 슬롯 재사용 설정이 수행된 실행블록과 연결된 인텐트들의 슬롯들은 상기 시나리오가 종료된 후 다시 실행했을 때에도 슬롯 값이 삭제되지 않을 수 있다.In this case, the slot values of the intents connected to the execution block for which the slot reuse setting is performed may not be deleted even when the scenario is executed again after the end of the scenario.

이 때, 인텐트 매핑 리스트는 인텐트별로 인텐트 식별자 및 슬롯 조건을 포함할 수 있다.In this case, the intent mapping list may include an intent identifier and a slot condition for each intent.

본 발명에 따르면, 동일한 인텐트가 서로 다른 실행블록에서 사용되는 경우에 실행블록에 정의된 슬롯 필링을 기반으로 다르게 동작하도록 설정함으로써 다양한 사용자 대화 패턴에 대해 챗봇이 효과적으로 대응할 수 있다.According to the present invention, when the same intent is used in different execution blocks, the chatbot can effectively respond to various user conversation patterns by setting to operate differently based on the slot filling defined in the execution block.

또한, 본 발명은 하나의 슬롯에 매핑된 여러 개의 엔티티들을 이용하여 인텐트에 존재하는 슬롯뿐만 아니라 전혀 새로운 슬롯에 대한 슬롯 필링을 수행할 수 있고, 이를 통해 사용자가 처음부터 말하기 어려운 정보나 대화를 진행하면서 추가된 정보들에 대해서도 슬롯 필링이 가능하게 할 수 있다.In addition, the present invention can perform slot filling for a completely new slot as well as a slot existing in an intent using several entities mapped to one slot, and through this, information or conversation that is difficult for the user to speak from the beginning Slot filling may also be enabled for information added in progress.

또한, 본 발명은 슬롯 재사용 기능을 제공함으로써 컨텍스트 흐름을 유지하기 위한 과정을 간소화하고, 컨텍스트 흐름 유지를 위해 설정되는 슬롯 값들을 보다 효과적으로 관리할 수 있다.In addition, the present invention simplifies a process for maintaining a context flow by providing a slot reuse function, and can more effectively manage slot values set for maintaining a context flow.

또한, 본 발명은 자연어 처리기에 적합하게 분류된 인텐트들과 인텐트들을 처리하는 실행블록들 사이의 N: N(N은 자연수) 매핑이 가능하도록 하여, 여러가지 다른 발화들로 하나의 기능을 실행할 수 있고, 반대로 유사한 발화들로 전혀 다른 기능을 수행할 수 있다.In addition, the present invention enables N:N (N is a natural number) mapping between intents classified as suitable for a natural language processor and execution blocks processing the intents, so that one function can be executed with various different utterances. and conversely, similar utterances can perform completely different functions.

또한, 본 발명은 하나 이상의 인텐트별로 인텐트 식별자와 슬롯 조건을 포함하는 인텐트 매핑 리스트를 이용하여 다양한 인텐트-실행블록 매핑 관계를 정의하는 것이 가능하다.Also, according to the present invention, it is possible to define various intent-execution block mapping relationships by using an intent mapping list including an intent identifier and a slot condition for each one or more intents.

본 실시 예들의 효과는 이상에서 언급한 효과들로 제한되지 않으며, 언급되지 않은 또 다른 효과들은 청구범위의 기재로부터 통상의 기술자에게 명확하게 이해될 수 있을 것이다.The effects of the present embodiments are not limited to the effects mentioned above, and other effects not mentioned will be clearly understood by those skilled in the art from the description of the claims.

도 1은 본 발명의 일실시예에 따른 슬롯 필링 기반의 챗봇 서비스 제공 방법을 나타낸 동작 흐름도이다.
도 2는 본 발명에 따른 엔티티의 일 예를 나타낸 도면이다.
도 3은 도 2에 도시된 엔티티가 적용된 인텐트의 일 예를 나타낸 도면이다.
도 4는 도 3에 도시된 인텐트를 기반으로 인텐트 매핑 정보의 일 예를 나타낸 도면이다.
도 5는 본 발명에 따른 슬롯 필링 처리 과정의 일 예를 나타낸 동작흐름도이다.
도 6은 본 발명의 일실시예에 따른 슬롯 필링 기반의 챗봇 서비스 제공 장치를 나타낸 블록도이다.
도 7은 본 발명의 일실시예에 따른 챗봇 서비스 시스템을 나타낸 블록도이다.
도 8은 본 발명의 일실시예에 따른 '커피 주문' 시나리오의 블록 다이어그램을 나타낸 도면이다.
도 9는 도 8에 도시된 시나리오에 사용되는 인텐트들의 일 예를 나타낸 도면이다.
도 10은 복수개의 인텐트들과 복수개의 실행블록들 사이의 연결을 나타낸 블록도이다.
도 11은 도 9에 도시된 실행블록 커피 선택의 일 예를 나타낸 도면이다.
도 12는 도 9에 도시된 실행블록 핫아이스확인의 일 예를 나타낸 도면이다.
도 13은 도 9에 도시된 실행블록 테이크아웃확인의 일 예를 나타낸 도면이다.
도 9는 도 9 내지 도 13에 도시된 실행블록들의 연결관계를 나타낸 블록도이다.
도 10은 실행블록에서 사용자 응답 대기 상태를 정의하여 블록들을 연결하는 일 예를 도시한 도면이다.
도 16은 발화 패턴별로 정의된 인텐트를 블록에 매핑하는 일 예를 나타낸 도면이다.
도 17은 인텐트와 실행블록을 1:1 매핑하는 경우를 나타낸 도면이다.
도 18은 본 발명의 일실시예에 따른 인텐트 분류 및 블록 매핑의 일 예를 나타낸 도면이다.
도 19는 도 27에 도시된 응답들에 상응하는 실행블록들을 나타낸 도면이다.
도 20은 도 8 내지 도 9에서 예시된 커피주문 시나리오에 상응하는 조건의 포함관계에 따른 우선순위 정렬 예를 나타낸 도면이다.
도 21은 챗봇 실행에 필요한 모듈들의 일 예를 나타낸 블록도이다.
도 22는 챗봇 실행 중 인텐트와 블록을 검색하는 과정을 나타낸 도면이다.
도 23은 본 발명의 다른 실시예에 따른 챗봇 서비스 제공 방법을 나타낸 동작 흐름도이다.
도 24는 발화 패턴수 증가에 따른 자연어 처리기 성능을 나타낸 그래프이다.
1 is an operational flowchart illustrating a method of providing a chatbot service based on slot filling according to an embodiment of the present invention.
2 is a diagram illustrating an example of an entity according to the present invention.
FIG. 3 is a diagram illustrating an example of an intent to which the entity shown in FIG. 2 is applied.
FIG. 4 is a diagram illustrating an example of intent mapping information based on the intent shown in FIG. 3 .
5 is an operational flow diagram illustrating an example of a slot filling process according to the present invention.
6 is a block diagram illustrating an apparatus for providing a chatbot service based on slot filling according to an embodiment of the present invention.
7 is a block diagram showing a chatbot service system according to an embodiment of the present invention.
8 is a block diagram of a 'coffee order' scenario according to an embodiment of the present invention.
FIG. 9 is a diagram illustrating an example of intents used in the scenario shown in FIG. 8 .
10 is a block diagram showing connections between a plurality of intents and a plurality of execution blocks.
FIG. 11 is a diagram illustrating an example of the execution block coffee selection shown in FIG. 9 .
FIG. 12 is a diagram illustrating an example of hot ice checking of the execution block shown in FIG. 9 .
13 is a diagram illustrating an example of execution block takeout confirmation shown in FIG. 9 .
9 is a block diagram showing a connection relationship between execution blocks shown in FIGS. 9 to 13 .
10 is a diagram illustrating an example of connecting blocks by defining a waiting state for a user response in an execution block.
16 is a diagram illustrating an example of mapping intents defined for each speech pattern to blocks.
17 is a diagram illustrating a case of 1:1 mapping between intents and execution blocks.
18 is a diagram illustrating an example of intent classification and block mapping according to an embodiment of the present invention.
FIG. 19 is a diagram showing execution blocks corresponding to the responses shown in FIG. 27 .
FIG. 20 is a diagram showing an example of priorities sorted according to inclusion relationships of conditions corresponding to the coffee ordering scenarios illustrated in FIGS. 8 to 9 .
21 is a block diagram illustrating an example of modules necessary for executing a chatbot.
22 is a diagram illustrating a process of searching for intents and blocks while the chatbot is running.
23 is an operational flowchart illustrating a method of providing a chatbot service according to another embodiment of the present invention.
24 is a graph showing performance of a natural language processor according to an increase in the number of speech patterns.

이하 본 발명의 바람직한 실시예를 첨부한 도면을 참조하여 상세히 설명한다. 다만, 하기의 설명 및 첨부된 도면에서 본 발명의 요지를 흐릴 수 있는 공지 기능 또는 구성에 대한 상세한 설명은 생략한다. 또한, 도면 전체에 걸쳐 동일한 구성 요소들은 가능한 한 동일한 도면 부호로 나타내고 있음에 유의하여야 한다.Hereinafter, preferred embodiments of the present invention will be described in detail with reference to the accompanying drawings. However, detailed descriptions of well-known functions or configurations that may obscure the gist of the present invention will be omitted in the following description and accompanying drawings. In addition, it should be noted that the same components are indicated by the same reference numerals throughout the drawings as much as possible.

이하에서 설명되는 본 명세서 및 청구범위에 사용된 용어나 단어는 통상적이거나 사전적인 의미로 한정해서 해석되어서는 아니 되며, 발명자는 그 자신의 발명을 가장 최선의 방법으로 설명하기 위한 용어의 개념으로 적절하게 정의할 수 있다는 원칙에 입각하여 본 발명의 기술적 사상에 부합하는 의미와 개념으로 해석되어야만 한다. 따라서 본 명세서에 기재된 실시예와 도면에 도시된 구성은 본 발명의 가장 바람직한 일 실시예에 불과할 뿐이고, 본 발명의 기술적 사상을 모두 대변하는 것은 아니므로, 본 출원시점에 있어서 이들을 대체할 수 있는 다양한 균등물과 변형 예들이 있을 수 있음을 이해하여야 한다. 또한 제 1, 제 2 등의 용어는 다양한 구성요소들을 설명하기 위해 사용하는 것으로, 하나의 구성요소를 다른 구성요소로부터 구별하는 목적으로만 사용될 뿐, 상기 구성요소들을 한정하기 위해 사용되지 않는다.The terms or words used in this specification and claims described below should not be construed as being limited to a conventional or dictionary meaning, and the inventors should appropriate the concept of terms to describe their invention in the best way. It should be interpreted as a meaning and concept consistent with the technical spirit of the present invention based on the principle that it can be defined in the following way. Therefore, the embodiments described in this specification and the configurations shown in the drawings are only one of the most preferred embodiments of the present invention, and do not represent all of the technical ideas of the present invention, so various alternatives can be made at the time of this application. It should be understood that there may be equivalents and variations. In addition, terms such as first and second are used to describe various components, and are used only for the purpose of distinguishing one component from another, and are not used to limit the components.

종래의 챗봇 서비스에서는 사용자의 최초 발화만을 이용하거나 슬롯에 매핑된 하나의 엔티티만을 기반으로 동의어 매칭을 수행하여 슬롯 값을 추출하였기 때문에 사용자가 처음부터 말하기 어려운 정보라던지 챗봇이 사용자와 대화를 진행하면서 추가된 정보들에 대해서는 슬롯 필링이 어렵다는 단점이 존재하였다. In the conventional chatbot service, slot values are extracted by using only the user's initial utterance or performing synonym matching based on only one entity mapped to the slot. There was a disadvantage that slot filling was difficult for the added information.

또한, 슬롯 필링 수행 시, 단순히 인텐트에 종속된 슬롯의 필수 여부나 유도 메시지(prompt message)를 설정하는 것만으로는, 동일한 인텐트가 기능이 다른 실행블록에서도 모두 동일하게 슬롯을 처리하게 만들어서 오히려 비효율적인 결과를 야기하기도 하였다.In addition, when slot filling is performed, the same intent processes slots identically in execution blocks with different functions simply by setting whether a slot dependent on an intent is required or a prompt message is set. It can also lead to inefficient results.

따라서, 본 발명에서는 상술한 문제점들을 해소할 수 있는 슬롯 필링 기반의 챗봇 서비스 제공 기술을 제안하고자 한다.Therefore, the present invention intends to propose a chatbot service providing technology based on slot filling that can solve the above problems.

도 1은 본 발명의 일실시예에 따른 슬롯 필링 기반의 챗봇 서비스 제공 방법을 나타낸 동작 흐름도이다.1 is an operational flowchart illustrating a method of providing a chatbot service based on slot filling according to an embodiment of the present invention.

도 1을 참조하면, 본 발명의 일실시예에 따른 슬롯 필링 기반의 챗봇 서비스 제공 방법은 사용자 대화에 상응하는 인텐트를 결정한다(S110).Referring to FIG. 1 , the method for providing a chatbot service based on slot filling according to an embodiment of the present invention determines an intent corresponding to a user conversation (S110).

이 때, 사용자 대화에 상응하는 인텐트는 현재 블록과 그래프(graph)를 통해 연결된 하나 이상의 후보블록 또는 메인블록에 연결된 인텐트 후보 내에서 선택될 수 있다.In this case, an intent corresponding to the user dialogue may be selected from one or more candidate blocks connected to the current block through a graph or from among intent candidates connected to the main block.

이 때, 사용자 대화에 상응하는 인텐트는 후보블록에 연결된 제1 인텐트 후보가 메인블록에 연결된 제2 인텐트 후보보다 우선적으로 고려되어 결정될 수 있다.In this case, the intent corresponding to the user dialogue may be determined by considering the first intent candidate linked to the candidate block with priority over the second intent candidate linked to the main block.

또한, 본 발명의 일실시예에 따른 슬롯 필링 기반의 챗봇 서비스 제공 방법은 인텐트 매핑 리스트를 이용하여 인텐트에 상응하는 실행블록을 선택한다(S120).In addition, in the method for providing a chatbot service based on slot filling according to an embodiment of the present invention, an execution block corresponding to an intent is selected using an intent mapping list (S120).

이 때, 인텐트 매핑 리스트는 실행블록들 각각을 위하여 구비되고, 적어도 하나 이상의 인텐트에 상응하는 것일 수 있다.In this case, the intent mapping list is provided for each of the execution blocks and may correspond to one or more intents.

이 때, 인텐트 매핑 리스트는 인텐트별로 인텐트 식별자 및 슬롯 조건을 포함할 수 있다. In this case, the intent mapping list may include an intent identifier and a slot condition for each intent.

이 때, 슬롯 조건은 하나 이상의 슬롯(slot)에 관련된 조건문에 상응하는 것일 수 있다.In this case, the slot condition may correspond to conditional statements related to one or more slots.

이 때, 슬롯 조건은 널(NULL) 조건을 포함할 수 있다.At this time, the slot condition may include a null condition.

이 때, 인텐트 매핑 리스트는 복수의 인텐트들에 상응하는 인텐트 식별자들 및 슬롯 조건들을 포함하는 경우가 있고(N:1), 인텐트는 서로 상이한 실행블록들이 동일한 인텐트 식별자를 가지는 경우에 슬롯 조건들이 상이하면 서로 상이한 실행블록들에 연결(1:N)될 수 있다.In this case, the intent mapping list may include intent identifiers and slot conditions corresponding to a plurality of intents (N:1), and execution blocks having different intents have the same intent identifier. If the slot conditions are different, it can be connected (1:N) to different execution blocks.

이 때, 실행블록에 상응하는 슬롯들은, 인텐트 매핑 리스트를 통해 실행블록과 연결된 인텐트들의 슬롯들을 포함할 수 있다.In this case, the slots corresponding to the execution block may include slots of intents connected to the execution block through the intent mapping list.

이 때, 인텐트에 상응하는 실행블록은 사용자 대화에 상응하는 인텐트가 복수개의 실행블록들과 연결되는 경우, 큰 집합에 상응하는 슬롯 조건의 포함관계를 가지는 제1 실행블록이 상기 큰 집합에 포함되는 작은 집합에 상응하는 슬롯 조건의 포함관계를 가지는 제2 실행블록보다 우선적으로 고려되어 선택될 수 있다. 이 때, 슬롯 조건의 포함관계는 슬롯 조건에 포함된 슬롯들의 포함관계일 수 있다. 예를 들어, $level == "정회원" and $service == "가입"에 해당하는 실행블록이 $service == "가입"에 해당하는 실행블록보다 우선적으로 고려되어 선택될 수 있다.At this time, the execution block corresponding to the intent, when the intent corresponding to the user dialogue is connected to a plurality of execution blocks, the first execution block having an inclusion relationship of the slot condition corresponding to the large set is included in the large set. A second execution block having an inclusion relationship of a slot condition corresponding to an included small set may be prioritized and selected. In this case, the inclusion relationship of the slot condition may be the inclusion relationship of slots included in the slot condition. For example, an execution block corresponding to $level == "regular member" and $service == "subscription" may be selected with priority over an execution block corresponding to $service == "subscription".

또한, 본 발명의 일실시예에 따른 슬롯 필링 기반의 챗봇 서비스 제공 방법은 실행블록에 상응하는 슬롯 필링을 수행한다(S130).In addition, the slot filling-based chatbot service providing method according to an embodiment of the present invention performs slot filling corresponding to an execution block (S130).

이 때, 슬롯 필링은 슬롯에 입력 가능한 슬롯 값을 사용자로부터 입력 받는 과정을 의미할 수 있다. In this case, slot filling may refer to a process of receiving a slot value that can be input into a slot from a user.

이 때, 슬롯에 매핑된 엔티티, 실행블록에 상응하는 슬롯들 및 슬롯의 인텐트 매핑 정보 중 적어도 하나를 기반으로 슬롯 필링을 수행할 수 있다. In this case, slot filling may be performed based on at least one of an entity mapped to a slot, slots corresponding to an execution block, and intent mapping information of the slot.

예를 들어, 사용자가 챗봇과의 대화를 통해 슬롯 값을 정확하게 말했을 경우에는 슬롯에 매핑된 엔티티를 기반으로 슬롯 필링을 수행할 수 있고, 사용자가 현재 실행블록에 상응하는 인텐트에 해당하는 문장을 말했을 경우에는 실행블록에 상응하는 슬롯들을 기반으로 슬롯 필링을 수행할 수 있다. For example, if the user accurately said the slot value through a conversation with the chatbot, slot filling can be performed based on the entity mapped to the slot, and the user can send a sentence corresponding to the intent corresponding to the current execution block. In this case, slot filling can be performed based on slots corresponding to execution blocks.

이 때, 슬롯에 매핑된 엔티티에 대한 동의어 매칭을 수행하여 슬롯 값을 추출할 수 있다. 즉, 슬롯에 매핑된 엔티티들은 슬롯에 어떤 슬롯 값이 입력될 수 있는지를 나타낼 수 있다. In this case, a slot value may be extracted by performing synonym matching on entities mapped to the slot. That is, entities mapped to slots may indicate which slot values can be input to slots.

예를 들어, 'order_coffee'라는 인텐트가 포함하는 $coffee 슬롯에 '커피' 엔티티가 매핑되어 있다고 가정하면, $coffee 슬롯의 슬롯 값에는 '커피' 엔티티에 상응하게 슬롯 값이 입력될 수 있다. For example, assuming that the 'coffee' entity is mapped to the $coffee slot included in the 'order_coffee' intent, the slot value corresponding to the 'coffee' entity may be input to the slot value of the $coffee slot.

다른 예를 들어, 'order_juice'라는 인텐트가 포함하는 $juice 슬롯에 '주스' 엔티티가 매핑되어 있다고 가정하면, $juice 슬롯의 슬롯 값에는 '주스' 엔티티에 상응하게 슬롯 값이 입력될 수 있다.For another example, assuming that the 'juice' entity is mapped to the $juice slot included in the 'order_juice' intent, the slot value corresponding to the 'juice' entity can be input to the slot value of the $juice slot. .

이 때, 하나의 슬롯은 복수개의 엔티티들과 매핑 가능할 수 있다. In this case, one slot may be mappable with a plurality of entities.

이 때, 본 발명에서는 하나의 슬롯에 복수개의 엔티티들을 매핑함으로써 사용자 발화를 통해 발생할 수 있는 다양한 상황에 대응할 수 있다. At this time, in the present invention, by mapping a plurality of entities to one slot, it is possible to respond to various situations that may occur through user speech.

예를 들어, '커피 주문'이나 '주스 주문'처럼 카테고리가 정해진 인텐트가 아니라 '음료 주문'처럼 커피와 주스 등의 음료를 모두 주문 가능한 경우에는 'order_drink' 인텐트가 포함하는 $drink 슬롯에 '커피' 엔티티, '주스' 엔티티, '음료' 엔티티 등을 복수로 매핑함으로써 사용자가 발화하는 다양한 음료를 정의할 수 있도록 한다. For example, if you can order both coffee and juice, such as 'order drink', rather than an intent with a defined category, such as 'order coffee' or 'order juice', the $drink slot included in the 'order_drink' intent By mapping a plurality of 'coffee' entities, 'juice' entities, and 'drink' entities, the user can define various beverages to ignite.

이 때, 본 발명에 일실시예에 따라 엔티티가 매핑되지 않은 슬롯이 존재할 수도 있는데, 이러한 경우에는 엔티티 동의어 매칭 이외의 방식을 기반으로 사용자의 발화 내용에서 자유롭게 슬롯 값을 설정할 수도 있다. At this time, according to an embodiment of the present invention, a slot to which an entity is not mapped may exist. In this case, a slot value may be freely set in the user's utterance based on a method other than entity synonym matching.

이 때, 엔티티에 대한 동의어 매칭은, 사용자 발화 내용 중 엔티티의 동의어로 설정되어 있는 값이 존재하는지 여부를 매칭하는 것으로, 사용자 발화 내용 중 엔티티의 동의어가 검출되었다면, 해당 엔티티에 상응하게 슬롯 값을 입력할 수 있다. At this time, the synonym matching for the entity is to match whether there is a value set as a synonym for the entity in the user's speech. If a synonym for the entity is detected in the user's speech, a slot value corresponding to the entity is selected. can be entered.

예를 들어, 'member_action' 인텐트가 포함하는 $action 슬롯에 대해 도 2에 도시된 join 엔티티, register 엔티티, cancel 엔티티, withdraw 엔티티가 매핑되어 있다고 가정할 수 있다. 이 때 만약, 사용자로부터 "가입할래요"라는 발화가 입력되면, 엔티티 동의어 매칭을 수행하여 join 엔티티에 상응하는 대표어 'join'을 슬롯 값으로 입력할 수 있다. For example, it can be assumed that the join entity, register entity, cancel entity, and withdraw entity shown in FIG. 2 are mapped to the $action slot included in the 'member_action' intent. At this time, if the utterance "I want to join" is input from the user, entity synonym matching may be performed and the representative word 'join' corresponding to the join entity may be input as a slot value.

이 때, 본 발명에서는 현재 실행블록에 상응하는 인텐트에는 존재하지 않는 인텐트들에 대해서도 추가적으로 슬롯 필링을 수행하기 위해서 슬롯의 인텐트 매핑 정보 기반으로 슬롯 필링을 수행할 수 있다. At this time, in the present invention, slot filling may be performed based on intent mapping information of a slot in order to additionally perform slot filling even for intents that do not exist in the intent corresponding to the current execution block.

이 때, 본 발명에서는 슬롯 필링을 수행할 때 인텐트 매핑 정보를 기반으로 인텐트에 존재하는 슬롯뿐만 아니라 전혀 새로운 슬롯에 대해서도 슬롯 필링을 수행할 수 있으며, 이 때에도 마찬가지로 슬롯에 엔티티를 지정하여 사용할 수 있다. 이러한 과정을 통해 사용자 발화에 의해 발생할 수 있는 다양한 상황을 챗봇이 유연하게 대응하여 처리하는 것이 가능하다. At this time, in the present invention, when performing slot filling, slot filling can be performed not only for slots existing in the intent but also for completely new slots based on intent mapping information. In this case, similarly, an entity can be designated and used in a slot. can Through this process, it is possible for the chatbot to flexibly respond to and handle various situations that may occur due to user speech.

예를 들어, 사용자가 "HDMI 연결이 안돼요"라고 말했을 때, 챗봇이 "모델 확인을 위해 뒷면의 시리얼 번호를 입력해주세요"라고 응답할 수 있다. For example, when the user says "HDMI connection is not available", the chatbot can respond with "Please enter the serial number on the back to check the model."

다른 예를 들어, 사용자가 "구매 취소해주세요"라고 말했을 때, 챗봇이 사용자의 휴대폰으로 인증번호를 발송하고 나서"본인확인을 위해 휴대폰으로 발송된 인증 번호를 입력해주세요"라고 응답할 수 있다. For another example, when the user says "Please cancel the purchase", the chatbot sends an authentication number to the user's mobile phone and then responds with "Please enter the authentication number sent to the mobile phone for identity verification".

즉, 사용자가 처음부터 말하기 어려운 정보나, 대화를 진행하면서 추가된 정보들도 슬롯 필링을 수행할 수 있다.That is, slot filling may also be performed on information that is difficult for the user to say from the start or information added during a conversation.

이 때, 인텐트 매핑 정보는 슬롯에 매핑된 인텐트 이름, 슬롯에 매핑된 인텐트의 슬롯 이름, 슬롯에 매핑된 인텐트의 슬롯 값 및 슬롯에 매핑된 인텐트의 슬롯 값에 의한 결과 값 중 적어도 하나를 포함할 수 있다. In this case, the intent mapping information is selected from among result values of the intent name mapped to the slot, the slot name of the intent mapped to the slot, the slot value of the intent mapped to the slot, and the slot value of the intent mapped to the slot. may contain at least one.

이하에서는, 도 2 내지 도 4를 참조하여 인텐트 매핑 정보를 기반으로 슬롯 필링을 수행하는 과정을 상세하게 설명하도록 한다. Hereinafter, a process of performing slot filling based on intent mapping information will be described in detail with reference to FIGS. 2 to 4 .

예를 들어, 도 2에 도시된 것처럼 엔티티가 정의되어 있고, 도 3에 도시된 것처럼 인텐트와 슬롯이 정의되어 있는 상태라고 가정한다면, 'join_confirm' 슬롯에는 join 엔티티와 cancel 엔티티가 매핑되어 있으므로 'join_confirm' 슬롯에 대한 인텐트 매핑 정보는 도 4에 도시된 것처럼 정의될 수 있다. For example, assuming that an entity is defined as shown in FIG. 2 and an intent and a slot are defined as shown in FIG. 3, the join entity and the cancel entity are mapped to the 'join_confirm' slot. Intent mapping information for the 'join_confirm' slot may be defined as shown in FIG. 4 .

예를 들어, 도 4에 도시된 인텐트들 중 첫번째 위치하는 'join_confirm' 인텐트의 경우, 슬롯에 매핑된 인텐트 이름을 이용하여 매핑된 것일 수 있다.For example, in the case of the 'join_confirm' intent located first among the intents shown in FIG. 4, it may be mapped using an intent name mapped to a slot.

이 때, 도 3을 참조하면 'join_confirm' 인텐트에 'join_confirm'슬롯이 포함되어 있으므로, 'join_confirm' 인텐트에 상응하게 슬롯 값을 입력할 수 있다. At this time, referring to FIG. 3, since the 'join_confirm' intent includes the 'join_confirm' slot, a slot value corresponding to the 'join_confirm' intent can be input.

다른 예를 들어, 도 4에 도시된 인텐트들 중 두번째 위치하는 'positive' 인텐트의 경우, 슬롯에 매핑된 인텐트 이름과 슬롯에 매핑된 인텐트의 슬롯 값에 의한 결과 값을 이용하여 매핑된 것일 수 있다.As another example, in the case of the second 'positive' intent among the intents shown in FIG. may have been

즉, 봇의 "가입하시겠습니까?"라는 질문에 대해 사용자가 "예"라고 대답하였다면, 도 3을 기반으로 'positive' 인텐트로 분류될 수 있고, 인텐트 매핑 정보에 따라 결과 값인 'join'이 join_confirm'슬롯의 슬롯 값으로 입력될 수 있다.That is, if the user answered "yes" to the bot's question "Do you want to join?", it can be classified as a 'positive' intent based on FIG. It can be input as a slot value of the 'join_confirm' slot.

다른 예를 들어, 도 4에 도시된 인텐트들 중 세번째 위치하는 'member_action' 인텐트의 경우, 슬롯에 매핑된 인텐트 이름과 슬롯에 매핑된 인텐트의 슬롯 이름을 이용하여 매핑된 것일 수 있다. As another example, in the case of the 'member_action' intent located third among the intents shown in FIG. 4, it may be mapped using the intent name mapped to the slot and the slot name of the intent mapped to the slot. .

즉, 봇의 "가입하시겠습니까?"라는 질문에 대해 사용자가 "가입할래요"라고 대답하였다면, 도 3을 기반으로 'member_action' 인텐트로 분류될 수 있다. 이 때, 'member_action' 인텐트의 'action' 슬롯은 '가입'을 동의어로 매칭할 수 있는 'join' 엔티티가 매핑되어 있으므로, 엔티티 대표어에 해당하는 'join'이 'join_confirm'슬롯의 슬롯 값으로 입력될 수 있다.That is, if the user answers "Would you like to join?" to the bot's question "Do you want to join?", the intent may be classified as 'member_action' based on FIG. 3 . At this time, the 'action' slot of the 'member_action' intent is mapped with the 'join' entity that can match 'join' as a synonym, so the 'join' corresponding to the entity representative word is the slot value of the 'join_confirm' slot. can be entered as

다른 예를 들어, 도 4에 도시된 인텐트들 중 네번째 위치하는 'member_action' 인텐트의 경우, 슬롯에 매핑된 인텐트 이름, 슬롯에 매핑된 인텐트의 슬롯 이름, 슬롯에 매핑된 인텐트의 슬롯 값 및 슬롯에 매핑된 인텐트의 슬롯 값에 의한 결과 값을 모두 이용하여 매핑된 것일 수 있다.As another example, in the case of the 'member_action' intent located fourth among the intents shown in FIG. 4, the intent name mapped to the slot, the slot name of the intent mapped to the slot, and the intent mapped to the slot. It may be mapped using both the slot value and the result value of the slot value of the intent mapped to the slot.

즉, 봇의 "가입하시겠습니까?"라는 질문에 대해 사용자가 "수영 등록할래요"라고 대답하였다면, 도 3을 기반으로 'member_action' 인텐트로 분류될 수 있다. 이 때, 'member_action' 인텐트의 'action' 슬롯은 '등록'을 동의어로 매칭할 수 있는 'register' 엔티티가 매핑되어 있고, 'member_action' 인텐트의 'action' 슬롯의 슬롯 값이 'register'인 경우의 결과 값으로 'join'이 매핑되어 있으므로, 'join_confirm'슬롯의 슬롯 값에도 'join'이 입력될 수 있다. That is, if the user answers "Do you want to register for swimming?" to the bot's question "Do you want to join?", it can be classified as a 'member_action' intent based on FIG. 3 . At this time, the 'action' slot of the 'member_action' intent is mapped with the 'register' entity that can match 'register' as a synonym, and the slot value of the 'action' slot of the 'member_action' intent is 'register'. Since 'join' is mapped as the result value in case of 'join', 'join' can also be input to the slot value of the 'join_confirm' slot.

이하에서는 도 5를 참조하여, 본 발명의 일실시예에 따른 슬롯 필링 처리 과정을 보다 상세하게 설명하도록 한다. Hereinafter, with reference to FIG. 5, a slot filling process according to an embodiment of the present invention will be described in detail.

본 발명의 일실시예에 따르면, 실행블록 내의 컴포넌트들을 순서대로 처리하면서 슬롯 컴포넌트에서 지정한 슬롯에 대한 슬롯 필링이 필요한지 여부를 판단하고(S502), 슬롯 값이 비어있어 슬롯 필링이 필요한 경우에는 챗봇이 프롬프트 메시지(Bot Prompt)를 통해 사용자에게 입력을 요청한 후(S504) 사용자의 응답을 대기(Slot Listen)할 수 있다(S506).According to one embodiment of the present invention, while processing the components in the execution block in order, it is determined whether slot filling is required for the slot designated by the slot component (S502), and if slot filling is required because the slot value is empty, the chatbot After requesting input from the user through a prompt message (Bot Prompt) (S504), a response from the user may be slot listened (S506).

이 후, 사용자가 발화에 의해 사용자 메시지가 입력되면(S508), 입력된 메시지 해당하는 문장에 대해 슬롯 필링을 수행할 대상 슬롯에 매핑된 엔티티의 동의어들과 동의어 매칭을 수행할 수 있다(S510).Then, when a user message is input by the user's speech (S508), synonym matching with the synonyms of the entity mapped to the target slot for which slot filling is to be performed may be performed on a sentence corresponding to the input message (S510). .

이 후, 엔티티 동의어 매칭에 의해 추출되는 슬롯 값이 존재하는지 여부를 판단하고(S512), 단계(S512)의 판단결과 엔티티 동의어 매칭에 의해 추출되는 슬롯 값이 존재하면, action validation을 수행하여 슬롯 값에 대한 검증을 수행한 뒤(S522) 검증이 성공하면 다음 블록 컴포넌트를 실행할 수 있다.Thereafter, it is determined whether a slot value extracted by entity synonym matching exists (S512), and if the slot value extracted by entity synonym matching exists as a result of the determination in step S512, action validation is performed to determine the slot value After verifying (S522), if the verification succeeds, the next block component can be executed.

이 때, 단계(S512)의 판단결과 엔티티 동의어 매칭에 실패하여 엔티티 동의어 매칭에 의해 추출되는 슬롯 값이 존재하지 않으면, 실행블록에 선언된 인텐트들(block intent)을 기반으로 슬롯 값을 추출할 수 있다(S514).At this time, as a result of the determination in step S512, if the entity synonym matching fails and the slot value extracted by the entity synonym matching does not exist, the slot value is extracted based on the block intents declared in the execution block. It can (S514).

즉, 실행블록에 선언된 인텐트들이 포함하는 슬롯들을 기반으로 슬롯 값을 추출할 수 있다. That is, a slot value can be extracted based on slots included in intents declared in an execution block.

이 후, 실행블록에 선언된 인텐트들(block intent)을 기반으로 추출되는 슬롯 값이 존재하는지 여부를 판단하고(S516), 단계(S516)의 판단결과 실행블록에 선언된 인텐트들(block intent)을 기반으로 추출되는 슬롯 값이 존재하면, action validation을 수행하여 슬롯 값에 대한 검증을 수행한 뒤(S522) 검증이 성공하면 다음 블록 컴포넌트를 실행할 수 있다.Thereafter, it is determined whether the extracted slot value exists based on the intents declared in the execution block (block intent) (S516), and as a result of the determination in step S516, the intents declared in the execution block (block intent) are determined. If there is a slot value extracted based on intent), action validation is performed to verify the slot value (S522), and if the validation succeeds, the next block component can be executed.

이 때, 단계(S516)의 판단결과 실행블록에 선언된 인텐트들(block intent)을 사용한 추출이 실패하여 실행블록에 선언된 인텐트들(block intent)을 기반으로 추출되는 슬롯 값이 존재하지 않으면, 대상 슬롯의 인텐트 매핑 정보를 사용하여 슬롯 값을 추출할 수 있다(S518).At this time, as a result of the determination in step S516, the extraction using the block intents declared in the execution block fails, so the slot value extracted based on the block intents declared in the execution block does not exist. Otherwise, a slot value may be extracted using intent mapping information of the target slot (S518).

이 후, 인텐트 매핑 정보를 이용해 추출되는 슬롯 값이 존재하는지 여부를 판단하고(S520), 단계(S520)의 판단결과 인텐트 매핑 정보를 이용해 추출되는 슬롯 값이 존재하면, action validation을 수행하여 슬롯 값에 대한 검증을 수행한 뒤(S522) 검증이 성공하면 다음 블록 컴포넌트를 실행할 수 있다.Thereafter, it is determined whether a slot value extracted using the intent mapping information exists (S520), and if a slot value extracted using the intent mapping information exists as a result of the determination in step S520, action validation is performed to After verifying the slot value (S522), if the verification succeeds, the next block component can be executed.

이 때, 단계(S520)의 판단결과 인텐트 매핑 정보를 이용한 추출이 실패하여 대상 슬롯의 슬롯 값을 채울 수 없다면, 슬롯 필링 재시도 여부를 판단할 수 있다(S524).At this time, as a result of the determination in step S520, if the extraction using the intent mapping information fails and the slot value of the target slot cannot be filled, it may be determined whether to retry slot filling (S524).

단계(S524)의 판단결과 슬롯 필링을 재시도할 수 있으면, 사용자에게 재시도를 안내하여 다시 입력할 것을 요청하고(S526), 단계(S504)부터 다시 수행할 수 있다. As a result of the determination in step S524, if slot filling can be retried, the user is guided to retry and requested to input again (S526), and the process can be performed again from step S504.

이 때, 단계(S524)의 판단결과 재시도 횟수를 초과하였거나 재시도 불가능한 경우에는 슬롯 필링이 실패한 것으로 처리할 수 있다.At this time, as a result of the determination in step S524, if the number of retries is exceeded or retries are impossible, it may be treated as failure of slot filling.

또한, 본 발명의 일실시예에 따르면, 대상 슬롯에 대한 슬롯 값이 채워지고 단계(S522)에 상응하게 action validation을 수행하였으나 슬롯 값에 대한 검증이 실패하는 경우에도 슬롯 필링 재시도 여부를 판단할 수 있다(S528).In addition, according to one embodiment of the present invention, even if the slot value for the target slot is filled and action validation is performed in accordance with step S522, but validation of the slot value fails, whether to retry slot filling can be determined. It can (S528).

단계(S528)의 판단결과 슬롯 필링을 재시도할 수 있으면, 재시도를 안내하여 다시 입력할 것을 요청하고(S530), 단계(S504)부터 다시 수행할 수 있다. As a result of the determination in step S528, if the slot filling can be retried, a retry is guided and re-input is requested (S530), and the process can be performed again from step S504.

이 때, 단계(S528)의 판단결과 재시도 횟수를 초과하였거나 재시도 불가능한 경우에는 슬롯 필링이 실패한 것으로 처리할 수 있다.At this time, as a result of the determination in step S528, if the number of retries is exceeded or retries are impossible, it may be treated as failure of slot filling.

또한, 도 1에는 도시하지 아니하였으나, 본 발명의 일실시예에 따른 슬롯 필링 기반의 챗봇 서비스 제공 방법은 실행블록이 포함되는 시나리오를 고려하여 슬롯 컨텍스트를 유지하기 위한 슬롯 재사용 설정을 수행할 수 있다. In addition, although not shown in FIG. 1, the method for providing a chatbot service based on slot filling according to an embodiment of the present invention may perform slot reuse setting to maintain a slot context in consideration of a scenario including an execution block. .

즉, 사용자가 발화했을 때, 실행되는 블록에 연결된 슬롯의 재사용 설정 정보에 따라 해당 슬롯의 슬롯 값을 재사용할지 또는 새로 입력 받을지를 결정할 수 있다.That is, when a user speaks, it is possible to determine whether to reuse a slot value of a corresponding slot or to receive a new input according to reuse setting information of a slot connected to a block to be executed.

이 때, 슬롯 재사용 설정은 시나리오의 종류에 따른 다양한 상황을 고려하여 수행될 수 있다. At this time, slot reuse configuration may be performed in consideration of various situations according to the type of scenario.

예를 들어, '커피 주문'시나리오의 경우에는 시나리오가 종료되어 커피 주문을 위한 슬롯 값을 모두 입력한 이후, '커피 주문 변경'시나리오가 동작할 수도 있다. 이러한 경우에는 '커피 주문 변경'시나리오를 실행하면서 슬롯 필링을 위해 처음부터 다시 질문하도록 하기 위해 슬롯 재사용을 설정하지 않아야 한다. For example, in the case of the 'coffee order' scenario, the 'coffee order change' scenario may operate after the scenario ends and all slot values for the coffee order are input. In this case, you shouldn't set up slot reuse to run the 'coffee order change' scenario and ask again from the beginning for slot filling.

상세한 예를 들어 설명하면, '커피 주문'시나리오에서는 먼저 사용자의 "커피 주세요"라는 발화가 수신되면, 챗봇이 "무슨 커피 드릴까요?"라고 응답할 수 있다.As a detailed example, in the 'coffee order' scenario, when a user's utterance "coffee please" is first received, the chatbot may respond with "what kind of coffee would you like?"

이 후, 사용자로부터 "{아메리카노:coffee} 주세요"라는 발화가 수신되면, 챗봇이 "따뜻하게 드릴까요? 아이스로 드릴까요?"라고 응답할 수 있다. Thereafter, when the user says "{Americano:coffee} please" is received, the chatbot may respond with "Would you like it warm or iced?"

이 후, 사용자로부터 "{아이스:hotice}로 주세요"라는 발화가 수신되면, 챗봇이 "드시고 가실 건가요?"라고 응답할 수 있다. Thereafter, when a utterance "Please give me {ice:hotice}" is received from the user, the chatbot may respond with "Do you want to eat and go?"

이 후, 사용자로부터 "{테이크아웃:takeout}이요"라는 발화가 수신되면, 챗봇이 각 슬롯들($coffee, $hotice, $takeout)에 입력된 슬롯 값을 이용하여 "아이스 아메리카노 테이크아웃 주문되었습니다"라고 주문을 확인하는 발화를 실행하면서 '커피 주문'시나리오가 종료될 수 있다. After that, when the user says "{Takeout: takeout}", the chatbot uses the slot values entered in each slot ($coffee, $hotice, $takeout) to say "Iced Americano takeout has been ordered. ', the 'coffee order' scenario may end by executing the utterance confirming the order.

이 때 만약, 각 슬롯들($coffee, $hotice, $takeout)에 대해 슬롯 재사용 설정이 되어있고, 사용자로부터 "{라떼:coffee}로 변경할게요"라는 발화가 수신되었다고 가정한다면, '커피 주문 변경'시나리오에서는 사용자가 말하지 않은 슬롯들인 $hotice와 $takeout의 슬롯 값이 유지되어서, 챗봇이 "아이스 라떼 테이크아웃으로 변경되었습니다"라고 바로 응답할 수 있다. At this time, assuming that slot reuse is set for each slot ($coffee, $hotice, $takeout) and a user says "I'll change it to {latte:coffee}" is received, 'change coffee order' In the 'scenario, the slot values of $hotice and $takeout, which are slots that the user did not say, are maintained, so the chatbot can immediately respond with "Iced Latte Takeout".

즉, 이러한 경우에는 $hotice와 $takeout의 슬롯 값에 대해서도 다시 슬롯 필링이 수행되어야 하므로, 슬롯을 재사용하지 않도록 설정할 수 있다.That is, in this case, since slot filling must be performed again for the slot values of $hotice and $takeout, slots can be configured not to be reused.

따라서, 각 슬롯들($coffee, $hotice, $takeout)에 대해 슬롯 재사용 설정이 되어있지 않고, 상기와 같은 주문 이후에 다시 사용자로부터 "{카푸치노:coffee} 주세요"라는 발화가 수신되었다면, 사용자가 말하지 않은 슬롯들인 $hotice와 $takeout의 슬롯 값을 초기화되어 지워지고, 지워진 슬롯 값들을 다시 채우기 위해 챗봇이 사용자에게 질문할 수 있다. Therefore, if slot reuse is not set for each of the slots ($coffee, $hotice, $takeout), and the utterance "{cappuccino:coffee} please" is received from the user again after the above order, the user The slot values of $hotice and $takeout, which are unspoken slots, are initialized and deleted, and the chatbot can ask the user to refill the deleted slot values.

종래에는 슬롯 컨텍스트를 유지하기 위해 인텐트 단위 별로 input, output 속성을 설정하고, 앞/뒤 인텐트마다 매번 설정된 값을 관리해주어야 했기 때문에 시나리오에 따라 슬롯 컨텍스트 유지 여부가 변경되는 경우에는 관리가 어려운 문제가 있었다. In the past, input and output properties had to be set for each intent unit to maintain the slot context, and the set value had to be managed for each previous/next intent, so it is difficult to manage if the slot context is maintained or not depending on the scenario. there was

본 발명에서는 슬롯 재사용 설정을 통해 이러한 문제점을 해결하고, 보다 효과적으로 이전 인텐트에 의한 컨텍스트를 유지할 수 있다. In the present invention, this problem can be solved through slot reuse configuration, and the context by the previous intent can be maintained more effectively.

이 때, 슬롯 재사용 설정이 수행된 실행블록과 연결된 인텐트들의 슬롯들은 시나리오가 종료된 후 다시 실행했을 때에도 슬롯 값이 삭제되지 않을 수 있다. In this case, the slot values of the intents connected to the execution block for which the slot reuse setting is performed may not be deleted even when the scenario is executed again after the end.

예를 들어, 본 발명에 따르면 사용자 대화에 상응하게 매핑된 인텐트로부터 슬롯을 추출할 때에 슬롯 재사용 설정되어 있는 슬롯들의 경우, 사용자가 말하지 않은 슬롯이라면 이미 채워진 슬롯 값을 삭제하지 않고 기억하고 있다가 처리할 수 있다. 이 때, 시나리오가 종료된 이후에도 슬롯 컨텍스트를 유지해야 하므로 컨텍스트에 존재하는 슬롯 값들은 여전히 삭제하지 않고 계속 유지할 수 있다. For example, according to the present invention, in the case of slots in which slot reuse is set when extracting slots from intents mapped to correspond to user conversations, if the slots are not spoken by the user, the already filled slot values are stored in memory without deleting them. can be dealt with In this case, since the slot context needs to be maintained even after the scenario ends, slot values existing in the context can be maintained without being deleted.

또한, 슬롯 재사용이 설정되지 않은 슬롯들은, 사용자 대화에 상응하게 매핑된 인텐트로부터 슬롯을 추출할 때에 사용자가 말하지 않은 슬롯이라면 슬롯 값을 초기화 시킬 수도 있다.Also, for slots for which slot reuse is not set, when extracting a slot from an intent mapped to a user conversation, the slot value may be initialized if the user did not speak.

이와 같은 처리 과정을 통해 별도의 input, output 속성을 관리하지 않고도 컨텍스트를 유지할 수 있으므로, 챗봇 서버에 부담을 주지 않으면서 효율적으로 서비스를 제공할 수 있다. Through this processing process, the context can be maintained without managing separate input and output properties, so the service can be provided efficiently without burdening the chatbot server.

이 때, 슬롯에 설정된 조건을 고려하여 필요한 경우에는 어사인(assign) 액션이나 리셋(reset) 액션 등을 이용하여 슬롯 값을 직접 변경할 수도 있다.In this case, the slot value may be directly changed by using an assign action or a reset action, if necessary, in consideration of conditions set in the slot.

또한, 본 발명의 일실시예에 따른 슬롯 필링 기반의 챗봇 서비스 제공 방법은 슬롯 필링에 기반하여 인텐트에 상응하는 대화 처리를 수행한다(S140).In addition, the method for providing a chatbot service based on slot filling according to an embodiment of the present invention performs conversation processing corresponding to an intent based on slot filling (S140).

이와 같이 본 발명은, 인텐트에서는 슬롯 정보를 자연어 처리 관점에서 필요한 정보 위주로만 정의하고, 기능을 실행하는데 필요한 슬롯 필링 정보는 실행블록에서 정의하도록 분리함으로써 동일한 슬롯이 사용되는 다른 실행블록들이 각각의 실행블록에 정의된 슬롯 필링 정보에 따라 다르게 동작할 수 있다. As such, the present invention defines slot information mainly in the intent from the viewpoint of natural language processing, and divides the slot filling information necessary to execute the function to be defined in the execution block, so that different execution blocks using the same slot are each It can operate differently according to the slot filling information defined in the execution block.

즉, 인텐트에서 정의된 슬롯 정보는 완전히 픽스(fix)된 것이 아니라 디폴트(default) 설정 정도의 의미일 수 있으며, 실행블록에 의해 재정의 될 수 있는 개념에 상응할 수 있다. That is, the slot information defined in the intent may not be completely fixed, but may have a meaning of a default setting, and may correspond to a concept that may be redefined by an execution block.

상술한 구성에 의하여, 본 발명의 일실시예에 따른 챗봇 서비스 제공 방법은 동일한 인텐트가 서로 다른 실행블록에서 사용되는 경우에 실행블록에 정의된 슬롯 필링을 기반으로 다르게 동작하도록 설정함으로써 다양한 사용자 대화 패턴에 대해 챗봇이 효과적으로 대응하도록 할 수 있다. According to the configuration described above, the method for providing a chatbot service according to an embodiment of the present invention sets various user conversations by setting the same intent to operate differently based on the slot filling defined in the execution block when used in different execution blocks. You can make chatbots respond effectively to patterns.

또한, 본 발명의 일실시예에 따른 챗봇 서비스 제공 방법은 하나의 슬롯에 매핑된 여러 개의 엔티티들을 이용하여 인텐트에 존재하는 슬롯뿐만 아니라 전혀 새로운 슬롯에 대한 슬롯 필링을 수행할 수 있고, 이를 통해 사용자가 처음부터 말하기 어려운 정보나 대화를 진행하면서 추가된 정보들에 대해서도 슬롯 필링이 가능하게 할 수 있다.In addition, the method for providing a chatbot service according to an embodiment of the present invention can perform slot filling not only for a slot existing in an intent but also for an entirely new slot using several entities mapped to one slot. Slot filling may also be enabled for information that is difficult for the user to say from the beginning or information that is added while having a conversation.

또한, 본 발명의 일실시예에 따른 챗봇 서비스 제공 방법은 슬롯 재사용 기능을 제공함으로써 컨텍스트 흐름을 유지하기 위한 과정을 간소화하고, 컨텍스트 흐름 유지를 위해 설정되는 슬롯 값들을 보다 효과적으로 관리할 수 있다.In addition, the chatbot service providing method according to an embodiment of the present invention simplifies the process of maintaining the context flow by providing a slot reuse function, and can more effectively manage slot values set for maintaining the context flow.

도 6은 본 발명의 일실시예에 따른 챗봇 서비스 제공 장치를 나타낸 블록도이다.6 is a block diagram showing a chatbot service providing apparatus according to an embodiment of the present invention.

도 6을 참조하면, 본 발명의 일실시예에 따른 챗봇 서비스 제공 장치는, 프로세서(620) 및 실행메모리(630)를 포함한다. 실시예에 따라, 챗봇 서비스 제공 장치는 통신부(610)를 더 포함할 수 있다.Referring to FIG. 6 , an apparatus for providing a chatbot service according to an embodiment of the present invention includes a processor 620 and an execution memory 630. According to the embodiment, the chatbot service providing device may further include a communication unit 610 .

통신부(610)는 네트워크와 같은 통신망을 통해 다수의 다른 장치들과 챗봇 서비스와 관련된 정보를 송신하는 역할을 할 수 있다. 이 때, 네트워크는 장치들간에 데이터를 전달하는 통로를 제공하는 것으로서, 기존에 이용되는 네트워크 및 향후 개발 가능한 네트워크를 모두 포괄하는 개념이다.The communication unit 610 may serve to transmit information related to a chatbot service with a plurality of other devices through a communication network such as a network. At this time, the network provides a path for transferring data between devices, and is a concept encompassing both existing networks and networks that can be developed in the future.

예를 들면, 네트워크는 인터넷 프로토콜(IP)을 통하여 대용량 데이터의 송수신 서비스 및 끊기는 현상이 없는 데이터 서비스를 제공하는 아이피망, 아이피를 기반으로 서로 다른 망을 통합한 아이피망 구조인 올 아이피(All IP)망 등일 수 있으며, 유선망, Wibro(Wireless Broadband)망, WCDMA를 포함하는 3세대 이동통신망, HSDPA(High Speed Downlink Packet Access)망 및 LTE 망을 포함하는 3.5세대 이동통신망, LTE advanced를 포함하는 4세대 이동통신망, 위성통신망 및 와이파이(Wi-Fi)망 중에서 하나 이상을 결합하여 이루어질 수 있다.For example, the network is an IP network that provides large data transmission and reception services and data services without disconnection through the Internet Protocol (IP), and All IP, an IP network structure that integrates different networks based on IP. ) network, and can be a wired network, Wibro (Wireless Broadband) network, 3G mobile communication network including WCDMA, 3.5G mobile communication network including HSDPA (High Speed Downlink Packet Access) network and LTE network, 4 including LTE advanced It may be achieved by combining one or more of a household mobile communication network, a satellite communication network, and a Wi-Fi network.

예를 들어, 네트워크는 한정된 지역 내에서 각종 정보장치들의 통신을 제공하는 유무선근거리 통신망, 이동체 상호 간 및 이동체와 이동체 외부와의 통신을 제공하는 이동통신망, 위성을 이용해 지구국과 지구국간 통신을 제공하는 위성통신망이거나 유무선 통신망 중에서 어느 하나이거나, 둘 이상의 결합으로 이루어질 수 있다. 한편, 네트워크의 전송 방식 표준은, 기존의 전송 방식 표준에 한정되는 것은 아니며, 향후 개발될 모든 전송 방식 표준을 포함할 수 있다.For example, the network includes a wired and wireless local area network that provides communication between various information devices within a limited area, a mobile communication network that provides communication between mobile bodies and between mobile bodies and the outside of the mobile body, and a satellite that provides communication between earth stations and earth stations. It may be a satellite communication network or any one of wired and wireless communication networks, or a combination of two or more. Meanwhile, the transmission method standards of the network are not limited to existing transmission method standards, and may include all transmission method standards to be developed in the future.

실행메모리(630)는 프로세서(620)에 의해 실행되는 적어도 하나 이상의 프로그램을 저장한다.The execution memory 630 stores one or more programs executed by the processor 620 .

이 때, 적어도 하나의 프로그램은 사용자 대화에 상응하는 인텐트를 결정하고, 인텐트 매핑 리스트를 이용하여 인텐트에 상응하는 실행블록을 선택하고, 실행블록에 상응하는 슬롯 필링을 수행하고, 슬롯 필링에 기반하여 인텐트에 상응하는 대화 처리를 수행한다.At this time, at least one program determines an intent corresponding to the user dialogue, selects an execution block corresponding to the intent using the intent mapping list, performs slot filling corresponding to the execution block, and performs slot filling. Based on this, conversation processing corresponding to the intent is performed.

이 때, 인텐트 매핑 리스트는 실행블록들 각각을 위하여 구비되고, 적어도 하나 이상의 인텐트에 상응할 수 있다.In this case, the intent mapping list is provided for each of the execution blocks and may correspond to at least one or more intents.

이 때, 상기 적어도 하나 이상의 프로그램은 슬롯에 매핑된 엔티티, 상기 실행블록에 상응하는 슬롯들 및 슬롯의 인텐트 매핑 정보 중 적어도 하나를 기반으로 슬롯 필링을 수행할 수 있다.In this case, the at least one program may perform slot filling based on at least one of an entity mapped to a slot, slots corresponding to the execution block, and intent mapping information of the slot.

이 때, 인텐트 매핑 정보는 슬롯에 매핑된 인텐트 이름, 슬롯에 매핑된 인텐트의 슬롯 이름, 슬롯에 매핑된 인텐트의 슬롯 값 및 슬롯에 매핑된 인텐트의 슬롯 값에 의한 결과 값 중 적어도 하나를 포함할 수 있다.In this case, the intent mapping information is selected from among result values of the intent name mapped to the slot, the slot name of the intent mapped to the slot, the slot value of the intent mapped to the slot, and the slot value of the intent mapped to the slot. may contain at least one.

이 때, 실행블록에 상응하는 슬롯들은 상기 인텐트 매핑 리스트를 통해 상기 실행블록과 연결된 인텐트들의 슬롯들을 포함할 수 있다.In this case, slots corresponding to the execution block may include slots of intents connected to the execution block through the intent mapping list.

이 때, 상기 적어도 하나 이상의 프로그램은 상기 슬롯에 매핑된 엔티티에 대한 동의어 매칭을 수행하여 슬롯 값을 추출할 수 있다.In this case, the at least one program may extract a slot value by performing synonym matching on an entity mapped to the slot.

이 때, 하나의 슬롯은 복수개의 엔티티들과 매핑 가능할 수 있다.In this case, one slot may be mappable with a plurality of entities.

이 때, 상기 적어도 하나 이상의 프로그램은 실행블록이 포함되는 시나리오를 고려하여 슬롯 컨텍스트를 유지하기 위한 슬롯 재사용 설정을 수행할 수 있다.At this time, the at least one or more programs may perform slot reuse configuration for maintaining a slot context in consideration of a scenario including an execution block.

이 때, 슬롯 재사용 설정이 수행된 실행블록과 연결된 인텐트들의 슬롯들은 상기 시나리오가 종료된 후 다시 실행했을 때에도 슬롯 값이 삭제되지 않을 수 있다.In this case, the slot values of the intents connected to the execution block for which the slot reuse setting is performed may not be deleted even when the scenario is executed again after the end of the scenario.

이 때, 인텐트 매핑 리스트는 인텐트별로 인텐트 식별자 및 슬롯 조건을 포함할 수 있다.In this case, the intent mapping list may include an intent identifier and a slot condition for each intent.

도 6에 도시된 장치는 숫자 및 문자 정보 등의 다양한 정보를 입력 받고, 각종 기능을 설정 및 장치의 기능 제어와 관련하여 입력되는 신호를 입력부를 통해 프로세서(620)로 전달할 수 있다. 또한, 입력부는 사용자의 터치 또는 조작에 따른 입력 신호를 발생하는 키패드와 터치패드 중 적어도 하나를 포함하여 구성할 수 있다. 이 때, 장치의 입력부는 표시부와 함께 하나의 터치패널(또는 터치 스크린(touch screen))의 형태로 구성되어 입력과 표시 기능을 동시에 수행할 수 있다. 또한, 입력부는 키보드, 키패드, 마우스, 조이스틱 등과 같은 입력 장치 외에도 향후 개발될 수 있는 모든 형태의 입력 수단이 사용될 수 있다.The device shown in FIG. 6 may receive various types of information such as numbers and text information, and transmit input signals to the processor 620 through an input unit in relation to setting various functions and controlling functions of the device. In addition, the input unit may include at least one of a keypad and a touchpad that generate an input signal according to a user's touch or manipulation. At this time, the input unit of the device is configured in the form of a single touch panel (or touch screen) together with the display unit to simultaneously perform input and display functions. In addition, the input unit may use any type of input means that may be developed in the future, in addition to input devices such as a keyboard, keypad, mouse, joystick, and the like.

또한, 표시부는 장치의 기능 수행 중에 발생하는 일련의 동작상태 및 동작결과 등에 대한 정보를 표시할 수 있다. 또한, 표시부는 장치의 메뉴 및 사용자가 입력한 사용자 데이터 등을 표시할 수 있다. 여기서, 표시부는 액정표시장치(LCD, Liquid Crystal Display), 초박막 액정표시장치(TFT-LCD, Thin Film Transistor LCD), 발광다이오드(LED, Light Emitting Diode), 유기 발광다이오드(OLED, Organic LED), 능동형 유기발광다이오드(AMOLED, Active Matrix OLED), 레티나 디스플레이(Retina Display), 플렉시블 디스플레이(Flexible display) 및 3차원(3Dimension) 디스플레이 등으로 구성될 수 있다. 이 때, 표시부가 터치스크린 형태로 구성된 경우, 표시부는 입력부의 기능 중 일부 또는 전부를 수행할 수 있다.In addition, the display unit may display information about a series of operation states and operation results that occur while performing functions of the device. Also, the display unit may display menus of the device and user data input by the user. Here, the display unit includes a liquid crystal display (LCD), a thin film transistor LCD (TFT-LCD), a light emitting diode (LED), an organic light emitting diode (OLED), It can be composed of an active organic light emitting diode (AMOLED, Active Matrix OLED), a Retina Display, a flexible display, and a 3D display. At this time, when the display unit is configured in the form of a touch screen, the display unit may perform some or all of the functions of the input unit.

또한, 장치의 저장부는 데이터를 저장하기 위한 장치로, 주 기억장치 및 보조 기억장치를 포함하고, 장치의 기능 동작에 필요한 응용 프로그램을 저장할 수 있다. 이러한 저장부는 크게 프로그램 영역과 데이터 영역을 포함할 수 있다. 여기서, 장치는 사용자의 요청에 상응하여 각 기능을 활성화하는 경우, 프로세서(620)의 제어 하에 해당 응용 프로그램들을 실행하여 각 기능을 제공하게 된다.In addition, the storage unit of the device is a device for storing data, includes a main memory device and an auxiliary memory device, and may store application programs required for functional operation of the device. This storage unit may largely include a program area and a data area. Here, when the device activates each function in response to a user's request, the corresponding application programs are executed under the control of the processor 620 to provide each function.

또한, 통신부(610)는 네트워크을 통해 데이터를 송수신하기 위한 기능을 수행할 수 있다. 여기서 통신부(610)는 송신되는 신호의 주파수를 상승 변환 및 증폭하는 RF 송신 수단과 수신되는 신호를 저잡음 증폭하고 주파수를 하강 변환하는 RF 수신 수단 등을 포함할 수 있다. 이러한 통신부(1810)는 무선통신 모듈 및 유선 통신 모듈 중 적어도 하나를 포함할 수 있다. 그리고, 무선통신 모듈은 무선 통신 방법에 따라 데이터를 송수신하기 위한 구성이며, 장치가 무선 통신을 이용하는 경우, 무선망 통신 모듈, 무선랜 통신 모듈 및 무선팬 통신 모듈 중 어느 하나를 이용하여 데이터를 장치로 송수신할 수 있다. 또한, 유선통신 모듈은 유선으로 데이터를 송수신하기 위한 것이다. 유선통신 모듈은 유선을 통해 네트워크에 접속하여, 장치에 데이터를 송수신할 수 있다. 즉 장치는 무선통신 모듈 또는 유선통신 모듈을 이용하여 네트워크에 접속하며, 네트워크을 통해 다른 장치와 데이터를 송수신할 수 있다.In addition, the communication unit 610 may perform a function for transmitting and receiving data through a network. Here, the communication unit 610 may include an RF transmitter for up-converting and amplifying the frequency of a transmitted signal, and an RF receiver for low-noise amplifying a received signal and down-converting the frequency. The communication unit 1810 may include at least one of a wireless communication module and a wired communication module. And, the wireless communication module is a component for transmitting and receiving data according to a wireless communication method, and when the device uses wireless communication, data is transmitted using any one of a wireless network communication module, a wireless LAN communication module, and a wireless fan communication module. can be sent and received. In addition, the wired communication module is for transmitting and receiving data by wire. The wired communication module may access a network through a wire and transmit/receive data to and from the device. That is, the device accesses the network using a wireless communication module or a wired communication module, and can transmit/receive data with other devices through the network.

또한, 프로세서(620)는 운영 체제(OS, Operation System) 및 각 구성을 구동시키는 프로세스 장치가 될 수 있다.In addition, the processor 620 may be a process device that drives an operating system (OS) and each component.

상술한 구성에 의하여, 본 발명의 일실시예에 따른 슬롯 필링 기반의 챗봇 서비스 제공 장치는 동일한 인텐트가 서로 다른 실행블록에서 사용되는 경우에 실행블록에 정의된 슬롯 필링을 기반으로 다르게 동작하도록 설정함으로써 다양한 사용자 대화 패턴에 대해 챗봇이 효과적으로 대응할 수 있다.According to the configuration described above, the slot filling-based chatbot service providing apparatus according to an embodiment of the present invention is set to operate differently based on the slot filling defined in the execution block when the same intent is used in different execution blocks By doing so, the chatbot can effectively respond to various user conversation patterns.

또한, 본 발명의 일실시예에 따른 슬롯 필링 기반의 챗봇 서비스 제공 장치는 하나의 슬롯에 매핑된 여러 개의 엔티티들을 이용하여 인텐트에 존재하는 슬롯뿐만 아니라 전혀 새로운 슬롯에 대한 슬롯 필링을 수행할 수 있고, 이를 통해 사용자가 처음부터 말하기 어려운 정보나 대화를 진행하면서 추가된 정보들에 대해서도 슬롯 필링이 가능하게 할 수 있다.In addition, an apparatus for providing a chatbot service based on slot filling according to an embodiment of the present invention can perform slot filling not only for a slot existing in an intent but also for a completely new slot using several entities mapped to one slot. Through this, slot filling can be made possible for information that is difficult for the user to say from the beginning or information that is added while having a conversation.

또한, 본 발명의 일실시예에 따른 슬롯 필링 기반의 챗봇 서비스 제공 장치는 슬롯 재사용 기능을 제공함으로써 컨텍스트 흐름을 유지하기 위한 과정을 간소화하고, 컨텍스트 흐름 유지를 위해 설정되는 슬롯 값들을 보다 효과적으로 관리할 수 있다.In addition, the apparatus for providing a chatbot service based on slot filling according to an embodiment of the present invention simplifies the process of maintaining the context flow by providing a slot reuse function, and more effectively manages slot values set for maintaining the context flow. can

또한, 본 발명은 대화형 AI 에이전트 시스템에 의해 수행되는 자연어 처리에 따라 자연어의 입력에 대응하는 인텐트를 유사한 속성에 따라 분류하고, 분류된 복수의 인텐트들을 봇의 처리 단위인 블록에 매핑하는 기술에 관한 것이다.In addition, according to the present invention, according to natural language processing performed by a conversational AI agent system, intents corresponding to natural language inputs are classified according to similar properties, and a plurality of classified intents are mapped to a block, which is a processing unit of a bot. It's about technology.

유용한 챗봇 서비스를 위해서는 사업이나 서비스 도메인별 용어들에 대한 자연어 처리 능력 및 제공되는 기능이나 업무에 대한 처리 능력을 지속적으로 향상시킬 필요가 있다.For a useful chatbot service, it is necessary to continuously improve the ability to process natural language for terms by business or service domain and the processing ability for provided functions or tasks.

이를 위해, 다양한 도메인별 용어들과 문장들이 자연어 처리기에 의하여 처리될 수 있도록 자연어 처리기를 학습시킬 필요가 있는데, 이 때 자연어 처리기에서 유사 발화들 간의 충돌이 발생하지 않도록 인텐트들을 분류해야 한다. 즉, 기능이나 업무 단위로만 인텐트를 정의하는 것이 아니라 자연어 처리(Natural Language Understanding; NLU)의 관점에서의 인텐트 정의가 필요한 것이다.To this end, it is necessary to train the natural language processor so that various domain-specific terms and sentences can be processed by the natural language processor. At this time, the natural language processor needs to classify intents so that collisions between similar utterances do not occur. In other words, it is necessary to define intent from the perspective of Natural Language Understanding (NLU), rather than defining intent only by function or task.

한편, 기능이나 업무에 대한 처리가 효과적으로 이루어지기 위해서는 세부 처리 단계나 흐름이 실행블록들로 정의되어야 하고, 정의된 실행블록들의 연결관계(선후관계)가 정의될 필요가 있다. 이 때, 연결관계는 리스트나 트리 형태보다는 여러 실행블록들을 자유롭게 연결하기 위한 그래프 형태로 정의되는 것이 바람직하다. 이 때, 실행블록들은 자연어 처리의 관점보다는 서비스가 제공하는 기능에 적합하게 정의되는 것이 바람직하다.On the other hand, in order to efficiently process functions or tasks, detailed processing steps or flows need to be defined as execution blocks, and a connection (order relationship) between the defined execution blocks needs to be defined. At this time, it is preferable that the connection relationship be defined in the form of a graph for freely connecting various execution blocks rather than in the form of a list or tree. At this time, it is preferable that the execution blocks are defined to suit the function provided by the service rather than from the perspective of natural language processing.

이와 같이, 각각의 목적에 맞게 적합한 형태로 정의된 인텐트들과 블록들을 자유롭게(N:N) 맵핑할 수 있어야, 사용자의 의도에 부합하는 챗봇 서비스를 효율적으로 제공할 수 있다. 즉, 인텐트 하나가 여러 블록에 쓰일 수 있고, 또 블록 하나가 여러 인텐트들을 처리할 수 있어야 하고, 이를 위해서는 인텐트들과 블록들이 1:1 매핑이 아닌 N: N으로 매핑될 수 있어야 한다.In this way, it is necessary to be able to freely (N:N) map intents and blocks defined in a form suitable for each purpose in order to efficiently provide a chatbot service that meets the user's intention. In other words, one intent can be written to several blocks, and one block must be able to handle multiple intents. To this end, intents and blocks must be mapped N:N rather than 1:1. .

많은 양의 발화 패턴들이 다양한 인 텐트들로 분류된 대량의 데이터를 처리할 때, 유사 발화들 간의 충돌이 발생하고 이에 대한 검증과 처리가 필요하다.When processing a large amount of data in which a large amount of utterance patterns are classified into various intents, collisions between similar utterances occur, which requires verification and processing.

이 때, 유사 발화 패턴들을 같은 인 텐트로 묶고, 슬롯을 기준으로 조건을 주어 서로 다른 봇 응답이 가능하도록 대응할 수 있다.At this time, similar utterance patterns can be grouped into the same intent, and conditions can be given based on slots to enable different bot responses.

또한, 유사 발화는 아니지만, 같은 응답으로 처리 가능할 수 있도록, 하나의 봇 응답 단위(실행블록)에 복수 개의 사용자 발화단위들을 매핑하는 것이 가능하도록 하면, 발화 유형이 다르더라도 같은 응답으로 처리하는 것이 가능하게 되어 효율적인 인텐트 관리가 가능하다.In addition, if it is possible to map a plurality of user speech units to one bot response unit (execution block) so that they can be processed with the same response, even though they are not similar speech, it is possible to process them with the same response even if the speech type is different. This enables efficient intent management.

이하에서, 챗봇 서비스는 사용자의 음성을 기반으로 하는 음성 서비스뿐만 아니라 사용자로부터 입력된 텍스트를 기반으로 하는 메신저 서비스를 커버하는 개념이다.Hereinafter, a chatbot service is a concept covering not only a voice service based on a user's voice but also a messenger service based on text input from a user.

챗봇의 설계 및 구현은, 크게 챗봇 빌더, 자연어 처리(Natural Language Understanding; NLU) 및 대화흐름처리(Dialog Management; DM)의 3부분으로 나눌 수 있다. 이 때, 챗봇 빌더에서는 대화흐름처리(DM)가 동작하기 위한 데이터를 구조화하고 정의하여 이를 제공하고, 대화흐름처리(DM)에서는 이 데이터를 기반으로 봇 대응을 처리한다.Chatbot design and implementation can be largely divided into three parts: chatbot builder, natural language understanding (NLU), and dialog management (DM). At this time, the chatbot builder structures and defines data for the dialog flow processing (DM) to operate and provides it, and the dialog flow processing (DM) processes the bot response based on this data.

챗봇 프로세스가 구동을 위해 크게 두 개의 작업영역이 필요할 수 있는데, 하나는 봇 디자이너가 봇 구동 프로세스를 정의하는 작업영역이고, 다른 하나는 정의된 프로세스를 실행하는 실행영역이다.A chatbot process may require two workspaces to run. One is a workspace where the bot designer defines the bot driving process, and the other is an execution area where the defined process is executed.

도 7은 본 발명의 일실시예에 따른 챗봇 서비스 시스템을 나타낸 블록도이다.7 is a block diagram showing a chatbot service system according to an embodiment of the present invention.

도 7을 참조하면, 챗봇 서비스 시스템은 챗봇(710), 자연어 처리기(720), 챗봇 리소스 데이터베이스(730) 및 챗봇 빌더(740)를 포함한다.Referring to FIG. 7 , the chatbot service system includes a chatbot 710, a natural language processor 720, a chatbot resource database 730, and a chatbot builder 740.

챗봇(710)은 사용자로부터 발화문장을 입력 받고, 이에 대한 응답을 생성하여 사용자에게 챗봇 응답을 제공한다.The chatbot 710 receives a spoken sentence from the user, generates a response thereto, and provides a chatbot response to the user.

자연어 처리기(720)는 챗봇으로부터 발화문장을 제공 받고, 챗봇 리소스 데이터베이스(730)로부터 인텐트 정의 정보를 제공 받아서 인텐트 분류 결과 및 슬롯 추출 결과를 생성하여 챗봇(710)으로 제공한다.The natural language processor 720 receives spoken sentences from the chatbot, receives intent definition information from the chatbot resource database 730, generates intent classification results and slot extraction results, and provides them to the chatbot 710.

챗봇 리소스 데이터베이스(730)는 챗봇 빌더로부터 인텐트 정의 정보, 블록 정보, 응답 정보 및 시나리오 정보 등을 제공 받고, 챗봇(710)으로 블록 정보, 응답 정보 및 시나리오 정보를 제공하고, 자연어 처리기(720)로 인텐트 정의 정보를 제공한다.The chatbot resource database 730 receives intent definition information, block information, response information, and scenario information from the chatbot builder, provides block information, response information, and scenario information to the chatbot 710, and the natural language processor 720 provides intent definition information.

챗봇 빌더(740)는 봇디자이너로부터 챗봇 리소스에 관한 입력을 제공 받고, 챗봇(710)을 생성하고, 챗봇 리소스 데이터베이스(730)로 인텐트 정의 정보, 블록 정보, 응답 정보 및 시나리오 정보 등을 제공한다.The chatbot builder 740 receives input on chatbot resources from the bot designer, creates a chatbot 710, and provides intent definition information, block information, response information, and scenario information to the chatbot resource database 730. .

챗봇 빌더(740)에서 학습 발화문장과 봇 처리의 중요정보인 슬롯(slot)을 인텐트로 정의하고, 정의된 인텐트를 실행블록에 매핑하고 실행블록에서 조건을 설정하고 이에 따른 봇의 액션을 정의할 수 있다. 또한, 챗봇 빌더(740)에서 응답대기상태에서 처리할 수 있는 블록들이 설정되고, 이 블록들이 그래프 형태의 시나리오로 정의될 수 있다.In the chatbot builder 740, learning utterances and slots, which are important information for bot processing, are defined as intents, the defined intents are mapped to execution blocks, conditions are set in the execution blocks, and bot actions are performed accordingly. can be defined In addition, blocks that can be processed in the response waiting state are set in the chatbot builder 740, and these blocks can be defined as graph-type scenarios.

이 때, 봇 디자이너는 챗봇 빌더(740)를 통해 봇 구동 프로세스를 정의하는 작업을 하는데, 먼저 주요 업무처리에 대한 봇 시나리오들이 그래프 형태로 정의된 블록 다이어그램이 제공될 수 있다.At this time, the bot designer works to define the bot driving process through the chatbot builder 740. First, a block diagram in which bot scenarios for major business processes are defined in a graph form may be provided.

도 8은 본 발명의 일실시예에 따른 '커피 주문' 시나리오의 블록 다이어그램을 나타낸 도면이다.8 is a block diagram of a 'coffee order' scenario according to an embodiment of the present invention.

도 8을 참조하면, 커피 주문 챗봇의 블록 발화 시나리오에서는 먼저 사용자의 "커피 주문할게요"라는 발화가 수신된다(811).Referring to FIG. 8 , in the block speech scenario of the coffee ordering chatbot, a user's speech "I will order coffee" is first received (811).

또한, 커피 주문 챗봇의 블록 발화 시나리오에서는 챗봇이 "무슨 커피 드릴까요?"라는 발화를 실행한다(821).In addition, in the block speech scenario of the coffee ordering chatbot, the chatbot executes the speech "What kind of coffee would you like?" (821).

챗봇의 발화에 응답하여, 커피 주문 챗봇의 블록 발화 시나리오에서는 사용자가 원하는 커피 이름을 발화한다(812).In response to the chatbot's utterance, in the coffee ordering chatbot's block utterance scenario, the user's desired coffee name is uttered (812).

사용자의 발화에 응답하여, 커피 주문 챗봇의 블록 발화 시나리오에서는 챗봇이 "따뜻한걸로 드릴까요? 아이스로 드릴까요?"라는 발화를 실행한다(822).In response to the user's utterance, in the block utterance scenario of the coffee ordering chatbot, the chatbot executes the utterance "Would you like something warm or iced?" (822).

챗봇의 발화에 응답하여, 커피 주문 챗봇의 블록 발화 시나리오에서는 사용자가 핫(hot) 또는 아이스(ice)를 선택한다(813).In response to the conversation of the chatbot, the user selects hot or ice in a scenario where the coffee ordering chatbot triggers a block (813).

사용자의 발화에 응답하여, 커피 주문 챗봇의 블록 발화 시나리오에서는 챗봇이 "드시고가실건가요?"라는 발화를 실행한다(823).In response to the user's speech, in the block speech scenario of the coffee ordering chatbot, the chatbot executes the speech "Are you going to eat?" (823).

챗봇의 발화에 응답하여, 커피 주문 챗봇의 블록 발화 시나리오에서는 사용자가 매장식사 또는 테이크아웃을 선택한다(814).In response to the conversation of the chatbot, the user selects in-store dining or takeout in a scenario where the coffee ordering chatbot triggers a block (814).

$(커피이름), $(핫아이스) 및 $(테이크아웃)의 3개 슬롯들이 모두 입력되면, 커피 주문 챗봇의 블록 발화 시나리오에서는 챗봇이 주문을 확인하는 발화를 실행한다(1324).When all three slots of $ (coffee name), $ (hot ice), and $ (takeout) are input, the chatbot executes an utterance to confirm the order in a block utterance scenario of the coffee ordering chatbot (1324).

챗봇의 발화에 응답하여, 커피 주문 챗봇의 블록 발화 시나리오에서는 사용자가 '예'(815) 또는 '아니오'(816)를 발화하고, 사용자가 '예'라고 발화한 경우에는 챗봇이 커피 주문을 실행하는 커스텀 액션(custom action)을 실행하고(825) 주문내용을 확인하는 발화를 실행하고(826), 사용자가 '아니오'라고 발화한 경우에는 챗봇이 "주문을 취소합니다."라는 발화를 실행(827)한 후 동작을 종료한다.In response to the chatbot's utterance, in the coffee ordering chatbot's block firing scenario, the user utters 'yes' (815) or 'no' (816), and if the user utters 'yes', the chatbot executes the coffee order executes a custom action (825) and executes an utterance to confirm the order (826), and if the user utters 'No', the chatbot executes the utterance "Cancel the order" ( 827), and then the operation ends.

도 8에서 "User"는 사용자의 발화를 나타내고, "templete"는 챗봇의 발화를 나타내고, "Custom Action"은 실행블록에 의하여 정의된 봇의 동작 처리를 나타낸다.In FIG. 8 , "User" represents a user's utterance, "templete" represents a chatbot's utterance, and "Custom Action" represents a bot action process defined by an execution block.

도 8에 도시된 예에서, $(커피이름), $(핫아이스), $(테이크아웃) 및 $(주문번호)는 필수 슬롯에 해당하고, 도 8에는 명시적으로 도시되지 아니하였으나, 커피 주문 챗봇의 블록 발화 시나리오에서는 옵션슬롯이 더 사용될 수 있다. 이 때, 필수 슬롯 및/또는 옵션 슬롯은 사용자의 발화로부터 생성된 것일 수도 있고, 기타 챗봇 시스템의 상태를 나타내는 슬롯이거나 블록에서 조건에 따라 생성된 것일 수도 있다.In the example shown in FIG. 8, $ (coffee name), $ (hot ice), $ (takeout), and $ (order number) correspond to required slots, and although not explicitly shown in FIG. 8, coffee Option slots may be further used in the block firing scenario of the ordering chatbot. In this case, the required slot and/or the optional slot may be generated from the user's speech, or may be slots indicating the status of other chatbot systems or generated according to conditions in the block.

도 8에 도시된 바와 같은 다이어그램을 토대로 각 블록에서 처리할 수 있는 모든 발화 패턴들을 수집하고, 자연어 처리기가 분류하기 용이한 형태로 패턴들을 그룹핑할 수 있다. 또한, 그룹핑된 정보를 기준으로 인텐트가 분류되고 발화 패턴별로 슬롯을 태깅하여 인텐트가 설정되면, 그룹핑되어 분류된 인텐트를 기준으로 발화 패턴들을 학습 의도에 맞게 자연어 처리기(NLU)의 학습 데이터로 사용할 수 있다.Based on the diagram shown in FIG. 8, all speech patterns that can be processed in each block can be collected, and the patterns can be grouped in a form that is easy for the natural language processor to classify. In addition, when an intent is classified based on grouped information and an intent is set by tagging slots for each utterance pattern, the utterance patterns based on the grouped and classified intents are matched to the learning intent of the natural language processor (NLU) learning data. can be used as

시나리오는 블록들을 그래프 형태로 연결한 것으로 볼 수 있고, 각 블록에서는 처리할 수 있는 인텐트들의 목록이 정의될 수 있다.Scenarios can be viewed as connecting blocks in the form of a graph, and a list of intents that can be processed can be defined in each block.

도 9는 도 13에 도시된 시나리오에 사용되는 인텐트들의 일 예를 나타낸 도면이다.FIG. 9 is a diagram illustrating an example of intents used in the scenario shown in FIG. 13 .

도 9를 참조하면, 커피 주문 시나리오에 사용되는 인텐트들은 인텐트 order_coffee(910), 인텐트 order_hotice(920), 인텐트 order_takeout(930), 인텐트 order_togo(940) 및 인텐트 order_eatin(950)를 포함하는 것을 알 수 있다.Referring to FIG. 9, the intents used in the coffee ordering scenario include the intent order_coffee (910), the intent order_hotice (920), the intent order_takeout (930), the intent order_togo (940), and the intent order_eatin (950). can be found to contain.

이 때, 인텐트 order_coffee(910)에 대해서는 슬롯 $coffee, 슬롯 $hotice 및 슬롯 $takeout이 정의되고, 인텐트 order_hotice(920)에 대해서는 슬롯 $hotice이 정의되고, 인텐트 order_takeout(930)에 대해서는 슬롯 $takeout이 정의되고, 인텐트 order_togo(940) 및 인텐트 order_eatin(950)에 대해서는 슬롯이 정의되지 않을 수 있다.At this time, slot $coffee, slot $hotice, and slot $takeout are defined for intent order_coffee(910), slot $hotice is defined for intent order_hotice(920), and slot $hotice is defined for intent order_takeout(930). $takeout is defined, and slots may not be defined for intent order_togo (940) and intent order_eatin (950).

도 9에 도시된 인텐트들을 봇이 처리할 때, 블록(처리블록)이라는 단위로 처리하게 되는데, 하나의 블록에 복수개의 인텐트들이 매핑되어 처리될 수 있다. 또한, 하나의 인텐트가 복수개의 블록들에 매핑될 수도 있다.When the bot processes the intents shown in FIG. 9, they are processed in units called blocks (processing blocks), and a plurality of intents can be mapped to and processed in one block. Also, one intent may be mapped to a plurality of blocks.

도 10 내지 도 13은 도 9에 도시된 시나리오에 사용되는 실행블록들의 일 예를 나타낸 도면이다.10 to 13 are diagrams illustrating examples of execution blocks used in the scenario shown in FIG. 9 .

도 10은 복수개의 인텐트들과 복수개의 실행블록들 사이의 연결을 나타낸 블록도이다.10 is a block diagram showing connections between a plurality of intents and a plurality of execution blocks.

도 10을 참조하면, 인텐트 order_coffee(910), 인텐트 order_hotice(920) 및 인텐트 order_takeout(930)이 실행블록 커피 선택(1010)에 연결된 것을 알 수 있다. 이 때, 실행블록 커피 선택(1010)의 인텐트 매핑 리스트에는 인텐트 order_coffee(910), 인텐트 order_hotice(920) 및 인텐트 order_takeout(930)에 상응하는 인텐트 식별자들이 포함될 수 있다.Referring to FIG. 10 , it can be seen that the intent order_coffee 910 , the intent order_hotice 920 , and the intent order_takeout 930 are connected to the execution block coffee selection 1010 . In this case, the intent mapping list of the execution block coffee selection 1010 may include intent identifiers corresponding to the intent order_coffee 910 , the intent order_hotice 920 , and the intent order_takeout 930 .

이 때, 인텐트 order_hotice(920) 및 인텐트 order_takeout(930)은 실행블록 핫아이스확인(1020)에도 연결된다. At this time, the intent order_hotice (920) and the intent order_takeout (930) are also connected to the execution block hotice confirmation (1020).

이 때, 인텐트 order_takeout(930)는 실행블록 테이크아웃확인(1030)에도 연결된다.At this time, the intent order_takeout (930) is also connected to the execution block takeout confirmation (1030).

인텐트 order_togo(940), 인텐트 order_eatin(950), 인텐트 followup.yes(960) 및 인텐트 followup.no(970)는 실행블록 테이크아웃확인(1030)에 연결된다.The intent order_togo (940), the intent order_eatin (950), the intent followup.yes (960), and the intent followup.no (970) are connected to the action block takeout confirmation (1030).

도 10에 도시된 바와 같이, 인텐트들이 그 실행을 위한 블록들에 매핑되고, 매핑된 인텐트별로 슬롯이라는 변수를 기준으로 조건을 문법식으로 정의하여, 봇이 사용자 발화별 의도 분류로만 발화를 처리하지 않고 조건을 통해 적절한 세부처리가 가능하다.As shown in FIG. 10, intents are mapped to blocks for their execution, and a condition is defined as a grammar expression based on a variable called a slot for each mapped intent, so that the bot classifies utterances only by classifying intents for each user utterance. Appropriate detailed processing is possible through conditions without processing.

도 10에 도시된 바와 같이, 하나의 블록에 복수개의 인텐트들이 연결될 수도 있고(N: 1), 복수개의 블록들이 하나의 인텐트에 연결될 수도 있어서(1:N), 인텐트와 블록간의 자유로운 매핑(N: N)이 가능하다.As shown in FIG. 10, a plurality of intents may be connected to one block (N: 1) or a plurality of blocks may be connected to one intent (1:N), so that there is freedom between intents and blocks. Mapping (N: N) is possible.

나아가, 하나의 실행블록은 이후 실행가능한 다른 실행블록들과의 연결관계를 가질 수 있다. 예를 들어, 실행블록 커피 선택(1010)은 실행블록 핫아이스확인(1020) 및 실행블록 테이크아웃확인(1030)과 연결될 수 있고, 실행블록 핫아이스확인(1020)은 실행블록 테이크아웃확인(1030)과 연결될 수 있다.Furthermore, one execution block may have a connection relationship with other execution blocks that can be executed later. For example, runblock coffee selection 1010 can be linked with runblock ice confirmation 1020 and runblock takeout confirmation 1030, where runblock hotice confirmation 1020 confirms runblock takeout 1030 ) can be associated with

도 11은 도 10에 도시된 실행블록 커피선택의 일 예를 나타낸 도면이다.FIG. 11 is a diagram showing an example of the execution block coffee selection shown in FIG. 10 .

도 11을 참조하면, 실행블록 커피선택(1010)은 연결된 인텐트 목록, 슬롯, 슬롯 필링 및 액션 정보를 포함할 수 있다.Referring to FIG. 11, the execution block coffee selection 1010 may include a connected intent list, slot, slot filling, and action information.

이 때, 연결된 인텐트 목록은 인텐트 매핑 리스트에 포함될 수 있고, 인텐트 매핑 리스트는 인텐트별로 인텐트 식별자 및 슬롯 조건을 포함할 수 있다. 이 때, 슬롯 조건은 하나 이상의 슬롯에 관련된 조건문에 상응하는 것일 수 있고, 널(NULL) 조건을 포함할 수 있다.In this case, the connected intent list may be included in the intent mapping list, and the intent mapping list may include an intent identifier and a slot condition for each intent. In this case, the slot condition may correspond to conditional statements related to one or more slots and may include a null condition.

도 11에 도시된 슬롯들($coffee, $hotice, $takeout)은 실행블록 커피선택(1010)이 연결된 인텐트들(order_coffee, order_hotice, order_takeout)에 상응하는 모든 슬롯들의 합집합을 포함할 수 있다.The slots ($coffee, $hotice, $takeout) shown in FIG. 11 may include the union of all slots corresponding to the intents (order_coffee, order_hotice, order_takeout) to which the execution block coffee selection 1010 is connected.

슬롯 필링순위 정보는 실행블록 커피선택(1010)의 슬롯들의 필링순위에 관한 정보 및 해당 슬롯을 먼저 필링하기 위해 필요한 발화정보를 포함할 수 있다.The slot filling order information may include information on the filling order of the slots of the execution block coffee selection 1010 and ignition information necessary for filling the corresponding slot first.

액션 정보는 조건(condition)과 해당 조건이 만족되는 경우의 응답(response)으로 이루어질 수 있다. 이 때, 조건은 슬롯을 이용한 하나 이상의 조건문에 상응하는 것일 수 있고, 응답은 다른 블록을 호출하는 링크(link)를 포함할 수 있다.Action information may include a condition and a response when the condition is satisfied. At this time, the condition may correspond to one or more conditional sentences using slots, and the response may include a link calling another block.

예를 들어, 실행블록 커피 선택(1010)은 슬롯 $hotice를 이용한 조건 판단에 기반하여 실행블록 핫아이스확인(1020)을 연결할 수 있다.For example, the execution block coffee selection 1010 may connect the execution block hot ice check 1020 based on the condition determination using the slot $hotice.

예를 들어, 실행블록 커피 선택(1010)은 슬롯 $takeout을 이용한 조건 판단에 기반하여 실행블록 테이크아웃확인(1030)을 연결할 수 있다.For example, the execution block coffee selection 1010 may connect the execution block takeout check 1030 based on the condition determination using the slot $takeout.

도 12는 도 10에 도시된 실행블록 핫아이스확인의 일 예를 나타낸 도면이다.FIG. 12 is a diagram illustrating an example of hot ice checking of the execution block shown in FIG. 10 .

도 12를 참조하면, 실행블록 핫아이스확인(1020)은 연결된 인텐트 목록, 슬롯, 슬롯 필링 및 액션 정보를 포함할 수 있다.Referring to FIG. 12 , the execution block hot ice check 1020 may include a connected intent list, slot, slot filling, and action information.

도 12에 도시된 슬롯들($hotice, $takeout)은 실행블록 핫아이스확인(1020)이 연결된 인텐트들(order_hotice, order_takeout)에 상응하는 모든 슬롯들의 합집합을 포함할 수 있다.The slots ($hotice, $takeout) shown in FIG. 12 may include the union of all slots corresponding to intents (order_hotice, order_takeout) to which the execution block hotice check 1020 is connected.

슬롯 필링순위 정보는 실행블록 핫아이스확인(1020)의 슬롯들의 필링순위에 관한 정보 및 해당 슬롯을 먼저 필링하기 위해 필요한 발화정보를 포함할 수 있다.The slot filling priority information may include information on the filling priority of the slots of the execution block hot ice check 1020 and ignition information necessary for filling the corresponding slot first.

액션 정보는 조건(condition)과 해당 조건이 만족되는 경우의 응답(response)으로 이루어질 수 있다. 이 때, 조건은 슬롯을 이용한 하나 이상의 조건문에 상응하는 것일 수 있고, 응답은 다른 블록을 호출하는 링크(link)를 포함할 수 있다.Action information may include a condition and a response when the condition is satisfied. At this time, the condition may correspond to one or more conditional sentences using slots, and the response may include a link calling another block.

예를 들어, 실행블록 핫아이스확인(1020)은 슬롯 $takeout을 이용한 조건 판단에 기반하여 실행블록 테이크아웃확인(1030)을 연결할 수 있다.For example, the execution block hot ice check 1020 may connect the execution block takeout check 1030 based on the condition determination using the slot $takeout.

도 13은 도 10에 도시된 실행블록 테이크아웃확인의 일 예를 나타낸 도면이다.FIG. 13 is a diagram illustrating an example of execution block takeout confirmation shown in FIG. 10 .

도 13을 참조하면, 실행블록 테이크아웃확인(1030)은 연결된 인텐트 목록, 슬롯, 슬롯 필링 및 액션 정보를 포함할 수 있다.Referring to FIG. 13 , execution block takeout confirmation 1030 may include a connected intent list, slot, slot filling, and action information.

도 13에 도시된 슬롯($takeout)은 실행블록 테이크아웃확인(1030)이 연결된 인텐트들(order_takeout, order_togo, order_eatin, followup.yes, followup.no)에 상응하는 모든 슬롯들의 합집합을 포함할 수 있다.The slot ($takeout) shown in FIG. 13 may include the union of all slots corresponding to the intents (order_takeout, order_togo, order_eatin, followup.yes, followup.no) to which the execution block takeout confirmation 1030 is connected. have.

슬롯 필링순위 정보는 실행블록 테이크아웃확인(1030)의 슬롯들의 필링순위에 관한 정보 및 해당 슬롯을 먼저 필링하기 위해 필요한 발화정보를 포함할 수 있다.Slot filling priority information may include information on the filling priority of the slots of the execution block takeout check 1030 and ignition information necessary for filling the corresponding slot first.

액션 정보는 조건(condition)과 해당 조건이 만족되는 경우의 응답(response)으로 이루어질 수 있다. 이 때, 조건은 슬롯을 이용한 하나 이상의 조건문에 상응하는 것일 수 있고, 응답은 다른 블록을 호출하는 링크(link)를 포함할 수 있다.Action information may include a condition and a response when the condition is satisfied. At this time, the condition may correspond to one or more conditional sentences using slots, and the response may include a link calling another block.

도 14는 도 10 내지 도 13에 도시된 실행블록들의 연결관계를 나타낸 블록도이다.14 is a block diagram showing a connection relationship between execution blocks shown in FIGS. 10 to 13 .

도 14를 참조하면, 실행블록 커피 선택(1010), 실행블록 핫아이스확인(1020) 및 실행블록 테이크아웃확인(1030)이 그래프 형태로 연결된 것을 알 수 있다.Referring to FIG. 14 , it can be seen that an execution block coffee selection 1010, an execution block hot ice confirmation 1020, and an execution block takeout confirmation 1030 are connected in a graph form.

이 때, 실행블록들간의 연결은 특정 현재블록에서 사용자 발화대기 상태에 진입할 때, 사용자의 발화를 처리가능한 다음 실행블록들과의 연결을 의미할 수 있다. 즉, 특정 현재블록에서 사용자 발화가 수신되는 경우 발생가능한 상황은 현재블록과 연결된 실행블록들이므로 이들 실행블록들과 연결된 인텐트들만이 사용자 발화 처리가 필요한 인텐트들로 서칭 대상이 될 수 있다. 사용자 발화 대기 상태에서 현재 블록 기준으로 연결된 하위 블록들에 포함된 인텐트들만을 수집하여 자연어 처리기를 통해 인텐트를 검색하면 모든 인텐트를 서칭 대상으로 하는 경우에 비하여 훨씬더 신속하고 정확하게 발화에 해당하는 인텐트를 식별할 수 있게 된다.In this case, the connection between the execution blocks may mean a connection with next execution blocks capable of processing the user's speech when entering the user's speech standby state in a specific current block. That is, since a situation that can occur when a user speech is received in a specific current block is execution blocks connected to the current block, only intents connected to these execution blocks can be searched as intents requiring user speech processing. In the state of waiting for user utterance, if you collect only the intents included in the sub-blocks connected based on the current block and search for the intents through the natural language processor, they correspond to utterances much more quickly and accurately than when all intents are searched. Intent can be identified.

도 14에 도시된 예에서, 실행블록 커피 선택(1010)은 실행블록 핫아이스선택(1020) 및 실행블록 테이크아웃확인(1030)과 연결되므로, 실행블록 커피 선택(1010)의 상태에서 사용자 발화가 입력되는 경우 다음 상태는 실행블록 핫아이스선택(1020) 또는 실행블록 테이크아웃확인(1030)이 될 수 있다.In the example shown in FIG. 14, since the execution block coffee selection 1010 is connected to the execution block hot ice selection 1020 and the execution block takeout confirmation 1030, the user utterance in the state of execution block coffee selection 1010 If input, the next state may be execution block hot ice selection (1020) or execution block takeout confirmation (1030).

또한, 실행블록 핫아이스선택(1020)의 상태에서 사용자 발화가 입력되는 경우 다음 상태는 실행블록 테이크아웃확인(1030)이 될 수 있다.In addition, when user utterance is input in the state of execution block hot ice selection 1020, the next state may be execution block takeout confirmation 1030.

사용자 발화로부터 사용자 인텐트가 식별되면, 식별된 인텐트를 포함하는 블록들의 인텐트 조건들의 우선순위 및/또는 봇 설계자가 정의한 우선순위 순으로 정렬하여 블록들을 검색할 수 있다.If a user intent is identified from the user's speech, the blocks may be searched by arranging them in the order of priority of intent conditions of blocks including the identified intent and/or a priority defined by a bot designer.

조건에 맞는 블록이 검색되면, 해당 블록으로 이동하여 해당 블록 설정에 따라 정의된 동작을 수행하고, 다시 액션의 조건에 따라 사용자 응답 대기 상태로 돌아갈 수 있다.When a block that satisfies the conditions is searched for, it moves to the corresponding block, performs an operation defined according to the corresponding block setting, and returns to a state of waiting for a user response according to the condition of the action.

블록과 블록을 연결하는 것은 사용자 응답 대기 상태로 진입했을 때, 현재 블록에서 다음에 처리될 블록들을 나열하는 것으로 정의될 수 있으며, 하나의 블록에 여러 개의 사용자 응답 대기 상태들이 정의될 수도 있다.Connecting blocks to blocks may be defined as enumerating blocks to be processed next from the current block when a user response waiting state is entered, and several user response waiting states may be defined in one block.

도 15는 실행블록에서 사용자 응답 대기 상태를 정의하여 블록들을 연결하는 일 예를 도시한 도면이다.15 is a diagram illustrating an example of connecting blocks by defining a waiting state for a user response in an execution block.

도 15를 참조하면, 하나의 블록이 그래프 형태로 복수의 다른 블록들과 연결될 수 있는 것을 알 수 있다.Referring to FIG. 15 , it can be seen that one block can be connected to a plurality of other blocks in the form of a graph.

도 15에 도시된 블록 1(Block 1)은 블록 2(Block 2), 블록 3(Block 3), 블록 4(Block 4) 및 블록 5(Block 5)와 연결된다. 이 때, 블록 1(Block 1)은 조건 4(Condition 4)에 의하여 블록 2(Block 2) 및 블록 3(Block 3)과 연결되고, 조건 5(Condition 5)에 의하여 블록 3(Block 3), 블록 4(Block 4) 및 블록 5(Block 5)와 연결될 수 있다. 따라서, 블록 1(Block 1) 이후에는 블록 2(Block 2), 블록 3(Block 3), 블록 4(Block 4) 및 블록 5(Block 5)의 상황이 발생할 수 있다.Block 1 shown in FIG. 15 is connected to Block 2, Block 3, Block 4, and Block 5. At this time, Block 1 is connected to Block 2 and Block 3 by Condition 4, and by Condition 5, Block 3, It can be connected with Block 4 and Block 5. Accordingly, after Block 1, situations of Block 2, Block 3, Block 4, and Block 5 may occur.

블록 2(Block 2)는 블록 6(Block 6)과 연결된다. 따라서, 블록 2(Block 2) 이후에는 블록 6(Block 6)의 상황이 발생할 수 있다.Block 2 is connected to Block 6. Therefore, after Block 2, the situation of Block 6 may occur.

블록 3(Block 3)은 블록 6(Block 6) 및 블록 7(Block 7)과 연결된다. 따라서, 블록 3(Block 3) 이후에는 블록 6(Block 6) 및 블록 7(Block 7)의 상황이 발생할 수 있다.Block 3 is connected to Block 6 and Block 7. Accordingly, situations of Block 6 and Block 7 may occur after Block 3.

블록 5(Block 5)는 블록 6(Block 6) 및 블록 7(Block 7)과 연결된다. 따라서, 블록 5(Block 5) 이후에는 블록 6(Block 6) 및 블록 7(Block 7)의 상황이 발생할 수 있다.Block 5 is connected to Block 6 and Block 7. Accordingly, situations of Block 6 and Block 7 may occur after Block 5.

예를 들어, 현재 상태가 블록 2(Block 2)에 해당하는 상태라면, 이후 사용자의 발화는 블록 6(Block 6)에 해당하는 인텐트들만을 대상으로 인텐트를 서치하면 충분하고, 발생가능성이 없는 블록 7(Block 7)에 해당하는 인텐트들을 대상으로 사용자 발화 매칭을 수행할 필요가 없다.For example, if the current state corresponds to Block 2, it is sufficient to search for intents targeting only the intents corresponding to Block 6 for subsequent utterances, and the possibility of occurrence is high. There is no need to perform user utterance matching for intents corresponding to Block 7 that do not exist.

하나의 인텐트와 하나의 실행 블록을 매핑하는 경우, 하나의 인텐트가 복수개의 발화 패턴을 포함해야 할 수 있다. When one intent and one execution block are mapped, one intent may need to include a plurality of firing patterns.

예를 들어, 인텐트(I1: 가입 의도)가 학습문장들 "써보고 싶어요"(패턴분류 P1), "쓰려면 어떻게 해요"(패턴분류 P1), "가입 방법이 궁금해요"(패턴분류 P3) 및 "가입방법 문의 좀"(패턴분류 P3)을 포함하고, 인텐트(I2: 탈퇴 의도)가 학습문장들 "그만 쓰고 싶어요"(패턴분류 P2), "이제 안쓸래요"(패턴분류 P2), "탈퇴 방법 궁금해요"(패턴분류 P3) 및 "탈퇴 방법 문의합니다"(패턴분류 P3)를 포함할 수 있다.For example, the intent (I1: intent to sign up) is the learning sentences "I want to write" (pattern classification P1), "How do I write" (pattern classification P1), "I'm curious about how to sign up" (pattern classification P3) and "Inquiry on how to join" (pattern classification P3), and the intent (I2: withdrawal intention) includes the learning sentences "I want to stop writing" (pattern classification P2), "I don't want to write anymore" (pattern classification P2), It may include "I'm curious about how to cancel" (pattern classification P3) and "Inquire about how to cancel" (pattern classification P3).

이 때, 인텐트(I1: 가입 의도)에 블록 하나가 연결되고, 인텐트(I2: 탈퇴 의도)에 블록 하나가 연결될 수 있으나, 인텐트들이 복수개의 발화 패턴들을 포함하게 되어 자연어 처리기의 성능이 저하될 수 있다.At this time, one block may be connected to the intent (I1: intent to join) and one block may be connected to the intent (I2: intent to leave), but the performance of the natural language processor may deteriorate as the intents include a plurality of speech patterns may be lowered

따라서, 자연어 처리기의 성능 저하를 방지하기 위해서는 하나의 인텐트에 복수개의 발화 패턴들이 포함되는 것을 피하는 것이 바람직하다. 예를 들어, 인텐트(I1: 가입 의도)는 학습문장들 "써보고 싶어요"(패턴분류 P1) 및 "쓰려면 어떻게 해요"(패턴분류 P1)만을 포함하고, 인텐트(I2: 탈퇴 의도)는 학습문장들 "그만 쓰고 싶어요"(패턴분류 P2) 및 "이제 안쓸래요"(패턴분류 P2)만을 포함하고, 인텐트(I3: 문의 의도)가 학습문장들 "<가입> 방법이 궁금해요"(패턴분류 P3), "<가입> 방법 문의 좀"(패턴분류 P3), "<탈퇴> 방법 궁금해요"(패턴분류 P3) 및 "<탈퇴> 방법 문의합니다"(패턴분류 P3)를 포함할 수 있다.Therefore, in order to prevent degradation of the performance of the natural language processor, it is desirable to avoid including a plurality of speech patterns in one intent. For example, the intent (I1: subscription intent) includes only the learning sentences "I want to write" (pattern classification P1) and "how to write" (pattern classification P1), and the intent (I2: withdrawal intent) It includes only the learning sentences "I want to stop writing" (pattern classification P2) and "I don't want to use anymore" (pattern classification P2), and the intent (I3: inquiry intent) is the learning sentences "I'm curious about the <sign up> method" ( Pattern classification P3), "Inquire about how to <register>" (pattern classification P3), "I'm curious about the <withdrawal> method" (pattern classification P3), and "Inquire about how to <subscribe>" (pattern classification P3). have.

이와 같이 자연어 처리기에서 효과적으로 처리될 수 있도록 인텐트를 분류하는 경우, 인텐트들과 처리 블록들이 보다 다양한 형태로 연결될 필요가 있다. 이를 위해, 블록의 인텐트들은 각각 조건을 가질 수 있고, 이 조건은 슬롯값들을 비교하는 구문들로 정의될 수 있다. 즉, 블록과 인텐트 매핑 정보는 인텐트와 슬롯 조건을 쌍으로 묶인 목록(인텐트 매핑 리스트)의 형태로 블록에 정의될 수 있다.In this way, when an intent is classified so that it can be effectively processed by a natural language processor, it is necessary to connect the intents and processing blocks in more diverse forms. To this end, each of the block's intents may have a condition, and this condition may be defined as statements comparing slot values. That is, block and intent mapping information may be defined in a block in the form of a list (intent mapping list) in which intents and slot conditions are paired.

도 16은 발화 패턴별로 정의된 인텐트를 블록에 매핑하는 일 예를 나타낸 도면이다.16 is a diagram illustrating an example of mapping intents defined for each speech pattern to blocks.

도 16을 참조하면, 인텐트와 슬롯 조건의 쌍으로 3개의 인텐트들이 2개의 블록들에 연결된 것을 알 수 있다.Referring to FIG. 16, it can be seen that three intents are connected to two blocks as a pair of intent and slot conditions.

이 때, 슬롯 조건에 사용되는 슬롯들은 현재 인텐트에서 정의된 슬롯뿐만 아니라, 이전 대화를 실행하면서 설정된 다른 블록의 슬롯이나, 시스템에서 제공되는 슬롯들을 포함할 수 있다.At this time, the slots used for the slot condition may include not only slots defined in the current intent, but also slots of other blocks set while executing a previous conversation, or slots provided by the system.

도 16에 도시된 예에서 인텐트 1(Intent 1)은 발화 패턴 1(Pattern 1)에 상응하고, 인텐트 2(Intent 2)는 발화 패턴 2(Pattern 2)에 상응하고, 인텐트 3(Intent 3)은 발화 패턴 3(Pattern 3)에 상응하는 것을 알 수 있다.In the example shown in FIG. 16, Intent 1 corresponds to Speech Pattern 1, Intent 2 corresponds to Speech Pattern 2, and Intent 3 corresponds to Speech Pattern 2. It can be seen that 3) corresponds to the ignition pattern 3 (Pattern 3).

도 16에 도시된 예에서, 블록 1(Block 1)의 인텐트 매핑 리스트에는 인텐트 1(Intent 1)과 조건 1(Condition 1)의 쌍 및 인텐트 3(Intent 3)과 조건 2(Condition 2)의 쌍의 두 개의 엘리먼트들이 존재한다. 따라서, 블록 1(Block 1)은 두 개의 인텐트들(Intent 1, Intent 3)과 연결된다.In the example shown in FIG. 16, the intent mapping list of Block 1 includes a pair of Intent 1 and Condition 1, and a pair of Intent 3 and Condition 2. ), there are two elements of the pair. Therefore, Block 1 is connected to two Intents (Intent 1 and Intent 3).

블록 2(Block 2)의 인텐트 매핑 리스트에는 인텐트 2(Intent 2)와 조건 3(Condition 3)의 쌍 및 인텐트 3(Intent 3)과 조건 4(Condition 4)의 쌍의 두 개의 엘리먼트들이 존재한다. 따라서, 블록 2(Block 2)은 두 개의 인텐트들(Intent 2, Intent 3)과 연결된다.In the intent mapping list of Block 2, there are two elements: a pair of Intent 2 and Condition 3 and a pair of Intent 3 and Condition 4. exist. Therefore, Block 2 is connected with two intents (Intent 2 and Intent 3).

도 17은 인텐트와 실행블록을 1:1 매핑하는 경우를 나타낸 도면이다.17 is a diagram illustrating a case of 1:1 mapping between intents and execution blocks.

도 17을 참조하면, 3개의 인텐트들(I1, I2, I3)이 각각 4개씩의 발화 패턴을 포함하는 것을 알 수 있다.Referring to FIG. 17 , it can be seen that each of the three intents I1, I2, and I3 includes four firing patterns.

즉, 인텐트 I1(가입 의도)는 발화 패턴들 "써보고 싶어요", "쓰려면 어떻게 해요", "가입 방법이 궁금해요" 및 "가입 방법 문의 좀"을 포함한다.That is, intent I1 (subscription intention) includes speech patterns "I want to try", "How do I write", "I'm curious about how to sign up", and "Inquire how to sign up".

인텐트 I2(탈퇴 의도)는 발화 패턴들 "그만 쓰고 싶어요", "이제 안쓸래요", 탈퇴 방법이 궁금해요" 및 "탈퇴하는 법 문의합니다"를 포함한다.Intent I2 (withdrawal intent) includes the utterance patterns "I want to stop using", "I don't want to use anymore", I'm curious about how to unsubscribe, and "Inquire about how to unsubscribe".

인텐트 I3(정회원 문의 의도)는 발화 패턴들 "정회원이 되고 싶어요", "정회원으로 승급하고 싶어요", 정회원 가입 방법이 궁금해요", "정회원 가입하는 방법은"을 포함한다.Intent I3 (intent to inquire about regular membership) includes speech patterns "I want to become a regular member", "I want to be promoted to a regular member", "I'm curious about how to become a regular member", and "How to become a regular member".

인텐트(의도)와 응답(실행블록)이 1:1로 매핑되면, "*** 궁금해요"와 같은 문장이 여러 인텐트에 등장하는 경우, 자연어 처리기(NLU)가 이들 유사한 문장들을 구분하기 어렵다. 예를 들어, "저 처음인데 가입하는 법 문의합니다"와 같은 문장은 상황에 따라 자연어 처리기에 의해 탈퇴 의도의 "탈퇴하는 법 문의합니다"와 유사한 문장으로 처리되어 잘못된 의도 인식이 발생할 수 있다.When intents (intents) and responses (execution blocks) are mapped 1:1, when a sentence like "*** I'm curious" appears in multiple intents, the natural language processor (NLU) can distinguish between these similar sentences. difficult. For example, a sentence such as "I am new to sign up, ask how to sign up" is processed by the natural language processor as a sentence similar to "inquire how to sign up" of the withdrawal intent, depending on the circumstances, resulting in false intention recognition.

즉, 사용자의 의도 분류는 자연어 처리기(NLU)에 의해 처리되기 쉬운 의도 분류와는 상이할 수 있는데, 실제 사용자의 의도 하나가 자연어 처리기가 처리하기 용이한 의도들 여러 개로 분리될 수 있고 또 반대로 여러 개의 사용자의 의도들이 자연어 처리기가 처리하기 용이한 하나의 의도로 분류될 수도 있다.That is, the user's intent classification may be different from the intent classification that is easy to be processed by a natural language processor (NLU). One actual user's intent may be divided into several intents that are easy to be processed by a natural language processor, and conversely, several The intentions of the user may be classified into one intention that is easy for the natural language processor to process.

도 18은 본 발명의 일실시예에 따른 인텐트 분류 및 블록 매핑의 일 예를 나타낸 도면이다.18 is a diagram illustrating an example of intent classification and block mapping according to an embodiment of the present invention.

도 18을 참조하면, 자연어 처리기(NLU)가 처리하기 용이한 형태로 문장들이 분류되고, 필요한 슬롯을 태깅하여 조건에 따라 응답들(responses)이 매핑된 것을 알 수 있다.Referring to FIG. 18 , it can be seen that sentences are classified into a form that is easy to process by a natural language processor (NLU), and responses are mapped according to conditions by tagging necessary slots.

도 18에 도시된 예에서, 4개의 인텐트들(I1, I2, I3, I4)이 3개의 응답들(R1, R2, R3)에 연결된다.In the example shown in FIG. 18 , four intents (I1, I2, I3, and I4) are linked to three responses (R1, R2, and R3).

이 때, 인텐트 1(I1)은 가입 안내 응답(R1)에 연결된다. 이 때, 슬롯 조건은 널(NULL) 조건일 수 있다.At this time, Intent 1 (I1) is connected to the subscription information response (R1). At this time, the slot condition may be a null condition.

이 때, 인텐트 4(I4)는 가입 안내 응답(R1), 탈퇴 안내 응답(R2) 및 정회원 안내 응답(R3)에 연결된다. 이 때, 인텐트 4(I4)는 슬롯 조건 $service == "가입"에 의해 가입 안내 응답(R1)에 연결될 수 있다. 이 때, 인텐트 4(I4)는 슬롯 조건 $service == "탈퇴"에 의해 탈퇴 안내 응답(R2)에 연결될 수 있다. 이 때, 인텐트 4(I4)는 슬롯 조건 $level == "정회원" and $service == "가입"에 의해 정회원 안내 응답(R3)에 연결될 수 있다.At this time, Intent 4 (I4) is connected to a subscription guide response (R1), a withdrawal guide response (R2), and a member guide response (R3). At this time, intent 4 (I4) can be connected to the subscription information response (R1) by the slot condition $service == "subscription". At this time, intent 4 (I4) may be connected to the withdrawal guidance response (R2) by the slot condition $service == "withdrawal". At this time, intent 4 (I4) can be connected to regular member information response (R3) by slot conditions $level == "regular member" and $service == "subscription".

이 때, 인텐트 2(I2)는 탈퇴 안내 응답(R2)에 연결된다. 이 때, 슬롯 조건은 널(NULL) 조건일 수 있다.At this time, Intent 2 (I2) is connected to the withdrawal guidance response (R2). At this time, the slot condition may be a null condition.

이 때, 인텐트 3(I3)는 정회원 안내 응답(R3)에 연결된다. 이 때, 슬롯 조건은 널(NULL) 조건일 수 있다.At this time, Intent 3 (I3) is connected to the regular member information response (R3). At this time, the slot condition may be a null condition.

도 18에 도시된 응답들은 각각 하나의 실행블록에 상응하는 것일 수 있다.Each of the responses shown in FIG. 18 may correspond to one execution block.

이 때, 실행블록은 인텐트와 슬롯 조건 및 챗봇의 응답 처리를 포함하여 정의될 수 있다.At this time, the execution block may be defined including intent, slot conditions, and response processing of the chatbot.

도 19는 도 18에 도시된 응답들에 상응하는 실행블록들을 나타낸 도면이다.FIG. 19 is a diagram showing execution blocks corresponding to the responses shown in FIG. 18 .

도 19를 참조하면, 각 실행블록들은 적어도 하나의 인텐트와 슬롯 조건의 쌍을 포함하는 인텐트 매핑 리스트 및 동작 정보를 포함한다.Referring to FIG. 19 , each execution block includes an intent mapping list including a pair of at least one intent and a slot condition and action information.

도 19에 도시된 바와 같이, 슬롯 조건은 "조건없음"에 해당하는 널(NULL) 조건을 포함할 수 있고, 하나 이상의 슬롯을 이용한 조건문을 포함할 수 있다.As shown in FIG. 19 , the slot condition may include a null condition corresponding to “no condition” and may include conditional statements using one or more slots.

챗봇이 대화 처리를 수행하게 되면, 먼저 사용자가 입력한 문장으로부터 자연어 처리기가 인텐트를 분류하고 슬롯을 추출한 뒤, 분류된 인텐트를 포함하는 블록에 나열된 조건들을 검사해가면서 매칭되는 블록을 찾게 된다.When the chatbot performs conversation processing, the natural language processor first classifies the intent from the sentence input by the user, extracts the slot, and then finds a matching block by examining the conditions listed in the block containing the classified intent. .

도 18 및 도 19에 도시된 예에서, "I4: 문의 의도"로 인텐트가 분류된 경우, 이 인텐트를 포함하고 있는 블록은 B1, B2 및 B3이며, 조건에 따라 매칭되는 블록들은 아래 표 1과 같다.In the examples shown in FIGS. 18 and 19, when an intent is classified as "I4: Intent of inquiry", the blocks containing this intent are B1, B2, and B3, and the blocks matched according to the conditions are listed in the table below. Same as 1.

조건Condition 블록block 사용자 지정 조건 검사 순서Custom condition check order $service == "가입"$service == "subscribe" B1:가입 안내B1: Enrollment Guide 1One $service == "탈퇴"$service == "Withdrawal" B2:탈퇴 안내B2: Withdrawal Information 22 $level == "정회원" and $service == "가입"$level == "Full Member" and $service == "Registration" B3:정회원 안내B3: Regular member information 33

조건을 검사하는 순서는 블록을 나열하는 순서등을 사용자가 지정함으로써 정해질 수 있다. 만약, 표 1과 같이 단순히 사용자가 나열한 순서대로만 처리되는 경우, 정회원 가입과 같은 문장은 $level == "정회원" and $service == "가입" 이라는 조건을 만족하지만, 동시에 논리적으로는 $service == "가입" 이라는 조건도 만족하게 되고, 조건 검사 순위가 높은 B1 블록이 실행될 수 있고 이는 바람직한 결과가 아닐 수 있다.The order of checking conditions can be determined by the user designating the order of listing blocks. If, as shown in Table 1, processing is performed in the order listed by the user, a sentence such as regular member registration satisfies the conditions of $level == "regular member" and $service == "registration", but at the same time logically $service = = "subscription" condition is also satisfied, and block B1 having a higher condition check order may be executed, which may not be a desirable result.

이 문제를 해결하기 위해 조건의 포함관계를 고려하여 다시 우선 순위를 부여하면 하기 표 2와 같이 정해질 수 있다.In order to solve this problem, if priority is given again in consideration of the inclusion relationship of conditions, it can be determined as shown in Table 2 below.

조건Condition 블록block 사용자 지정 조건 검사 순서Custom condition check order 포함관계 고려 순위 재정렬Reordering the ranking considering inclusion $level == "정회원" and $service == "가입"$level == "Full Member" and $service == "Registration" B3:정회원 안내B3: Regular member information 33 1One $service == "가입"$service == "subscribe" B1:가입 안내B1: Enrollment Guide 1One 22 $service == "탈퇴"$service == "Withdrawal" B2:탈퇴 안내B2: Withdrawal Information 22 33

이 때, 조건의 포함관계는 조건식 내에 사용된 슬롯들의 집합의 포함관계로 결정될 수 있는데, 포함하고 있는 쪽(큰 집합)이 포함되는 쪽(작은 집합)보다 우선적으로 처리되고, 서로 포함관계가 없으면 사용자가 지정한 우선순위가 유지될 수 있다. 표 2의 예에서, level과 service를 모두 검사하는 B3의 조건이 service만 검사하는 B1, B2보다 조건 포함관계 순위가 더 높아서, B1이나 B2보다 B3가 우선적으로 처리될 수 있다.At this time, the inclusion relationship of the condition can be determined by the inclusion relationship of the set of slots used in the conditional expression. The inclusive side (large set) is processed with priority over the included side (small set), and if there is no inclusion relationship with each other, Priorities designated by the user may be maintained. In the example of Table 2, the condition of B3, which inspects both level and service, has a higher order of condition inclusion than B1 and B2, which inspect only service, so B3 can be processed with priority over B1 or B2.

도 20는 도 9 내지 도 14에서 예시된 커피주문 시나리오에 상응하는 조건의 포함관계에 따른 우선순위 정렬 예를 나타낸 도면이다.FIG. 20 is a diagram illustrating an example of prioritization according to inclusion relationships of conditions corresponding to the coffee ordering scenarios illustrated in FIGS. 9 to 14 .

도 20을 참조하면, coffee 슬롯 하나에 해당하는 조건보다 coffee 슬롯 및 takeout 슬롯 두 개에 해당하는 조건이 우선순위가 높은 것을 알 수 있다.Referring to FIG. 20, it can be seen that the condition corresponding to two coffee slots and the takeout slot has higher priority than the condition corresponding to one coffee slot.

따라서, 사용자가 "아메리카노 테이크아웃할래요"라고 발화하면 슬롯 coffee이 "아메리카노"로 채워지고, 슬롯 takeout이 "테이크아웃"으로 채워지므로 실행블록 테이크아웃확인보다 실행블록 커피 주문이 우선적으로 실행되게 된다.Therefore, when the user says "I want to take Americano takeout", the slot coffee is filled with "Americano" and the slot takeout is filled with "Takeout", so the execution block coffee order takes precedence over the execution block takeout confirmation.

챗봇 프로세스가 실행될 때는, 현재 사용자 응답 대기 상태에서 연결된 블록들에서 인텐트들을 수집하고, 자연어 처리기를 통해 수집된 인텐트들 중에서 적합한 인텐트를 검색할 수 있다.When the chatbot process is executed, it collects intents from connected blocks in the current user response waiting state, and can search for an appropriate intent among the intents collected through the natural language processor.

인텐트로 블록을 찾을 때는 인텐트를 포함하고 있는 블록들의 인텐트 조건들의 우선순위, 사용자가 정의한 우선순위 순으로 정렬하여 적합한 블록을 검색할 수 있다.When searching for a block by intent, a suitable block can be searched by arranging in the order of the priority of the intent conditions of the blocks that contain the intent and the priority defined by the user.

조건에 맞지 않아 적합한 블록을 찾지 못했을 때는 다음으로 적합한 인텐트를 사용하여 위 방법을 반복할 수 있다.If a suitable block is not found because the condition is not met, the above method can be repeated using the next suitable intent.

조건이 맞는 블록을 찾았을 때는 해당 블록으로 이동한 후 챗봇의 응답 프로세스에 정해진 동작을 수행하고 조건에 따라 다음 사용자 응답 대기 상태로 진입할 수 있다.When a block that satisfies the conditions is found, it moves to the corresponding block, performs a predetermined action in the chatbot's response process, and enters the state of waiting for the next user response according to the condition.

도 21은 챗봇 실행에 필요한 모듈들의 일 예를 나타낸 블록도이다.21 is a block diagram illustrating an example of modules necessary for executing a chatbot.

도 21을 참조하면, 봇 디자이너가 정의한 리소스들을 챗봇이 실행할 때 필요한 모듈들은 대화 흐름 처리기를 중심으로 크게 나눈다면, 메시지 입출력을 제어하는 부분, 블록 상태를 관리하는 부분, 자연어를 처리하는 부분, 블록 조건들을 처리하는 부분 및 블록들을 실행하는 부분으로 볼 수 있다.Referring to FIG. 21, if the modules required when the chatbot executes the resources defined by the bot designer are largely divided around the conversation flow processor, the part that controls message input and output, the part that manages block status, the part that processes natural language, and the block It can be seen as a part that processes conditions and a part that executes blocks.

도 21의 예에서, 챗봇 실행에 필요한 모듈들은 대화 흐름 처리기, 블록 상태 관리기, 메시지 입력 게이트웨이, 메시지 출력 게이트웨이, 응답 메시지 생성기, 블록 프로세스 실행기, NLU 검색기, 블록 검색기, 의도 분류기, 슬롯 추출기, 자연어 처리기, NLU 우선 순위 관리자, 조건 해석기 및 블록 조건 우선순위 관리자를 포함할 수 있다.In the example of FIG. 21, the modules necessary for running the chatbot include a dialog flow processor, a block state manager, a message input gateway, a message output gateway, a response message generator, a block process executor, an NLU searcher, a block searcher, an intent classifier, a slot extractor, and a natural language processor. , NLU priority manager, condition resolver and block condition priority manager.

도 22는 챗봇 실행 중 인텐트와 블록을 검색하는 과정을 나타낸 도면이다.22 is a diagram illustrating a process of searching for intents and blocks while the chatbot is running.

도 22를 참조하면, 챗봇이 사용자 입력을 대기중인 상태에서 사용자의 발화가 입력되면, 먼저 현재 위치에서 실행 가능한 블록들이 서칭된다. 이 때, 현재 (실행)블록에 연결된 하위 블록들이 먼저 서칭되고, 시나리오의 메인블록들이 서칭될 수 있다. 이 때, 메인블록이란 대화 초기 상태에서 동작할 블록들의 목록을 의미하며, 사용자가 최초 발화시 봇이 서칭하는 대상 블록들이 된다. 즉, 현재 블록 이후에 실행가능성이 있는 하위블록들과, 새로 실행가능한 메인블록들만을 대상으로 인텐트를 식별하게 되면, 효율적인 대화 흐름 처리가 가능하다.Referring to FIG. 22, when a user's utterance is input while the chatbot is waiting for a user's input, blocks that can be executed at the current location are first searched. At this time, sub-blocks connected to the current (execution) block may be searched first, and then main blocks of the scenario may be searched. At this time, the main block means a list of blocks to be operated in the initial state of the conversation, and becomes the target blocks that the bot searches for when the user first speaks. That is, if the intent is identified only for the subblocks that are executable after the current block and the main blocks that are newly executable, efficient dialog flow processing is possible.

블록이 서칭되면, 서칭된 블록에 매핑된 인텐트들을 나열하여 처리 우선순위를 검사하게 된다. 이 때, 서칭된 블록들에 정의된 인텐트들이 나열되고, 자연어 처리기를 사용하여 사용자 발화에 해당하는 인텐트들의 매칭 스코어(score)를 결정한다. 정의된 인텐트 패턴 문턱 스코어(threshold score) 목록을 순차적으로 조회하면서, 인텐트들의 이름과 매칭 점수를 비교하여, 패턴과 문턱 스코어를 만족하는 인텐트들 중 매칭 점수가 가장 높은 인텐트를 가장 먼저 추출한다.When a block is searched, the processing priority is checked by enumerating intents mapped to the searched block. At this time, intents defined in the searched blocks are listed, and matching scores of intents corresponding to the user's speech are determined using a natural language processor. The defined intent pattern threshold score list is sequentially searched, and the names of intents and matching scores are compared, and the intent with the highest matching score among the intents that satisfy the pattern and threshold score is selected first. extract

매칭된 인텐트가 속한 블록이 1개 이상인 경우, 정의된 인텐트 매핑 조건에 따라 처리 우선순위를 정렬하고, 조건의 우선순위가 동일한 경우는 사용자가 직접 정의한 시나리오 및 블록의 우선순위를 따른다. 이 때, 조건의 우선순위는 조건 비교 구문의 포함 관계에 따라 우선 순위가 매겨질 수 있다. 즉, 사용자의 발화로부터 추출된 슬롯을 기반으로 조건을 구성하는 경우, 조건을 구성하는 비교 구문은 사용자가 언급한 슬롯들 위주로 구성되고 언급되지 않은 슬롯은 생략되므로, 많은 슬롯을 포함하고 있는 조건이 사용자의 의도를 더 잘 반영한 것이라고 볼 수 있다. 즉, 조건 구문 내에 참인 조건이 여러 개인 경우, 제약 사항이나 슬롯을 더 많이 포함하는 조건이 우선 순위가 더 높은 것으로 간주될 수 있다.If there is one or more blocks to which the matched intent belongs, the processing priorities are sorted according to the defined intent mapping condition, and if the conditions have the same priority, the scenario and block priorities defined by the user are followed. At this time, the priority of the condition may be prioritized according to the inclusion relationship of the condition comparison phrase. That is, when the condition is constructed based on the slots extracted from the user's utterance, the comparison syntax constituting the condition is composed mainly of the slots mentioned by the user and the slots not mentioned are omitted, so a condition containing many slots It can be seen as a better reflection of the user's intention. That is, when there are several conditions that are true in the conditional statement, the condition that includes more constraints or slots may be considered higher in priority.

정렬된 조건들을 우선순위에 따라 검사하여, 가장 첫 번째 순서로 만족하는 조건이 속한 블록을 실행 블록으로 처리한다. 만약 조건을 만족하는 블록을 찾을 수 없을 때는 다음 우선 순위의 인텐트로 다시 인텐트가 속한 블록들을 찾고 조건의 우선 순위 판단 및 조건 검사 과정을 반복하여 블록을 찾는다.The sorted conditions are inspected in order of priority, and the block to which the condition satisfied in the first order belongs is treated as an execution block. If a block that satisfies the condition is not found, the blocks to which the intent belongs are searched again with the intent of the next priority, and the block is found by repeating the process of determining the priority of the condition and checking the condition.

도 23은 본 발명의 다른 실시예에 따른 챗봇 서비스 제공 방법을 나타낸 동작 흐름도이다.23 is an operational flowchart illustrating a method of providing a chatbot service according to another embodiment of the present invention.

도 23을 참조하면, 본 발명의 다른 실시예에 따른 챗봇 서비스 제공 방법은 사용자 대화에 상응하는 인텐트를 결정한다(S2310).Referring to FIG. 23 , a method for providing a chatbot service according to another embodiment of the present invention determines an intent corresponding to a user conversation (S2310).

이 때, 사용자 대화에 상응하는 인텐트는 현재 블록과 그래프(graph)를 통해 연결된 하나 이상의 후보블록 또는 메인블록에 연결된 인텐트 후보 내에서 선택될 수 있다.In this case, an intent corresponding to the user dialogue may be selected from one or more candidate blocks connected to the current block through a graph or from among intent candidates connected to the main block.

이 때, 사용자 대화에 상응하는 인텐트는 상기 후보블록에 연결된 제1 인텐트 후보가 상기 메인블록에 연결된 제2 인텐트 후보보다 우선적으로 고려되어 결정될 수 있다.In this case, the intent corresponding to the user dialogue may be determined by considering the first intent candidate linked to the candidate block with priority over the second intent candidate linked to the main block.

또한, 본 발명의 다른 실시예에 따른 챗봇 서비스 제공 방법은 인텐트 매핑 리스트를 이용하여 상기 인텐트에 상응하는 실행블록을 선택한다(S2320).In addition, in the chatbot service providing method according to another embodiment of the present invention, an execution block corresponding to the intent is selected using an intent mapping list (S2320).

이 때, 인텐트 매핑 리스트는 실행블록들 각각을 위하여 구비되고, 적어도 하나 이상의 인텐트에 상응하는 것일 수 있다.In this case, the intent mapping list is provided for each of the execution blocks and may correspond to one or more intents.

이 때, 인텐트 매핑 리스트는 인텐트별로 인텐트 식별자 및 슬롯 조건을 포함할 수 있다.In this case, the intent mapping list may include an intent identifier and a slot condition for each intent.

이 때, 슬롯 조건은 하나 이상의 슬롯(slot)에 관련된 조건문에 상응하는 것일 수 있다.In this case, the slot condition may correspond to conditional statements related to one or more slots.

이 때, 슬롯 조건은 널(NULL) 조건을 포함할 수 있다.At this time, the slot condition may include a null condition.

이 때, 인텐트 매핑 리스트는 복수의 인텐트들에 상응하는 인텐트 식별자들 및 슬롯 조건들을 포함하는 경우가 있고(N:1), 상기 인텐트는 서로 상이한 실행블록들이 동일한 인텐트 식별자를 가지는 경우에 상기 슬롯 조건들이 상이하면 서로 상이한 실행블록들에 연결(1:N)될 수 있다.In this case, the intent mapping list may include intent identifiers and slot conditions corresponding to a plurality of intents (N:1), and the intent is that different execution blocks have the same intent identifier. In this case, if the slot conditions are different, they may be connected (1:N) to different execution blocks.

이 때, 실행블록에 상응하는 슬롯들은, 상기 인텐트 매핑 리스트를 통해 상기 실행블록과 연결된 인텐트들의 슬롯들을 포함할 수 있다.In this case, the slots corresponding to the execution block may include slots of intents connected to the execution block through the intent mapping list.

이 때, 인텐트에 상응하는 실행블록은 상기 사용자 대화에 상응하는 인텐트가 복수개의 실행블록들과 연결되는 경우, 큰 집합에 상응하는 슬롯 조건의 포함관계를 가지는 제1 실행블록이 상기 큰 집합에 포함되는 작은 집합에 상응하는 슬롯 조건의 포함관계를 가지는 제2 실행블록보다 우선적으로 고려되어 선택될 수 있다. 이 때, 슬롯 조건의 포함관계는 슬롯 조건에 포함된 슬롯들의 포함관계일 수 있다. 예를 들어, $level == "정회원" and $service == "가입"에 해당하는 실행블록이 $service == "가입"에 해당하는 실행블록보다 우선적으로 고려되어 선택될 수 있다.At this time, the execution block corresponding to the intent is a first execution block having an inclusion relationship of the slot condition corresponding to the large set when the intent corresponding to the user dialogue is connected to a plurality of execution blocks. It can be selected with priority over the second execution block having an inclusion relationship of slot conditions corresponding to a small set included in . In this case, the inclusion relationship of the slot condition may be the inclusion relationship of slots included in the slot condition. For example, an execution block corresponding to $level == "regular member" and $service == "subscription" may be selected with priority over an execution block corresponding to $service == "subscription".

또한, 본 발명의 다른 실시예에 따른 챗봇 서비스 제공 방법은 상기 실행블록에 기반하여 상기 인텐트에 상응하는 대화 처리를 수행한다(S2330).In addition, the chatbot service providing method according to another embodiment of the present invention performs conversation processing corresponding to the intent based on the execution block (S2330).

상술한 구성에 의하여, 본 발명의 일실시예에 따른 챗봇 서비스 제공 방법은 자연어 처리기에 적합하게 분류된 인텐트들과 인텐트들을 처리하는 실행블록들 사이의 N:N(N은 자연수) 매핑이 가능하도록 하여, 여러가지 다른 발화들로 하나의 기능을 실행할 수 있고, 반대로 유사한 발화들로 전혀 다른 기능을 수행할 수 있다.According to the above configuration, the chatbot service providing method according to an embodiment of the present invention has N:N (N is a natural number) mapping between intents classified as suitable for a natural language processor and execution blocks processing the intents. This allows several different utterances to perform one function, and conversely, similar utterances to perform completely different functions.

또한, 본 발명의 일실시예에 따른 챗봇 서비스 제공 방법은 인텐트별로 인텐트 식별자와 슬롯 조건을 포함하는 인텐트 매핑 리스트를 이용하여 다양한 인텐트-실행블록 매핑 관계를 정의하는 것이 가능하다.In addition, in the chatbot service providing method according to an embodiment of the present invention, it is possible to define various intent-execution block mapping relationships by using an intent mapping list including an intent identifier and a slot condition for each intent.

또한, 본 발명의 일실시예에 따른 챗봇 서비스 제공 방법은 사용자 대화에 상응하는 인텐트를 식별할 때, 현재 실행블록 이후에 실행될 수 있는 후보블록들을 식별하고, 후보블록들과 연결된 인텐트들만을 식별 대상으로 하여 빠르고 정확한 인텐트 식별이 가능하다.In addition, in the method for providing a chatbot service according to an embodiment of the present invention, when an intent corresponding to a user conversation is identified, candidate blocks that can be executed after the current execution block are identified, and only intents connected to the candidate blocks are identified. Fast and accurate intent identification is possible by targeting the identification.

도 24는 발화 패턴수 증가에 따른 자연어 처리기 성능을 나타낸 그래프이다.24 is a graph showing performance of a natural language processor according to an increase in the number of speech patterns.

도 24를 참조하면, 인텐트를 챗봇이 제공하는 기능별로 구분하는 경우, 다양한 발화 문장들이 추가될 경우 비슷한 발화 패턴이 여러 인텐트들에 자주 나타나게 되고, A와 같이 자연어 처리기(NLU)의 인텐트 분류 성능이 급격히 저하되는 것을 알 수 있다.Referring to FIG. 24, when intents are classified according to functions provided by a chatbot, when various spoken sentences are added, similar speech patterns often appear in several intents, and natural language processor (NLU) intents as shown in A It can be seen that the classification performance is rapidly degraded.

이런 문제를 해결하기 위해 자연어 처리기가 처리하기 적합한 형태로 유사한 발화 패턴별로 인텐트를 정의할 수 있도록 함으로써, 발화 패턴이 늘어나더라도 B과 같이 자연어 처리기 성능을 높게 유지할 수 있다.In order to solve this problem, by defining an intent for each similar speech pattern in a form suitable for processing by the natural language processor, even if the speech pattern increases, the performance of the natural language processor can be maintained high as in B.

또한, 서로 다른 발화패턴을 '블록'이라는 단위에 매핑하여 조건에 의하여 봇이 적절히 처리할 수 있도록 함으로써, 다양한 발화 패턴이 효율적으로 처리될 수 있다.In addition, by mapping different speech patterns to a unit called 'block' so that the bot can properly process them according to conditions, various speech patterns can be efficiently processed.

블록들은 그래프 형태로 연결되고 조건에 따라 응답 대기 상태를 여러 개로 정의할 수 있어서, 조건에 따라 처리 흐름이나 단계가 다양한 업무 처리를 적은 수의 블록들로도 가시적으로 정의할 수 있다.Blocks are connected in the form of a graph, and several response waiting states can be defined according to conditions, so that work processes with various processing flows or steps can be visually defined with a small number of blocks.

본 명세서에서 설명하는 기능적인 동작과 주제의 구현물들은 디지털 전자 회로로 구현되거나, 본 명세서에서 개시하는 구조 및 그 구조적인 등가물들을 포함하는 컴퓨터 소프트웨어, 펌웨어 혹은 하드웨어로 구현되거나, 이들 중 하나 이상의 결합으로 구현 가능하다. 본 명세서에서 설명하는 주제의 구현물들은 하나 이상의 컴퓨터 프로그램 제품, 다시 말해 처리 시스템의 동작을 제어하기 위하여 혹은 이것에 의한 실행을 위하여 유형의 프로그램 저장매체 상에 인코딩된 컴퓨터 프로그램 명령에 관한 하나 이상의 모듈로서 구현될 수 있다.Implementations of the functional operations and subject matter described herein may be implemented in digital electronic circuitry, or in computer software, firmware, or hardware, including the structures disclosed herein and their structural equivalents, or in a combination of one or more of the foregoing. can be implemented Implementations of the subject matter described herein are one or more computer program products, that is, one or more modules of computer program instructions encoded on a tangible program storage medium for execution by or for controlling the operation of a processing system. can be implemented

컴퓨터로 판독 가능한 매체는 기계로 판독 가능한 저장 장치, 기계로 판독 가능한 저장 기판, 메모리 장치, 기계로 판독 가능한 전파형 신호에 영향을 미치는 물질의 조성물 혹은 이들 중 하나 이상의 조합일 수 있다.A computer readable medium may be a machine readable storage device, a machine readable storage substrate, a memory device, a composition of matter that affects a machine readable propagating signal, or a combination of one or more of these.

본 명세서에서 '시스템'이나 '장치'라 함은 예컨대 프로그래머블 프로세서, 컴퓨터 혹은 다중 프로세서나 컴퓨터를 포함하여 데이터를 처리하기 위한 모든 기구, 장치 및 기계를 포괄한다. 처리 시스템은, 하드웨어에 부가하여, 예컨대 프로세서 펌웨어를 구성하는 코드, 프로토콜 스택, 데이터베이스 관리 시스템, 운영 체제 혹은 이들 중 하나 이상의 조합 등 요청 시 컴퓨터 프로그램에 대한 실행 환경을 형성하는 코드를 포함할 수 있다.In this specification, the term 'system' or 'apparatus' encompasses all devices, devices, and machines for processing data, including, for example, a programmable processor, computer, or multiple processors or computers. A processing system may include, in addition to hardware, code that forms an execution environment for computer programs on demand, such as, for example, code constituting processor firmware, a protocol stack, a database management system, an operating system, or a combination of one or more of these. .

컴퓨터 프로그램(프로그램, 소프트웨어, 소프트웨어 어플리케이션, 스크립트 혹은 코드로도 알려져 있음)은 컴파일되거나 해석된 언어나 선험적 혹은 절차적 언어를 포함하는 프로그래밍 언어의 어떠한 형태로도 작성될 수 있으며, 독립형 프로그램이나 모듈, 컴포넌트, 서브루틴 혹은 컴퓨터 환경에서 사용하기에 적합한 다른 유닛을 포함하여 어떠한 형태로도 전개될 수 있다. 컴퓨터 프로그램은 파일 시스템의 파일에 반드시 대응하는 것은 아니다. 프로그램은 요청된 프로그램에 제공되는 단일 파일 내에, 혹은 다중의 상호 작용하는 파일(예컨대, 하나 이상의 모듈, 하위 프로그램 혹은 코드의 일부를 저장하는 파일) 내에, 혹은 다른 프로그램이나 데이터를 보유하는 파일의 일부(예컨대, 마크업 언어 문서 내에 저장되는 하나 이상의 스크립트) 내에 저장될 수 있다. 컴퓨터 프로그램은 하나의 사이트에 위치하거나 복수의 사이트에 걸쳐서 분산되어 통신 네트워크에 의해 상호 접속된 다중 컴퓨터나 하나의 컴퓨터 상에서 실행되도록 전개될 수 있다.A computer program (also known as a program, software, software application, script or code) may be written in any form of programming language, including compiled or interpreted language, a priori or procedural language, and may be a stand-alone program or module; It may be deployed in any form including components, subroutines, or other units suitable for use in a computer environment. A computer program does not necessarily correspond to a file in a file system. A program may be in a single file provided to the requested program, or in multiple interacting files (e.g., one or more modules, subprograms, or files that store portions of code), or parts of files that hold other programs or data. (eg, one or more scripts stored within a markup language document). A computer program may be deployed to be executed on a single computer or multiple computers located at one site or distributed across multiple sites and interconnected by a communication network.

한편, 컴퓨터 프로그램 명령어와 데이터를 저장하기에 적합한 컴퓨터로 판독 가능한 매체는, 예컨대 EPROM, EEPROM 및 플래시메모리 장치와 같은 반도체 메모리 장치, 예컨대 내부 하드디스크나 외장형 디스크와 같은 자기 디스크, 자기광학 디스크 및 CD-ROM과 DVD-ROM 디스크를 포함하여 모든 형태의 비휘발성 메모리, 매체 및 메모리 장치를 포함할 수 있다. 프로세서와 메모리는 특수 목적의 논리 회로에 의해 보충되거나, 그것에 통합될 수 있다.On the other hand, computer-readable media suitable for storing computer program instructions and data include, for example, semiconductor memory devices such as EPROM, EEPROM and flash memory devices, magnetic disks such as internal hard disks or external disks, magneto-optical disks and CDs. - may include all forms of non-volatile memory, media and memory devices, including ROM and DVD-ROM disks. The processor and memory may be supplemented by, or incorporated into, special purpose logic circuitry.

본 명세서에서 설명한 주제의 구현물은 예컨대 데이터 서버와 같은 백엔드 컴포넌트를 포함하거나, 예컨대 어플리케이션 서버와 같은 미들웨어 컴포넌트를 포함하거나, 예컨대 사용자가 본 명세서에서 설명한 주제의 구현물과 상호 작용할 수 있는 웹 브라우저나 그래픽 유저 인터페이스를 갖는 클라이언트 컴퓨터와 같은 프론트엔드 컴포넌트 혹은 그러한 백엔드, 미들웨어 혹은 프론트엔드 컴포넌트의 하나 이상의 모든 조합을 포함하는 연산 시스템에서 구현될 수도 있다. 시스템의 컴포넌트는 예컨대 통신 네트워크와 같은 디지털 데이터 통신의 어떠한 형태나 매체에 의해서도 상호 접속 가능하다.Implementations of the subject matter described herein may include back-end components, such as, for example, data servers, or may include middleware components, such as, for example, application servers, or may include, for example, web browsers or graphical users through which users may interact with implementations of the subject matter described herein. It may also be implemented in a computing system that includes a front-end component, such as a client computer having an interface, or any combination of one or more of such back-ends, middleware, or front-end components. The components of the system are interconnectable by any form or medium of digital data communication, such as, for example, a communication network.

본 명세서는 다수의 특정한 구현물의 세부사항들을 포함하지만, 이들은 어떠한 발명이나 청구 가능한 것의 범위에 대해서도 제한적인 것으로서 이해되어서는 안되며, 오히려 특정한 발명의 특정한 실시형태에 특유할 수 있는 특징들에 대한 설명으로서 이해되어야 한다. 마찬가지로, 개별적인 실시형태의 문맥에서 본 명세서에 기술된 특정한 특징들은 단일 실시형태에서 조합하여 구현될 수도 있다. 반대로, 단일 실시형태의 문맥에서 기술한 다양한 특징들 역시 개별적으로 혹은 어떠한 적절한 하위 조합으로도 복수의 실시형태에서 구현 가능하다. 나아가, 특징들이 특정한 조합으로 동작하고 초기에 그와 같이 청구된 바와 같이 묘사될 수 있지만, 청구된 조합으로부터의 하나 이상의 특징들은 일부 경우에 그 조합으로부터 배제될 수 있으며, 그 청구된 조합은 하위 조합이나 하위 조합의 변형물로 변경될 수 있다.Although this specification contains many specific implementation details, they should not be construed as limiting on the scope of any invention or what is claimed, but rather as a description of features that may be unique to a particular embodiment of a particular invention. It should be understood. Likewise, certain features that are described in this specification in the context of separate embodiments may also be implemented in combination in a single embodiment. Conversely, various features that are described in the context of a single embodiment can also be implemented in multiple embodiments individually or in any suitable subcombination. Further, while features may operate in particular combinations and are initially depicted as such claimed, one or more features from a claimed combination may in some cases be excluded from that combination, and the claimed combination is a subcombination. or sub-combination variations.

또한, 본 명세서에서는 특정한 순서로 도면에서 동작들을 묘사하고 있지만, 이는 바람직한 결과를 얻기 위하여 도시된 그 특정한 순서나 순차적인 순서대로 그러한 동작들을 수행하여야 한다거나 모든 도시된 동작들이 수행되어야 하는 것으로 이해되어서는 안 된다. 특정한 경우, 멀티태스킹과 병렬 프로세싱이 유리할 수 있다. 또한, 상술한 실시형태의 다양한 시스템 컴포넌트의 분리는 그러한 분리를 모든 실시형태에서 요구하는 것으로 이해되어서는 안되며, 설명한 프로그램 컴포넌트와 시스템들은 일반적으로 단일의 소프트웨어 제품으로 함께 통합되거나 다중 소프트웨어 제품에 패키징될 수 있다는 점을 이해하여야 한다In addition, although operations are depicted in the drawings in a specific order in this specification, it is not to be understood that such operations must be performed in the specific order shown or sequential order or that all illustrated operations must be performed in order to obtain desired results. Can not be done. In certain cases, multitasking and parallel processing can be advantageous. Further, the separation of various system components in the embodiments described above should not be understood as requiring such separation in all embodiments, and the program components and systems described may generally be integrated together into a single software product or packaged into multiple software products. It should be understood that you can

이와 같이, 본 명세서는 그 제시된 구체적인 용어에 본 발명을 제한하려는 의도가 아니다. 따라서, 상술한 예를 참조하여 본 발명을 상세하게 설명하였지만, 당업자라면 본 발명의 범위를 벗어나지 않으면서도 본 예들에 대한 개조, 변경 및 변형을 가할 수 있다. 본 발명의 범위는 상기 상세한 설명보다는 후술하는 특허청구범위에 의하여 나타내어지며, 특허청구범위의 의미 및 범위 그리고 그 등가개념으로부터 도출되는 모든 변경 또는 변형된 형태가 본 발명의 범위에 포함되는 것으로 해석되어야 한다.As such, this specification is not intended to limit the invention to the specific terms presented. Therefore, although the present invention has been described in detail with reference to the above-described examples, those skilled in the art may make alterations, changes, and modifications to the present examples without departing from the scope of the present invention. The scope of the present invention is indicated by the following claims rather than the detailed description above, and all changes or modifications derived from the meaning and scope of the claims and their equivalent concepts should be interpreted as being included in the scope of the present invention. do.

이상에서와 같이 본 발명에 따른 슬롯 필링 기반의 챗봇 서비스 제공 방법 및 장치는 상기한 바와 같이 설명된 실시예들의 구성과 방법이 한정되게 적용될 수 있는 것이 아니라, 상기 실시예들은 다양한 변형이 이루어질 수 있도록 각 실시예들의 전부 또는 일부가 선택적으로 조합되어 구성될 수도 있다.As described above, the slot filling-based chatbot service providing method and apparatus according to the present invention are not limited to the configuration and method of the embodiments described above, but the embodiments can be modified in various ways All or part of each embodiment may be configured by selectively combining them.

본 발명에 의하면 슬롯 필링 기반의 챗봇 서비스 제공 방법 및 장치가 개시된다. 본 발명의 일실시예에 따른 챗봇 서비스 제공 방법은, 사용자 대화에 상응하는 인텐트를 결정하고, 인텐트 매핑 리스트를 이용하여 인텐트에 상응하는 실행블록을 선택하고, 실행블록에 상응하는 슬롯 필링을 수행하고, 슬롯 필링에 기반하여 인텐트에 상응하는 대화 처리를 수행하고, 인텐트 매핑 리스트는 실행블록들 각각을 위하여 구비되고, 적어도 하나 이상의 인텐트에 상응한다. 이에 따라, 다양한 사용자 대화 패턴에 대해 챗봇이 효과적으로 대응할 수 있어, 효율적인 챗봇 서비스를 제공하는 것이 가능하다.According to the present invention, a method and apparatus for providing a chatbot service based on slot filling are disclosed. A method for providing a chatbot service according to an embodiment of the present invention determines an intent corresponding to a user conversation, selects an execution block corresponding to the intent using an intent mapping list, and fills slots corresponding to the execution block. , performs dialog processing corresponding to an intent based on slot filling, and an intent mapping list is provided for each of the execution blocks and corresponds to at least one intent. Accordingly, the chatbot can effectively respond to various user conversation patterns, making it possible to provide an efficient chatbot service.

610: 통신부 620: 프로세서
630: 메모리 710: 챗봇
720: 자연어 처리기 730: 챗봇 리소스 DB
740: 챗봇 빌더
610: communication unit 620: processor
630: memory 710: chatbot
720: natural language processor 730: chatbot resource DB
740: chatbot builder

Claims (5)

슬롯 필링 기반의 서비스 제공 장치가,
사용자 대화에 상응하는 인텐트를 결정하는 단계;
인텐트 매핑 리스트를 이용하여 상기 인텐트에 상응하는 실행블록을 선택하는 단계;
상기 실행블록에 상응하는 슬롯 필링을 수행하는 단계;
상기 슬롯 필링에 기반하여 상기 인텐트에 상응하는 대화 처리를 수행하는 단계를 포함하고,
하나의 슬롯은 복수개의 엔티티들과 매핑 가능한 것을 특징으로 하는 슬롯 필링 기반의 챗봇 서비스 제공 방법.
A slot filling based service providing device,
determining an intent corresponding to the user conversation;
selecting an execution block corresponding to the intent using an intent mapping list;
performing slot filling corresponding to the execution block;
performing conversation processing corresponding to the intent based on the slot filling;
A slot filling-based chatbot service providing method, characterized in that one slot can be mapped with a plurality of entities.
청구항 1에 있어서,
하나의 엔티티는 복수개의 대표어들을 갖는 것을 특징으로 하는 슬롯 필링 기반의 챗봇 서비스 제공 방법.
The method of claim 1,
A method for providing a chatbot service based on slot filling, characterized in that one entity has a plurality of representative words.
청구항 1에 있어서,
상기 슬롯 필링 기반의 챗봇 서비스 제공 장치가,
상기 실행블록이 포함되는 시나리오를 고려하여 이전에 입력된 슬롯을 그대로 사용하여 슬롯 컨텍스트를 유지할 수 있는 슬롯 재사용 설정을 수행하는 단계를 더 포함하는 것을 특징으로 하는 슬롯 필링 기반의 챗봇 서비스 제공 방법.
The method of claim 1,
The slot filling-based chatbot service providing device,
Slot filling-based chatbot service providing method further comprising the step of performing a slot reuse setting capable of maintaining a slot context by using a previously input slot as it is in consideration of a scenario including the execution block.
청구항 3에 있어서,
상기 슬롯 재사용 설정이 수행된 실행블록과 연결된 인텐트들의 슬롯들은 상기 시나리오가 종료된 후 다시 실행했을 때에도 슬롯 값이 삭제되지 않는 것을 특징으로 하는 슬롯 필링 기반의 챗봇 서비스 제공 방법.
The method of claim 3,
The method of providing a chatbot service based on slot filling, characterized in that the slot values of the slots of intents connected to the execution block in which the slot reuse setting is performed are not deleted even when the slots are re-executed after the scenario ends.
청구항 1에 있어서,
상기 인텐트 매핑 리스트는
실행블록들 각각을 위하여 구비되고, 적어도 하나 이상의 인텐트에 상응하되, 인텐트별로 인텐트 식별자 및 슬롯 조건을 포함하는 것을 특징으로 하는 슬롯 필링 기반의 챗봇 서비스 제공 방법.
The method of claim 1,
The intent mapping list is
A method for providing a chatbot service based on slot filling, which is provided for each of the execution blocks, and corresponds to at least one intent, but includes an intent identifier and a slot condition for each intent.
KR1020220148686A 2020-09-22 2022-11-09 Method and apparatus for providing chatbot service based on slot filling KR20220155957A (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1020220148686A KR20220155957A (en) 2020-09-22 2022-11-09 Method and apparatus for providing chatbot service based on slot filling

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
KR1020200122353A KR102466947B1 (en) 2020-09-22 2020-09-22 Method and apparatus for providing chatbot service based on slot filling
KR1020220148686A KR20220155957A (en) 2020-09-22 2022-11-09 Method and apparatus for providing chatbot service based on slot filling

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
KR1020200122353A Division KR102466947B1 (en) 2020-09-22 2020-09-22 Method and apparatus for providing chatbot service based on slot filling

Publications (1)

Publication Number Publication Date
KR20220155957A true KR20220155957A (en) 2022-11-24

Family

ID=80995897

Family Applications (2)

Application Number Title Priority Date Filing Date
KR1020200122353A KR102466947B1 (en) 2020-09-22 2020-09-22 Method and apparatus for providing chatbot service based on slot filling
KR1020220148686A KR20220155957A (en) 2020-09-22 2022-11-09 Method and apparatus for providing chatbot service based on slot filling

Family Applications Before (1)

Application Number Title Priority Date Filing Date
KR1020200122353A KR102466947B1 (en) 2020-09-22 2020-09-22 Method and apparatus for providing chatbot service based on slot filling

Country Status (1)

Country Link
KR (2) KR102466947B1 (en)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114881046B (en) * 2022-05-23 2023-07-25 平安科技(深圳)有限公司 Training method and device for task session model, computer equipment and storage medium

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20190006403A (en) 2017-07-10 2019-01-18 삼성전자주식회사 Voice processing method and system supporting the same

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101883185B1 (en) * 2016-08-09 2018-07-30 주식회사 피노텍 Robot automatic counselling method and system with determined scenario using machine-learning
KR102289917B1 (en) * 2017-06-30 2021-08-12 삼성에스디에스 주식회사 Method for processing dialogue using dialogue act information and Apparatus thereof
KR102155739B1 (en) * 2019-10-24 2020-09-14 한경훈 Method, server, and system for providing chatbot service with adaptive reuse of question and answer dataset

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20190006403A (en) 2017-07-10 2019-01-18 삼성전자주식회사 Voice processing method and system supporting the same

Also Published As

Publication number Publication date
KR102466947B1 (en) 2022-11-14
KR20220039339A (en) 2022-03-29

Similar Documents

Publication Publication Date Title
US10878009B2 (en) Translating natural language utterances to keyword search queries
CA3040373C (en) Deep learning techniques based multi-purpose conversational agents for processing natural language queries
US10540965B2 (en) Semantic re-ranking of NLU results in conversational dialogue applications
US10585957B2 (en) Task driven user intents
US10466885B2 (en) Transactional conversation-based computing system
US11315560B2 (en) Method for conducting dialog between human and computer
CN109690480B (en) Disambiguating conversational understanding system
CN103700369B (en) Phonetic navigation method and system
US20220237233A1 (en) Method and system for generating a conversational agent by automatic paraphrase generation based on machine translation
EP3513324B1 (en) Computerized natural language query intent dispatching
US20200036762A1 (en) Facilitating conversations with automated location mapping
CN109033223A (en) For method, apparatus, equipment and computer readable storage medium across type session
WO2021082836A1 (en) Robot dialogue method, apparatus and device, and computer-readable storage medium
US20120253789A1 (en) Conversational Dialog Learning and Correction
KR20180108973A (en) Method and for providing automatic translation in user conversation using multiple languages
CN101923565A (en) The method and system that is used for query tree navigation
KR20220155957A (en) Method and apparatus for providing chatbot service based on slot filling
US11823082B2 (en) Methods for orchestrating an automated conversation in one or more networks and devices thereof
KR102566822B1 (en) Method and apparatus for providing chatbot service
US20230108637A1 (en) Generating sorted lists of chat bot design nodes using escalation logs
KR102280439B1 (en) Apparatus for analyzing intention of query and method thereof
KR102475796B1 (en) Method and apparatus for providing chatbot service using condition expression generated interface
KR102518901B1 (en) Method and apparatus for providing chatbot service using block component
KR102192447B1 (en) Method and for providing automatic translation in user conversation using multiple languages
KR102655058B1 (en) Method and apparatus for providing chatbot service using condition expression generated interface

Legal Events

Date Code Title Description
A107 Divisional application of patent