KR102495011B1 - Method for recommending product using regression analysis according to product code and purchase pattern and apparatus for the same - Google Patents

Method for recommending product using regression analysis according to product code and purchase pattern and apparatus for the same Download PDF

Info

Publication number
KR102495011B1
KR102495011B1 KR1020210079058A KR20210079058A KR102495011B1 KR 102495011 B1 KR102495011 B1 KR 102495011B1 KR 1020210079058 A KR1020210079058 A KR 1020210079058A KR 20210079058 A KR20210079058 A KR 20210079058A KR 102495011 B1 KR102495011 B1 KR 102495011B1
Authority
KR
South Korea
Prior art keywords
purchase
product
details
target
code
Prior art date
Application number
KR1020210079058A
Other languages
Korean (ko)
Other versions
KR20220126182A (en
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 KR1020210079058A priority Critical patent/KR102495011B1/en
Publication of KR20220126182A publication Critical patent/KR20220126182A/en
Application granted granted Critical
Publication of KR102495011B1 publication Critical patent/KR102495011B1/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/0601Electronic shopping [e-shopping]
    • G06Q30/0631Item recommendations
    • 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/0601Electronic shopping [e-shopping]
    • G06Q30/0641Shopping interfaces

Abstract

상품 코드와 구매 패턴에 따른 회귀분석을 이용한 상품 추천 방법 및 장치가 개시된다. 상품 코드와 구매 패턴에 따른 회귀분석을 이용한 상품 추천 방법은, 사용자 단말로부터 구매 요청을 수신하는 단계; 상기 구매 요청에 상응하는 거래를 완료하고 상기 사용자 단말의 타겟 사용자와 대응하는 기준 구매 패턴을 획득하는 단계; 상기 기준 구매 패턴을 미리 수집된 다수의 사용자들 각각의 구매 패턴과 비교하여 복수의 후보 사용자들을 선정하는 단계; 상기 구매 요청에 따른 구매 시점을 기준으로, 상기 타겟 사용자의 제1 타겟 구매 내역과 상기 후보 사용자들 각각에 대응하는 복수의 제1 구매 내역들을 획득하는 단계; 상기 제1 타겟 구매 내역과 상기 제1 구매 내역들을 서로 비교하여 상기 후보 사용자들 중 하나를 비교 대상 사용자로 선정하는 단계; 상기 구매 요청에 따른 구매 시점을 기준으로, 상기 비교 대상 사용자의 제2 구매 내역과 상기 타겟 사용자의 제2 타겟 구매 내역을 새롭게 획득하고, 상기 제2 구매 내역과 상기 제2 타겟 구매 내역을 서로 비교하여 추천 상품을 결정하는 단계; 및 상기 추천 상품을 포함하는 거래 완료 메시지를 상기 사용자 단말에 전송하는 단계를 포함한다.A product recommendation method and apparatus using regression analysis according to product codes and purchase patterns are disclosed. A product recommendation method using regression analysis according to product codes and purchase patterns includes receiving a purchase request from a user terminal; completing a transaction corresponding to the purchase request and obtaining a reference purchase pattern corresponding to a target user of the user terminal; selecting a plurality of candidate users by comparing the reference purchase pattern with purchase patterns of each of a plurality of users previously collected; obtaining a first target purchase detail of the target user and a plurality of first purchase details corresponding to each of the candidate users, based on a purchase time point according to the purchase request; comparing the first target purchase details with the first purchase details and selecting one of the candidate users as a comparison target user; Based on the purchase time according to the purchase request, the second purchase details of the comparison target user and the second target purchase details of the target user are newly acquired, and the second purchase details and the second target purchase details are compared with each other to determine a recommended product; and transmitting a transaction completion message including the recommended product to the user terminal.

Figure R1020210079058
Figure R1020210079058

Description

상품 코드와 구매 패턴에 따른 회귀분석을 이용한 상품 추천 방법 및 장치{METHOD FOR RECOMMENDING PRODUCT USING REGRESSION ANALYSIS ACCORDING TO PRODUCT CODE AND PURCHASE PATTERN AND APPARATUS FOR THE SAME}Product recommendation method and apparatus using regression analysis according to product code and purchase pattern

본 발명은 상품 추천 시스템에 관한 것으로, 더욱 상세하게는 상품 코드와 구매 패턴에 따른 회귀분석을 이용한 상품 추천 방법 및 장치에 관한 것이다.The present invention relates to a product recommendation system, and more particularly, to a product recommendation method and apparatus using regression analysis according to a product code and purchase pattern.

상품 추천 시스템은 정보 필터링을 사용하여 사용자에게 상품을 추천하는 시스템을 의미할 수 있다.The product recommendation system may refer to a system that recommends products to a user using information filtering.

정보 시스템은 사용자에게 개인 신상, 관심 분야, 선호도 등을 질의하여 사용자의 정보 프로파일을 획득하는 기법으로, 추천 시스템은 이러한 정보를 기반으로 고객의 심리 정보와 선호도 정보에 알맞은 정보 및 상품을 추천하거나 제공하는 방법이다. 영화, 음악, 뉴스, 책, 연구 주제, 탐색 질의, 상품 등 검색에 적용될 수 있다.An information system is a technique that obtains a user's information profile by querying the user for personal information, areas of interest, and preferences. Based on this information, a recommendation system recommends or provides information and products suitable for the customer's psychological information and preference information. way to do it It can be applied to searches such as movies, music, news, books, research topics, search queries, and products.

한편, 이러한 추천 시스템은 고객의 선호도, 구매 내역 등을 고려하여 상품을 추천하는 것이 일반적이지만 선호도나 구매 내역을 단순 비교하여 일치하는 항목을 기준으로 상품을 추천하는 정도에 그치고 있어 추천 정확도가 높지 않은 문제가 있다.On the other hand, it is common for these recommendation systems to recommend products in consideration of customer preferences and purchase history, but they are limited to recommending products based on matched items by simply comparing preferences and purchase history, so the recommendation accuracy is not high. there is a problem.

또한, 사용자들 전체의 구매 내역을 모두 일괄적으로 비교하여 판단할 경우, 굉장히 많은 연산 부하가 소모되고, 이로 인해 사용자 단말에서 즉각적으로 추천 상품을 확인하는 데까지 딜레이(delay)가 발생하므로 사용자의 불편을 야기한다.In addition, when all purchase details of all users are collectively compared and judged, a lot of computational load is consumed, which causes a delay to immediately check recommended products on the user terminal, which causes inconvenience to the user. cause

따라서, 빠른 속도로 추천 상품을 선정하여 사용자에게 제공함과 동시에 사용자가 가장 구매 유인이 높을 것으로 추정되는 상품을 사용자에게 제공함으로써 추천 정확도를 높일 수 있는 방안이 필요한 실정이다.Therefore, there is a need for a method of increasing recommendation accuracy by quickly selecting recommended products and providing them to the user, and at the same time providing the user with a product that is estimated to have the highest purchase incentive for the user.

상기와 같은 문제점을 해결하기 위한 본 발명의 목적은, 상품 코드와 구매 패턴에 따른 회귀분석을 이용한 상품 추천 방법 및 장치를 제공하는 데 있다.An object of the present invention to solve the above problems is to provide a product recommendation method and apparatus using regression analysis according to product codes and purchase patterns.

상기 목적을 달성하기 위한 본 발명의 일 측면은, 상품 코드와 구매 패턴에 따른 회귀분석을 이용한 상품 추천 방법 및 장치을 제공한다.One aspect of the present invention for achieving the above object provides a product recommendation method and apparatus using regression analysis according to product codes and purchase patterns.

상품 코드와 구매 패턴에 따른 회귀분석을 이용한 상품 추천 방법은, 사용자 단말로부터 구매 요청을 수신하는 단계; 상기 구매 요청에 상응하는 거래를 완료하고 상기 사용자 단말의 타겟 사용자와 대응하는 기준 구매 패턴을 획득하는 단계; 상기 기준 구매 패턴을 미리 수집된 다수의 사용자들 각각의 구매 패턴과 비교하여 복수의 후보 사용자들을 선정하는 단계; 상기 구매 요청에 따른 구매 시점을 기준으로, 상기 타겟 사용자의 제1 타겟 구매 내역과 상기 후보 사용자들 각각에 대응하는 복수의 제1 구매 내역들을 획득하는 단계; 상기 제1 타겟 구매 내역과 상기 제1 구매 내역들을 서로 비교하여 상기 후보 사용자들 중 하나를 비교 대상 사용자로 선정하는 단계; 상기 구매 요청에 따른 구매 시점을 기준으로, 상기 비교 대상 사용자의 제2 구매 내역과 상기 타겟 사용자의 제2 타겟 구매 내역을 새롭게 획득하고, 상기 제2 구매 내역과 상기 제2 타겟 구매 내역을 서로 비교하여 추천 상품을 결정하는 단계; 및 상기 추천 상품을 포함하는 거래 완료 메시지를 상기 사용자 단말에 전송하는 단계를 포함한다.A product recommendation method using regression analysis according to product codes and purchase patterns includes receiving a purchase request from a user terminal; completing a transaction corresponding to the purchase request and obtaining a reference purchase pattern corresponding to a target user of the user terminal; selecting a plurality of candidate users by comparing the reference purchase pattern with purchase patterns of each of a plurality of users previously collected; obtaining a first target purchase detail of the target user and a plurality of first purchase details corresponding to each of the candidate users, based on a purchase time point according to the purchase request; comparing the first target purchase details with the first purchase details and selecting one of the candidate users as a comparison target user; Based on the purchase time according to the purchase request, the second purchase details of the comparison target user and the second target purchase details of the target user are newly acquired, and the second purchase details and the second target purchase details are compared with each other to determine a recommended product; and transmitting a transaction completion message including the recommended product to the user terminal.

상기 기준 구매 패턴을 획득하는 단계는, 상기 타겟 사용자의 구매 시기별 구매 건수를 나타낸 그래프에서 선형 회귀 분석을 수행함으로써 구매 추세선을 획득할 수 있다.In the obtaining of the reference purchase pattern, a purchase trend line may be obtained by performing a linear regression analysis on a graph showing the number of purchases for each purchase period of the target user.

상기 복수의 후보 사용자들을 선정하는 단계는, 상기 그래프에서 상기 구매 추세선이 지나고, 상기 구매 건수를 나타내는 y축의 절편을 기준으로 임계값만큼 큰 상향 임계값과 상기 임계값만큼 작은 하향 임계값을 결정하는 단계; 상기 그래프에서 2개 이상의 좌표들을 지나는 라인들 중에서 상기 y축의 절편이 상기 상향 임계값과 상기 하향 임계값 사이에 속하고 기울기가 가장 큰 라인을 상향 임계선으로 선정하고, 상기 y축의 절편이 상기 상향 임계값과 상기 하향 임계값 사이에 속하고 기울기가 가장 작은 라인을 하향 임계선으로 선정하는 단계; 및 상기 사용자들 각각에 대한 구매 시기별 구매 건수를 이용하여 산출된 추세선들 중에서 상기 상향 임계선과 상기 하향 임계선 사이의 영역을 지나는 추세선과 대응하는 사용자들을 상기 후보 사용자들로 선정하는 단계를 포함한다.The selecting of the plurality of candidate users may include determining an upward threshold value larger than a threshold value and a downward threshold value smaller than the threshold value based on an intercept of the y-axis representing the number of purchases after the purchase trend line passes through the graph. step; Among the lines passing through two or more coordinates in the graph, a line whose y-axis intercept falls between the upward threshold and the downward threshold and has the largest slope is selected as the upward threshold line, and the y-axis intercept is the upward threshold. selecting a line between a threshold value and the downward threshold value and having the smallest slope as a downward threshold line; and selecting, as the candidate users, users corresponding to a trend line passing through an area between the upper threshold line and the lower threshold line among trend lines calculated using the number of purchases for each purchase period for each of the users. .

상기 후보 사용자들 중 하나를 비교 대상 사용자로 선정하는 단계는, 상품들마다 미리 고유하게 부여된 상품 코드를 기초로 상기 제1 타겟 구매 내역에 포함된 상품들과 상기 제1 구매 내역들 각각에 포함된 상품들을 서로 비교하여 유사한 상품을 결정하는 단계; 및 상기 제1 구매 내역들 중 유사한 상품이 미리 설정된 개수 이상인 제1 구매 내역과 대응하는 후보 사용자를 상기 비교 대상 사용자로 선정하는 단계를 포함한다.The step of selecting one of the candidate users as a comparison target user includes products included in the first target purchase details and each of the first purchase details based on a product code uniquely assigned to each product in advance. comparing the products to each other to determine similar products; and selecting, as the comparison target user, a candidate user corresponding to first purchase details having a preset number or more of similar products among the first purchase details.

상기 상품 코드는, 상품의 대분류를 지시하는 제1 코드; 상품의 소분류를 지시하는 제2 코드, 상품의 브랜드나 생산자를 지시하는 제3 코드, 상품의 특징을 지시하는 제4 코드, 및 상품의 원재료를 지시하는 제5 코드를 포함한다.The product code may include a first code indicating a large category of products; A second code indicating the subclass of the product, a third code indicating the brand or producer of the product, a fourth code indicating the characteristics of the product, and a fifth code indicating the raw material of the product.

상기 유사한 상품을 결정하는 단계는, 상기 제1 코드, 상기 제2 코드, 및 상기 제3 코드가 서로 동일한 상품을 상기 유사한 상품으로 결정할 수 있다.In the determining of the similar product, a product having the same first code, the second code, and the third code may be determined as the similar product.

상기 추천 상품을 결정하는 단계는, 상기 상품 코드를 이용하여 상기 제2 타겟 구매 내역에 포함된 상품들 각각에 대응하는 상품 벡터들을 생성하는 단계; 상기 상품 벡터들 각각을 열(column)로 갖는 상품 벡터 행렬을 생성하는 단계; 상기 상품 벡터 행렬의 고유벡터(eigenvector)를 산출하는 단계; 및 상기 고유벡터를 상기 제2 구매 내역에 포함된 상품들 각각에 대응하는 상품 벡터들과 비교하여 상기 제2 구매 내역에 포함된 상품들 중 하나를 상기 추천 상품으로 결정하는 단계를 포함할 수 있다.Determining the recommended product may include generating product vectors corresponding to each of the products included in the second target purchase details using the product code; generating a product vector matrix having each of the product vectors as a column; calculating an eigenvector of the product vector matrix; and determining one of the products included in the second purchase details as the recommended product by comparing the eigenvector with product vectors corresponding to respective products included in the second purchase details. .

상기와 같은 본 발명에 따른 상품 코드와 구매 패턴에 따른 회귀분석을 이용한 상품 추천 방법 및 장치를 이용할 경우에는 미리 상품마다 설정된 상품 코드를 이용하여 신속한 연산을 수행하기 때문에 빠른 속도로 추천 상품을 결정할 수 있다.In the case of using the product recommendation method and apparatus using regression analysis according to product codes and purchase patterns according to the present invention as described above, it is possible to quickly determine recommended products because rapid calculation is performed using product codes set for each product in advance. there is.

또한, 사용자의 구매 패턴을 정량화하여 명확히 설정된 지표로 다른 사용자의 구매 패턴과 비교하기 때문에 누구든지 본 발명을 이용하여 정확하게 구매 패턴을 비교할 수 있는 장점이 있다.In addition, since the user's purchase pattern is quantified and compared with other users' purchase patterns with a clearly set indicator, anyone can accurately compare the purchase patterns using the present invention.

또한, 비교 대상 사용자를 결정하는 데 사용된 구매 내역은 비교적 현재를 기준으로 비교적 최근 시점의 구매 내역을 활용함으로써 타겟 사용자의 최근 구매 패턴과 유사한 후보 사용자를 결정할 수 있다.In addition, purchase details used to determine the comparison target user may determine a candidate user similar to a recent purchase pattern of the target user by utilizing purchase details at a relatively recent point in time based on the present.

또한, 추천 상품은 타겟 사용자가 구매 시점이 상당히 지난 과거의 구매 내역을 활용하여 결정함으로써 최근에 구매한 적이 없으나 과거에 구매한 이력이 있는 상품과 유사한 상품을 추천 상품으로서 다시 구매할 수 있도록 유도할 수 있다.In addition, the recommended product is determined by using the past purchase history, which is considerably past the point of purchase by the target user, so that the product that has not been purchased recently but is similar to the product that has been purchased in the past can be induced to purchase again as a recommended product. there is.

도 1은 본 발명의 일 실시예에 따른 상품 추천 방법이 수행되는 환경을 도시한 도면이다.
도 2는 도 1에 따른 상품 추천 장치의 동작을 나타낸 대표 흐름도이다.
도 3은 도 2에 따른 단계 S120에서 기준 구매 패턴과 사용자들 각각의 구매 패턴을 서로 비교하는 과정을 설명하기 위한 그래프이다.
도 4는 도 2에 따른 단계 S140에서 타겟 구매 내역과 후보 사용자들 각각의 구매 내역들을 서로 비교하는 과정을 설명하기 위한 개념도이다.
도 5는 도 2에 따른 단계 S150에서 비교 대상 사용자의 구매 내역과 타겟 사용자의 타겟 구매 내역을 서로 비교하여 추천 상품을 결정하는 과정을 설명하기 위한 개념도이다.
도 6은 일 실시예에 따른 상품 추천 장치의 하드웨어 구성을 예시적으로 나타낸 도면이다.
1 is a diagram illustrating an environment in which a product recommendation method according to an embodiment of the present invention is performed.
FIG. 2 is a representative flowchart illustrating an operation of the product recommendation device according to FIG. 1 .
FIG. 3 is a graph for explaining a process of comparing a standard purchase pattern and a purchase pattern of each user in step S120 according to FIG. 2 .
FIG. 4 is a conceptual diagram for explaining a process of comparing target purchase details and purchase details of each candidate user in step S140 according to FIG. 2 .
FIG. 5 is a conceptual diagram for explaining a process of determining a recommended product by comparing purchase details of a comparison target user and target purchase details of a target user in step S150 according to FIG. 2 .
6 is a diagram showing a hardware configuration of a product recommendation device according to an exemplary embodiment.

본 발명은 다양한 변경을 가할 수 있고 여러 가지 실시예를 가질 수 있는 바, 특정 실시예들을 도면에 예시하고 상세한 설명에 상세하게 설명하고자 한다. 그러나, 이는 본 발명을 특정한 실시 형태에 대해 한정하려는 것이 아니며, 본 발명의 사상 및 기술 범위에 포함되는 모든 변경, 균등물 내지 대체물을 포함하는 것으로 이해되어야 한다. 각 도면을 설명하면서 유사한 참조부호를 유사한 구성요소에 대해 사용하였다. Since the present invention can make various changes and have various embodiments, specific embodiments will be illustrated in the drawings and described in detail in the detailed description. However, this is not intended to limit the present invention to specific embodiments, and should be understood to include all modifications, equivalents, and substitutes included in the spirit and scope of the present invention. Like reference numerals have been used for like elements throughout the description of each figure.

제1, 제2, A, B 등의 용어는 다양한 구성요소들을 설명하는데 사용될 수 있지만, 상기 구성요소들은 상기 용어들에 의해 한정되어서는 안 된다. 상기 용어들은 하나의 구성요소를 다른 구성요소로부터 구별하는 목적으로만 사용된다. 예를 들어, 본 발명의 권리 범위를 벗어나지 않으면서 제1 구성요소는 제2 구성요소로 명명될 수 있고, 유사하게 제2 구성요소도 제1 구성요소로 명명될 수 있다. 및/또는 이라는 용어는 복수의 관련된 기재된 항목들의 조합 또는 복수의 관련된 기재된 항목들 중의 어느 항목을 포함한다. Terms such as first, second, A, and B may be used to describe various components, but the components should not be limited by the terms. These terms are only used 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, without departing from the scope of the present invention. The terms and/or include any combination of a plurality of related recited items or any of a plurality of related recited items.

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

본 출원에서 사용한 용어는 단지 특정한 실시예를 설명하기 위해 사용된 것으로, 본 발명을 한정하려는 의도가 아니다. 단수의 표현은 문맥상 명백하게 다르게 뜻하지 않는 한, 복수의 표현을 포함한다. 본 출원에서, "포함하다" 또는 "가지다" 등의 용어는 명세서상에 기재된 특징, 숫자, 단계, 동작, 구성요소, 부품 또는 이들을 조합한 것이 존재함을 지정하려는 것이지, 하나 또는 그 이상의 다른 특징들이나 숫자, 단계, 동작, 구성요소, 부품 또는 이들을 조합한 것들의 존재 또는 부가 가능성을 미리 배제하지 않는 것으로 이해되어야 한다.Terms used in this application are only used to describe specific embodiments, and are not intended to limit the present invention. Singular expressions include plural expressions unless the context clearly dictates otherwise. In this application, the terms "include" or "have" are intended to designate that there is a feature, number, step, operation, component, part, or combination thereof described in the specification, but one or more other features It should be understood that the presence or addition of numbers, 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 to which the present invention belongs. 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 the present application, they should not be interpreted in an ideal or excessively formal meaning. don't

이하, 본 발명에 따른 바람직한 실시예를 첨부된 도면을 참조하여 상세하게 설명한다.Hereinafter, preferred embodiments according to the present invention will be described in detail with reference to the accompanying drawings.

도 1은 본 발명의 일 실시예에 따른 상품 추천 방법이 수행되는 환경을 도시한 도면이다.1 is a diagram illustrating an environment in which a product recommendation method according to an embodiment of the present invention is performed.

도 1을 참조하면, 사용자의 구매 내역에 기반한 상품 추천 방법은 사용자의 구매 내역에 기반한 상품 추천 장치(100, 이하에서 상품 추천 장치로 약칭될 수 있음)에 의해 수행될 수 있다.Referring to FIG. 1 , a product recommendation method based on a user's purchase details may be performed by a product recommendation device 100 (which may be abbreviated as a product recommendation device hereinafter) based on the user's purchase details.

상품 추천 장치(100)는, 사용자 단말(200)과 무선 또는 유선 네트워크를 이용하여 통신함으로써 온라인 상에서의 상품 구매를 지원할 수 있다. 예를 들어, 상품 추천 장치(100)는, 사용자 단말(200)로부터 사용자 정보를 제공받고, 사용자 정보를 인증하여 사용자 단말(200)의 접속을 허용하며, 접속이 허용된 사용자 단말(200)로부터 구매 요청을 수신할 수 있다.The product recommendation device 100 may support purchase of products online by communicating with the user terminal 200 through a wireless or wired network. For example, the product recommendation apparatus 100 receives user information from the user terminal 200, authenticates the user information, permits access of the user terminal 200, and provides access from the user terminal 200 to which access is allowed. Purchase requests can be received.

사용자 단말(200)의 예를 들면, 통신 가능한 데스크탑 컴퓨터(desktop computer), 랩탑 컴퓨터(laptop computer), 노트북(notebook), 스마트폰(smart phone), 태블릿 PC(tablet PC), 모바일폰(mobile phone), 스마트 워치(smart watch), 스마트 글래스(smart glass), e-book 리더기, PMP(portable multimedia player), 휴대용 게임기, 네비게이션(navigation) 장치, 디지털 카메라(digital camera), DMB(digital multimedia broadcasting) 재생기, 디지털 음성 녹음기(digital audio recorder), 디지털 음성 재생기(digital audio player), 디지털 동영상 녹화기(digital video recorder), 디지털 동영상 재생기(digital video player), PDA(Personal Digital Assistant) 등일 수 있다.For example, the user terminal 200 includes a communicable desktop computer, a laptop computer, a notebook, a smart phone, a tablet PC, and a mobile phone. ), smart watch, smart glass, e-book reader, portable multimedia player (PMP), portable game device, navigation device, digital camera, digital multimedia broadcasting (DMB) It may be a player, a digital audio recorder, a digital audio player, a digital video recorder, a digital video player, a personal digital assistant (PDA), and the like.

상품 추천 장치(100)는, 구매 요청에 포함된 상품의 거래를 완료하고, 거래 완료를 지시하는 메시지(C31)를 사용자 단말(200)에 통지할 수 있다. 이때, 상품 추천 장치(100)는, 거래 완료를 지시하는 메시지(C31)와 함께 추천 상품(C32)을 결정하여 사용자 단말(200)에 제공할 수 있다.The product recommendation device 100 may complete a transaction of the product included in the purchase request and notify the user terminal 200 of a message C31 instructing the transaction completion. At this time, the product recommendation device 100 may determine and provide the recommended product C32 to the user terminal 200 together with the message C31 indicating the completion of the transaction.

또한, 상품 추천 장치(100)는, 추천 상품(C32)의 도착 예정 시각(C33)을 결정하고, 결정된 도착 예정 시각(C33)을 사용자 단말(200)에 제공할 수 있다.Also, the product recommendation device 100 may determine the expected arrival time C33 of the recommended product C32 and provide the determined arrival time C33 to the user terminal 200 .

상품 추천 장치(100)는, 미리 등록된 다수의 상품들 각각에 대응하는 상품 정보를 저장할 수 있다. 예를 들어, 상품 정보는, 상품명, 상품마다 고유하게 부여된 상품 코드, 단가, 브랜드명, 제조사, 제조국, 형태, 색상 등을 포함할 수 있다.The product recommendation device 100 may store product information corresponding to each of a plurality of pre-registered products. For example, the product information may include a product name, a product code uniquely assigned to each product, unit price, brand name, manufacturer, country of origin, shape, color, and the like.

또한, 상품 추천 장치(100)는, 다수의 사용자 단말(200)들과 연동하여 구매 요청에 따른 거래 완료 처리 결과를 축적함으로써 사용자 단말(200)들 각각의 사용자와 대응하는 구매 내역을 생성할 수 있다.In addition, the product recommendation device 100 may generate purchase details corresponding to each user of the user terminals 200 by accumulating transaction completion processing results according to purchase requests in conjunction with a plurality of user terminals 200. there is.

여기서, 구매 내역은, 구매가 완료된 시기, 구매 건수, 구매한 상품의 리스트 등을 포함할 수 있다.Here, the purchase details may include a purchase completion time, the number of purchases, a list of purchased products, and the like.

상품 추천 장치(100)는, 구매 내역과 상품 정보를 참조하여 특정 사용자 단말(200)의 사용자와 대응하는 추천 상품(C32)을 결정하고, 결정된 추천 상품(C32)을 사용자 단말(200)에 전송함으로써 사용자 단말(200)에 추천 상품을 표시할 수 있다.The product recommendation device 100 determines a recommended product C32 corresponding to a user of a specific user terminal 200 by referring to purchase details and product information, and transmits the determined recommended product C32 to the user terminal 200 By doing so, recommended products can be displayed on the user terminal 200 .

도 2는 도 1에 따른 상품 추천 장치의 동작을 나타낸 대표 흐름도이다.FIG. 2 is a representative flowchart illustrating an operation of the product recommendation device according to FIG. 1 .

도 2를 참조하면, 상품 추천 장치(100)는, 사용자 단말(200)로부터 구매 요청을 수신할 수 있다(S100).Referring to FIG. 2 , the product recommendation device 100 may receive a purchase request from the user terminal 200 (S100).

상품 추천 장치(100)는, 수신된 구매 요청에 상응하는 거래를 완료하고, 사용자 단말(200)의 타겟 사용자와 대응하는 기준 구매 패턴을 획득할 수 있다(S110).The product recommendation device 100 may complete a transaction corresponding to the received purchase request and obtain a reference purchase pattern corresponding to the target user of the user terminal 200 (S110).

여기서, 기준 구매 패턴은 타겟 사용자의 구매 시기에 따른 구매 건수를 기초로 결정될 수 있다.Here, the reference purchase pattern may be determined based on the number of purchases according to the purchase timing of the target user.

상품 추천 장치(100)는, 기준 구매 패턴을 미리 수집된 다수의 사용자들 각각의 구매 패턴과 비교하여 복수의 후보 사용자들을 선정할 수 있다(S120). 예를 들어, 상품 추천 장치(100)는 기준 구매 패턴을 기준으로 미리 설정된 범위 내에 있는 구매 패턴을 갖는 사용자들을 후보 사용자들로 선정할 수 있다.The product recommendation apparatus 100 may select a plurality of candidate users by comparing the reference purchase pattern with the pre-collected purchase patterns of each of the plurality of users (S120). For example, the product recommendation apparatus 100 may select users having purchase patterns within a preset range based on a reference purchase pattern as candidate users.

여기서, 후보 사용자들은 타겟 사용자와 유사한 구매 패턴을 갖는 것으로 판단된 사용자로서 추천 상품을 결정하기 위한 구매 내역을 제공하는 사용자들일 수 있다.Here, the candidate users may be users who are determined to have a purchase pattern similar to that of the target user and provide purchase details for determining a recommended product.

상품 추천 장치(100)는, 구매 요청에 따른 구매 시점을 기준으로 타겟 사용자의 타겟 구매 내역과 후보 사용자들 각각에 대응하는 구매 내역들을 획득할 수 있다(S130). 예를 들어, 타겟 사용자의 구매 요청에 따른 구매 시점(현재)를 기준으로 미리 설정된 임계 기간(예를 들어 1달) 이내의 과거 시점에 속하는 타겟 구매 내역 및 후보 사용자들 각각에 대응하는 구매 내역들을 획득할 수 있다.The product recommendation apparatus 100 may obtain the target purchase details of the target user and purchase details corresponding to each of the candidate users based on the purchase time according to the purchase request (S130). For example, target purchase details belonging to a past point in time within a preset threshold period (for example, one month) based on the purchase point (current) according to the purchase request of the target user and purchase details corresponding to each of the candidate users can be obtained

상품 추천 장치(100)는, 타겟 구매 내역과 구매 내역들을 서로 비교함으로써 후보 사용자들 중 하나를 비교 대상 사용자로 선정할 수 있다(S140). 여기서 비교 대상 사용자는 해당 비교 대상 사용자의 구매 내역에 포함된 상품들 중 하나를 추천 상품으로서 타겟 사용자에게 제공할 수 있다.The product recommendation apparatus 100 may select one of the candidate users as a comparison target user by comparing target purchase details and purchase details (S140). Here, the comparison target user may provide one of the products included in the comparison target user's purchase details to the target user as a recommended product.

예를 들어, 상품 추천 장치(100)는, 타겟 구매 내역에 포함된 상품들과 구매 내역들 각각에 포함된 상품들을 서로 비교하여 타겟 구매 내역에 포함된 상품들과 유사한 상품들을 구매 내역으로 갖는 후보 사용자를 비교 대상 사용자로 선정할 수 있다. 이때, 상품 추천 장치(100)는, 미리 상품들 각각에 대하여 부여된 상품 코드를 기초로 타겟 구매 내역에 포함된 상품들과 구매 내역들 각각에 포함된 상품들을 서로 비교할 수 있다.For example, the product recommendation apparatus 100 compares products included in the target purchase details with products included in each of the purchase details, and selects products similar to the products included in the target purchase details as purchase details. A user may be selected as a comparison target user. At this time, the product recommendation device 100 may compare products included in the target purchase details with products included in each of the purchase details based on product codes assigned to each of the products in advance.

상품 추천 장치(100)는, 상기 구매 요청에 따른 구매 시점을 기준으로, 비교 대상 사용자의 구매 내역과 타겟 구매 내역을 새롭게 획득하고, 획득된 타겟 구매 내역과 구매 내역을 서로 비교하여 추천 상품을 결정할 수 있다(S150). 예를 들어, 상품 추천 장치(100)는, 타겟 사용자의 구매 요청에 따른 구매 시점(현재)를 기준으로 미리 설정된 임계 기간(예를 들어 3달)을 초과하는 과거 시점에 해당하는 비교 대상 사용자의 구매 내역과 타겟 구매 내역을 서로 비교할 수 있다. The product recommendation device 100 newly acquires the purchase details of the comparison target user and the target purchase details based on the purchase time according to the purchase request, and compares the acquired target purchase details and purchase details with each other to determine a recommended product. It can (S150). For example, the product recommendation device 100 is a comparison target user corresponding to a past time point exceeding a predetermined critical period (eg, 3 months) based on the purchase time (current) according to the purchase request of the target user. Purchase history and target purchase history can be compared with each other.

즉, 본 발명의 일 실시예에서는 구매 요청에 따른 구매 시점(현재)를 기준으로 가장 최근(예를 들어 1달) 이내의 구매 내역을 이용하여 비교 대상 사용자를 결정함으로써, 타겟 사용자의 최근 구매 실적과 유사한 구매 실적을 갖는 사용자를 비교 대상 사용자로 선정하되, 새롭게 추천 상품으로 선정하는 데 활용하는 구매 내역은 현재의 구매 요청에 따른 구매 시점을 기준으로 미리 설정된 임계 기간 이후에 속하는 구매 내역을 사용하기 때문에, 최근에 구매한 기록이 없는 상품을 추천 상품으로서 선정할 수 있는 장점이 있다.That is, in an embodiment of the present invention, by determining a user to be compared using the purchase history within the most recent (eg, one month) based on the purchase time (current) according to the purchase request, the target user's recent purchase performance Select a user with similar purchase performance as a user for comparison, but purchase history used to select a new recommended product belongs to a preset critical period based on the purchase time according to the current purchase request. Therefore, there is an advantage in that a product without a recent purchase record can be selected as a recommended product.

추천 상품이 결정되면, 상품 추천 장치(100)는 추천 상품을 포함하는 거래 완료 메시지를 사용자 단말(200)에 제공할 수 있다.When the recommended product is determined, the product recommendation device 100 may provide the user terminal 200 with a transaction completion message including the recommended product.

도 3은 도 2에 따른 단계 S120에서 기준 구매 패턴과 사용자들 각각의 구매 패턴을 서로 비교하는 과정을 설명하기 위한 그래프이다.FIG. 3 is a graph for explaining a process of comparing a standard purchase pattern and a purchase pattern of each user in step S120 according to FIG. 2 .

도 3을 참조하면, 본 발명의 일 실시예에서 구매 패턴의 비교는 구매 시기에 따른 구매 건수를 이용하여 수행된다. 이때, 통상적으로 구매 건수는 사용자마다 큰 폭으로 차이가 날 수 있다. 예를 들어, 상품 구매 비중이 높은 사용자의 경우는 다수의 시기에서 다수의 구매 건수들이 존재하기 때문에 구매 패턴을 결정할 수 있는 데이터가 풍부한 반면, 상품 구매 자체가 적은 사용자의 경우는 매우 적은 시기에서 소수의 구매 건수들이 있는 경우가 많다.Referring to FIG. 3 , in one embodiment of the present invention, comparison of purchase patterns is performed using the number of purchases according to the purchase time. In this case, the number of purchases may vary greatly for each user. For example, in the case of users with a high proportion of product purchases, there is a large number of purchases at multiple times, so there is abundant data for determining purchase patterns, whereas in the case of users who purchase small products themselves, there are a small number of purchases at very few times. There are many cases where there are purchases of

본 발명의 일 실시예에 따른 상품 추천 장치(100)는, 구매 시기에 따른 구매 건수가 비교적 적은 사용자라고 하더라도 구매 패턴을 도출하기 용이하도록 기록이 있는 구매 시기 별 구매 건수를 이용하여 구매 추세선(RL)을 산출할 수 있다.The product recommendation device 100 according to an embodiment of the present invention uses the number of purchases per purchase time that has a record to easily derive a purchase pattern even if the user has a relatively small number of purchases according to the purchase time. ) can be calculated.

예를 들어, 도 2에 도시된 것처럼, 1월 10일, 7월 12일, 9월 18일, 12월 31일 4개의 시기에서 각각 하나 이상의 구매 건수가 있는 사용자의 경우 4개의 시기에 따른 구매 건수들만을 이용하여 구매 시기별 구매 건수를 그래프로 생성하고, 생성된 그래프에서 구매 추세선(RL)을 산출할 수 있다.For example, as shown in FIG. 2, in the case of a user who has one or more purchases in each of the four periods of January 10, July 12, September 18, and December 31, purchases according to the four periods The number of purchases per purchase period may be generated as a graph using only the number of cases, and a purchase trend line RL may be calculated from the generated graph.

여기서, 구매 추세선(RL)은 주어진 구매 시기별 구매 건수를 나타낸 그래프에서 널리 알려진 선형 회귀 분석(Linear Regression Analysis)을 수행하여 얻어질 수 있으며, 구매 시기별 구매 건수 데이터가 적더라도 구매 추세선(RL)이 도출될 수 있어 구매 패턴으로 활용하기에 적합한 장점이 있다.Here, the purchase trend line (RL) can be obtained by performing a widely known linear regression analysis on a graph showing the number of purchases for a given purchase period, and the purchase trend line (RL) This can be derived and has the advantage of being suitable for use as a purchase pattern.

여기서, 산출되는 구매 추세선(RL)은 구매 시기(x)에 따른 구매 건수(y)를 나타내는 직선 방정식(y=ax+b, x는 구매 시기에 대한 변수, y는 구매 건수에 대한 변수)이며, 기울기(a)와 y축 절편(b)으로 특정된다. 구매 추세선(RL)이 타겟 사용자의 기준 구매 패턴을 대표하는 의미로 활용될 수 있다.Here, the calculated purchase trend line (RL) is a straight line equation representing the number of purchases (y) according to the purchase time (x) (y=ax+b, x is a variable for the purchase time, and y is a variable for the number of purchases) , specified by the slope (a) and the y-axis intercept (b). A purchase trend line (RL) may be used as a meaning representing a standard purchase pattern of a target user.

상품 추천 장치(100)는, 구매 추세선(RL)에 의해 특정되는 y축 절편(b)을 기준으로 임계값(th)만큼 큰 상향 임계값(b+th)과 임계값(th)만큼 작은 하향 임계값(b-th)을 결정할 수 있다. 예를 들어, y축 절편(b)과 상향 임계값(b+th) 사이의 간격과 y축 절편(b)과 하향 임계값(b-th) 사이의 간격(th)은 서로 같을 수 있다.The product recommendation device 100, based on the y-axis intercept (b) specified by the purchase trend line (RL), an upward threshold (b + th) as large as the threshold (th) and a downward as small as the threshold (th) A threshold value (b-th) can be determined. For example, the interval between the y-axis intercept (b) and the upward threshold value (b+th) and the interval (th) between the y-axis intercept (b) and the downward threshold value (b-th) may be equal to each other.

다음으로, 상품 추천 장치(100)는, 구매 시기별 구매 건수 데이터를 나타낸 그래프에서 2개 이상의 좌표를 지나는 라인들 중에서 y축 절편이 상향 임계값(b+de)과 하향 임계값(b-de) 사이에 속하고, 기울기가 가장 큰 라인을 상향 임계선(UL)으로 선정하고, y축 절편이 상향 임계값(b+de)과 하향 임계값(b-de) 사이에 속하고, 기울기가 가장 작은 라인을 하향 임계선(LL)으로 선정할 수 있다.Next, in the product recommendation device 100, among the lines passing through two or more coordinates in the graph representing the number of purchases by purchase time, the y-axis intercept is an upward threshold value (b+de) and a downward threshold value (b-de) ), and the line with the largest slope is selected as the upward threshold (UL), the y-axis intercept falls between the upward threshold (b + de) and the downward threshold (b-de), and the slope is The smallest line may be selected as the downward critical line (LL).

이때, 상품 추천 장치(100)는, 2개 이상의 좌표를 지나는 라인들 중에서 y축 절편이 y축 절편이 상향 임계값(b+de)과 하향 임계값(b-de) 사이에 속하지 않는 경우, 하나의 좌표를 지나는 라인들 중에서 y축 절편이 상향 임계값(b+de)을 지나고, 기울기가 가장 큰 라인을 상향 임계선(UL)으로 선정하고, y축 절편이 하향 임계값(b-de)을 지나고, 기울기가 가장 작은 라인을 하향 임계선(LL)으로 선정할 수 있다.At this time, the product recommendation device 100, if the y-axis intercept among the lines passing through two or more coordinates does not fall between the upper threshold value (b + de) and the lower threshold value (b-de), Among the lines passing through one coordinate, the y-axis intercept passes through the upward threshold value (b + de) and the line with the largest slope is selected as the upward threshold line (UL), and the y-axis intercept passes through the downward threshold value (b-de ), and a line having the smallest slope may be selected as the downward critical line LL.

도 2에서는, 2개 이상의 좌표를 지나는 라인들 중에서 y축 절편이 상향 임계값(b+de)과 하향 임계값(b-de) 사이에 속하고, 기울기가 가장 큰 라인이 존재하여 상향 임계선(UL)으로 선정하였다. 다만, 2개 이상의 좌표를 지나는 라인들 중에서 y축 절편이 상향 임계값(b+de)과 하향 임계값(b-de) 사이에 속하고, 기울기가 가장 작은 라인이 존재하지 않는다.In FIG. 2, among the lines passing through two or more coordinates, the y-axis intercept belongs between the upward threshold value (b+de) and the downward threshold value (b-de), and there is a line with the largest slope, so that the upward threshold line (UL). However, among the lines passing through two or more coordinates, there is no line whose y-axis intercept falls between the upward threshold value (b+de) and the downward threshold value (b-de) and has the smallest slope.

따라서, 도 2에서는 하나의 좌표를 지나는 라인들 중에서 y축 절편이 하향 임계값(b-de)을 지나고, 기울기가 가장 작은 라인을 하향 임계선(LL)으로 선정하였다.Therefore, in FIG. 2 , among lines passing through one coordinate, a line having a y-axis intercept passing through a downward threshold value (b-de) and having the smallest slope is selected as a downward threshold line (LL).

상품 추천 장치(100)는, 다수의 사용자들 각각의 구매 시각에 따른 구매 건수를 이용하여 다수의 사용자들 각각에 대응하는 추세선들을 산출하고, 산출된 추세선들 중 상향 임계선(UL)과 하향 임계선(LL) 사이의 영역을 지나는 추세선을 갖는 사용자를 후보 사용자들로 선정할 수 있다.The product recommendation apparatus 100 calculates trend lines corresponding to each of the plurality of users by using the number of purchases according to the purchase time of each of the plurality of users, and among the calculated trend lines, an upper threshold line (UL) and a lower threshold line Users having a trend line passing through an area between the lines LL may be selected as candidate users.

즉, 도 2에 도시된 상향 임계선(UL)과 하향 임계선(LL) 사이의 영역을 추세선으로서 갖는 사용자들을 후보 사용자들로 선정할 수 있다. 여기서 선정되는 후보 사용자들은 구매 시기에 따른 구매 건수를 통해 확인되는 구매 패턴이 타겟 사용자의 타겟 구매 패턴과 오차 범위(상향 임계선, 하향 임계선) 내에 있는 사용자로 판단될 수 있다.That is, users having an area between the upper threshold line UL and the lower threshold line LL shown in FIG. 2 as a trend line may be selected as candidate users. Candidate users selected here may be determined to be users whose purchase pattern, which is confirmed through the number of purchases according to the purchase time, is within an error range (upper threshold line, lower threshold line) from the target purchase pattern of the target user.

도 4는 도 2에 따른 단계 S140에서 타겟 구매 내역과 후보 사용자들 각각의 구매 내역들을 서로 비교하는 과정을 설명하기 위한 개념도이다.FIG. 4 is a conceptual diagram for explaining a process of comparing target purchase details and purchase details of each candidate user in step S140 according to FIG. 2 .

도 4를 참조하면, 타겟 사용자(사용자 A)의 구매 요청에 따른 구매 시점(현재)를 기준으로 미리 설정된 임계 기간(예를 들어 1달) 이내에 속하는 타겟 구매 내역(H1)은 쥬얼리, 포도, 키보드, 신발, 전동드릴 등을 포함할 수 있다.Referring to FIG. 4 , the target purchase history H1 belonging to a predetermined threshold period (for example, 1 month) based on the purchase time (current) according to the purchase request of the target user (user A) includes jewelry, grapes, and keyboards. , shoes, power drills, and the like.

또한, 후보 사용자 B의 현재를 기준으로 미리 설정된 임계 기간 이내에 속하는 구매 내역(H2)은 쥬얼리, 샤인머스킷, 마우스, 신발, 망치 등을 포함할 수 있다.In addition, the purchase details H2 belonging to a predetermined threshold period based on the present of the candidate user B may include jewelry, a shine musket, a mouse, shoes, a hammer, and the like.

또한, 후보 사용자 C의 현재를 기준으로 미리 설정된 임계 기간 이내에 속하는 구매 내역(H2)은 자켓, 쥬얼리, 핸드백, 식탁, 이불 등을 포함할 수 있다.In addition, the purchase details H2 belonging to a preset threshold period based on the present of candidate user C may include jackets, jewelry, handbags, dining tables, blankets, and the like.

또한, 후보 사용자 D의 현재를 기준으로 미리 설정된 임계 기간 이내에 속하는 구매 내역(H2)은 침대, 라면, 시계, 쥬얼리, 와인 등을 포함할 수 있다.In addition, the purchase history H2 belonging to a predetermined threshold period based on the present of candidate user D may include a bed, instant noodles, a watch, jewelry, wine, and the like.

상품 추천 장치(100)는, 타겟 구매 내역(H1)과 후보 사용자들 각각의 구매 내역들(H2, H3, H4)을 서로 비교하여 유사한 상품의 개수가 미리 설정된 개수 이상인 비교 대상 사용자를 선정할 수 있다.The product recommendation device 100 may compare the target purchase details H1 and the purchase details H2, H3, and H4 of each of the candidate users to select a comparison target user whose number of similar products is equal to or greater than a preset number. there is.

이때, 연산 속도를 극대화하기 위하여 상품 추천 장치(100)는 미리 상품들 각각에 대하여 고유하게 부여되는 상품 코드를 이용할 수 있다. 여기서 상품 코드는, 상품의 대분류를 지시하는 제1 코드(CD1), 상품의 소분류를 지시하는 제2 코드(CD2), 상품의 브랜드나 생산자를 지시하는 제3 코드(CD3), 상품의 특징을 지시하는 제4 코드(CD4), 및 상품의 원재료를 지시하는 제5 코드(CD5)를 포함할 수 있다. 이러한 상품 코드는 초기에 상품들을 상품 추천 장치(100)에 등록될 때 관리자에 의해 체계적으로 입력됨으로써 일종의 빅데이터로서 구축된다.At this time, in order to maximize the calculation speed, the product recommendation device 100 may use a product code uniquely assigned to each of the products in advance. Here, the product code includes a first code (CD1) indicating the major classification of the product, a second code (CD2) indicating the subclassification of the product, a third code (CD3) indicating the brand or manufacturer of the product, and a product characteristic. A fourth code (CD4) indicating the product and a fifth code (CD5) indicating the raw material of the product may be included. These product codes are constructed as a kind of big data by being systematically input by a manager when products are initially registered in the product recommendation device 100 .

여기서 대분류는 상품이 의류나 쥬얼리 등 중 어느 것에 속하는 지를 지시할 수 있고, 소분류는 상품이 의류인 경우 의류에 속하는 티셔츠, 청바지 등 중에서 어느 것에 속하는 지를 지시할 수 있다. 상품의 특징은 상품의 색상, 모양 등을 포함할 수 있다.Here, the major classification may indicate whether the product belongs to clothing or jewelry, and the subcategory may indicate whether the product belongs to clothing, such as a T-shirt or jeans belonging to clothing. Characteristics of the product may include the color and shape of the product.

따라서, 제1 코드(CD1)가 같으면 상품이 서로 동일한 의류나 쥬얼리라는 것을 알 수 있고, 제1 코드(CD1)와 제2 코드(CD2)가 같으면 상품이 서로 동일한 티셔츠나 청바지 등이라는 것을 알 수 있다.Therefore, if the first code CD1 is the same, it can be known that the product is the same clothing or jewelry, and if the first code CD1 and the second code CD2 are the same, it can be known that the product is the same T-shirt or jeans. there is.

상품 추천 장치(100)는, 이와 같이 부여되는 상품 코드를 참조하여 유사한 상품을 결정할 수 있다. 예를 들어, 상품 추천 장치(100)는, 상품 코드에 포함된 제1 내지 제3 코드(CD1~CD3)가 서로 동일한 상품을 유사한 상품으로 취급하여, 유사한 상품의 개수가 미리 설정된 개수 이상인 비교 대상 사용자를 선정할 수 있다.The product recommendation device 100 may determine a similar product by referring to the product code assigned in this way. For example, the product recommendation device 100 treats products having the same first to third codes (CD1 to CD3) included in the product codes as similar products, and compares the number of similar products to a preset number or more. Users can be selected.

이처럼, 본 발명의 상품 코드는 의미 없이 무작위로 설정된 코드로 부여되는 것이 아니라 상품의 분류와 특징 등을 고려하여 부여되기 때문에, 상품 코드의 일부만을 단순 비교하는 방식으로도 유사 상품을 판단할 수 있고 그로인해, 방대한 후보 사용자들을 대상으로 유사 상품을 비교할 때 매우 빠른 연산속도로 이루어질 수 있는 장점이 있다.As such, since the product code of the present invention is not assigned as a randomly set code without meaning, but given in consideration of the classification and characteristics of the product, similar products can be judged by simply comparing only a part of the product code, As a result, there is an advantage in that it can be performed at a very high computational speed when comparing similar products to a large number of candidate users.

도 5는 도 2에 따른 단계 S150에서 비교 대상 사용자의 구매 내역과 타겟 사용자의 타겟 구매 내역을 서로 비교하여 추천 상품을 결정하는 과정을 설명하기 위한 개념도이다.FIG. 5 is a conceptual diagram for explaining a process of determining a recommended product by comparing purchase details of a comparison target user and target purchase details of a target user in step S150 according to FIG. 2 .

상품 추천 장치(100)는, 비교 대상 사용자가 결정되면, 타겟 사용자의 구매 요청에 따른 구매 시점(현재)를 기준으로 미리 설정된 임계 기간(예를 들어 3달)을 초과하는 과거 시점에 해당하는 비교 대상 사용자의 구매 내역과 타겟 구매 내역을 새롭게 획득한다.When the comparison target user is determined, the product recommendation device 100 compares data corresponding to a past point in time exceeding a predetermined threshold period (for example, 3 months) based on the purchase point (current) according to the purchase request of the target user. Purchase details of the target user and target purchase details are newly acquired.

즉, 비교 대상 사용자를 결정하는 데 사용된 구매 내역은 비교적 현재를 기준으로 비교적 최근 시점의 구매 내역을 활용함으로써 타겟 사용자의 최근 구매 패턴과 유사한 후보 사용자를 결정할 수 있으나, 추천 상품은 타겟 사용자가 구매 시점이 상당히 지난 과거의 구매 내역을 활용하여 결정함으로써 최근에 구매한 적이 없으나 과거에 구매한 이력이 있는 상품과 유사한 상품을 추천 상품으로서 다시 구매할 수 있도록 유도한다.That is, the purchase history used to determine the comparison target user can determine a candidate user similar to the target user's recent purchase pattern by utilizing the purchase history at a relatively recent point in time based on the present. By making a decision using the past purchase details, which have not been purchased recently, but similar to products that have been purchased in the past, it is induced to re-purchase as a recommended product.

구체적으로, 상품 추천 장치(100)는 새롭게 획득한 타겟 사용자의 타겟 구매 내역(H11)에 포함된 상품들 각각에 대응하는 상품 코드를 이용하여 상품들 각각의 상품 벡터를 생성할 수 있다.Specifically, the product recommendation device 100 may generate a product vector for each product by using a product code corresponding to each product included in the newly acquired target purchase details H11 of the target user.

예를 들어, 상품 코드를 구성하는 제1 내지 제5 코드(CD1~CD5) 각각에 대응하는 값들을 성분값으로 갖는 상품 벡터를 생성할 수 있다. 즉, 상품 벡터는, 제1 코드(CD1)가 'A1'이면 'A1'과 대응하는 값을 첫번째 성분값으로 갖고, 제2 코드(CD2)가 'B8'이면, 'B8'과 대응하는 값을 두번째 성분값으로 갖고, 제3 코드(CD3)가 'C1'이면, 'C1'과 대응하는 값을 세번째 성분값으로 갖고, 제4 코드(CD4)가 'D3'이면, 'D3'과 대응하는 값을 네번째 성분값으로 갖고, 제5 코드(CD5)가 'EA'이면, 'EA'와 대응하는 값을 다섯번째 성분값으로 가질 수 있다. For example, a product vector having values corresponding to each of the first to fifth codes CD1 to CD5 constituting the product code as component values may be generated. That is, the product vector has a value corresponding to 'A1' as a first component value when the first code CD1 is 'A1', and a value corresponding to 'B8' when the second code CD2 is 'B8'. as a second component value, and if the third code CD3 is 'C1', has a value corresponding to 'C1' as a third component value, and if the fourth code CD4 is 'D3', corresponds to 'D3' is the fourth component value, and if the fifth code CD5 is 'EA', it may have a value corresponding to 'EA' as the fifth component value.

여기서 각 코드와 대응하는 값은 미리 코드와 대응하는 값을 정의한 코드 테이블을 참조하여 결정되며, 유사한 코드일수록 유사한 값으로 정의하는 것이 유리하다. 예를 들어, 상품의 소분류가 청바지와 면바지인 2개의 상품들 각각은 제2 코드와 대응하는 값이 3과 4와 같이 유사한 값으로 정의하고, 상품의 소분류가 청바지와 티셔츠인 2개의 상품들 각각은 제2 코드와 대응하는 값이 3과 6으로 조금 차이가 있는 값으로 정의하는 것이 유리하다.Here, a value corresponding to each code is determined by referring to a code table in which codes and corresponding values are defined in advance, and it is advantageous to define similar values as codes are similar. For example, each of two products whose subclasses are jeans and cotton pants are defined as having similar values such as 3 and 4 corresponding to the second code, and two products whose subclasses are jeans and T-shirts. It is advantageous to define each as a value slightly different from the value corresponding to the second code, such as 3 and 6.

이처럼, 상품마다 고유하게 부여되는 상품 코드는 코드 테이블을 이용하여 곧바로 상품 벡터로 변환될 수 있기 때문에 연산속도가 매우 빠른 장점을 가진다.As such, since the product code uniquely assigned to each product can be directly converted into a product vector using the code table, the operation speed is very fast.

이러한 방식으로, 상품 추천 장치(100)는, 타겟 구매 내역(H11)에 포함된 상품들 각각에 대응하는 상품 벡터들(x1~x5)을 생성할 수 있다. In this way, the product recommendation device 100 may generate product vectors x1 to x5 corresponding to each of the products included in the target purchase details H11.

다음으로, 상품 추천 장치(100)는, 생성된 상품 벡터들(x1~x5) 각각을 열(column)로 갖는 상품 벡터 행렬을 생성하고, 생성된 상품 벡터 행렬의 고유벡터(eigenvector)를 산출할 수 있다. 여기서 상품 벡터들 각각이 5개의 성분으로 구성된 5차원 벡터인 경우, 고유벡터도 5차원 벡터일 수 있다. 고유벡터를 산출하는 방법에 대해서는 이미 다양한 행렬연산을 통해 공개되어 있으므로 자세한 설명은 생략한다.Next, the product recommendation device 100 generates a product vector matrix having each of the generated product vectors (x1 to x5) as a column, and calculates an eigenvector of the generated product vector matrix. can Here, if each of the product vectors is a 5-dimensional vector composed of 5 components, the eigenvector may also be a 5-dimensional vector. Since the method for calculating the eigenvector has already been disclosed through various matrix operations, a detailed description thereof will be omitted.

상품 추천 장치(100)는 산출된 고유 벡터를 비교 대상 사용자의 구매 내역(H22)에 포함된 상품들을 변환하여 생성된 상품 벡터들(y1~y5)과 비교할 수 있다.The product recommendation device 100 may compare the calculated eigenvector with product vectors y1 to y5 generated by converting products included in the comparison target user's purchase history H22 .

구체적으로, 상품 추천 장치(100)는, 상품 벡터들(y1~y5) 중에서 고유 벡터를 다차원 공간에서 나타낸 방향각과 가장 유사한 방향각을 갖는 상품 벡터를 선정하고, 선정된 상품 벡터와 대응하는 상품을 추천 상품으로 결정할 수 있다.Specifically, the product recommendation device 100 selects a product vector having an azimuth angle most similar to an azimuth angle representing an eigenvector in a multidimensional space from among product vectors y1 to y5, and selects a product corresponding to the selected product vector. It can be decided as a recommended product.

이때, 고유 벡터가 5차원 벡터인 경우 5차원 공간 상에 고유 벡터를 나타낼 수 있으며, 이러한 다차원 공간 상에서의 2개의 벡터 사이의 방향각은 2개의 벡터 사이의 코사인 연산을 통해 결정될 수 있다. 예를 들어, 고유 벡터(ev)와 상품 벡터들 중 하나(yi) 사이의 방향각(θ)은 다음의 수학식 1에 따라 결정될 수 있다.In this case, when the eigenvector is a 5-dimensional vector, the eigenvector can be represented on a 5-dimensional space, and a direction angle between two vectors on this multi-dimensional space can be determined through a cosine operation between the two vectors. For example, the direction angle θ between the eigenvector ev and one of the product vectors yi may be determined according to Equation 1 below.

Figure 112021070216081-pat00001
Figure 112021070216081-pat00001

수학식 1에서, arccosine의 분자 부분은 고유 벡터(ev)와 상품 벡터(yi) 사이의 내적 연산이고, 분모 부분은 고유 벡터(ev)와 상품 벡터(yi) 각각의 크기의 곱이다.In Equation 1, the numerator part of arccosine is the dot product operation between the eigenvector (ev) and the product vector (yi), and the denominator part is the product of each magnitude of the eigenvector (ev) and product vector (yi).

상기 수학식 1에 따라 결정되는 고유 벡터(ev)와 상품 벡터(yi) 사이의 방향각(θ)이 가장 작은 상품 벡터를 선정하고, 선정된 상품 벡터와 대응하는 상품을 추천 상품으로 결정할 수 있다.A product vector having the smallest orientation angle (θ) between the eigenvector (ev) and the product vector (yi) determined according to Equation 1 may be selected, and a product corresponding to the selected product vector may be determined as a recommended product. .

이처럼, 본 발명에서는 타겟 사용자의 과거 시점에 구매한 상품들로부터 고유 벡터(ev)를 산출하고, 산출된 고유 벡터(ev)를 기준으로 비교 대상 사용자의 상품을 선정하기 때문에 2명의 사용자 사이에 단순히 상품이 공통되는 상품을 추천 상품으로 제공하는 종래의 기술에서 벗어나 타겟 사용자의 과거 시점에 구매한 상품들 전체를 대표하는 고유 벡터와 유사한 상품을 추천 상품으로서 제공할 수 있다.As such, in the present invention, since an eigenvector (ev) is calculated from products purchased by a target user in the past, and a product of a user to be compared is selected based on the calculated eigenvector (ev), it is simply Deviating from the conventional technique of providing products with common products as recommended products, products similar to eigenvectors representing all products purchased by the target user in the past may be provided as recommended products.

도 6은 일 실시예에 따른 상품 추천 장치의 하드웨어 구성을 예시적으로 나타낸 도면이다.6 is a diagram showing a hardware configuration of a product recommendation device according to an exemplary embodiment.

도 6을 참조하면, 상품 추천 장치(100)는, 적어도 하나의 프로세서(110) 및 상기 적어도 하나의 프로세서(110)가 적어도 하나의 동작(operation)을 수행하도록 지시하는 명령어들(instructions)을 저장하는 메모리(memory)를 포함할 수 있다.Referring to FIG. 6 , the product recommendation apparatus 100 stores at least one processor 110 and instructions instructing the at least one processor 110 to perform at least one operation. It may include a memory (memory) to.

상기 적어도 하나의 동작은 도 1 내지 도 5를 참조하여 설명한 상품 추천 장치의 동작이나 기능들 중 적어도 하나를 포함할 수 있다.The at least one operation may include at least one of operations or functions of the product recommendation device described with reference to FIGS. 1 to 5 .

여기서 적어도 하나의 프로세서(110)는 중앙 처리 장치(central processing unit, CPU), 그래픽 처리 장치(graphics processing unit, GPU), 또는 본 발명의 실시예들에 따른 방법들이 수행되는 전용의 프로세서를 의미할 수 있다. 메모리(120) 및 저장 장치(160) 각각은 휘발성 저장 매체 및 비휘발성 저장 매체 중에서 적어도 하나로 구성될 수 있다. 예를 들어, 메모리(120)는 읽기 전용 메모리(read only memory, ROM) 및 랜덤 액세스 메모리(random access memory, RAM) 중 하나일 수 있고, 저장 장치(160)는, 플래시메모리(flash-memory), 하드디스크 드라이브(HDD), 솔리드 스테이트 드라이브(SSD), 또는 각종 메모리 카드(예를 들어, micro SD 카드) 등일 수 있다.Here, the at least one processor 110 may mean a central processing unit (CPU), a graphics processing unit (GPU), or a dedicated processor for performing methods according to embodiments of the present invention. can Each of the memory 120 and the storage device 160 may include at least one of a volatile storage medium and a non-volatile storage medium. For example, the memory 120 may be one of a read only memory (ROM) and a random access memory (RAM), and the storage device 160 may be a flash-memory. , a hard disk drive (HDD), a solid state drive (SSD), or various memory cards (eg, a micro SD card).

또한, 상품 추천 장치(100)는, 무선 네트워크를 통해 통신을 수행하는 송수신 장치(transceiver)(130)를 포함할 수 있다. 또한, 상품 추천 장치(100)는 입력 인터페이스 장치(140), 출력 인터페이스 장치(150), 저장 장치(160) 등을 더 포함할 수 있다. 상품 추천 장치(100)에 포함된 각각의 구성 요소들은 버스(bus)(170)에 의해 연결되어 서로 통신을 수행할 수 있다.Also, the product recommendation device 100 may include a transceiver 130 that performs communication through a wireless network. Also, the product recommendation device 100 may further include an input interface device 140 , an output interface device 150 , a storage device 160 , and the like. Each component included in the product recommendation device 100 is connected by a bus 170 to communicate with each other.

상품 추천 장치(100)의 예를 들면, 통신 가능한 데스크탑 컴퓨터(desktop computer), 랩탑 컴퓨터(laptop computer), 노트북(notebook), 스마트폰(smart phone), 태블릿 PC(tablet PC), 모바일폰(mobile phone), 스마트 워치(smart watch), 스마트 글래스(smart glass), e-book 리더기, PMP(portable multimedia player), 휴대용 게임기, 네비게이션(navigation) 장치, 디지털 카메라(digital camera), DMB(digital multimedia broadcasting) 재생기, 디지털 음성 녹음기(digital audio recorder), 디지털 음성 재생기(digital audio player), 디지털 동영상 녹화기(digital video recorder), 디지털 동영상 재생기(digital video player), PDA(Personal Digital Assistant) 등일 수 있다.For example, the product recommendation device 100 may be a communicable desktop computer, a laptop computer, a notebook, a smart phone, a tablet PC, or a mobile phone. phone), smart watch, smart glass, e-book reader, portable multimedia player (PMP), portable game device, navigation device, digital camera, digital multimedia broadcasting (DMB) ) player, digital audio recorder, digital audio player, digital video recorder, digital video player, personal digital assistant (PDA), and the like.

본 발명에 따른 방법들은 다양한 컴퓨터 수단을 통해 수행될 수 있는 프로그램 명령 형태로 구현되어 컴퓨터 판독 가능 매체에 기록될 수 있다. 컴퓨터 판독 가능 매체는 프로그램 명령, 데이터 파일, 데이터 구조 등을 단독으로 또는 조합하여 포함할 수 있다. 컴퓨터 판독 가능 매체에 기록되는 프로그램 명령은 본 발명을 위해 특별히 설계되고 구성된 것들이거나 컴퓨터 소프트웨어 당업자에게 공지되어 사용 가능한 것일 수도 있다.The methods according to the present invention may be implemented in the form of program instructions that can be executed by various computer means and recorded on a computer readable medium. Computer readable media may include program instructions, data files, data structures, etc. alone or in combination. Program instructions recorded on a computer readable medium may be specially designed and configured for the present invention or may be known and usable to those skilled in computer software.

컴퓨터 판독 가능 매체의 예에는 롬(ROM), 램(RAM), 플래시 메모리(flash memory) 등과 같이 프로그램 명령을 저장하고 수행하도록 특별히 구성된 하드웨어 장치가 포함될 수 있다. 프로그램 명령의 예에는 컴파일러(compiler)에 의해 만들어지는 것과 같은 기계어 코드뿐만 아니라 인터프리터(interpreter) 등을 사용해서 컴퓨터에 의해 실행될 수 있는 고급 언어 코드를 포함할 수 있다. 상술한 하드웨어 장치는 본 발명의 동작을 수행하기 위해 적어도 하나의 소프트웨어 모듈로 작동하도록 구성될 수 있으며, 그 역도 마찬가지이다.Examples of computer readable media may include hardware devices specially configured to store and execute program instructions, such as ROM, RAM, flash memory, and the like. Examples of program instructions may include not only machine language codes generated by a compiler but also high-level language codes that can be executed by a computer using an interpreter and the like. The hardware device described above may be configured to operate with at least one software module to perform the operations of the present invention, and vice versa.

또한, 상술한 방법 또는 장치는 그 구성이나 기능의 전부 또는 일부가 결합되어 구현되거나, 분리되어 구현될 수 있다. In addition, the above-described method or device may be implemented by combining all or some of its components or functions, or may be implemented separately.

상기에서는 본 발명의 바람직한 실시예를 참조하여 설명하였지만, 해당 기술 분야의 숙련된 당업자는 하기의 특허 청구의 범위에 기재된 본 발명의 사상 및 영역으로부터 벗어나지 않는 범위 내에서 본 발명을 다양하게 수정 및 변경시킬 수 있음을 이해할 수 있을 것이다. Although the above has been described with reference to preferred embodiments of the present invention, those skilled in the art will variously modify and change the present invention within the scope not departing from the spirit and scope of the present invention described in the claims below. You will understand that it can be done.

Claims (1)

상품 코드와 구매 패턴에 따른 회귀분석을 이용한 상품 추천 방법으로,
사용자 단말로부터 구매 요청을 수신하는 단계;
상기 구매 요청에 상응하는 거래를 완료하고 상기 사용자 단말의 타겟 사용자와 대응하는 기준 구매 패턴을 획득하는 단계;
상기 기준 구매 패턴을 미리 수집된 다수의 사용자들 각각의 구매 패턴과 비교하여 복수의 후보 사용자들을 선정하는 단계;
상기 구매 요청에 따른 구매 시점을 기준으로, 상기 타겟 사용자의 제1 타겟 구매 내역과 상기 후보 사용자들 각각에 대응하는 복수의 제1 구매 내역들을 획득하는 단계;
상기 제1 타겟 구매 내역과 상기 제1 구매 내역들을 서로 비교하여 상기 후보 사용자들 중 하나를 비교 대상 사용자로 선정하는 단계;
상기 구매 요청에 따른 구매 시점을 기준으로, 상기 비교 대상 사용자의 제2 구매 내역과 상기 타겟 사용자의 제2 타겟 구매 내역을 새롭게 획득하고, 상기 제2 구매 내역과 상기 제2 타겟 구매 내역을 서로 비교하여 추천 상품을 결정하는 단계; 및
상기 추천 상품을 포함하는 거래 완료 메시지를 상기 사용자 단말에 전송하는 단계를 포함하고,
상기 후보 사용자들 중 하나를 비교 대상 사용자로 선정하는 단계는,
상품들마다 미리 고유하게 부여된 상품 코드를 기초로 상기 제1 타겟 구매 내역에 포함된 상품들과 상기 제1 구매 내역들 각각에 포함된 상품들을 서로 비교하여 유사한 상품을 결정하는 단계; 및
상기 제1 구매 내역들 중 유사한 상품이 미리 설정된 개수 이상인 제1 구매 내역과 대응하는 후보 사용자를 상기 비교 대상 사용자로 선정하는 단계를 포함하며,
상기 상품 코드는,
상품의 대분류를 지시하는 제1 코드; 상품의 소분류를 지시하는 제2 코드, 상품의 브랜드나 생산자를 지시하는 제3 코드, 상품의 특징을 지시하는 제4 코드, 및 상품의 원재료를 지시하는 제5 코드를 포함하며,
상기 유사한 상품을 결정하는 단계는,
상기 제1 코드, 상기 제2 코드, 및 상기 제3 코드가 서로 동일한 상품을 상기 유사한 상품으로 결정하고,
상기 추천 상품을 결정하는 단계는,
상기 상품 코드를 이용하여 상기 제2 타겟 구매 내역에 포함된 상품들 각각에 대응하는 상품 벡터들을 생성하는 단계;
상기 상품 벡터들 각각을 열(column)로 갖는 상품 벡터 행렬을 생성하는 단계;
상기 상품 벡터 행렬의 고유벡터(eigenvector)를 산출하는 단계;
상기 고유벡터와 상기 제2 구매 내역에 포함된 상품들 각각에 대응하는 상품 벡터들 사이의 방향각을 하기 수학식
Figure 112021070216081-pat00002
, (ev는 상기 고유벡터이고, yi는 상기 상품 벡터들 중 하나)
에 기초하여 산출하는 단계; 및
상기 제2 구매 내역에 포함된 상품들 중에서 상기 방향각이 가장 작은 상품 벡터와 대응하는 상품을 상기 추천 상품으로 결정하는 단계를 포함하고,
상기 기준 구매 패턴을 획득하는 단계는,
상기 타겟 사용자의 구매 시기별 구매 건수를 나타낸 그래프에서 선형 회귀 분석을 수행함으로써 구매 추세선을 획득하고,
상기 복수의 후보 사용자들을 선정하는 단계는,
상기 그래프에서 상기 구매 추세선이 지나고, 상기 구매 건수를 나타내는 y축의 절편을 기준으로 임계값만큼 큰 상향 임계값과 상기 임계값만큼 작은 하향 임계값을 결정하는 단계;
상기 그래프에서 2개 이상의 좌표들을 지나는 라인들 중에서 상기 y축의 절편이 상기 상향 임계값과 상기 하향 임계값 사이에 속하고 기울기가 가장 큰 라인을 상향 임계선으로 선정하고, 상기 y축의 절편이 상기 상향 임계값과 상기 하향 임계값 사이에 속하고 기울기가 가장 작은 라인을 하향 임계선으로 선정하는 단계; 및
상기 사용자들 각각에 대한 구매 시기별 구매 건수를 이용하여 산출된 추세선들 중에서 상기 상향 임계선과 상기 하향 임계선 사이의 영역을 지나는 추세선과 대응하는 사용자들을 상기 후보 사용자들로 선정하는 단계를 포함하는, 상품 추천 방법.
It is a product recommendation method using regression analysis according to product code and purchase pattern.
Receiving a purchase request from a user terminal;
completing a transaction corresponding to the purchase request and obtaining a reference purchase pattern corresponding to a target user of the user terminal;
selecting a plurality of candidate users by comparing the reference purchase pattern with purchase patterns of each of a plurality of users previously collected;
obtaining a first target purchase detail of the target user and a plurality of first purchase details corresponding to each of the candidate users, based on a purchase time point according to the purchase request;
comparing the first target purchase details with the first purchase details and selecting one of the candidate users as a comparison target user;
Based on the purchase time according to the purchase request, the second purchase details of the comparison target user and the second target purchase details of the target user are newly acquired, and the second purchase details and the second target purchase details are compared with each other to determine a recommended product; and
Transmitting a transaction completion message including the recommended product to the user terminal;
The step of selecting one of the candidate users as a comparison target user,
determining similar products by comparing products included in the first target purchase details with products included in each of the first purchase details based on a product code uniquely assigned to each product in advance; and
Selecting a candidate user corresponding to first purchase details having a preset number or more of similar products among the first purchase details as the comparison target user;
The product code is
A first code indicating a major classification of goods; A second code indicating the subclass of the product, a third code indicating the brand or producer of the product, a fourth code indicating the characteristics of the product, and a fifth code indicating the raw material of the product,
The step of determining the similar product is,
The first code, the second code, and the third code determine a product identical to each other as the similar product;
The step of determining the recommended product,
generating product vectors corresponding to respective products included in the second target purchase details using the product code;
generating a product vector matrix having each of the product vectors as a column;
calculating an eigenvector of the product vector matrix;
The eigenvector and the orientation angle between the product vectors corresponding to each of the products included in the second purchase details are calculated by the following equation
Figure 112021070216081-pat00002
, (ev is the eigenvector, yi is one of the product vectors)
Calculating based on; and
Determining a product corresponding to the product vector having the smallest orientation angle among products included in the second purchase details as the recommended product;
The step of obtaining the reference purchase pattern,
Obtaining a purchase trend line by performing linear regression analysis on a graph showing the number of purchases by purchase time of the target user;
The step of selecting the plurality of candidate users,
determining an upward threshold value that is greater than a threshold value and a downward threshold value that is less than the threshold value based on an intercept of a y-axis representing the number of purchases after the purchase trend line in the graph;
Among the lines passing through two or more coordinates in the graph, a line whose y-axis intercept falls between the upward threshold and the downward threshold and has the largest slope is selected as the upward threshold line, and the y-axis intercept is the upward threshold. selecting a line between a threshold value and the downward threshold value and having the smallest slope as a downward threshold line; and
Selecting users corresponding to a trend line passing through a region between the upper threshold line and the lower threshold line among trend lines calculated using the number of purchases by purchase time for each of the users as the candidate users, How to recommend a product.
KR1020210079058A 2021-03-08 2021-06-18 Method for recommending product using regression analysis according to product code and purchase pattern and apparatus for the same KR102495011B1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1020210079058A KR102495011B1 (en) 2021-03-08 2021-06-18 Method for recommending product using regression analysis according to product code and purchase pattern and apparatus for the same

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
KR1020210030114A KR102268739B1 (en) 2021-03-08 2021-03-08 Method for recommending product based on user purchase history and apparatus for the same
KR1020210079058A KR102495011B1 (en) 2021-03-08 2021-06-18 Method for recommending product using regression analysis according to product code and purchase pattern and apparatus for the same

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
KR1020210030114A Division KR102268739B1 (en) 2021-03-08 2021-03-08 Method for recommending product based on user purchase history and apparatus for the same

Publications (2)

Publication Number Publication Date
KR20220126182A KR20220126182A (en) 2022-09-15
KR102495011B1 true KR102495011B1 (en) 2023-02-06

Family

ID=76607435

Family Applications (2)

Application Number Title Priority Date Filing Date
KR1020210030114A KR102268739B1 (en) 2021-03-08 2021-03-08 Method for recommending product based on user purchase history and apparatus for the same
KR1020210079058A KR102495011B1 (en) 2021-03-08 2021-06-18 Method for recommending product using regression analysis according to product code and purchase pattern and apparatus for the same

Family Applications Before (1)

Application Number Title Priority Date Filing Date
KR1020210030114A KR102268739B1 (en) 2021-03-08 2021-03-08 Method for recommending product based on user purchase history and apparatus for the same

Country Status (1)

Country Link
KR (2) KR102268739B1 (en)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20230149529A (en) * 2022-04-20 2023-10-27 쿠팡 주식회사 Electronic apparatus for providing user profile information and method thereof

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101612061B1 (en) * 2015-01-28 2016-04-12 주식회사 포워드벤처스 System and method for providing shopping service
KR102128059B1 (en) * 2019-08-08 2020-06-29 (주)코바이노베이션 Electronic apparatus recommending optimal financial products through machine learning based on customer's information and purchase history of financial products
KR102213768B1 (en) * 2020-05-19 2021-02-08 주식회사 스타일씨코퍼레이션 Customer-specific product recommendation system that exposes products with high purchase conversion rate based on customer information by artificial intelligence based on big data

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101081947B1 (en) * 2009-09-21 2011-11-10 경상대학교산학협력단 Hybrid recommendation method and system for large scale data
KR101438050B1 (en) * 2012-06-19 2014-09-15 (주) 더존비즈온 System for monitoring client
KR102210442B1 (en) * 2014-02-26 2021-02-02 에스케이플래닛 주식회사 Method of generating category preference for each user, method of recommending products using the same and apparatus for the same

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101612061B1 (en) * 2015-01-28 2016-04-12 주식회사 포워드벤처스 System and method for providing shopping service
KR102128059B1 (en) * 2019-08-08 2020-06-29 (주)코바이노베이션 Electronic apparatus recommending optimal financial products through machine learning based on customer's information and purchase history of financial products
KR102213768B1 (en) * 2020-05-19 2021-02-08 주식회사 스타일씨코퍼레이션 Customer-specific product recommendation system that exposes products with high purchase conversion rate based on customer information by artificial intelligence based on big data

Also Published As

Publication number Publication date
KR102268739B1 (en) 2021-06-24
KR20220126182A (en) 2022-09-15

Similar Documents

Publication Publication Date Title
US20180357669A1 (en) System and method for information processing
CN105574089B (en) Knowledge graph generation method and device, and object comparison method and device
US20150221023A1 (en) Information providing device, information providing method, information providing program, and computer-readable storage medium storing the program
KR102389226B1 (en) Identification of intent and non-intent query parts
CN111695960A (en) Object recommendation system, method, electronic device and storage medium
CN103703436A (en) Data processing device, data processing method, data processing program, and computer-readable recording medium which records program
JP6696568B2 (en) Item recommendation method, item recommendation program and item recommendation device
CN111815404A (en) Virtual article sharing method and device
CN112488863A (en) Dangerous seed recommendation method and related equipment in user cold start scene
KR102495011B1 (en) Method for recommending product using regression analysis according to product code and purchase pattern and apparatus for the same
CN111414533A (en) Recommendation information generation method and device, electronic equipment and storage medium
CN115578163A (en) Personalized pushing method and system for combined commodity information
CN112424814A (en) Determining item relevance
JP5056803B2 (en) Information providing server and information providing method
US9804741B2 (en) Methods and systems for managing N-streams of recommendations
CN110020918B (en) Recommendation information generation method and system
KR101081947B1 (en) Hybrid recommendation method and system for large scale data
KR20100044394A (en) Method and server for searching commodity
JP6356774B2 (en) Selection device, selection method, and selection program
CN110827044A (en) Method and device for extracting user interest mode
CN104050174B (en) A kind of personal page generation method and device
KR20230079292A (en) Big data-based usability test methods and devices
CN111339434B (en) Information recommendation method and device, electronic equipment and computer storage medium
JP5056801B2 (en) Information providing server and information providing method
CN113837846B (en) Commodity recommendation method, commodity recommendation device, computer equipment and storage medium

Legal Events

Date Code Title Description
E701 Decision to grant or registration of patent right
GRNT Written decision to grant