KR20230066922A - Method for partner matching using machine reading comprehension and computer readable recording medium thereof - Google Patents

Method for partner matching using machine reading comprehension and computer readable recording medium thereof Download PDF

Info

Publication number
KR20230066922A
KR20230066922A KR1020210152445A KR20210152445A KR20230066922A KR 20230066922 A KR20230066922 A KR 20230066922A KR 1020210152445 A KR1020210152445 A KR 1020210152445A KR 20210152445 A KR20210152445 A KR 20210152445A KR 20230066922 A KR20230066922 A KR 20230066922A
Authority
KR
South Korea
Prior art keywords
user
partner
text
computing device
information
Prior art date
Application number
KR1020210152445A
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 KR1020210152445A priority Critical patent/KR20230066922A/en
Publication of KR20230066922A publication Critical patent/KR20230066922A/en

Links

Images

Classifications

    • 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
    • G06Q30/00Commerce
    • G06Q30/06Buying, selling or leasing transactions
    • G06Q30/08Auctions
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/20Natural language analysis

Landscapes

  • Engineering & Computer Science (AREA)
  • Business, Economics & Management (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Accounting & Taxation (AREA)
  • Finance (AREA)
  • General Physics & Mathematics (AREA)
  • Economics (AREA)
  • Strategic Management (AREA)
  • General Business, Economics & Management (AREA)
  • Marketing (AREA)
  • Development Economics (AREA)
  • Entrepreneurship & Innovation (AREA)
  • Health & Medical Sciences (AREA)
  • Artificial Intelligence (AREA)
  • Audiology, Speech & Language Pathology (AREA)
  • Computational Linguistics (AREA)
  • General Health & Medical Sciences (AREA)
  • General Engineering & Computer Science (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

According to various embodiments of the present disclosure, provided is a computer-readable storage medium for storing one or more programs. When the programs are executed by at least one processor of a computing device having a communication circuit, the programs include instructions for leading the computing device to: collect a plurality of user information input from user devices of a plurality of users; define a plurality of user characteristic texts related to each of the users to use the user information for machine reading comprehension (MRC) on the basis of a text; receive a request message including a partner searching request input by a user from another user device; generate a question text by preprocessing the request message to be used for the MRC; determine a matching score by extracting an answer section for the preprocessed question text from each of the user characteristic texts using an MRC engine; and determine at least a part of the users corresponding to the user characteristic text in which the matching score is a threshold or more among the user characteristic texts as a subject of the partner searching request. In addition, various other embodiments are possible. Therefore, a partner with similar interests and tastes can be more precisely matched.

Description

기계 독해를 이용한 파트너 매칭 방법 및 컴퓨터 판독가능 기록매체{METHOD FOR PARTNER MATCHING USING MACHINE READING COMPREHENSION AND COMPUTER READABLE RECORDING MEDIUM THEREOF}Partner matching method using machine reading comprehension and computer readable recording medium

기계 독해를 이용한 파트너 매칭 방법 및 컴퓨터 판독가능 기록매체에 관한 것이다. It relates to a partner matching method using machine reading comprehension and a computer readable recording medium.

그간 학교, 지역, 직장을 중심으로 존재하던 오프라인 커뮤니티가 빠르게 해체되고, 코로나(COVID-19) 사태가 겹쳐져 초개인사회로 진입함에 따라 느슨한 연결을 기반으로 한 온라인 커뮤니티 서비스에 대한 니즈가 어느 때 보다 높아졌다. 하지면 현재, 이러한 온라인 커뮤니티 서비스는 연애 상대를 찾거나, 특정 관심 분야에 치우쳐 다양성을 추구하기 어렵다는 단점이 있다. As offline communities that have existed centered on schools, regions, and workplaces are rapidly dissolving, and the corona (COVID-19) incident overlaps and enters a hyper-individual society, the need for online community services based on loose connections is greater than ever. It has risen. However, currently, these online community services have a disadvantage in that it is difficult to find a dating partner or pursue diversity because they are biased toward a specific field of interest.

예를 들어, 한국 공개특허공보 제10-2021-0109372호(2021.9.6. 공개)에서는 "골프 파트너 매칭 방법 및 장치"라는 선행발명을 개시하고 있다. 하지만 상기 선행발명을 이용하는 사용자들은 골프라는 통일된 관심사를 기반하여 파트너를 매칭하는 것에 이용하는 사용자들의 수와 함께 즐길 수 있는 활동이 제한적이다. 따라서, 더 많은 사람들이 취향이 통하는 친구와 여가를 즐길 수 있도록 돕는 관심사 기반의 온라인 커뮤니티 서비스가 필요하다. For example, Korean Patent Publication No. 10-2021-0109372 (published on September 6, 2021) discloses a prior invention called "golf partner matching method and device". However, the number of users using the prior invention for matching partners based on a unified interest of golf is limited in activities that can be enjoyed together with the number of users. Therefore, an interest-based online community service that helps more people enjoy leisure time with friends who have common tastes is needed.

대한민국 공개특허공보 제10-2021-0109372호(2021.9.6. 공개)Republic of Korea Patent Publication No. 10-2021-0109372 (published on September 6, 2021)

본 개시는 관심사 기반 커뮤니티 서비스로서, 관심분야와 취향이 통하는 파트너를 매칭시켜주는 서비스를 제공하는 파트너 매칭 방법 및 컴퓨터 판독가능 기록매체를 제공하고자 한다.The present disclosure intends to provide a partner matching method and a computer readable recording medium that provide a service for matching partners with common interests and tastes as an interest-based community service.

또한, 본 개시는 사용자가 서비스가 단순히 제안하는 형식에 맞추어 관심분야와 취향이 통하는 파트너를 찾는 것이 아니라, 파트너를 찾는 요청 메시지를 문장의 형태로 직접 입력하게 하고, 이에 대한 기계 독해를 통하여 해당 요청 메시지에 적합한 사용자를 파트너로서 결정하는, 기계 독해를 이용한 파트너 매칭 방법 및 컴퓨터 판독가능 기록매체를 제공하고자 한다.In addition, the present disclosure allows a user to directly input a request message to find a partner in the form of a sentence, rather than simply searching for a partner with interests and tastes in accordance with the form suggested by the service, and through machine reading of the corresponding request. It is intended to provide a partner matching method using machine reading and a computer readable recording medium that determines a user suitable for a message as a partner.

본 문서에서 이루고자 하는 기술적 과제는 상술한 기술적 과제로 제한되지 않으며, 언급되지 않은 또 다른 기술적 과제들은 아래의 기재로부터 본 발명이 속하는 기술분야에서 통상의 지식을 가진 자에게 명확하게 이해될 수 있을 것이다. The technical problem to be achieved in this document is not limited to the above-described technical problem, and other technical problems not mentioned will be clearly understood by those skilled in the art from the description below. .

본 개시의 다양한 실시예들에 따르는, 하나 이상의 프로그램들을 저장하는 컴퓨터 판독가능 저장 매체에 있어서, 상기 하나 이상의 프로그램들은, 통신 회로를 가지는 컴퓨팅 장치의 적어도 하나의 프로세서에 의해 실행될 시, 복수의 사용자의 사용자 장치로부터 입력된 복수의 사용자 정보를 수집하고; 상기 복수의 사용자 정보를 텍스트에 기초하여, 기계 독해(Machine Reading Comprehension, MRC)에 사용될 수 있도록, 상기 복수의 사용자 각각에 관련된 복수의 사용자 특성 텍스트를 정의하고; 또다른 사용자 장치로부터 사용자에 의해 입력된 파트너 찾기 요청이 포함된 요청 메시지를 수신하고; 상기 요청 메시지를 상기 기계 독해에 사용될 수 있도록 전처리하여 질문 텍스트를 생성하고; 기계 독해 엔진을 이용하여, 상기 복수의 사용자 특성 텍스트 각각으로부터 상기 전처리된 질문 텍스트에 대한 답변 구간을 추출하여 매칭 점수를 결정하고; 및 상기 복수의 사용자 특성 텍스트 중에서 상기 매칭 점수가 임계치 이상인 사용자 특성 텍스트에 대응하는 사용자 중 적어도 일부를 상기 파트너 찾기 요청의 대상으로 결정하도록, 상기 컴퓨팅 장치를 야기하는 인스트럭션들을 포함할 수 있다. According to various embodiments of the present disclosure, in a computer readable storage medium storing one or more programs, the one or more programs, when executed by at least one processor of a computing device having communication circuitry, for a plurality of users. Collecting a plurality of user information input from the user device; Defining a plurality of user characteristic texts related to each of the plurality of users so that the plurality of user information can be used for machine reading comprehension (MRC) based on text; Receive a request message including a request for finding a partner input by a user from another user device; generating question text by preprocessing the request message so that it can be used for the machine reading comprehension; extracting an answer section for the preprocessed question text from each of the plurality of user characteristic texts using a machine reading engine to determine a matching score; and instructions for causing the computing device to determine at least some of users corresponding to user characteristic text having a matching score equal to or greater than a threshold among the plurality of user characteristic texts as targets of the partner search request.

본 개시의 다양한 실시예들에 따르는 상기 하나 이상의 프로그램들은, 상기 복수의 사용자 특성 텍스트 중에서 상기 매칭 점수가 임계치 이상인 사용자 특성에 대응하는 사용자를 상기 파트너 찾기 요청의 대상으로 결정하도록, 상기 컴퓨팅 장치를 야기하는 인스트럭션들을 포함할 수 있다. The one or more programs according to various embodiments of the present disclosure may cause the computing device to determine a user corresponding to a user characteristic having a matching score equal to or higher than a threshold among the plurality of user characteristic texts as a target of the partner search request. It may contain instructions that

본 개시의 다양한 실시예들에 따르는 상기 하나 이상의 프로그램들은, 상기 복수의 사용자 특성 텍스트 중에서 상기 매칭 점수가 임계치 이상인 사용자 특성 텍스트에 대한 감정 분석을 수행하여 상기 매칭 점수를 보정하도록, 상기 컴퓨팅 장치를 야기하는 인스트럭션들을 포함할 수 있다. The one or more programs according to various embodiments of the present disclosure cause the computing device to correct the matching score by performing sentiment analysis on a user characteristic text having a matching score greater than or equal to a threshold value among the plurality of user characteristic texts. It may contain instructions that

본 개시의 다양한 실시예들에 따르는 상기 하나 이상의 프로그램들은, 상기 복수의 사용자 정보의 각각은, 복수의 사용자 각각의 거주지 정보를 더 포함하고, 상기 하나 이상의 프로그램들은, 통신 회로를 가지는 컴퓨팅 장치의 적어도 하나의 프로세서에 의해 실행될 시, 상기 또다른 사용자 장치의 사용자의 거주지 정보와 비교하여 일정 기준을 충족하지 못하는 경우, 해당 사용자는 상기 파트너 찾기 요청의 대상에서 제외되도록, 상기 컴퓨팅 장치를 야기하는 인스트럭션들을 더 포함할 수 있다. In the one or more programs according to various embodiments of the present disclosure, each of the plurality of user information further includes residence information of each of the plurality of users, and the one or more programs may include at least one of a computing device having a communication circuit. Instructions that, when executed by one processor, cause the computing device to be compared with the user's residence information of the other user device and to exclude the user from the partner search request if a certain criterion is not satisfied. can include more.

본 개시의 다양한 실시예들에 따르면, 상기 복수의 사용자 정보의 각각은, 복수의 사용자 각각의 성격 정보를 더 포함하고, 상기 하나 이상의 프로그램들은, 통신 회로를 가지는 컴퓨팅 장치의 적어도 하나의 프로세서에 의해 실행될 시, 상기 또다른 사용자 장치의 사용자의 성격 정보와 비교하여 일정 기준을 충족하지 못하는 경우, 해당 사용자는 상기 파트너 찾기 요청의 대상에서 제외되도록, 상기 컴퓨팅 장치를 야기하는 인스트럭션들을 더 포함할 수 있다. According to various embodiments of the present disclosure, each of the plurality of user information further includes personality information of each of the plurality of users, and the one or more programs are executed by at least one processor of a computing device having a communication circuit. When executed, it may further include instructions that cause the computing device to exclude the user from the target of the partner search request when the user's personality information of the other user device does not meet a predetermined criterion. .

본 개시의 다양한 실시예들에 따르면, 상기 요청 메시지를 상기 기계 독해에 사용되도록 전처리하여 질문 텍스트를 생성하도록, 상기 컴퓨팅 장치를 야기하는 인스트럭션들을 포함하는 상기 하나 이상의 프로그램들은, 상기 요청 메시지에서 키워드를 추출하고, 상기 추출된 키워드를 이용하여 상기 질문 텍스트를 생성하도록, 상기 컴퓨팅 장치를 야기하는 인스트럭션들을 포함할 수 있다. According to various embodiments of the present disclosure, the one or more programs including instructions that cause the computing device to preprocess the request message to be used for machine reading comprehension to generate a query text, the one or more programs including keywords in the request message and instructions that cause the computing device to extract and generate the question text using the extracted keywords.

본 개시의 다양한 실시예들에 있어서 상기 복수의 사용자 정보의 각각은, 복수의 사용자 각각의, 적어도 하나의 관심 분야에 대한 정보를 포함하고, 상기 하나 이상의 프로그램들은, 상기 복수의 사용자 정보를 텍스트를 기계 독해에 사용될 수 있도록, 상기 복수의 사용자 각각에 관련된 복수의 사용자 특성 텍스트를 정의하도록, 상기 컴퓨팅 장치를 야기하는 인스트럭션들을 포함할 수 있다. In various embodiments of the present disclosure, each of the plurality of user information includes information on at least one area of interest of each of the plurality of users, and the one or more programs convert the plurality of user information into text. and instructions that cause the computing device to define a plurality of user specific texts associated with each of the plurality of users so that they can be used for machine reading.

본 개시의 다양한 실시예들에 있어서, 상기 하나 이상의 프로그램들은, 통신 회로를 가지는 컴퓨팅 장치의 적어도 하나의 프로세서에 의해 실행될 시, 상기 또다른 사용자 장치에 상기 파트너 찾기 요청의 대상으로 결정된 사용자에 대한 사용자 정보를 송신하도록, 상기 컴퓨팅 장치를 야기하는 인스트럭션들을 포함할 수 있다. In various embodiments of the present disclosure, when the one or more programs are executed by at least one processor of a computing device having a communication circuit, the user for the user determined as the target of the partner search request to the other user device. It may include instructions that cause the computing device to transmit information.

본 개시의 다양한 실시예들에 따르는 상기 하나 이상의 프로그램들은, 또다른 사용자 장치의 사용자가 자격 요건으로서 챌린지를 달성하였는지를 확인하고; 및 또 상기 또다른 사용자 장치의 사용자가 자격 요건으로서 챌린지를 달성한 경우에만 상기 또다른 사용자 장치로부터 파트너 찾기 요청에 포함된 텍스트를 입력받는 동작을 인가하도록, 상기 컴퓨팅 장치를 야기하는 인스트럭션들을 포함할 수 있다. The one or more programs according to various embodiments of the present disclosure may check whether a user of another user device has achieved a challenge as a qualification requirement; and instructions for causing the computing device to authorize an operation of receiving text included in a request to find a partner from the other user device only when the user of the other user device achieves a challenge as a qualification. can

본 개시의 다양한 실시예들에 따른 기계 독해를 이용한 파트너 매칭 방법 및 컴퓨터 판독가능 기록매체는, 사용자의 직접입력 정보 및 선택입력 정보에 대한 기계 독해를 통하여, 단순하게 파라미터를 비교하는 기존의 매칭 시스템와 비교하여 관심분야 및 취향이 통하는 파트너를 보다 정교하게 매칭시켜줄 수 있다. A partner matching method and a computer readable recording medium using machine reading according to various embodiments of the present disclosure are a conventional matching system and a computer readable recording medium that simply compare parameters through machine reading of user's direct input information and selective input information. By comparing, it is possible to more precisely match partners with interests and tastes.

본 개시에서 얻을 수 있는 효과는 상술한 효과들로 제한되지 않으며, 언급하지 않은 또 다른 효과들은 아래의 기재로부터 본 개시가 속하는 기술 분야에서 통상의 지식을 가진 자에게 명확하게 이해될 수 있을 것이다. Effects obtainable in the present disclosure are not limited to the above-mentioned effects, and other effects not mentioned will be clearly understood by those skilled in the art from the description below.

도 1은 사용자가 로컬 컴퓨팅 장치로서 사용자 장치와 상호작용하여 다른 사용자를 파트너로서 매칭시켜주는 서비스를 받을 수 있는 시스템 환경을 도시한다.
도 2는 본 개시의 다양한 실시예들에 따른 파트너 매칭기의 세부 구성도이다.
도 3a 내지 도 3d는 본 개시의 다양한 실시예들에 따라서, 사용자 정보를 입력하고, 입력된 사용자 정보에 기초하여 생성되는 사용자 프로필이 사용자 장치 상에 디스플레이되는 예시적인 화면을 도시한다.
도 4a는 본 개시의 다양한 실시예들에 따라서, 사용자 장치 상에 파트너 찾기 요청을 입력받기 위해 디스플레이되는 예시적인 화면 및 도식화된 전처리 과정을 도시한다.
도 4b는 본 개시의 다양한 실시예들에 따라서, 사용자 장치 상에 파트너로서 결정된 다른 사용자들에 대한 사용자 정보가 디스플레이되는 예시적인 화면을 도시한다.
도 5는 본 개시의 다양한 실시예들에 따라 기계 독해를 이용하여 파트너를 매칭하는 프로세스를 나타내는 흐름도이다.
도 6은본 개시의 다양한 실시예들에 따라 파트너 찾기 요청이 포함된 요청 메시지를 수신하는 경우 수행되는 구체적인 프로세서를 나타내는 흐름도이다.
도 7은 본 개시의 다양한 실시예들에 따라, 기계 독해를 이용한 파트너 매칭 시스템을 운용하는 데 이용될 수 있는 컴퓨터 프로그램 제품을 도시한다.
1 illustrates a system environment in which a user can interact with a user device as a local computing device to receive a service that matches other users as partners.
2 is a detailed configuration diagram of a partner matcher according to various embodiments of the present disclosure.
3A to 3D illustrate exemplary screens in which user information is input and a user profile generated based on the input user information is displayed on a user device, according to various embodiments of the present disclosure.
4A illustrates an exemplary screen displayed on a user device to receive a request to find a partner and a schematic pre-processing process, according to various embodiments of the present disclosure.
4B illustrates an example screen on which user information for other users determined as partners is displayed on a user device, in accordance with various embodiments of the present disclosure.
5 is a flow diagram illustrating a process of matching a partner using machine reading in accordance with various embodiments of the present disclosure.
6 is a flowchart illustrating a specific process performed when a request message including a request to find a partner is received according to various embodiments of the present disclosure.
7 illustrates a computer program product that may be used to operate a partner matching system using machine reading, in accordance with various embodiments of the present disclosure.

이하, 첨부한 도면을 참조하여 본 개시가 속하는 기술 분야에서 통상의 지식을 가진 자가 용이하게 실시할 수 있도록 본원의 구현예 및 실시예를 상세히 설명한다. 그러나, 본원은 여러 가지 상이한 형태로 구현될 수 있으며 여기에서 설명하는 구현예 및 실시예에 한정되지 않는다.Hereinafter, with reference to the accompanying drawings, embodiments and embodiments of the present disclosure will be described in detail so that those skilled in the art can easily practice them. However, this disclosure may be embodied in many different forms and is not limited to the embodiments and examples set forth herein.

실시예들에 대한 특정한 구조적 또는 기능적 설명들은 단지 예시를 위한 목적으로 개시된 것으로서, 다양한 형태로 변경되어 실시될 수 있다. 따라서, 실시예들은 특정한 개시형태로 한정되는 것이 아니며, 본 명세서의 범위는 기술적 사상에 포함되는 변경, 균등물, 또는 대체물을 포함한다.Specific structural or functional descriptions of the embodiments are disclosed for illustrative purposes only, and may be modified and implemented in various forms. Therefore, the embodiments are not limited to the specific disclosed form, and the scope of the present specification includes changes, equivalents, or substitutes included in the technical spirit.

제1 또는 제2 등의 용어를 다양한 구성요소들을 설명하는데 사용될 수 있지만, 이런 용어들은 하나의 구성요소를 다른 구성요소로부터 구별하는 목적으로만 해석되어야 한다. 예를 들어, 제1 구성요소는 제2 구성요소로 명명될 수 있고, 유사하게 제2 구성요소는 제1 구성요소로도 명명될 수 있다.Although terms such as first or second may be used to describe various components, such terms should only be construed for the purpose of distinguishing one component from another. For example, a first element may be termed a second element, and similarly, a second element may be termed a first element.

어떤 구성요소가 다른 구성요소에 "연결되어" 있다고 언급된 때에는, 그 다른 구성요소에 직접적으로 연결되어 있거나 또는 접속되어 있을 수도 있지만, 중간에 다른 구성요소가 존재할 수도 있다고 이해되어야 할 것이다.It should be understood that when an element is referred to as being “connected” to another element, it may be directly connected or connected to the other element, but other elements may exist in the middle.

단수의 표현은 문맥상 명백하게 다르게 뜻하지 않는 한, 복수의 표현을 포함한다. 본 명세서에서, "포함하다" 또는 "가지다" 등의 용어는 설명된 특징, 숫자, 단계, 동작, 구성요소, 부분품 또는 이들을 조합한 것이 존재함으로 지정하려는 것이지, 하나 또는 그 이상의 다른 특징들이나 숫자, 단계, 동작, 구성요소, 부분품 또는 이들을 조합한 것들의 존재 또는 부가 가능성을 미리 배제하지 않는 것으로 이해되어야 한다.Singular expressions include plural expressions unless the context clearly dictates otherwise. In this specification, terms such as "comprise" or "have" are intended to designate that the described feature, number, step, operation, component, part, or combination thereof exists, but one or more other features or numbers, It should be understood that the presence or addition of steps, operations, components, parts, or combinations thereof is not precluded.

다르게 정의되지 않는 한, 기술적이거나 과학적인 용어를 포함해서 여기서 사용되는 모든 용어들은 해당 기술 분야에서 통상의 지식을 가진 자에 의해 일반적으로 이해되는 것과 동일한 의미를 가진다. 일반적으로 사용되는 사전에 정의되어 있는 것과 같은 용어들은 관련 기술의 문맥상 가지는 의미와 일치하는 의미를 갖는 것으로 해석되어야 하며, 본 명세서에서 명백하게 정의하지 않는 한, 이상적이거나 과도하게 형식적인 의미로 해석되지 않는다.Unless defined otherwise, all terms used herein, including technical or scientific terms, have the same meaning as commonly understood by one of ordinary skill in the art. Terms such as those defined in commonly used dictionaries should be interpreted as having a meaning consistent with the meaning in the context of the related art, and unless explicitly defined in this specification, it should not be interpreted in an ideal or excessively formal meaning. don't

도 1은 사용자가 로컬 컴퓨팅 장치로서 사용자 장치(102)와 상호작용하여 다른 사용자를 파트너로서 매칭시켜주는 서비스를 받을 수 있는 시스템(100)을 도시한다. 사용자 장치(102)는 데스크탑 컴퓨터, 노트북 컴퓨터, 태블릿 컴퓨터, 스마트폰, 게임 콘솔, 텔레비전 등과 같은 임의의 컴퓨팅 장치일 수 있다. 사용자 장치(102)는 네트워크(104)를 통해 하나 이상의 네트워크 컴퓨팅 장치(106)(또는 서버)와 통신할 수 있다. 네트워크(104)는 LAN, WAN, 인터넷, 전화 네트워크, 케이블 네트워크, 피어-투-피어 네트워크, 메쉬 네트워크 등과 같은 임의의 데이터 통신 네트워크 중 하나 이상의 유형일 수 있다. 네트워크 컴퓨팅 장치(106)는 네트워크 서버, 웹 서버, 파일 서버, 슈퍼컴퓨터, 데스크탑 컴퓨터 등과 같은 컴퓨팅 장치들의 임의의 유형 또는 유형들의 조합일 수 있다. 네트워크 컴퓨팅 장치(106)는 복수의 다른 사용자 장치(108)와 연결될 수 있다. 다른 사용자 장치(108)는 사용자 장치(102)와 실질적으로 동일한 장치일 수 있으며, 이하의 설명에서는 사용자 장치(102)를 기준으로 본 개시의 다양한 실시예들을 설명하기로 한다. 1 illustrates a system 100 in which a user can interact with a user device 102 as a local computing device to receive services that match other users as partners. User device 102 may be any computing device, such as a desktop computer, notebook computer, tablet computer, smart phone, game console, television, or the like. User device 102 may communicate with one or more networked computing devices 106 (or servers) over network 104 . Network 104 may be any one or more types of data communication networks, such as LAN, WAN, Internet, telephone network, cable network, peer-to-peer network, mesh network, and the like. Network computing device 106 may be any type or combination of types of computing devices, such as network servers, web servers, file servers, supercomputers, desktop computers, and the like. The network computing device 106 may be coupled with a plurality of other user devices 108 . Another user device 108 may be substantially the same device as the user device 102, and various embodiments of the present disclosure will be described with reference to the user device 102 in the following description.

파트너 매칭 시스템(110)은 적어도 하나 이상의 메모리(112)와 적어도 하나 이상의 프로세서(111)를 포함할 수 있다. 프로세서(111)는 CPU, GPU(graphical processing units), 싱글 코어 프로세서, 멀티 코어 프로세서, ASIC(application specific integrated circuits) 등의 임의의 조합을 포함할 수 있다. 적어도 하나 이상의 프로세서(111)는 하드웨어 구현에 더하여 소프트웨어 및/또는 펌웨어로 구현될 수 있다. 프로세서(111)의 소프트웨어 또는 펌웨어 구현은 임의의 적절한 프로그래밍 언어로 기술되어 전술한 다양한 기능을 수행하는 컴퓨터- 또는 머신- 실행가능 명령어를 포함할 수 있다. 프로세서(111)의 소프트웨어 구현은 메모리(112) 내에 그 전체 또는 일부가 저장될 수 있다.The partner matching system 110 may include at least one memory 112 and at least one processor 111 . Processor 111 may include any combination of CPU, graphical processing units (GPUs), single core processors, multi-core processors, application specific integrated circuits (ASICs), and the like. At least one processor 111 may be implemented in software and/or firmware in addition to hardware implementation. A software or firmware implementation of processor 111 may include computer- or machine-executable instructions written in any suitable programming language to perform the various functions described above. A software implementation of processor 111 may be stored in whole or in part in memory 112 .

메모리(112)는 프로세서(111) 상에 로딩되어 실행될 수 있는 명령어들의 프로그램과 이들 프로그램의 실행 중에 생성되는 데이터를 저장할 수 있다. 메모리(112) 상에 저장되는 프로그램과 데이터의 예로는 사용자 장치(102)에 이용가능한 하드웨어 및 소프트웨어 리소스의 동작을 제어하는 운영 체제, 네트워크 컴퓨팅 장치(106), 다른 사용자 장치(108), 하드웨어 장치들과 상호작용하기 위한 드라이버, 네트워크(104) 및 다른 컴퓨팅 장치들과 데이터를 주고받을 수 있는 통신 프로토콜, 추가적인 소프트웨어 어플리케이션를 포함할 수 있다. 사용자 장치(102) 및/또는 네트워크 컴퓨팅 장치(106)의 구성 및 종류에 따라, 메모리(112)는 (RAM과 같은) 휘발성일 수도 있고, (ROM이나 플래시 메모리와 같은) 비휘발성일 수도 있다. The memory 112 may store programs of instructions that may be loaded and executed on the processor 111 and data generated during execution of these programs. Examples of programs and data stored on memory 112 include operating systems that control the operation of hardware and software resources available to user device 102, network computing device 106, other user devices 108, and hardware devices. It may include drivers for interacting with devices, communication protocols for sending and receiving data to and from the network 104 and other computing devices, and additional software applications. Depending on the configuration and type of user device 102 and/or network computing device 106 , memory 112 may be volatile (such as RAM) or non-volatile (such as ROM or flash memory).

파트너 매칭 시스템(110)은 착탈가능형 저장부, 비-착탈가능형 저장부, 로컬 저장부 및/또는 원격 저장부와 같은 추가적인 컴퓨터-판독가능 매체도 포함할 수 있다. 메모리(112) 및 임의의 연관된 컴퓨터-판독가능 매체는 컴퓨터 판독가능 명령어, 데이터 구조, 프로그램 모듈 및 기타 데이터의 저장을 제공할 수 있다. 컴퓨터-판독가능 매체는 적어도 두 가지 종류의 컴퓨터-판독가능 매체, 즉, 컴퓨터 저장 매체와 통신 매체를 포함할 수 있다.Partner matching system 110 may also include additional computer-readable media, such as removable storage, non-removable storage, local storage, and/or remote storage. Memory 112 and any associated computer-readable media may provide storage of computer-readable instructions, data structures, program modules, and other data. Computer-readable media may include at least two types of computer-readable media: computer storage media and communication media.

컴퓨터 저장 매체는 컴퓨터 판독가능 명령어, 데이터 구조, 프로그램 모듈, 또는 기타 데이터와 같은 정보 저장을 위한 임의의 기법이나 방법에서 구현되는 휘발성 및 비휘발성, 착탈가능형 및 비착탈가능형 매체를 포함한다. 컴퓨터 저장 매체의 예로는 RAM, ROM, EEPROM, 플래시 메모리 또는 기타 메모리 기법, CD-ROM, DVD 또는 기타 광학 저장부, 자기 카세트, 자기 테이프, 자기 디스크 저장부 또는 기타 자기 저장 장치, 또는 기타 저장 장치, 또는 컴퓨터에 의해 액세스될 수 있는 정보를 저장하는 데 사용될 수 있는 기타 비-전송형 매체가 있으나, 여기에 제한되지는 않는다. 한편, 통신 매체는 컴퓨터 판독가능 명령어, 데이터 구조, 프로그램 모듈, 또는 기타 데이터를 반송파와 같은 변조된 데이터 신호 또는 기타 전송 메커니즘에 구현할 수 있다. Computer storage media includes volatile and nonvolatile, removable and non-removable media implemented in any technology or method for storage of information such as computer readable instructions, data structures, program modules, or other data. Examples of computer storage media include RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, DVD or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or other storage devices. , or other non-transportable media that can be used to store information that can be accessed by a computer, but is not limited thereto. On the other hand, communication media may embody computer readable instructions, data structures, program modules, or other data in a modulated data signal such as a carrier wave or other transport mechanism.

파트너 매칭 시스템(110)은 사용자 장치(102)와 네트워크 컴퓨팅 장치(106) 중 하나 또는 모두 상에 그 전체 또는 일부가 존재할 수 있다. 따라서, 파트너 매칭 시스템(110)은 다양한 물리적 및 데이터 컴포넌트가 하나 이상의 장소에 위치하면서 함께 작동하여 파트너 매칭 시스템(110)의 역할을 수행하는 분산형 시스템일 수 있다. 어떤 구현예에서는, 파트너 매칭 시스템(110)의 모든 특징이 사용자 장치(102) 상에 존재할 수 있다. Partner matching system 110 may reside in whole or in part on one or both of user device 102 and network computing device 106 . Accordingly, partner matching system 110 may be a distributed system in which various physical and data components are located in one or more locations and work together to perform the role of partner matching system 110 . In some implementations, all features of partner matching system 110 may reside on user device 102 .

파트너 매칭 시스템(110)은 사용자를 위하여 각각의 사용자에 대한 매칭 점수를 산정하는 파트너 매칭기(113)를 포함할 수 있다. 일부 실시예에서, 파트너 매칭기(113)는 메모리(112) 내에 전체 또는 부분적으로 존재하는 저장부일 수 있다. 일부 실시예에서, 파트너 매칭기(113)는 ASIC의 일부와 같이 프로세서(111)의 일부로서 구현될 수도 있다. 파트너 매칭 시스템(110) 자체와 같이, 파트너 매칭기(113)는 사용자 장치(102)와 네트워크 컴퓨팅 장치(106) 중 하나 또는 모두 상에 전체 또는 일부가 존재할 수 있다. 다양한 실시예들에 있어서, 파트너 매칭기(113)는 적어도 하나의 컴퓨터 프로그램 제품(computer program product)에 포함되어 제공될 수 있다. 컴퓨터 프로그램 제품은 상품으로서 판매자 및 구매자 간에 거래될 수 있다. 컴퓨터 프로그램 제품은 기기로 읽을 수 있는 저장 매체(예: compact disc read only memory (CD-ROM))의 형태로 배포되거나, 또는 어플리케이션 스토어(예: 플레이 스토어TM, 또는 앱 스토어TM)를 통해 또는 두개의 사용자 장치들(예: 스마트폰들) 간에 직접, 온라인으로 배포(예: 다운로드 또는 업로드)될 수 있다. 온라인 배포의 경우에, 컴퓨터 프로그램 제품의 적어도 일부는 제조사의 서버, 어플리케이션 스토어의 서버, 또는 중계 서버의 메모리와 같은 기기로 읽을 수 있는 저장 매체에 적어도 일시 저장되거나, 임시적으로 생성될 수 있다. The partner matching system 110 may include a partner matcher 113 that calculates a matching score for each user for the user. In some embodiments, partner matcher 113 may be a storage unit that resides in whole or in part within memory 112 . In some embodiments, partner matcher 113 may be implemented as part of processor 111, such as part of an ASIC. Like partner matching system 110 itself, partner matcher 113 may reside in whole or in part on one or both of user device 102 and network computing device 106 . In various embodiments, the partner matcher 113 may be included in at least one computer program product. Computer program products may be traded between sellers and buyers as commodities. A computer program product is distributed in the form of a device-readable storage medium (eg compact disc read only memory (CD-ROM)), or through an application store (eg Play Store TM , or App Store TM ) or both. It can be distributed (eg, downloaded or uploaded) directly or online between user devices (eg, smartphones) of the user. In the case of online distribution, at least part of the computer program product may be temporarily stored or temporarily created in a device-readable storage medium such as a manufacturer's server, an application store server, or a relay server's memory.

다양한 실시예들에 있어서, 파트너 매칭기(113)의 일부 또는 전부가 복수의 컴퓨팅 장치 상에 중복적으로 위치하는 경우, 어느 컴퓨팅 장치를 사용하여 파트너 매칭기(113)를 구현할지는 관련 처리 속도, 네트워크(104)를 통한 정보 전송 속도 및/또는 다른 요인에 따라 선택될 수 있다.In various embodiments, when a part or all of the partner matcher 113 is redundantly located on a plurality of computing devices, which computing device is used to implement the partner matcher 113, the related processing speed, The selection may be based on the rate of transmission of information over the network 104 and/or other factors.

도 2는 본 개시의 다양한 실시예들에 따른 파트너 매칭기의 세부 구성도이다. 도 2는 도 1에 도시한 시스템(100)의 파트너 매칭기(113) 일 수 있다. 2 is a detailed configuration diagram of a partner matcher according to various embodiments of the present disclosure. FIG. 2 may be the partner matcher 113 of the system 100 shown in FIG. 1 .

도 2를 참조하면, 본 개시의 다양한 실시예들에 따른 파트너 매칭기(113)는 사용자 정보 수집 모듈(210), 사용자 정보 데이터베이스(220), 사용자 특성 텍스트 정의 모듈(231), 파트너 찾기 요청 전처리 모듈(232)을 포함하는 텍스트 전처리 모듈(230), 파트너 매칭 모듈(240), 기계 독해 엔진(250), 감성 분석 엔진(770), 대화방 생성 모듈(270), 챌린지 달성 모듈(280)을 포함할 수 있다. Referring to FIG. 2 , the partner matcher 113 according to various embodiments of the present disclosure includes a user information collection module 210, a user information database 220, a user characteristic text definition module 231, and preprocessing of a partner search request. Includes a text pre-processing module 230 including a module 232, a partner matching module 240, a machine reading comprehension engine 250, a sentiment analysis engine 770, a chat room creation module 270, and a challenge achievement module 280 can do.

다양한 실시예들에 있어서, 사용자 정보 수집 모듈(210)은 다른 사용자 장치(예: 도 1의 108)로부터 사용자에 의해 입력된 사용자 정보를 수집할 수 있다. 예를 들어, 사용자 정보는, 선택입력 정보로서, 성격유형(예: MBTI), 거주지 정보, 관심분야, 자기계발 활동)을 포함할 수 있다. 사용자 정보는 직접입력 정보로서, 자기소개서, 자기계발 계획을 포함할 수 있다. In various embodiments, the user information collection module 210 may collect user information input by a user from another user device (eg, 108 of FIG. 1 ). For example, the user information may include, as selection input information, personality type (eg, MBTI), residence information, interests, and self-development activities. User information is direct input information, and may include a self-introduction letter and a self-development plan.

다양한 실시예들에서, 사용자 정보 데이터베이스(220)는 하나의(single) 물리적 기기(machine)로 구현될 수도 있고, 복수의(multiple) 물리적 기기들로 구현될 수도 있다. 사용자 정보 수집 모듈(210)은 사용자 정보 데이터베이스(220)와의 연동에 기반하여, 클라이언트 장치인 사용자 장치(102)(또는 또다른 사용자 장치(108))의 사용자를 등록하거나, 사용자 장치(102)로부터 수신되는 계정 정보 및 상기 사용자 정보를 저장하는 사용자 정보 데이터베이스(220) 내에 저장된 계정 정보 사이의 관련성에 적어도 기반하여(based at least on) 상기 사용자의 인증을 실행할 수 있다. 파트너 매칭기(113)(또는, 사용자 정보 수집 모듈(210))는 사용자 정보 데이터베이스(220)와의 연동에 기반하여, 사용자 장치(102)의 사용자에 대한 정보를 개인화(customizing)하여 사용자 프로필을 생성할 수 있으며, 생성된 사용자 프로필은 파트너 매칭 서비스를 제공하기 이용될 수 있다. In various embodiments, the user information database 220 may be implemented as a single physical machine or may be implemented as multiple physical machines. The user information collection module 210 registers a user of the user device 102 (or another user device 108), which is a client device, based on the interworking with the user information database 220, or from the user device 102. Authentication of the user may be performed based on at least on a relationship between the received account information and the account information stored in the user information database 220 that stores the user information. The partner matcher 113 (or the user information collection module 210) creates a user profile by customizing information about the user of the user device 102 based on the linkage with the user information database 220. and the created user profile can be used to provide partner matching services.

도 3a 내지 도 3d는 본 개시의 다양한 실시예들에 따라서, 사용자 정보를 입력하고, 입력된 사용자 정보에 기초하여 생성되는 사용자 프로필이 사용자 장치 상에 디스플레이되는 예시적인 화면을 도시한다. 도 3a 내지 도 3d의 화면(310, 320, 330, 340)은 웹 페이지, 텍스트 문서, 워드 프로세싱 문서, 스프레드시트 문서, 또는 HTML이나 XML과 같은 마크업 언어로 기록된 문서를 포함하는 기타 임의의 유형 또는 어플리케이션에 의해 표시되는 그래픽 유저 인터페이스(graphic user interface)일 수 있으며, 여기에 한정되지는 않는다. 3A to 3D illustrate exemplary screens in which user information is input and a user profile generated based on the input user information is displayed on a user device, according to various embodiments of the present disclosure. The screens 310, 320, 330, and 340 of FIGS. 3A to 3D are web pages, text documents, word processing documents, spreadsheet documents, or other arbitrary documents including documents written in markup languages such as HTML or XML. It may be a graphic user interface displayed by a type or application, but is not limited thereto.

도 3a를 참조하면, 제1 화면(310)은 사용자 장치(102)에서 표시되어 사용자에 대한 직접입력 정보를 입력받는 화면일 수 있다. 다양한 실시예들에 있어서, 제1 화면(310)은 직접입력 정보를 입력받는 UI(user interface)로서, 사용자 이미지 입력 객체(311), 사용자 이름 입력 객체(312), 자기소개 입력 객체(313), 및 SNS 입력 객체(314)를 포함할 수 있다. Referring to FIG. 3A , the first screen 310 may be a screen that is displayed on the user device 102 and receives direct input information for the user. In various embodiments, the first screen 310 is a UI (user interface) for receiving direct input information, and includes a user image input object 311, a user name input object 312, and a self-introduction input object 313. , and an SNS input object 314.

직접입력 정보는 다른 사용자가 요청한 파트너 찾기에 대상으로서 적절한지 여부를 판단하는데 이용될 수 있다. 예를 들어, 자기소개 입력 객체(313)에는 사용자가 사용자 장치(102)에서 키보드를 자기를 소개하는 문장(또는 텍스트)를 기입할 수 있는데, 자기소개 입력 객체(313)에 입력된 문장은 기계 독해에 이용되어 파트너 찾기에 이용될 수 있다. 예를 들어, 사용자 이미지, 사용자 이름(또는 닉네임), SNS에 대한 정보는 다른 사용자가 다른 파트너를 찾는데 도움이 될 수 있도록, 다른 사용자에게 직접적으로 전달될 수 있다. Direct input information may be used to determine whether or not it is suitable as a target for finding a partner requested by another user. For example, in the self-introduction input object 313, the user may enter a sentence (or text) introducing himself using the keyboard on the user device 102. The sentence entered in the self-introduction input object 313 is machine It can be used for reading comprehension and can be used to find a partner. For example, information about a user image, user name (or nickname), and SNS may be directly communicated to other users to help other users find other partners.

도 3b를 참조하면, 제2 화면(320)은 사용자 장치(102)에서 표시되어 사용자에 대한 선택입력 정보를 입력받는 화면일 수 있다. 다양한 실시예들에 있어서, 제2 화면(320)은 선택입력 정보에 포함되는 관심분야를 입력받는 UI(user interface)를 표시할 수 있다. 제2 화면(320)에 표시되는 관심분야는 예를 들어, 커리어, 문화예술, 글쓰기, 라이프스타일, 프다&드링크, 아웃도어, 뷰티&헬스를 포함할 수 있고 각 관심분야의 세부분야도 포함할 수 있다. Referring to FIG. 3B , the second screen 320 may be a screen that is displayed on the user device 102 and receives selection input information for the user. In various embodiments, the second screen 320 may display a user interface (UI) for receiving an input of a field of interest included in the selection input information. Areas of interest displayed on the second screen 320 may include, for example, career, culture and arts, writing, lifestyle, food & drink, outdoor, beauty & health, and detailed fields of each area of interest may also be included. can

또한, 도 3c를 참조하면 제3 화면(330)은 사용자 장치(102)에서 표시되어 사용자에 대한 선택입력 정보를 입력받는 다른 화면일 수 있다. 다양한 실시예들에 있어서, 제3 화면(330)은 입력받는 UI(user interface)로서, 성격유형 입력 객체(331), 거주지 설정 객체(332)를 포함할 수 있다. Also, referring to FIG. 3C , the third screen 330 may be another screen that is displayed on the user device 102 and receives selection input information for the user. In various embodiments, the third screen 330 is a user interface (UI) that receives input and may include a personality type input object 331 and a residence setting object 332 .

선택입력 정보는 다른 사용자가 요청한 파트너 찾기에 대상으로서 적절한지 여부를 판단하는데 이용될 수 있다. 예를 들어, 제2 화면(320)에 표시된 UI에 기초하여 선택된 관심분야에 대한 정보는 다른 사용자가 선택한 관심분야와의 비교를 통하여, 관심분야의 유사율이 결정될 수 있다. 다른 예를 들어, 제2 화면(320)에 표시된 UI에 기초하여 선택된 관심분야에 대한 정보는 해당 사용자의 특성에 대한 문장(또는 텍스트)를 정의(또는 생성)하는데 이용될 수 있다.The selection input information may be used to determine whether or not it is suitable as a target for finding a partner requested by another user. For example, the similarity rate of the field of interest may be determined by comparing the information on the field of interest selected based on the UI displayed on the second screen 320 with the field of interest selected by other users. For another example, information on a field of interest selected based on the UI displayed on the second screen 320 may be used to define (or create) a sentence (or text) related to the user's characteristics.

다른 예를 들어, 제3 화면(330)에 표시된 성격유형 입력 객체(331)에서 사용자에 의해서 선택된 성격유형은 미리 결정된 기준에 의하여 다른 사용자의 성격유형과의 비교를 통해 매칭성공률을 결정하는데 이용될 수 있다. 구체적으로, 임의의 사용자가 성격 유형을 'INFJ'로 선택한 경우, 해당 사용자는 다른 사용자의 성격 유형이 'ENFP'인 경우 매칭성공률이 높은 것으로 결정될 수 있고, 성격유형이'ESFP'인 사용자와는 매칭성공률이 낮은 것으로 판단될 수 있다. For another example, the personality type selected by the user from the personality type input object 331 displayed on the third screen 330 will be used to determine the matching success rate through comparison with the personality types of other users based on a predetermined criterion. can Specifically, if a user selects 'INFJ' as the personality type, the matching success rate can be determined to be high when the personality type of other users is 'ENFP', and it is different from the user whose personality type is 'ESFP'. It may be determined that the matching success rate is low.

또한, 제3 화면(330)에 표시된 거주지 정보 객체(331)에서 사용자에 의해서 선택된 사용자의 거주지 정보(또는 위치 정보)는, 사용자가 함께 설정한 거리 설정 기준에 따라 다른 사용자의 거주지 정보와의 비교를 통해 매칭성공률을 결정하는데 사용될 수 있다. 예를 들어, 사용자가 거리 설정 기준에 따라 최소 500m 이상 2km 이하에 위치하는 사용자는 매칭성공률이 높은 것으로 결정할 수 있고, 그 이외의 범위는 매칭성공률이 낮은 것으로 결정할 수 있다. In addition, the user's residence information (or location information) selected by the user in the residence information object 331 displayed on the third screen 330 is compared with the residence information of other users according to the distance setting criterion set by the user. It can be used to determine the matching success rate through For example, a user located within a range of at least 500 m and less than 2 km according to the distance setting criterion may be determined to have a high matching success rate, and other ranges may be determined to have a low matching success rate.

다양한 실시예들에 있어서, 사용자들의 선택입력 정보에 따라서 결정되는 매칭성공률은 파트너를 찾는데, 절대적인 기준으로서 미리 결정된 기준에 부합되지 않는 경우 다른 정보(예: 직접입력 정보)에 기초한 판단 결과(예: 매칭 점수)와 무관하게 파트너로 추천되지 않게 하는 절대적 기준이 될 수 있다. 다른 실시예에서, 매칭성공률은 다른 정보에 기초한 판단 결과를 보정하는 기준이 될 수 있다. In various embodiments, the matching success rate determined according to the user's selection input information is an absolute criterion for finding a partner, and a decision result based on other information (eg, direct input information) (eg, direct input information) when the predetermined criterion is not met. Matching score) can be an absolute criterion for not being recommended as a partner. In another embodiment, the matching success rate may be a criterion for correcting a determination result based on other information.

도 3d를 참조하면, 제4 화면(340)은 도 3a 내지 도 3c에서의 화면(310, 320, 330) 중 적어도 하나를 통하여 입력된 사용자에 대한 정보에 기초하여 생성된 사용자 프로파일을 도시한다. 예를 들어, 제4 화면(340)은 사용자 이미지 및 이름을 표시하는 제1 영역(341), 직접입력 정보로서 자기소개를 표시하는 제2 영역(342), 선택입력 정보로서 관심 분야를 표시하는 제3 영역(343)을 포함할 수 있다. Referring to FIG. 3D, a fourth screen 340 shows a user profile generated based on user information input through at least one of the screens 310, 320, and 330 of FIGS. 3A to 3C. For example, the fourth screen 340 includes a first area 341 displaying a user image and name, a second area 342 displaying self-introduction as direct input information, and displaying fields of interest as selection input information. A third area 343 may be included.

다시 도 2를 참조하면, 텍스트 전처리 모듈(230)은 파트너 매칭기(113)에서 수집된 정보들을 언어 모델(Language Model)에 사용될 수 있도록 전처리할 수 있다. 언어 모델이란 언어라는 현상을 모델링하기 위하여 단어 문장(sequence)에 확률을 할당하는 모델이다. 다시 말하면, 언어 모델은 가장 자연스러운 단어 시퀀스를 찾아내는 모델이다. 언어 모델은 통계를 이용한 방법 또는 인공 신경망을 이용한 방법에 기초하여 생성될 수 있다. 텍스트 전처리 모듈(230)은 사람이 평소에 사용하는 언어로서 자연어(Natural Language)를 자연어의 구성단위인 형태소, 구문 등을 분석하고 처리하는 자연어처리(NLP: Natural Language Processing) 기술을 사용하여 사용자 특성 텍스트를 전처리할 수 있다. 구체적으로 텍스트 전처리 모듈(230)은 자연어 처리를 통해 언어 모델 또는 기계 독해가 사용될 수 있는 형태의 텍스트(text)로 파트너 찾기 요청 및 사용자 정보를 번역할 수 있다.Referring back to FIG. 2 , the text pre-processing module 230 may pre-process the information collected by the partner matcher 113 so that it can be used in a language model. A language model is a model that assigns probabilities to word sequences in order to model the phenomenon of language. In other words, a language model is a model that finds the most natural word sequence. The language model may be generated based on a method using statistics or a method using an artificial neural network. The text pre-processing module 230 uses natural language processing (NLP) technology to analyze and process morphemes, syntax, etc., which are structural units of natural language, as a language normally used by humans, to characterize the user. Text can be preprocessed. In detail, the text pre-processing module 230 may translate the partner search request and user information into text in a form in which a language model or machine reading comprehension can be used through natural language processing.

다양한 실시예들에 있어서, 파트너 찾기 요청 전처리 모듈(230)은 또다른 사용자 장치(108)(또는 사용자 장치(102))에 의해 입력된 파트너 찾기 요청을 위한 문장을 전처리하여 질문 텍스트(query text)를 생성할 수 있다. 구체적으로, 파트너 찾기 요청 전처리 모듈(230)은 파트너 찾기 요청을 위한 문장에서 키워드를 추출하고, 추출된 키워드를 이용하여 질문 텍스트를 정의할 수 있다. 다양한 실시예들에서 '키워드'는 선택입력 정보로서 관심분야 또는 세부 관심분야 일 수 있다. 다시 말하면, 파트너 찾기 요청 전처리 모듈(230)은 또다른 사용자 장치(108)에 의해 입력된 파트너 찾기 요청을 위한 문장으로부터 미리 결정된 관심분야 또는 세부 관심분야에 대한 키워드를 추출하는 것일 수 있다. In various embodiments, the partner finding request preprocessing module 230 preprocesses a sentence for a partner finding request input by another user device 108 (or user device 102) to obtain query text can create Specifically, the partner search request pre-processing module 230 may extract keywords from a sentence for a partner search request and define question text using the extracted keywords. In various embodiments, a 'keyword' may be a field of interest or a detailed field of interest as selection input information. In other words, the partner search request pre-processing module 230 may extract a keyword for a predetermined area of interest or detailed area of interest from a sentence for requesting a search for a partner input by another user device 108 .

도 4a는 본 개시의 다양한 실시예들에 따라서, 사용자 장치 상에 파트너 찾기 요청을 입력받기 위해 디스플레이되는 예시적인 화면 및 도식화된 전처리 과정을 도시한다.4A illustrates an exemplary screen displayed on a user device to receive a request to find a partner and a schematic pre-processing process, according to various embodiments of the present disclosure.

도 4를 참조하면, 제5 화면(410)은 파트너 찾기 요청을 직접 입력받는 UI(user interface)로서, 요청 메시지 입력 박스(411)를 포함할 수 있다. 예를 들어, 요청 메시지 입력 박스(411)에는 사용자가 사용자 장치(102)에서 키보드를 자기를 소개하는 문장(또는 텍스트)를 기입할 수 있는데, 요청 메시지 입력 박스(411)에 입력된 문장은, 파트너 찾기 요청 전처리 모듈(230)에 의한 전처리 과정을 통하여 키워드가 추출될 수 있다. 예를 들어 도 4에서는 "설악산의 별과 일출보러 가실 분 함께해요! 혼자 갈려니 쉽지 않네요, 함께 산행 정보도 공유하며 즐거운 시간 만들어요. 정상에서 서로 인간 삼각대가 되어주기!" 라는 파트너 찾기 요청 메시지로부터 '새벽 등산', '야간 등산', '정보 공유', '사진 촬영'과 같은 키워드(412)가 추출될 수 있다. 파트너 찾기 요청 전처리 모듈(230)은 추출된 키워드(412)를 통하여 기계 독해에 이용될 질문 텍스트(413)를 생성할 수 있다. 예를 들어, 키워드(412)에 기초하여 "새벽 등산이나 야간 등산에 대한 정보를 공유하고 등산을 함께하며, 정상에서는 함께 사진을 찍는 것을 좋아하시나요?"라는 질문 텍스트(413)가 생성될 수 있다. Referring to FIG. 4 , a fifth screen 410 is a user interface (UI) that directly receives a request for finding a partner, and may include a request message input box 411 . For example, in the request message input box 411, the user may enter a sentence (or text) introducing himself using the keyboard on the user device 102. The sentence entered in the request message input box 411 is, Keywords may be extracted through a preprocessing process by the partner search request preprocessing module 230 . For example, in Figure 4, "Those who want to go to see the stars and sunrise of Mt. Seorak, join us! It's not easy going alone. Let's share hiking information together and have a good time. Let's become human tripods at the top!" Keywords 412 such as 'dawn hiking', 'night hiking', 'information sharing', and 'photographing' may be extracted from the partner search request message. The partner search request pre-processing module 230 may generate question text 413 to be used for machine reading comprehension through the extracted keyword 412 . For example, question text 413 may be generated based on the keyword 412, "Do you like to share information on mountain climbing at dawn or mountain climbing at night, climb together, and take pictures together at the summit?" .

다양한 실시예들에 있어서, 사용자 특성 텍스트 정의 모듈(232)은 파트너 매칭기(113)(또는 사용자 정보 수집 모듈(210))에서 수집된 정보들, 예를 들어, 직접입력 정보 및/또는 선택입력 정보를 언어 모델(Language Model)에 사용될 수 있도록 전처리할 수 있다. 다양한 실시예들에 있어서, 사용자 특성 텍스트 정의 모듈(232)은 사용자 장치(102)에 의해 입력된 정보에 기초하여 사용자 특성 텍스트(user character text)를 생성할 수 있다. 예를 들어, 사용자 특성 텍스트 정의 모듈(232)은 사용자가 자기소개 입력 객체(313)를 통해 입력한 자기소개 문장을 전처리하여 사용자 특성 텍스트로 생성할 수 있다. In various embodiments, the user characteristic text definition module 232 may use information collected by the partner matcher 113 (or user information collection module 210), for example, direct input information and/or optional input. Information can be preprocessed so that it can be used in a language model. In various embodiments, the user characteristic text definition module 232 may generate user character text based on information input by the user device 102 . For example, the user characteristic text definition module 232 may generate user characteristic text by pre-processing a self-introduction sentence input by the user through the self-introduction input object 313 .

다양한 실시예들에 있어서, 사용자 특성 텍스트 정의 모듈(232)은 선택입력 정보로서 관심분야를 입력받는 UI(예: 제2 화면(320))를 통해 선택한 관심 분야를 전처리하여 사용자 특성 텍스트로 생성할 수 있다. 예를 들어, 사용자 '스타트업', '디자인', '러닝', '등산'을 관심분야로 선택한 경우, 이를 이용하여 해당 사용자에 대한 사용자 특성 텍스트로서 "저는 스타트업, 디자인, 또는 디자인 스타트업에 관심이 있고, 취미활동으로 러닝과 등산을 하고 있습니다."라는 사용자 특성 텍스트가 생성될 수 있다. In various embodiments, the user characteristic text definition module 232 may generate user characteristic text by pre-processing the field of interest selected through a UI (eg, the second screen 320) that receives the field of interest as selection input information. can For example, if a user selects 'start-up', 'design', 'running', or 'mountain climbing' as an area of interest, this is used as the user characteristic text for the user "I am a startup, design, or design startup". I am interested in, and running and mountain climbing as hobbies" may be generated.

다양한 실시예들에 있어서, 사용자 특성 텍스트 정의 모듈(232)은 선택입력 정보로서 거주지 설정 객체(332)를 통해 입력받은 위치 정보를 전처리하여 사용자 특성 텍스트로 생성할 수 있다. 예를 들어, 사용자의 거주지를 '서울시 마포구'로 선택하고, 거리 설정 기준을 500m 이상 2km 이하인 경우, 이를 이용하여 해당 사용자에 대한 사용자 특성 텍스트로서 "저는 서울시 마포구에 거주하고, 파트너는 용산구, 서대문구에 거주하는 분이면 좋겠습니다."라는 텍스트가 생성될 수 있다. In various embodiments, the user characteristic text definition module 232 may generate user characteristic text by pre-processing location information input through the residence setting object 332 as selection input information. For example, if the user's residence is selected as 'Mapo-gu, Seoul' and the distance setting criterion is 500m or more and 2km or less, using this as the user characteristic text for the user, "I live in Mapo-gu, Seoul, and my partners are Yongsan-gu and Seodaemun-gu. The text "I hope you live in ." may be generated.

앞서 설명한 바와 같이, 다양한 실시예들에 있어서 선택입력 정보로서 관심분야, 거주지 정보, 성격유형 정보는 사용자 특성 텍스트를 생성하거나 정의하는데 이용되지 않고, 다른 사용자의 관심분야, 거주지 정보, 성격유형 정보와의 비교를 통하여 파트너 매칭의 절대적 기준이 되거나, 다른 정보에 기초한 판단결과(예: 매칭 점수)를 보정하는데 사용될 수도 있다. As described above, in various embodiments, interests, residence information, and personality type information as optional input information are not used to create or define user characteristic text, but are combined with other users' interests, residence information, and personality type information. It can be used as an absolute criterion for partner matching through comparison of , or used to correct the judgment result (eg, matching score) based on other information.

다양한 실시예들에 있어서, 파트너 매칭 모듈(240)은 사용자 특성 텍스트 정의 모듈(232)이 정의한, 복수의 사용자들 각각에 대한 사용자 특성 텍스트에 대하여, 기계 독해(MRC: Machine Reading Comprehension)를 이용함으로써, 파트너 찾기 요청 전처리 모듈(231)이 정의한 질문 텍스트에 대한 매칭 점수를 결정할 수 있다. 매칭 점수는 질문 텍스트와 사용자 특성 텍스트의 관련되는 정도를 나타낼 수 있으며 수치로 결정될 수 있다. 예를 들어, 질문 텍스트 및 사용자 특성 텍스트가 어떠한 기준, 요청 대상, 또는 관심 분야에 관한 내용을 포함할 것인지는 파트너 찾기 요청 메시지를 작성한 사용자가 결정하는 것이므로, 다른 사용자들에 대한 사용자 특성 텍스트가 정의된 질문 텍스트에 관련된 것인지를 확인하여 관련도가 높은 경우 높은 매칭 점수로 결정될 수 있다. 여기에서 관련도 높다는 것은 사용자 특성 텍스트로부터 질문 텍스트에 대한 답변 구간이 추출될 수 있다는 것을 의미할 수 있다. In various embodiments, partner matching module 240 may use Machine Reading Comprehension (MRC) for user characteristic text for each of a plurality of users, which is defined by user characteristic text definition module 232. , Matching scores for the question text defined by the partner search request preprocessing module 231 may be determined. The matching score may represent the degree of relation between the question text and the user characteristic text and may be determined numerically. For example, it is up to the user who created the partner search request message to decide which criteria, request target, or area of interest to include in the question text and user property text, so user property text for other users is defined. It is checked whether it is related to the question text, and when the relevance is high, a high matching score may be determined. Here, high relevance may mean that an answer section to the question text can be extracted from the user characteristic text.

다양한 실시예들에 있어서, 파트너 매칭 모듈(240)은 기계 독해 엔진(250)을 이용하여, 복수의 사용자들에 대한 전처리된 사용자 특성 텍스트의 적어도 일부와 질문 텍스트와의 매칭 점수를 판단하고, 매칭 점수가 일정 기준 이상인 경우 해당 텍스트를 질문에 대한 관련도가 높은 것으로 판단할 수 있다. In various embodiments, the partner matching module 240 uses the machine reading comprehension engine 250 to determine a matching score between at least a portion of preprocessed user characteristic text and question text for a plurality of users, If the score is higher than a certain standard, the corresponding text may be judged to be highly relevant to the question.

예를 들어, 파트너 매칭 모듈(240)은 정의된 질문 텍스트로서 "새벽 등산이나 야간 등산에 대한 정보를 공유하고 등산을 함께하며, 정상에서는 함께 사진을 찍는 것을 좋아하시나요?"인 경우를 상정하기로 한다. 만약 상기 질문 텍스트에 대한 기계 독해 대상으로서, "저는 아웃도어 활동을 좋아하고, 런닝으로 상쾌하게 아침을 맞이하는 것을 좋아해요"라는 사용자 특성 텍스트에 대해서는 매칭 점수를 0.8로 결정할 수 있고, "저는 등산을 좋아하고, 여유로운 시간을 가지는 것을 좋아해요"라는 사용자 특성 텍스트에 대해서는 매칭 점수를 0.7로 결정할 수 있다. 후자의 경우, '등산'이라는 관심분야가 일치하지만, '여유로운 시간'이라는 키워드로부터 '새벽 등산' 및 '야간 등산'과의 관련도가 낮게 평가될 수 있기 때문이다.For example, the partner matching module 240 assumes the case of "Do you like to share information about morning mountain climbing or night mountain climbing, climb together, and take pictures together at the summit?" as a defined question text. do. If, as a machine reading target for the above question text, a matching score of 0.8 can be determined for the user characteristic text "I like outdoor activities, and I like to greet a refreshing morning with running", and "I like mountain climbing. A matching score of 0.7 may be determined for the user characteristic text "I like having a leisurely time". In the case of the latter, although the field of interest in 'hiking' coincides, the degree of relevance to 'dawn mountain climbing' and 'night mountain climbing' can be evaluated low from the keyword 'relaxed time'.

다른 예를 들어, 상기 질문 텍스트에 대한 기계 독해 대상으로서, "저는 영화나 음악 감상을 좋아하고, 무언가 배우러 다니는 것을 좋아해요"라는 사용자 특성 텍스트에 대해서는 매칭 점수가 0점으로 결정될 수 있다. 왜냐하면 사용자 특성 텍스트로부터 상기 질문 텍스트에 대한 어떠한 답(또는 답변 구간)도 추출할 수 없기 때문에 매칭 점수를 0으로 결정할 수 있다. For another example, as a machine reading target for the question text, a matching score may be determined as 0 for user characteristic text "I like watching movies or music, and I like going to learn something". Because no answer (or answer section) to the question text can be extracted from the user characteristic text, the matching score can be determined as 0.

다양한 실시예들에 있어서, 파트너 매칭 모듈(240)은 복수의 사용자 특성 텍스트에 대하여 정의된 질문 텍스트에 매칭 점수를 결정하고 매칭 점수가 임계치 이상인 경우의 사용자 특성 텍스트만을 추출할 수 있다. 예를 들어, 분석 대상으로서 100명을 대상으로 한 복수의 사용자 특성 텍스트가 있다고 가정할 때, 파트너 매칭 모듈(240)은 미리 결정된 임계치로서 매칭 점수가 0.7 이상인 30명을 대상으로 한 사용자 특성 텍스트만이 정의된 질문 텍스트와 관련 있다고 결정할 수 있다.In various embodiments, the partner matching module 240 may determine a matching score for a question text defined for a plurality of user characteristic texts and extract only user characteristic text when the matching score is equal to or greater than a threshold value. For example, assuming that there are a plurality of user characteristic texts targeting 100 people as analysis targets, the partner matching module 240 only uses user characteristic texts targeting 30 people whose matching scores are 0.7 or higher as a predetermined threshold. can be determined to be related to this defined question text.

다양한 실시예들에 있어서 파트너 매칭 모듈(240)은 기계 독해를 이용하여 결정된 매칭 점수를 다른 정보에 의해 결정되는 매칭성공률에 의해 보정할 수 있다. 예를 들어, 사용자가 입력한 선택정보로서 성격유형 또는 거주지 정보에 의해 결정된 매칭성공률이 매칭 점수를 보정할 수 있다. 예를 들어, 기계 독해를 이용하여 결정된 매칭 점수가 0.6인 사용자 특성 텍스트에 있어서, 해당 사용자 특성 텍스트의 사용자가 입력한 성격유형이 파트너 찾기 요청 메시지를 입력한 사용자의 성격유형과 매우 적합한 성격유형의 경우 매칭성공률을 1.2로 결정하고, 0.6점의 매칭 점수가 1.2배되어 0.72점으로 보정될 수 있다. 이에 따라, 기계 독해를 이용하여 결정된 매칭 점수가 0.6인 경우에도. 매칭성공률에 의하여 0.72점으로 보정되어 임계치 0.7 이상인 대상으로 결정될 수 있다. 다른 예를 들어, 기계 독해에 의해 결정된 매칭 점수가 임계치 이상인 경우에도, 매칭성공률에 의해 보정되어 임계치 미만의 점수로 결정될 수도 있다. In various embodiments, the partner matching module 240 may correct a matching score determined using machine reading by a matching success rate determined by other information. For example, a matching success rate determined by personality type or residence information as selection information input by a user may correct a matching score. For example, in a user characteristic text with a matching score of 0.6 determined using machine reading comprehension, the personality type input by the user of the corresponding user characteristic text is a personality type that is very compatible with the personality type of the user who entered the partner search request message. In this case, the matching success rate is determined as 1.2, and the matching score of 0.6 points is multiplied by 1.2 to be corrected to 0.72 points. Accordingly, even when the matching score determined using machine reading comprehension is 0.6. It can be corrected to 0.72 points by the matching success rate and determined as a target having a threshold value of 0.7 or higher. For another example, even when the matching score determined by machine reading is equal to or higher than the threshold value, it may be corrected by the matching success rate and determined as a score lower than the threshold value.

다양한 실시예들에 있어서, 파트너 매칭 모듈(240)은 사용자 정보 수집 모듈(210)이 수집한 사용자 정보 및 기계 독해의 결과로 결정된 매칭 점수를 적합도 우선순위에 따라 가중치를 부여하여, 파트너 찾기 요청의 사용자와 적합한 다른 사용자를 결정할 수 있다. 적합도 우선순위에 따라 가중치가 부여되는 파라미터는, 성격유형(예: MBTI), 관심분야, 거주지 정보(또는 위치정보), 자기계발 활동를 더 포함할 수 있고, 자기소개 등에 의해 결정된 사용자 특성 텍스트와 질문 텍스트와의 기계 독해 결과로 결정된 매칭 점수를 포함할 수 있다. 예를 들어, 적합도 우선순위는 기계 독해 매칭 점수 > 성격유형 > 거주지 정보 > 자기계발 활동 > 관심분야의 순서로 결정될 수 있고, 이에 따라 각 파라미터들의 비교 우선순위가 결정될 수도 있다. 위 적합도 우선순위에 따른 파라미터들의 비교결과에 따라 파트너 대상으로 결정되는 사용자를 결정하는 최종 매칭 점수가 결정될 수 있다. 최종 매칭 점수는 기계 독해 결과의 매칭 점수가 다른 파라미터들의 적합도 우선순위, 유사도, 관련도 등에 의하여 보정되는 것을 의미할 수 있다. In various embodiments, the partner matching module 240 weights the user information collected by the user information collection module 210 and the matching score determined as a result of machine reading according to the suitability priority, so that the partner search request You can decide which other users are suitable for you. Parameters weighted according to suitability priority may further include personality type (e.g., MBTI), field of interest, residence information (or location information), and self-development activities, and user characteristic text and questions determined by self-introduction, etc. Matching scores determined as a result of machine reading with text may be included. For example, the suitability priority may be determined in the order of machine reading matching score > personality type > residence information > self-development activity > interest, and accordingly, the comparison priority of each parameter may be determined. A final matching score for determining a user to be determined as a partner may be determined according to a comparison result of parameters according to the above suitability priority order. The final matching score may mean that the matching score of the machine reading result is corrected according to the suitability priority, similarity, relevance, and the like of other parameters.

한편, 기계 독해 엔진(250)은 문장 또는 텍스트에 포함된 단어(word)의 의미를 밀집 벡터화(dense vector)하는 워드 임베딩(Word Embedding) 방법을 이용할 수 있다. Meanwhile, the machine reading engine 250 may use a word embedding method of dense vectoring the meaning of words included in a sentence or text.

워드 임베딩(Word Embedding)이란 단어를 밀집 벡터(dense vector)로 표현하는 방법으로, 단어를 밀집 표현(Dense Representation)으로 변환하는 것을 의미할 수 있다. 밀집 표현은 희소 표현(Sparse Representation)의 반대되는 개념으로서, 시스템이 설정한 값으로 모든 단어의 벡터 표현의 차원으로 통일하는 것을 의미할 수 있다. 또한, 워드 임베딩은 LSA, Word2Vec, FastText, Glove를 포함하는 다양한 방식으로 구현될 수 있다. 위와 같은 워드 임베딩은 단어들을 벡터화 하기 위하여 웹 백과사전(예: 위키디피아)와 같은 방대한 양의 코퍼스(corpus, 말뭉치)를 가지고 미리 훈련된 임베딩 벡터(Pre-trained embedding vector)를 불러오는 방법을 이용할 수 있다. 또한 사용자 특성 텍스트와 정의된 질문에 적절한 훈련 데이터를 별도로 마련하여 기존 모델의 상위 층(layer)을 해제하여 새로운 층과 함께 학습시키는 Fine-Tuning, 기존 모델을 사용하지 않고 학습하여 벡터화하는 Full-Learning의 방법을 이용할 수도 있다. 이와 같은 기계 학습은 기계 독해 엔진(250)에 포함된 Pre-trained Embedding 모델 및 Fine-tuned 모델을 이용할 수 있다. Word embedding is a method of expressing a word as a dense vector, and may mean converting a word into a dense representation. Dense representation is the opposite concept of sparse representation, and may mean unifying the dimension of vector representation of all words with a value set by the system. Also, word embedding can be implemented in a variety of ways, including LSA, Word2Vec, FastText, and Glove. The above word embedding can use a method of loading a pre-trained embedding vector with a vast amount of corpus (corpus) such as a web encyclopedia (eg Wikipedia) in order to vectorize words. . In addition, fine-tuning, which separately prepares training data suitable for user-characteristic text and defined questions, releases the upper layer of the existing model and trains it together with a new layer, and full-learning, which vectorizes by learning without using the existing model method can also be used. Such machine learning may use a pre-trained embedding model and a fine-tuned model included in the machine reading engine 250 .

감성 분석 엔진(260)은 파트너 매칭 모듈(240)(또는 기계 독해 엔진(250)이 매칭 점수가 임계치 이상이라고 판단한 사용자 특성 데이터에 대하여 감성 분석(Sentimental Analysis)을 수행할 수 있다.The sentiment analysis engine 260 may perform sentimental analysis on user characteristic data determined by the partner matching module 240 (or the machine reading comprehension engine 250 to have a matching score equal to or greater than a threshold value).

다양한 실시예들에 있어서, 감성 분석 엔진(260)은 긍정, 부정, 또는 중립의 3개의 클래스로 입력 데이터를 분류하는 모델일 수도 있고, 다른 실시 예에 따라서는 강한긍정, 약한긍정, 강한부정, 약한부정, 중립 등과 같이 더 많은 클래스로 입력 데이터를 분류하도록 학습되는 모델일 수도 있다. 감성 분석 엔진(260)은 컨텍스트 센서티브한 자연어 처리모델(예컨대, BERT(Bidirectional Encoder Representations from Transformers) 또는 KoBERT))을 대량의 코퍼스(또는 문서)로 사전학습(pre-training)한 후, 사전학습된 모델을 이용하여 상술한 바와 같은 감성분석을 수행하도록 파인튜닝함으로써 구축할 수 있다. 이러한 사전학습에는 전술한 바와 같이 BERT 등의 공개된 자연어 처리모델 그 자체 또는 관심분야 등과 관련된 데이터를 추가로 학습하여 구축할 수 있다. In various embodiments, the sentiment analysis engine 260 may be a model that classifies input data into three classes of positive, negative, or neutral, and according to other embodiments, strong positive, weak positive, strong negative, It could also be a model that is trained to classify the input data into more classes, such as weak negative, neutral, etc. The sentiment analysis engine 260 pre-trains a context-sensitive natural language processing model (e.g., Bidirectional Encoder Representations from Transformers (BERT) or KoBERT) with a large amount of corpus (or documents), and then converts the pre-trained It can be constructed by fine-tuning to perform sentiment analysis as described above using a model. As described above, such pre-learning may be constructed by additionally learning open natural language processing models such as BERT or data related to areas of interest.

감성 분석 엔진(260)은 단순히 질문 텍스트와 사용자 특성 텍스트의 관련도를 기준으로 매칭 점수를 결정하였을 때 발생할 수 있는 오류를 보완하도록 기능할 수 있다. 예를 들어, "새벽 등산이나 야간 등산에 대한 정보를 공유하고 등산을 함께하며, 정상에서는 함께 사진을 찍는 것을 좋아하시나요?"가 질문 텍스트로 정의된 경우, 기계 독해 대상으로서, "저는 아웃도어 활동을 좋아하지만, 아침에 일찍 일어나는 것을 싫어해요"라는 사용자 특성 텍스트에 대해서는, 아침이라는 키워드가 포함되었기 때문에 매칭 점수를 0.8로 결정할 수 있다. 하지만, 감정 분석 엔진(260)은 위와 같은 경우에서, 답변구간으로서 추출된 "아침에 일찍 일어나는 것을 싫어해요"라는 텍스트에 대한 감정 분석을 진행하여 해당 감정이 강한 부정인 것으로 결정할 수 있고, 이 경우 0.8점의 매칭 점수를 0점으로 보정할 수 있다. 다른 예에서, 감정 분석이 약한 부정인 경우에는 매칭 점수를 0.8배하여 보정할 수 있고, 또다른 예에서, 강한 긍정 또는 약한 긍정의 감정 분석 결과는 매칭 점수를 1배 이상으로 보정할 수도 있다. The sentiment analysis engine 260 may function to supplement an error that may occur when a matching score is determined simply based on the degree of relevance between the question text and the user characteristic text. For example, if "Do you like to share information about mountain climbing or night mountain climbing, climb together, and take pictures together at the summit?" is defined as the question text, as a machine reading target, "I am outdoor For the user characteristic text "I like but I hate getting up early in the morning", a matching score of 0.8 can be determined because the keyword morning is included. However, in the above case, the emotion analysis engine 260 may determine that the emotion is strong negative by performing emotion analysis on the text "I hate waking up early in the morning" extracted as an answer section, and in this case A matching score of 0.8 points can be corrected to 0 points. In another example, when the emotion analysis is weakly negative, the matching score may be multiplied by 0.8, and in another example, the matching score may be corrected by 1 or more times when the emotion analysis result is strongly positive or weakly positive.

대화방 생성 모듈(270)은 매칭 점수가 임계치 이상인 사용자와, 파트너 찾기 요청의 대상으로 결정된 사용자가 연결된 대화방을 생성할 수 있다. 대화방이란 대화방에 참여한 사용자들 사이에 텍스트 메시지, 음성 메시지, 이미지, 동영상 등을 실시간으로 교환하기 위해 생성된 가상의 공간을 의미할 수 있다. 예를 들어, 대화방 생성 모듈(270)은 파트너 찾기를 요청한 사용자와, 매칭 점수가 가장 높은 한 명의 사용자가 동시에 접속할 수 있는 대화방을 생성할 수 있다. 다른 예를 들어, 대화방 생성 모듈(270)은 파트너 찾기를 요청한 사용자가, 매칭 점수가 임계치 이상인 사용자들 중에서 선택한 적어도 한 명의 사용자가 동식에 접속할 수 있는 대화방을 생성할 수 있다. The chat room creation module 270 may create a chat room in which a user having a matching score equal to or higher than a threshold value and a user determined as a target of a partner search request are connected. A chat room may refer to a virtual space created to exchange text messages, voice messages, images, videos, and the like between users participating in the chat room in real time. For example, the chat room creation module 270 may create a chat room to which a user requesting to find a partner and a user with the highest matching score can access at the same time. For another example, the chat room creation module 270 may create a chat room to which at least one user selected from among users whose matching score is equal to or higher than a threshold value by the user requesting to find a partner can access the same type.

도 4b는 본 개시의 다양한 실시예들에 따라서, 사용자 장치 상에 파트너로서 결정된 다른 사용자들에 대한 사용자 정보가 디스플레이되는 예시적인 화면을 도시한다. 도 4b를 참조하면, 제6 화면(420)은 매칭 점수가 임계치 이상인 적어도 하나의 사용자 각각의 이름(또는 닉네임)과 사용자 정보(예: 성격유형, 자기소개) 중 일부가 표시될 수 있다. 4B illustrates an example screen on which user information for other users determined as partners is displayed on a user device, in accordance with various embodiments of the present disclosure. Referring to FIG. 4B , the sixth screen 420 may display a name (or nickname) of at least one user whose matching score is equal to or greater than a threshold and part of user information (eg, personality type, self-introduction).

챌린지 달성 모듈(280)은 파트너 찾기 요청 메시지를 입력한 사용자가 자격이 되는지 여부를 확인할 수 있다. 파트너 매칭 시스템(110)에서, 파트너 찾기 서비스의 무분별한 요청을 방지하기 위하여, 파트너 찾기 서비스를 이용하기 위한 자격요건이 필요할 수 있다. 따라서, 파트너 매칭 시스템(110)(또는 파트너 매칭기(113))은 일정한 챌린지를 달성한 사용자 만이 파트너 찾기 요청 메시지를 입력할 수 있도록 제한할 수 있다. 챌린지 달성의 예로서, 일정 금액이상의 결제, 일정 출석률 달성, 이벤트 완료, 추첨에 의한 선택 등 다양한 실시예가 가능하다. The challenge achievement module 280 may check whether the user who inputs the partner search request message is qualified. In the partner matching system 110, in order to prevent indiscriminate request of the partner finding service, qualification requirements for using the partner finding service may be required. Accordingly, the partner matching system 110 (or the partner matcher 113) may restrict only users who have achieved a certain challenge to input a partner search request message. As an example of achieving the challenge, various embodiments are possible, such as payment of a certain amount or more, achievement of a certain attendance rate, completion of an event, selection by lottery, and the like.

도 5는 본 개시의 다양한 실시예들에 따라 기계 독해를 이용하여 파트너를 매칭하는 프로세스(500)를 나타내는 흐름도이다. 이해를 용이하게 하기 위해, 본 개시에서 논의되는 프로세스는 독립된 블럭으로 표시된 분리된 동작으로서 설명된다. 그러나, 이처럼 분리되어 설명한 동작들이 그 수행에 있어 반드시 정해진 순서대로 수행되어야 하는 것으로 해석해서는 안 된다. 기술된 프로세스들의 수행 순서는 한정사항으로 해석되어서는 안 되고, 설명된 프로세스 블럭 중 임의의 블럭(들)이 임의의 순서로 결합되어 본 프로세스 또는 대체적인 프로세스를 구현할 수 있다. 또한, 제공된 동작들 중 하나 이상이 수정되거나 생략될 수 있다.5 is a flow diagram illustrating a process 500 for matching a partner using machine reading in accordance with various embodiments of the present disclosure. For ease of understanding, the processes discussed in this disclosure are described as discrete operations represented as discrete blocks. However, it should not be construed that the operations described separately in this way must be performed in the order in which they are performed. The order of performance of the described processes is not to be construed as limiting, and any block(s) of the described process blocks may be combined in any order to implement this process or alternative processes. Additionally, one or more of the operations presented may be modified or omitted.

프로세스들은 논리적 흐름도 내의 블럭들의 모음으로 도시되어 있는데, 이는 하드웨어, 소프트웨어, 또는 하드웨어와 소프트웨어의 조합으로 구현될 수 있는 일련의 동작들을 나타낸다. 논의를 위해, 프로세스들은 도 1 내지 도 4를 통해 설명된 기계 독해를 이용한 파트너 매칭 시스템의 구성 및 사용자 인터페이스를 참조하여 기술된다. 그러나, 프로세스들은 다른 시스템 및/또는 사용자 인터페이스를 이용하여 수행될 수도 있다.Processes are depicted as collections of blocks within a logical flow diagram, which represent a series of operations that may be implemented in hardware, software, or a combination of hardware and software. For discussion, the processes are described with reference to the configuration and user interface of the partner matching system using machine reading described with reference to FIGS. 1 to 4 . However, processes may be performed using other systems and/or user interfaces.

도 5를 참조하면, 동작 501에서, 파트너 매칭 시스템(100)(또는 사용자 정보 수집 모듈(210))은 복수의 사용자의 사용자 장치로부터 입력된 복수의 사용자 정보를 수집할 수 있다. 사용자 정보는 선택입력 정보 및 직접입력 정보를 포함할 수 있다. 예를 들어 선택입력 정보는 성격유형(예: MBTI), 거주지 정보, 관심분야를 포함할 수 있고, 직접입력 정보는, 자기소개를 포함할 수 있다. Referring to FIG. 5 , in operation 501, the partner matching system 100 (or the user information collection module 210) may collect a plurality of user information input from user devices of a plurality of users. User information may include selection input information and direct input information. For example, the selective input information may include personality type (eg, MBTI), residence information, and field of interest, and direct input information may include self-introduction.

동작 503에서 파트너 매칭 시스템(100)(또는, 사용자 특성 텍스트 정의 모듈(232))은 상기 수집한 복수의 사용자 정보를 텍스트에 기초하여, 기계 독해(Machine Reading Comprehension, MRC)에 사용될 수 있도록, 상기 복수의 사용자 각각에 관련된 복수의 사용자 특성 텍스트를 정의(또는 생성)할 수 있다. 예를 들어, 파트너 매칭 시스템(100)은 사용자가 사용자 장치에 표시된 자기소개 입력 객체를 통해 입력한 자기소개 문장을 전처리하여 사용자 특성 텍스트로 생성할 수 있다. 다양한 실시예들에 있어서, 선택입력 정보로서 관심분야, 거주지 정보, 성격유형 정보는, 다른 사용자의 관심분야, 거주지 정보, 성격유형 정보와의 비교를 통하여 파트너 매칭의 절대적 기준이 되거나, 매칭성공률로서 매칭 점수를 보정하는데 사용될 수도 있다. In operation 503, the partner matching system 100 (or the user characteristic text definition module 232) uses the collected plurality of user information based on text to be used for machine reading comprehension (MRC). A plurality of user characteristic texts related to each of a plurality of users may be defined (or created). For example, the partner matching system 100 may pre-process a self-introduction sentence input by the user through a self-introduction input object displayed on the user device to generate user characteristic text. In various embodiments, interest, residence information, and personality type information as selection input information are absolute standards for partner matching through comparison with other users' interests, residence information, and personality type information, or matching success rate It can also be used to calibrate the matching score.

동작 505에서, 파트너 매칭 시스템(100)은 또다른 사용자 장치로부터 사용자에 의해 입력된 파트너 찾기 요청이 포함된 요청 메시지를 수신할 수 있다. 다음 동작 507에서 파트너 매칭 시스템(100)(또는, 파트너 찾기 요청 전처리 모듈(231))은 상기 요청 메시지를 상기 기계 독해에 사용될 수 있도록 전처리하여 질문 텍스트를 생성할 수 있다. 예를 들어, 파트너 매칭 시스템(100)은 요청 메시지 내의 키워드를 추출하고 이를 이용하여 질문 텍스트를 생성할 수 있다. In operation 505, the partner matching system 100 may receive a request message including a request for finding a partner input by a user from another user device. In the next operation 507, the partner matching system 100 (or the partner finding request pre-processing module 231) may generate question text by pre-processing the request message so that it can be used for machine reading. For example, the partner matching system 100 may extract keywords from a request message and generate question text using them.

동작 509에서, 파트너 매칭 시스템(100)(또는, 파트너 매칭 모듈(240))은 기계 독해 엔진(260)을 이용하여, 복수의 사용자 특성 텍스트 각각으로부터 상기 전처리된 질문 텍스트에 대한 매칭 점수를 결정할 수 있다. 예를 들어, 파트너 매칭 시스템(100)은 기계 독해 엔진을 이용하여, 전처리된 상기 복수의 사용자 특성 텍스트의 각각으로부터 상기 정의된 질문 텍스트에 대한 답변 구간을 추출하고, 질문 텍스트와 답변 구간의 관련도를 기준으로 매칭 점수를 결정할 수 있다. In operation 509, the partner matching system 100 (or the partner matching module 240) may determine a matching score for the preprocessed question text from each of a plurality of user characteristic texts using the machine reading comprehension engine 260. there is. For example, the partner matching system 100 extracts an answer section for the defined question text from each of the plurality of preprocessed user characteristic texts using a machine reading comprehension engine, and the relationship between the question text and the answer section. A matching score may be determined based on .

동작 511에서, 파트너 매칭 시스템(100)(또는, 대화방 생성 모듈(270))은 상기 복수의 사용자 특성 텍스트 중에서 상기 매칭 점수가 임계치 이상인 사용자 특성 텍스트에 대응하는 사용자들 적어도 일부를 상기 파트너 찾기 요청의 대상으로 결정할 수 있다. 예를 들어, 파트너 매칭 시스템(100)은 매칭 점수가 임계치 이상인 사용자들에 대한 정보를 파트너 찾기를 요청한 사용자 장치에 송신할 수 있다. 다른 예를 들어, 파트너 매칭 시스템(100)은 매칭 점수가 상위 10명인 사용자들에 대한 정보를 파트너 찾기를 요청한 사용자 장치에 송신할 수 있다.In operation 511, the partner matching system 100 (or the chat room creation module 270) selects at least some of the users corresponding to the user characteristic text whose matching score is equal to or greater than a threshold value among the plurality of user characteristic texts in response to the partner finding request. target can be determined. For example, the partner matching system 100 may transmit information about users whose matching scores are greater than or equal to a threshold value to the user device that has requested to find a partner. For another example, the partner matching system 100 may transmit information about users with the top 10 matching scores to the user device that has requested to find a partner.

동작 513에서, 파트너 매칭 시스템(100)(또는, 대화방 생성 모듈(270))은 상기 파트너 찾기 요청의 대상으로 결정된 사용자들 중 적어도 일부와 사용자 파트너 찾기를 요청한 사용자가 연결된 대화방을 생성할 수 있다. 예를 들어, 사용자 파트너 찾기를 요청한 사용자의 사용자 장치에서의 입력에 의해 선택된 사용자와, 사용자 파트너 찾기를 요청한 사용자의 대화방이 생성될 수 있다. 예를 들면, 파트너 매칭 시스템(100)은 사용자 파트너 찾기를 요청한 사용자의 사용자 장치로부터 특정 사용자와의 대화방 생성 요청이 수신되면, 특정 사용자의 사용자 장치에, 대화방 생성을 인가(allow)를 요청하는 메시지를 송신할 수 있고, 이에 응답하여, 상기 특정 사용자의 사용자 장치로부터 대화방 생성을 인가하는 신호가 수신되는 경우에, 상기 대화방을 생성할 수 있다. In operation 513, the partner matching system 100 (or the chat room creation module 270) may create a chat room in which at least some of the users determined to be the target of the partner search request and the user requesting the user partner search are connected. For example, a chat room of a user who has requested to find a user partner and a user selected by an input from a user device of the user who has requested to find a user partner may be created. For example, when a request for creating a chat room with a specific user is received from a user device of a user who has requested a search for a user partner, the partner matching system 100 sends a message requesting permission to create a chat room to the user device of the specific user. In response to this, when a signal authorizing creation of a chat room is received from the user device of the specific user, the chat room can be created.

다양한 실시예에 있어서, 파트너 매칭 시스템(100)(또는, 파트너 매칭 모듈(240))은 기계 독해 엔진(260)을 이용하여, 복수의 사용자 특성 텍스트 각각으로부터 상기 전처리된 질문 텍스트에 대한 매칭 점수를 결정하는 동작 509는, 파트너 매칭 시스템(100)(또는 감정 분석 엔진(260))이 복수의 사용자 특성 텍스트 중에서 상기 매칭 점수가 임계치 이상인 사용자 특성 텍스트에 대한 감정 분석을 수행하여 상기 매칭 점수를 보정할 수 있다. 예를 들어, 파트너 매칭 시스템(100)은 사용자 특성 텍스트 중에서, 질문 텍스트의 답변 구간으로 추출된 텍스트에 대한 감정 분석 결과에 따라, 매칭 점수를 0점으로 하거나, 일정 배수로 보정할 수 있다. In various embodiments, the partner matching system 100 (or the partner matching module 240) obtains a matching score for the preprocessed question text from each of a plurality of user characteristic texts using the machine reading comprehension engine 260. In operation 509 of determining, the partner matching system 100 (or the emotion analysis engine 260) performs emotion analysis on a user characteristic text whose matching score is equal to or greater than a threshold value among a plurality of user characteristic texts to correct the matching score. can For example, the partner matching system 100 may set the matching score to 0 or correct it by a predetermined multiple according to the emotion analysis result of the text extracted as the answer section of the question text from the user characteristic text.

다양한 실시예에 있어서, 파트너 매칭 시스템(100)(또는, 파트너 매칭 모듈(240))은 기계 독해 엔진(260)을 이용하여, 복수의 사용자 특성 텍스트 각각으로부터 상기 전처리된 질문 텍스트에 대한 매칭 점수를 결정하는 동작 509는, 파트너 매칭 시스템(100))(또는, 파트너 매칭 모듈(240)) 은 결정된 매칭 점수를 매칭성공률로 보정하는 동작을 포함할 수 있다. 매칭성공률은 사용자 정보로서 입력된 선택입력 정보(예: 관심 분야, 성격유형, 거주지 정보 등)에 의해 결정될 수 있다. In various embodiments, the partner matching system 100 (or the partner matching module 240) obtains a matching score for the preprocessed question text from each of a plurality of user characteristic texts using the machine reading comprehension engine 260. In operation 509 of determining, the partner matching system 100 (or the partner matching module 240) may include an operation of correcting the determined matching score with a matching success rate. The matching success rate may be determined by selection input information (eg, field of interest, personality type, residence information, etc.) input as user information.

도 6은본 개시의 다양한 실시예들에 따라 파트너 찾기 요청이 포함된 요청 메시지를 수신하는 경우 수행되는 구체적인 프로세스(505)를 나타내는 흐름도이다. 도 6을 참조하면, 동작 601에서, 파트너 매칭 시스템(100)은 또다른 사용자 장치로부터 사용자에 의해 입력된 파트너 찾기 요청이 포함된 요청 메시지를 수신하면, 동작 603에서 또다른 사용자 장치의 사용자가 챌린지를 달성하였는지 판단할 수 있다. 챌린지 달성의 예로서, 일정 금액이상의 결제, 일정 출석률 달성, 이벤트 완료, 추첨에 의한 선택 등 다양한 실시예가 가능하다. 동작 603에서 또다른 사용자가 챌린지를 달성하지 못한 것으로 판단되는 경우, 바로 프로세스(505)를 종료하고, 동작 603에서 또다른 사용자가 챌린지를 달성하였다고 판단한 경우에는 동작 605로 진행되어, 또다른 사용자 장치로부터 파트너 찾기 요청이 포함된 요청 메시지를 수신할 수 있다.6 is a flowchart illustrating a specific process 505 performed when a request message including a request to find a partner is received according to various embodiments of the present disclosure. Referring to FIG. 6 , in operation 601, when the partner matching system 100 receives a request message including a request to find a partner input by a user from another user device, in operation 603, the user of another user device challenges the user. can be judged whether it has been achieved. As an example of achieving the challenge, various embodiments are possible, such as payment of a certain amount or more, achievement of a certain attendance rate, completion of an event, selection by lottery, and the like. If it is determined in operation 603 that another user has not achieved the challenge, the process 505 is immediately terminated. A request message including a request to find a partner may be received from

위와 같은 프로세스(505)에 의해 본 개시의 다양한 실시예들에 따른 파트너 찾기 서비스에 챌린지 달성이라는 조건을 부여하여 파트너 찾기 서비스에 대한 무분별한 요청을 방지할 수 있다. Through the process 505 described above, it is possible to prevent an indiscriminate request for a partner finding service according to various embodiments of the present disclosure by giving a condition of achieving a challenge.

도 7은 본 개시의 다양한 실시예들에 따라, 기계 독해를 이용한 파트너 매칭 시스템을 운용하는 데 이용될 수 있는 컴퓨터 프로그램 제품(700)을 도시한다. 예시적인 컴퓨터 프로그램 제품의 예시적인 실시예는 신호 베어링 매체(710)를 이용하여 제공된다. 일부 실시예에서, 하나 이상의 컴퓨터 프로그램 제품(700)의 신호 베어링 매체(710)는 컴퓨터 판독가능 매체(730) 및/또는 기록 가능 매체(740)를 포함할 수 있다.7 illustrates a computer program product 700 that may be used to operate a partner matching system using machine reading, in accordance with various embodiments of the present disclosure. An exemplary embodiment of an exemplary computer program product is provided using a signal bearing medium 710. In some embodiments, signal bearing medium 710 of one or more computer program products 700 may include computer readable medium 730 and/or recordable medium 740 .

신호 베어링 매체(710)에 포함된 명령어(720)는 파트너 매칭 시스템(110) 내의 프로세서(111) 같은 컴퓨팅 장치에 의해 실행될 수 있고 메모리(112)에 저장될 수 있다. 명령어(720)는, 실행되면, 컴퓨팅 장치로 하여금 복수의 사용자 특성 텍스트를 수집하는 동작; 수집된 상기 복수의 사용자 특성 텍스트의 문장을 기계 독해(Machine Reading Comprehension, MRC)에 사용될 수 있도록 전처리하는 동작; 토픽 및 상기 토픽에 관련되고 상기 기계 독해에 사용될 수 있는 질문을 정의하는 동작; 기계 독해 엔진을 이용하여, 전처리된 상기 복수의 사용자 특성 텍스트의 각각으로부터 상기 정의된 질문에 대한 답변 구간을 추출하고, 매칭 점수를 결정하는 동작; 및 상기 복수의 사용자 특성 텍스트 중에서 상기 매칭 점수가 임계치 이상인 사용자 특성 텍스트를 상기 토픽에 대한 사용자 특성 텍스트로 결정하는 동작을 수행하도록 하는 하나 이상의 명령어를 포함할 수 있다.Instructions 720 contained in signal bearing medium 710 may be executed by a computing device such as processor 111 in partner matching system 110 and stored in memory 112 . Instruction 720, when executed, causes the computing device to collect a plurality of user characteristic text; pre-processing the collected sentences of the plurality of user characteristic texts so that they can be used for machine reading comprehension (MRC); defining a topic and a question related to the topic and usable for the machine reading comprehension; extracting an answer section for the defined question from each of the plurality of pre-processed user characteristic texts using a machine reading comprehension engine, and determining a matching score; and one or more instructions for performing an operation of determining, among the plurality of user characteristic texts, a user characteristic text having a matching score equal to or greater than a threshold value as the user characteristic text for the topic.

전술한 본원의 설명은 예시를 위한 것이며, 본원이 속하는 기술분야의 통상의 지식을 가진 자는 본원의 기술적 사상이나 필수적인 특징을 변경하지 않고서 다른 구체적인 형태로 쉽게 변형이 가능하다는 것을 이해할 수 있을 것이다. 그러므로, 이상에서 기술한 실시예들은 모든 면에서 예시적인 것이며 한정적이 아닌 것으로 이해해야만 한다. 예를 들어, 단일형으로 설명되어 있는 각 구성 요소는 분산되어 실시될 수도 있으며, 마찬가지로 분산된 것으로 설명되어 있는 구성 요소들도 결합된 형태로 실시될 수도 있다.The above description of the present application is for illustrative purposes, and those skilled in the art will understand that it can be easily modified into other specific forms without changing the technical spirit or essential features of the present application. Therefore, it should be understood that the embodiments described above are illustrative in all respects and not restrictive. For example, each component described as a single type may be implemented in a distributed manner, and similarly, components described as distributed may also be implemented in a combined form.

이상, 본 개시에서 청구하고자 하는 대상에 대해 구체적으로 살펴보았다. 본 개시에서 청구된 대상은 앞서 기술한 특정 구현예로 그 범위가 제한되지 않는다. 예컨대, 어떤 구현예에서는 장치 또는 장치의 조합 상에서 동작 가능하게 사용되는 하드웨어의 형태일 수 있으며, 다른 구현예에서는 소프트웨어 및/또는 펌웨어의 형태로 구현될 수 있고, 또 다른 구현예에서는 신호 베어링 매체, 저장 매체와 같은 하나 이상의 물품을 포함할 수 있다. 여기서, CD-ROM, 컴퓨터 디스크, 플래시 메모리 등과 같은 저장 매체는, 예컨대 컴퓨팅 시스템, 컴퓨팅 플랫폼 또는 기타 시스템과 같은 컴퓨팅 장치에 의하여 실행될 때 앞서 설명한 구현예에 따라 해당 프로세서의 실행을 야기시킬 수 있는 명령을 저장할 수 있다. 이러한 컴퓨팅 장치는 하나 이상의 처리 유닛 또는 프로세서, 디스플레이, 키보드 및/또는 마우스와 같은 하나 이상의 입/출력 장치, 및 정적 랜덤 액세스 메모리, 동적 랜덤 액세스 메모리, 플래시 메모리 및/또는 하드 드라이브와 같은 하나 이상의 메모리를 포함할 수 있다.In the above, the object to be claimed in the present disclosure has been specifically examined. The subject matter claimed in this disclosure is not limited in scope to the specific implementations described above. For example, in some implementations it may be in the form of hardware operatively used on a device or combination of devices, in other implementations it may be implemented in the form of software and/or firmware, and in still other implementations it may be in the form of a signal bearing medium; It may include one or more items, such as storage media. Here, the storage medium, such as a CD-ROM, a computer disk, a flash memory, etc., when executed by a computing device, such as a computing system, a computing platform, or other system, may cause the corresponding processor to execute according to the implementation described above. can be saved. Such computing devices may include one or more processing units or processors, a display, one or more input/output devices such as a keyboard and/or mouse, and one or more memories such as static random access memory, dynamic random access memory, flash memory and/or hard drives. can include

전술한 상세한 설명에서는 블록도, 흐름도 및/또는 기타 예시를 통해 장치 및/또는 프로세스의 다양한 실시예를 설명하였다. 그러한 블록도, 흐름도, 및/또는 기타 예시는 하나 이상의 기능 및/또는 동작을 포함하게 되며, 당업자라면 블록도, 흐름도 및/또는 기타 예시 내의 각각의 기능 및/또는 동작이 하드웨어, 소프트웨어, 펌웨어, 또는 이들의 임의의 조합에 의해 개별적으로 혹은 집합적으로 구현될 수 있다는 점을 이해할 수 있을 것이다. 다양한 실시예들에서, 본 개시에 기재된 대상의 몇몇 부분은 ASIC(Application Specific Integrated Circuit), FPGA(Field Programmable Gate Array), DSP(Digital Signal Processor) 또는 다른 집적의 형태를 통해 구현될 수 있다. 이와 달리, 본 개시의 실시예의 일부 양상은 하나 이상의 컴퓨터 상에 실행되는 하나 이상의 컴퓨터 프로그램(예를 들어, 하나 이상의 컴퓨터 시스템 상에 실행되는 하나 이상의 프로그램), 하나 이상의 프로세서 상에서 실행되는 하나 이상의 프로그램(예를 들어, 하나 이상의 마이크로프로세서 상에서 실행되는 하나 이상의 프로그램), 펌웨어 또는 이들의 실질적으로 임의의 조합으로써 전체적으로 또는 부분적으로 균등하게 집적 회로에서 구현될 수도 있으며, 소프트웨어 및/또는 펌웨어를 위한 코드의 작성 및/또는 회로의 설계는 본 개시에 비추어 당업자의 기술 범위 내에 속하는 것이다. 또한, 당업자라면, 본 개시의 대상의 매커니즘들이 다양한 형태의 프로그램 제품으로 분배될 수 있음을 이해할 것이며, 본 개시의 대상의 예시는 분배를 실제로 수행하는데 사용되는 신호 베어링 매체의 특정 유형과 무관하게 적용됨을 이해할 것이다. In the foregoing detailed description, various embodiments of devices and/or processes have been described using block diagrams, flow diagrams, and/or other examples. Such block diagrams, flow diagrams, and/or other examples may include one or more functions and/or operations, and each function and/or operation in a block diagram, flow diagram, and/or other example may be hardware, software, firmware, or or any combination thereof, individually or collectively. In various embodiments, some portions of the subject matter described in this disclosure may be implemented via application specific integrated circuits (ASICs), field programmable gate arrays (FPGAs), digital signal processors (DSPs), or other forms of integration. In contrast, some aspects of embodiments of the present disclosure are directed to one or more computer programs running on one or more computers (eg, one or more programs running on one or more computer systems), one or more programs running on one or more processors (eg, one or more programs running on one or more computer systems). for example, one or more programs running on one or more microprocessors), firmware, or substantially any combination thereof, which may be implemented in whole or in part equivalently on an integrated circuit, writing code for software and/or firmware. and/or the design of the circuit is within the skill of those skilled in the art in light of this disclosure. Further, those skilled in the art will understand that the mechanisms of the present disclosure may be distributed in various forms of program product, and the examples of the present disclosure apply regardless of the specific type of signal bearing medium used to actually perform the distribution. will understand

특정 예시적 기법이 다양한 방법 및 시스템을 이용하여 여기에서 기술되고 도시되었으나, 당업자라면, 청구된 대상에서 벗어남이 없이, 다양한 기타의 수정 또는 등가물로의 치환 가능성을 이해할 수 있다. 추가적으로, 여기에 기술된 중심 개념으로부터 벗어남이 없이 특정 상황을 청구된 대상의 교시로 적응시키도록 많은 수정이 이루어질 수 있다. 따라서, 청구된 대상이 개시된 특정 예시로 제한되지 않으나, 그러한 청구된 대상은 또한 첨부된 청구범위 및 그 균등의 범위 내에 들어가는 모든 구현예를 포함할 수 있음이 의도된다.While certain exemplary techniques have been described and illustrated herein using a variety of methods and systems, those skilled in the art will appreciate the possibility of various other modifications or equivalent substitutions without departing from the claimed subject matter. Additionally, many modifications may be made to adapt a particular situation to the teachings of claimed subject matter without departing from the central concept described herein. Thus, it is intended that the claimed subject matter is not limited to the specific examples disclosed, but that such claimed subject matter may also include all implementations falling within the scope of the appended claims and their equivalents.

본 개시의 범위는 상기 상세한 설명보다는 후술하는 특허청구범위에 의하여 나타내어지며, 특허청구범위의 의미 및 범위, 그리고 그 균등 개념으로부터 도출되는 모든 변경 또는 변형된 형태가 본원의 범위에 포함되는 것으로 해석되어야 한다.The scope of the present disclosure 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 equivalent concepts thereof should be construed as being included in the scope of the present application. do.

Claims (7)

하나 이상의 프로그램들을 저장하는 컴퓨터 판독가능 저장 매체에 있어서, 상기 하나 이상의 프로그램들은, 통신 회로를 가지는 컴퓨팅 장치의 적어도 하나의 프로세서에 의해 실행될 시,
복수의 사용자의 사용자 장치로부터 입력된 복수의 사용자 정보를 수집하고;
상기 복수의 사용자 정보를 텍스트에 기초하여, 기계 독해(Machine Reading Comprehension, MRC)에 사용되도록, 상기 복수의 사용자의 각각에 관련된 복수의 사용자 특성 텍스트를 정의하고;
또다른 사용자 장치로부터 사용자에 의해 입력된 파트너 찾기 요청이 포함된 요청 메시지를 수신하고;
상기 요청 메시지를 상기 기계 독해에 사용되도록 전처리하여 질문 텍스트를 생성하고;
기계 독해 엔진을 이용하여, 상기 복수의 사용자 특성 텍스트의 각각으로부터 상기 전처리된 질문 텍스트에 대한 답변 구간을 추출하여 매칭 점수를 결정하고; 및
상기 복수의 사용자 특성 텍스트 중에서 상기 매칭 점수가 임계치 이상인 사용자 특성 텍스트에 대응하는 사용자 중 적어도 일부를 상기 파트너 찾기 요청의 대상으로 결정하도록, 상기 컴퓨팅 장치를 야기하는 인스트럭션들을 포함하는,
컴퓨터 판독가능 저장 매체.
A computer readable storage medium storing one or more programs, the one or more programs, when executed by at least one processor of a computing device having communication circuitry, comprising:
collect a plurality of user information input from user devices of a plurality of users;
defining a plurality of user characteristic texts related to each of the plurality of users to be used for machine reading comprehension (MRC) based on the plurality of user information as text;
Receive a request message including a request for finding a partner input by a user from another user device;
preprocessing the request message to be used for the machine reading comprehension to generate question text;
using a machine reading engine, extracting an answer section for the preprocessed question text from each of the plurality of user characteristic texts to determine a matching score; and
Including instructions for causing the computing device to determine at least some of the users corresponding to the user characteristic text having the matching score equal to or greater than a threshold among the plurality of user characteristic texts as the target of the partner finding request.
A computer readable storage medium.
제1항에 있어서, 상기 복수의 사용자 특성 텍스트 중에서 상기 매칭 점수가 임계치 이상인 사용자 특성에 대응하는 사용자를 상기 파트너 찾기 요청의 대상으로 결정하도록, 상기 컴퓨팅 장치를 야기하는 인스트럭션들을 포함하는 상기 하나 이상의 프로그램들은,
상기 복수의 사용자 특성 텍스트 중에서 상기 매칭 점수가 임계치 이상인 사용자 특성 텍스트에 대한 감정 분석을 수행하여 상기 매칭 점수를 보정하도록, 상기 컴퓨팅 장치를 야기하는 인스트럭션들을 포함하는,
컴퓨터 판독가능 저장 매체.
The one or more programs of claim 1 , further comprising instructions for causing the computing device to determine a user corresponding to a user characteristic having a matching score equal to or greater than a threshold among the plurality of user characteristic texts as a target of the request for finding a partner. heard,
Including instructions for causing the computing device to correct the matching score by performing sentiment analysis on user characteristic text having the matching score equal to or greater than a threshold value among the plurality of user characteristic texts.
A computer readable storage medium.
제1항에 있어서,
상기 복수의 사용자 정보의 각각은, 복수의 사용자 각각의 성격 유형 또는 거주지 정보를 더 포함하고,
상기 하나 이상의 프로그램들은, 통신 회로를 가지는 컴퓨팅 장치의 적어도 하나의 프로세서에 의해 실행될 시, 상기 또다른 사용자 장치의 사용자의 성격 유형 또는 거주지 정보와 비교하여 일정 기준을 충족하지 못하는 경우, 해당 사용자는 상기 파트너 찾기 요청의 대상에서 제외되도록, 상기 컴퓨팅 장치를 야기하는 인스트럭션들을 더 포함하는,
컴퓨터 판독가능 저장 매체.
According to claim 1,
Each of the plurality of user information further includes personality type or residence information of each of the plurality of users,
The one or more programs, when executed by at least one processor of a computing device having a communication circuit, are compared with the user's personality type or residence information of the other user device, and if a predetermined criterion is not satisfied, the user Further comprising instructions for causing the computing device to be excluded from the target of a partner finding request.
A computer readable storage medium.
제1항에 있어서, 상기 요청 메시지를 상기 기계 독해에 사용되도록 전처리하여 질문 텍스트를 생성하도록, 상기 컴퓨팅 장치를 야기하는 인스트럭션들을 포함하는 상기 하나 이상의 프로그램들은,
상기 요청 메시지에서 키워드를 추출하고, 상기 추출된 키워드를 이용하여 상기 질문 텍스트를 생성하도록, 상기 컴퓨팅 장치를 야기하는 인스트럭션들을 포함하는,
컴퓨터 판독가능 저장 매체.
The method of claim 1 , wherein the one or more programs including instructions that cause the computing device to preprocess the request message for use in the machine reading comprehension to generate query text include:
Including instructions that cause the computing device to extract a keyword from the request message and to generate the question text using the extracted keyword.
A computer readable storage medium.
제1항에 있어서,
상기 복수의 사용자 정보의 각각은, 복수의 사용자 각각의, 적어도 하나의 관심 분야에 대한 정보를 포함하고,
상기 하나 이상의 프로그램들은, 상기 복수의 사용자 정보를 텍스트를 기계 독해에 사용되도록, 상기 복수의 사용자의 각각에 관련된 복수의 사용자 특성 텍스트를 정의하도록, 상기 컴퓨팅 장치를 야기하는 인스트럭션들을 포함하는,
컴퓨터 판독가능 저장 매체.
According to claim 1,
Each of the plurality of user information includes information on at least one field of interest of each of the plurality of users,
wherein the one or more programs cause the computing device to define a plurality of user specific texts associated with each of the plurality of users to be used for machine reading text of the plurality of user information;
A computer readable storage medium.
제1항에 있어서, 상기 하나 이상의 프로그램들은, 통신 회로를 가지는 컴퓨팅 장치의 적어도 하나의 프로세서에 의해 실행될 시,
상기 또다른 사용자 장치에 상기 파트너 찾기 요청의 대상으로 결정된 사용자에 대한 사용자 정보를 송신하도록, 상기 컴퓨팅 장치를 야기하는 인스트럭션들을 포함하는,
컴퓨터 판독가능 저장 매체.
The method of claim 1, wherein the one or more programs, when executed by at least one processor of a computing device having communication circuitry,
Including instructions that cause the computing device to transmit user information about the user determined to be the target of the partner finding request to the another user device.
A computer readable storage medium.
제1항에 있어서, 상기 하나 이상의 프로그램들은, 통신 회로를 가지는 컴퓨팅 장치의 적어도 하나의 프로세서에 의해 실행될 시,
상기 또다른 사용자 장치의 사용자가 자격 요건으로서 챌린지를 달성하였는지를 확인하고; 및
상기 또다른 사용자 장치의 사용자가 자격 요건으로서 챌린지를 달성한 경우에만 상기 또다른 사용자 장치로부터 파트너 찾기 요청에 포함된 텍스트를 입력받는 동작을 인가하도록, 상기 컴퓨팅 장치를 야기하는 인스트럭션들을 포함하는,
컴퓨터 판독가능 저장 매체.
The method of claim 1, wherein the one or more programs, when executed by at least one processor of a computing device having communication circuitry,
confirm whether a user of the another user device has achieved a challenge as a qualification; and
Including instructions that cause the computing device to authorize an operation of receiving text included in a partner search request from the other user device only when the user of the other user device achieves a challenge as a qualification requirement.
A computer readable storage medium.
KR1020210152445A 2021-11-08 2021-11-08 Method for partner matching using machine reading comprehension and computer readable recording medium thereof KR20230066922A (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1020210152445A KR20230066922A (en) 2021-11-08 2021-11-08 Method for partner matching using machine reading comprehension and computer readable recording medium thereof

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020210152445A KR20230066922A (en) 2021-11-08 2021-11-08 Method for partner matching using machine reading comprehension and computer readable recording medium thereof

Publications (1)

Publication Number Publication Date
KR20230066922A true KR20230066922A (en) 2023-05-16

Family

ID=86546428

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020210152445A KR20230066922A (en) 2021-11-08 2021-11-08 Method for partner matching using machine reading comprehension and computer readable recording medium thereof

Country Status (1)

Country Link
KR (1) KR20230066922A (en)

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20210109372A (en) 2020-02-27 2021-09-06 정동훈 Method and appratus for matching golf partner

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20210109372A (en) 2020-02-27 2021-09-06 정동훈 Method and appratus for matching golf partner

Similar Documents

Publication Publication Date Title
US11669918B2 (en) Dialog session override policies for assistant systems
O’Halloran et al. Interpreting text and image relations in violent extremist discourse: A mixed methods approach for big data analytics
US11544550B2 (en) Analyzing spatially-sparse data based on submanifold sparse convolutional neural networks
US11308169B1 (en) Generating multi-perspective responses by assistant systems
US20200410401A1 (en) System and Method for Searching and Matching Content Over Social Networks to an Individual
US20220199079A1 (en) Systems and Methods for Providing User Experiences on Smart Assistant Systems
US11159767B1 (en) Proactive in-call content recommendations for assistant systems
CN111260545B (en) Method and device for generating image
US20150243279A1 (en) Systems and methods for recommending responses
US20190303768A1 (en) Community Question Answering-Based Article Recommendation Method, System, and User Device
CN114072832A (en) Memory-based conversational reasoning and question-answering for assistant systems
Blank Online research methods and social theory
US20230135179A1 (en) Systems and Methods for Implementing Smart Assistant Systems
US11468780B2 (en) Smart-learning and knowledge retrieval system
US11928985B2 (en) Content pre-personalization using biometric data
Park et al. Systematic review on chatbot techniques and applications
US20220415202A1 (en) Smart-learning and knowledge retrieval system with integrated chatbots
Olabiyi et al. A persona-based multi-turn conversation model in an adversarial learning framework
US20200184965A1 (en) Cognitive triggering of human interaction strategies to facilitate collaboration, productivity, and learning
CN112163560A (en) Video information processing method and device, electronic equipment and storage medium
US20230055991A1 (en) System and method for interactive dialogue
Milne et al. Connecting with the future: The role of science fiction movies in helping consumers understand privacy‐technology trade‐offs
KR20230066922A (en) Method for partner matching using machine reading comprehension and computer readable recording medium thereof
CN113806620B (en) Content recommendation method, device, system and storage medium
KR102568378B1 (en) Apparatus for Learning Service of Foreign Language and Driving Method Thereof

Legal Events

Date Code Title Description
E902 Notification of reason for refusal
E601 Decision to refuse application