KR20220150081A - Method and apparatus for recommending places - Google Patents

Method and apparatus for recommending places Download PDF

Info

Publication number
KR20220150081A
KR20220150081A KR1020210057338A KR20210057338A KR20220150081A KR 20220150081 A KR20220150081 A KR 20220150081A KR 1020210057338 A KR1020210057338 A KR 1020210057338A KR 20210057338 A KR20210057338 A KR 20210057338A KR 20220150081 A KR20220150081 A KR 20220150081A
Authority
KR
South Korea
Prior art keywords
score
place
places
calculating
time unit
Prior art date
Application number
KR1020210057338A
Other languages
Korean (ko)
Other versions
KR102570399B1 (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 KR1020210057338A priority Critical patent/KR102570399B1/en
Publication of KR20220150081A publication Critical patent/KR20220150081A/en
Application granted granted Critical
Publication of KR102570399B1 publication Critical patent/KR102570399B1/en

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F17/00Digital computing or data processing equipment or methods, specially adapted for specific functions
    • 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/02Marketing; Price estimation or determination; Fundraising
    • G06Q30/0282Rating or review of business operators or products
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q50/00Information and communication technology [ICT] specially adapted for implementation of business processes of specific business sectors, e.g. utilities or tourism
    • G06Q50/10Services

Landscapes

  • Business, Economics & Management (AREA)
  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Strategic Management (AREA)
  • Marketing (AREA)
  • Accounting & Taxation (AREA)
  • Finance (AREA)
  • Development Economics (AREA)
  • General Business, Economics & Management (AREA)
  • Economics (AREA)
  • Tourism & Hospitality (AREA)
  • Health & Medical Sciences (AREA)
  • Data Mining & Analysis (AREA)
  • Databases & Information Systems (AREA)
  • Mathematical Physics (AREA)
  • Software Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Primary Health Care (AREA)
  • General Health & Medical Sciences (AREA)
  • Entrepreneurship & Innovation (AREA)
  • Human Resources & Organizations (AREA)
  • Game Theory and Decision Science (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

Disclosed are a method and apparatus for recommending places. The method for recommending places, performed by a server, according to an embodiment includes the steps of: obtaining a list of places corresponding to a reference location; calculating a quality score and a variance score of the corresponding place based on the degree of interest of the corresponding place, by corresponding to each of the places, calculating; and selecting at least one recommendation target from among the places based on the quality score and the variance score calculated by corresponding to each of the places.

Description

장소 추천 방법 및 장치{METHOD AND APPARATUS FOR RECOMMENDING PLACES}Location recommendation method and device {METHOD AND APPARATUS FOR RECOMMENDING PLACES}

아래 실시예들은 장소 추천 방법 및 장치에 관한 것으로, 구체적으로는 지도 어플리케이션 혹은 지도 웹사이트에서 기준 위치에 대응하는 장소를 추천하는 방법 및 장소 추천 서비스를 제공하는 서버에 관한 것이다.The following embodiments relate to a method and apparatus for recommending a place, and more particularly, to a method for recommending a place corresponding to a reference location in a map application or a map website, and to a server providing a place recommendation service.

최근 스마트 폰, 태블릿, 웨어러블 디바이스 등 모바일 단말에서 주변 검색을 하거나, 길을 찾거나, 실시간 교통 정보를 확인하는 지도 어플리케이션의 사용이 보편화되고 있다. 지도 어플리케이션은 GPS 정보를 이용하여 단말의 실시간 위치를 판단하고, 주변에 위치하는 음식점, 카페, 편의점, 지하철역 등 다양한 장소에 관한 정보를 제공하고, 실시간 교통 정보를 이용하여 길 찾기 기능을 제공하는 등 다양한 서비스를 제공하고 있다. 지도 어플리케이션의 사용이 증가함에 따라 위치 기반 다양한 기능을 제공하기 위한 기술의 개발이 요구되고 있다. In recent years, the use of map applications for searching, finding directions, or checking real-time traffic information in mobile terminals such as smart phones, tablets, and wearable devices has become common. The map application uses GPS information to determine the real-time location of the terminal, provides information about various places such as restaurants, cafes, convenience stores, and subway stations located nearby, and provides a route finding function using real-time traffic information. We provide a variety of services. As the use of map applications increases, the development of technology for providing various location-based functions is required.

아래의 실시 예들을 통해 장소들에 대한 사용자들의 최근 관심도를 반영하여 장소를 추천하는 서비스를 제공할 수 있다.Through the following embodiments, a service for recommending a place may be provided by reflecting users' recent interest in places.

아래의 실시 예들을 통해 동일 지역에 대한 사용자의 장소 추천 요청의 시점에 따라 추천되는 장소 목록이 변화되는 장소 추천 서비스를 제공할 수 있다.Through the following embodiments, it is possible to provide a place recommendation service in which a list of recommended places is changed according to the timing of a user's request for place recommendation for the same area.

다만, 기술적 과제는 상술한 기술적 과제들로 한정되는 것은 아니며, 또 다른 기술적 과제들이 존재할 수 있다.However, the technical problems are not limited to the above-described technical problems, and other technical problems may exist.

일 측에 따른 서버에서 수행되는 장소 추천 방법은 기준 위치에 대응하는 장소들의 목록을 획득하는 단계; 상기 장소들 각각에 대응하여, 해당 장소의 누적 관심도에 기초하여, 상기 해당 장소의 퀄리티 스코어를 계산하는 단계; 및 상기 해당 장소의 관심도의 시간 단위 별 이동 평균 값들의 분포 및 기준 시간 단위의 이동 평균 값에 기초하여, 상기 해당 장소의 변화량 스코어를 계산하는 단계; 및 상기 장소들 각각에 대응하여 계산된 상기 퀄리티 스코어 및 상기 변화량 스코어에 기초하여, 상기 장소들 중 적어도 하나의 추천 대상을 선별하는 단계를 포함한다.According to one aspect, a method for recommending a place performed by a server includes: obtaining a list of places corresponding to a reference location; corresponding to each of the places, calculating a quality score of the corresponding place based on the cumulative interest level of the corresponding place; and calculating a change amount score of the corresponding place based on a distribution of moving average values for each time unit of interest of the corresponding place and a moving average value of a reference time unit. and selecting at least one recommendation target from among the places based on the quality score and the variation score calculated for each of the places.

상기 추천 대상을 선별하는 단계는 상기 장소들의 변화량 스코어들의 분위수(quantile)에 기초하여 획득된 변화량 스코어에 관한 제1 임계 값을 초과하는 장소를 아웃라이어(outlier)로 판단하는 단계; 및 상기 아웃라이어로 판단된 장소의 변화량 스코어를 최소 값으로 설정하는 단계를 더 포함할 수 있다.The selecting of the recommendation target may include: determining, as an outlier, a place exceeding a first threshold value with respect to a variance score obtained based on a quantile of variance scores of the places; and setting the change amount score of the place determined as the outlier to a minimum value.

상기 아웃라이어로 판단하는 단계는 상기 장소들의 변화량 스코어들을 로그 스케일로 변환하는 단계; 상기 변환된 변화량 스코어들의 분위수에 기초하여, 변화량 스코어에 관한 제1 임계 값을 획득하는 단계; 및 상기 장소들 중 변환된 변화량 스코어가 상기 제1 임계 값을 초과하는 장소를 아웃라이어로 판단하는 단계를 포함할 수 있다.The determining of the outliers may include: converting the variation scores of the places into a logarithmic scale; obtaining a first threshold value for the variance score based on the quantiles of the transformed variance scores; and determining, among the places, a place in which the converted change amount score exceeds the first threshold value as an outlier.

상기 아웃라이어로 판단하는 단계는 상기 장소들의 변화량 스코어들의 분위수에 기초하여 변화량 스코어에 관한 제1 임계 값을 획득하는 단계; 상기 장소들의 기준 시간 단위에 대응하는 관심도들에 기초하여, 관심도에 관한 제2 임계 값을 획득하는 단계; 및 상기 장소들 중 변화량 스코어가 제1 임계 값을 초과하고, 상기 기준 시간 단위에 대응하는 관심도가 제2 임계 값을 초과하는 장소를 아웃라이어로 판단하는 단계를 포함할 수 있다.The determining as the outlier may include: obtaining a first threshold value for the variance score based on quantiles of variance scores of the places; obtaining a second threshold value related to the degree of interest based on the degree of interest corresponding to the reference time unit of the places; and determining, as an outlier, a place in which the variation score exceeds a first threshold value and the degree of interest corresponding to the reference time unit exceeds a second threshold value among the places.

상기 변화량 스코어를 계산하는 단계는 상기 기준 시간 단위의 이전 시간 단위들의 이동 평균 값들의 평균 및 표준 편차를 계산하는 단계; 상기 표준 편차 및 상기 평균에 기초하여, 상기 기준 시간 단위의 이동 평균 값의 표준 점수를 계산하는 단계; 및 상기 표준 점수에 기초하여, 상기 변화량 스코어를 결정하는 단계를 포함할 수 있다.The calculating of the variance score may include calculating an average and standard deviation of moving average values of previous time units of the reference time unit; calculating a standard score of the moving average value of the reference time unit based on the standard deviation and the average; and determining the variation score based on the standard score.

상기 표준 점수를 계산하는 단계는 상기 표준 편차에 미리 정해진 값을 더하여 보정하는 단계; 및 상기 보정된 표준 편차 및 상기 평균에 기초하여, 상기 기준 시간 단위의 이동 평균 값의 표준 점수를 계산하는 단계를 포함할 수 있다.Calculating the standard score may include correcting by adding a predetermined value to the standard deviation; and calculating a standard score of the moving average value of the reference time unit based on the corrected standard deviation and the average.

상기 변화량 스코어를 계산하는 단계는 상기 기준 시간 단위의 이동 평균 값이 상기 기준 시간 단위의 이전 시간 단위들의 이동 평균 값들의 평균보다 작은 경우, 상기 변화량 스코어를 최소 값으로 설정하는 단계를 포함할 수 있다.Calculating the variance score may include setting the variance score to a minimum value when the moving average value of the reference time unit is smaller than an average of moving average values of previous time units of the reference time unit. .

상기 추천 대상을 선별하는 단계는 상기 장소들 각각에 대응하여, 해당 장소의 퀄리티 스코어 및 상기 해당 장소의 변화량 스코어를 합함으로써 상기 해당 장소의 최종 스코어를 계산하는 단계; 및 상기 장소들의 최종 스코어들에 기초하여, 상기 장소들 중 적어도 하나의 추천 대상을 선별하는 단계를 포함할 수 있다.The step of selecting the recommended target may include calculating a final score of the corresponding place by summing the quality score of the corresponding place and the variation score of the corresponding place corresponding to each of the places; and selecting at least one of the places to be recommended based on the final scores of the places.

상기 최종 스코어를 계산하는 단계는 상기 퀄리티 스코어에 대응하는 제1 가중치 및 상기 변화량 스코어에 대응하는 제2 가중치에 기초하여, 상기 해당 장소의 퀄리티 스코어 및 상기 해당 장소의 변화량 스코어를 가중 합함으로써 상기 해당 장소의 최종 스코어를 계산하는 단계를 포함할 수 있다.The calculating of the final score includes weighting and summing the quality score of the corresponding place and the variation score of the corresponding place based on a first weight corresponding to the quality score and a second weight corresponding to the variation score. calculating a final score for the venue.

상기 제2 가중치는 상기 제1 가중치보다 크게 설정될 수 있다.The second weight may be set to be greater than the first weight.

상기 최종 스코어를 계산하는 단계는 상기 장소들 각각에 대응하여 획득된 변화량 스코어를 일정 범위 내의 값을 갖도록 정규화하는 단계; 및 상기 장소들 각각에 대응하여, 해당 장소의 퀄리티 스코어 및 상기 해당 장소의 정규화된 변화량 스코어를 가중 합함으로써 상기 해당 장소의 최종 스코어를 계산하는 단계를 포함할 수 있다.The calculating of the final score may include: normalizing the variation score obtained for each of the places to have a value within a predetermined range; and calculating the final score of the corresponding place by weighted summing the quality score of the corresponding place and the normalized variation score of the corresponding place, corresponding to each of the places.

상기 시간 단위는 일주일 단위를 포함할 수 있다.The time unit may include a week unit.

상기 관심도의 시간 단위 별 이동 평균 값들은 미리 정해진 범위의 관심도에 관한 일별 시계열 데이터에 기초하여 획득된 일주일 동안의 관심도의 평균 값들을 포함할 수 있다.The moving average values for each time unit of the interest may include average values of the interest for a week obtained based on daily time series data regarding the interest in a predetermined range.

상기 관심도는 특정 장소에 대한 검색량 및 상기 특정 장소에 대한 클릭 수 중 적어도 하나에 기초하여 결정될 수 있다.The degree of interest may be determined based on at least one of a search amount for a specific place and a number of clicks for the specific place.

상기 장소들의 목록을 획득하는 단계는 상기 장소들에 대한 클릭 수에 대응하는 시계열 데이터를 획득하는 단계; 및 상기 장소들에 대한 검색량에 대응하는 시계열 데이터를 획득하는 단계 중 적어도 하나를 더 포함할 수 있다.The obtaining of the list of places may include: obtaining time series data corresponding to the number of clicks on the places; and obtaining time series data corresponding to a search amount for the places.

상기 추천 대상을 선별하는 단계는 상기 장소들 각각에 대응하여, 해당 장소의 위치 및 상기 기준 위치 사이의 거리를 계산하는 단계; 및 상기 장소들 각각에 대응하여 계산된 상기 퀄리티 스코어, 상기 변화량 스코어 및 상기 거리에 기초하여, 상기 장소들 중 적어도 하나의 추천 대상을 선별하는 단계를 포함할 수 있다.The selecting of the recommendation target may include calculating a distance between a location of the corresponding location and the reference location corresponding to each of the locations; and selecting at least one recommendation target from among the places based on the quality score, the variation score, and the distance calculated for each of the places.

상기 장소들의 목록을 획득하는 단계는 사용자로부터 장소의 카테고리에 관한 정보를 수신하는 단계 및 상기 기준 위치 및 상기 카테고리에 관한 정보에 기초하여, 상기 장소들의 목록을 획득하는 단계를 포함할 수 있다.Acquiring the list of places may include receiving information about a category of a place from a user, and obtaining the list of places based on the reference location and the information about the category.

상기 서버는 지도 어플리케이션 및 지도 웹사이트 중 적어도 하나를 제공하는 서버를 포함할 수 있다.The server may include a server that provides at least one of a map application and a map website.

일 측에 따른 서버는 기준 위치에 대응하는 장소들의 목록을 획득하고, 상기 장소들 각각에 대응하여, 해당 장소의 누적 관심도에 기초하여, 상기 해당 장소의 퀄리티 스코어를 계산하고, 상기 해당 장소의 관심도의 시간 단위 별 이동 평균 값들의 분포 및 기준 시간 단위의 이동 평균 값에 기초하여, 상기 해당 장소의 변화량 스코어를 계산하고, 상기 장소들 각각에 대응하여 계산된 상기 퀄리티 스코어 및 상기 변화량 스코어에 기초하여, 상기 장소들 중 적어도 하나의 추천 대상을 선별하는, 적어도 하나의 프로세서를 포함한다.A server according to one side obtains a list of places corresponding to a reference location, and, corresponding to each of the places, calculates a quality score of the corresponding place based on the cumulative interest level of the corresponding place, and the degree of interest of the corresponding place based on the distribution of moving average values for each time unit and the moving average value of the reference time unit, calculates the variation score of the corresponding place, and based on the quality score and the variation score calculated for each of the places , at least one processor for selecting at least one recommendation target from among the places.

상기 프로세서는, 상기 추천 대상을 선별함에 있어서, 상기 장소들의 변화량 스코어들의 분위수(quantile)에 기초하여 획득된 변화량 스코어에 관한 제1 임계 값을 초과하는 장소를 아웃라이어(outlier)로 판단하고, 상기 아웃라이어로 판단된 장소의 변화량 스코어를 최소 값으로 설정할 수 있다.The processor is configured to determine, as an outlier, a place exceeding a first threshold value with respect to a variance score obtained based on a quantile of variance scores of the places as an outlier in selecting the recommendation target; The change score of the place determined as an outlier can be set to the minimum value.

상기 프로세서는, 상기 변화량 스코어를 계산함에 있어서, 상기 기준 시간 단위의 이전 시간 단위들의 이동 평균 값들의 평균 및 표준 편차를 계산하고, 상기 표준 편차 및 상기 평균에 기초하여, 상기 기준 시간 단위의 이동 평균 값의 표준 점수를 계산하며, 상기 표준 점수에 기초하여, 상기 변화량 스코어를 결정할 수 있다.In calculating the variance score, the processor calculates an average and standard deviation of moving average values of previous time units of the reference time unit, and based on the standard deviation and the average, the moving average of the reference time unit A standard score of the values may be calculated, and the variance score may be determined based on the standard score.

상기 프로세서는, 상기 추천 대상을 선별함에 있어서, 상기 장소들 각각에 대응하여, 해당 장소의 퀄리티 스코어 및 상기 해당 장소의 변화량 스코어를 합함으로써 상기 해당 장소의 최종 스코어를 계산하고, 상기 장소들의 최종 스코어들에 기초하여, 상기 장소들 중 적어도 하나의 추천 대상을 선별할 수 있다.In selecting the recommended target, the processor calculates a final score of the corresponding place by summing the quality score of the corresponding place and the variation score of the corresponding place, corresponding to each of the places, and the final score of the places. Based on the locations, at least one recommendation target among the places may be selected.

아래의 실시 예들을 통해 동일 지역에 대응한 사용자의 장소 추천 요청 시점에 따라 추천되는 장소의 목록이 변화함으로써, 동일한 지역에 대한 다양한 장소 추천이 가능한 서비스를 제공할 수 있다.According to the following embodiments, the list of recommended places is changed according to the time of the user's request for place recommendation corresponding to the same area, so that it is possible to provide a service capable of recommending various places for the same area.

아래의 실시 예들을 통해 요일에 따른 관심도의 편차를 고려하여, 최근 관심도를 반영한 장소를 추천할 수 있는 서비스를 제공할 수 있다.Through the following embodiments, it is possible to provide a service for recommending a place reflecting the recent interest in consideration of the deviation of the interest level according to the day of the week.

도 1은 일 실시 예에 따른 장소 추천 방법의 동작 흐름도이다.
도 2는 장소들 각각에 대응하는 관심도에 대한 일별 시계열 데이터의 예시도이다.
도 3은 일 실시 예에 따른 개별 장소에 대한 관심도의 시간 단위 별 이동 평균 값을 설명하기 위한 도면이다.
도 4는 일 실시 예에 따른 개별 장소의 변화량 스코어 및 퀄리티 스코어를 계산하는 방법에 관한 동작 흐름도이다.
도 5는 일 실시 예에 따른 아웃라이어를 제거하는 방법에 관한 동작 흐름도이다.
도 6은 일 실시예에 따른 장소 추천 서비스를 제공하는 장치의 구성의 예시도이다.
1 is an operation flowchart of a place recommendation method according to an embodiment.
2 is an exemplary diagram of time-series data for each day with respect to the degree of interest corresponding to each of the places.
3 is a diagram for explaining a moving average value for each time unit of interest in an individual place according to an embodiment.
4 is an operation flowchart of a method of calculating a change amount score and a quality score of an individual place according to an embodiment.
5 is a flowchart illustrating a method of removing an outlier according to an embodiment.
6 is an exemplary diagram of a configuration of an apparatus for providing a place recommendation service according to an embodiment.

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

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

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

단수의 표현은 문맥상 명백하게 다르게 뜻하지 않는 한, 복수의 표현을 포함한다. 본 명세서에서, "포함하다" 또는 "가지다" 등의 용어는 설명된 특징, 숫자, 단계, 동작, 구성요소, 부분품 또는 이들을 조합한 것이 존재함으로 지정하려는 것이지, 하나 또는 그 이상의 다른 특징들이나 숫자, 단계, 동작, 구성요소, 부분품 또는 이들을 조합한 것들의 존재 또는 부가 가능성을 미리 배제하지 않는 것으로 이해되어야 한다.The singular expression includes the plural expression 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, and includes one or more other features or numbers, It should be understood that the possibility of the presence or addition of steps, operations, components, parts or combinations thereof is not precluded in advance.

다르게 정의되지 않는 한, 기술적이거나 과학적인 용어를 포함해서 여기서 사용되는 모든 용어들은 해당 기술 분야에서 통상의 지식을 가진 자에 의해 일반적으로 이해되는 것과 동일한 의미를 가진다. 일반적으로 사용되는 사전에 정의되어 있는 것과 같은 용어들은 관련 기술의 문맥상 가지는 의미와 일치하는 의미를 갖는 것으로 해석되어야 하며, 본 명세서에서 명백하게 정의하지 않는 한, 이상적이거나 과도하게 형식적인 의미로 해석되지 않는다.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 a commonly used dictionary should be interpreted as having a meaning consistent with the meaning in the context of the related art, and should not be interpreted in an ideal or excessively formal meaning unless explicitly defined in the present specification. does not

이하, 실시예들을 첨부된 도면들을 참조하여 상세하게 설명한다. 첨부 도면을 참조하여 설명함에 있어, 도면 부호에 관계없이 동일한 구성 요소는 동일한 참조 부호를 부여하고, 이에 대한 중복되는 설명은 생략하기로 한다.Hereinafter, embodiments will be described in detail with reference to the accompanying drawings. In the description with reference to the accompanying drawings, the same components are assigned the same reference numerals regardless of the reference numerals, and the overlapping description thereof will be omitted.

도 1은 일실시예에 따른 장소 추천 방법의 동작 흐름도이다.1 is an operation flowchart of a place recommendation method according to an embodiment.

도 1을 참조하면, 일 실시 예에 따른 서버에서 수행되는 장소 추천 방법은 기준 위치에 대응하는 장소들의 목록을 획득하는 단계(110), 장소들 각각에 대응하여 퀄리티 스코어 및 변화량 스코어를 계산하는 단계(120), 및 장소들 중 적어도 하나의 추천 대상을 선별하는 단계(130)를 포함할 수 있다.Referring to FIG. 1 , a method for recommending a place performed in a server according to an embodiment includes obtaining a list of places corresponding to a reference location ( 110 ), and calculating a quality score and a change amount score corresponding to each of the places. ( 120 ), and selecting ( 130 ) a recommendation target for at least one of the places may be included.

일 실시 예에 따른 서버는 이하에서 설명하는 장소 추천 서비스를 사용자 단말에 제공할 수 있다. 사용자 단말은 예를 들어, PC(Personal Computer), 넷북, 노트북, PDA(Personal Digital Appliance), 스마트폰, 웨어러블 디바이스(Wearable device), 및 유사한 기능을 수행하는 다양한 장치들을 포함할 수 있다. 서버는 장소 추천 서비스를 위한 프로세스를 수행하는 적어도 하나의 프로세서를 포함하며, 장소 추천 서비스를 위한 데이터를 저장하는 메모리를 포함할 수 있다. 일 실시 예에 따른 서버의 구체적인 구성은 이하의 도 6을 통해 상술한다.The server according to an embodiment may provide a place recommendation service, which will be described below, to the user terminal. The user terminal may include, for example, a personal computer (PC), a netbook, a notebook computer, a personal digital appliance (PDA), a smart phone, a wearable device, and various devices performing similar functions. The server may include at least one processor for performing a process for the place recommendation service, and may include a memory for storing data for the place recommendation service. A detailed configuration of the server according to an embodiment will be described in detail with reference to FIG. 6 below.

일 실시 예에 따르면, 서버는 지도 어플리케이션을 통해 장소 추천 서비스를 제공할 수 있다. 지도 어플리케이션은 GPS를 이용하여 어플리케이션이 설치된 단말의 위치를 획득하고, 획득된 단말의 위치 혹은 사용자에 의해 지정된 위치 주변의 지도를 표시하며, 표시된 지도에 포함된 지역에 관한 정보를 제공하는 기능을 포함할 수 있다. 사용자 단말은 설치된 지도 어플리케이션에 의해 구동될 수 있으며, 사용자는 단말에 설치된 지도 어플리케이션을 통해 서버에서 제공하는 서비스를 이용할 수 있다. 서버는 사용자 인터페이스(UI), 기능(function), 동작(operation) 또는 서비스 등을 위하여 사용자 단말에 설치된 지도 어플리케이션과 연동될 수 있다.According to an embodiment, the server may provide a place recommendation service through a map application. The map application obtains the location of the terminal where the application is installed using GPS, displays a map around the acquired location of the terminal or a location designated by the user, and includes a function to provide information about the area included in the displayed map can do. The user terminal may be driven by an installed map application, and the user may use a service provided by the server through the map application installed in the terminal. The server may be linked with a map application installed in the user terminal for a user interface (UI), a function, an operation, or a service.

일 실시 예에 따르면, 서버는 지도 웹사이트를 통해 장소 추천 서비스를 제공할 수 있다. 지도 웹사이트는 GPS를 이용하여 웹사이트에 접속한 단말의 위치를 획득하고, 획득된 단말의 위치 혹은 사용자에 의해 지정된 위치 주변의 지도를 표시하며, 표시된 지도에 포함된 지역에 관한 정보를 제공하는 기능을 포함할 수 있다. 사용자는 단말을 통해 접속한 지도 웹사이트를 통해 서버에서 제공하는 서비스를 이용할 수 있다.According to an embodiment, the server may provide a place recommendation service through a map website. The map website obtains the location of the terminal accessing the website using GPS, displays a map around the acquired location of the terminal or a location designated by the user, and provides information on the area included in the displayed map. function may be included. The user can use the service provided by the server through the map website accessed through the terminal.

일 실시 예에 따른 단계(110)는 기준 위치를 기준으로 결정된 지역 범위에 포함된 장소들의 목록을 획득하는 단계에 해당할 수 있다. 기준 위치는 단말의 위치, 사용자에 의해 지정된 위치 혹은 디폴트로 설정된 위치로 결정될 수 있다. 예를 들어, 사용자에 의해 입력된 주소 혹은 장소 이름에 해당하는 위치가 기준 위치로 결정될 수 있다. 기준 위치를 기준으로 결정된 지역 범위는 기준 위치로부터 일정 거리 내의 지역 범위를 포함할 수 있으며, 예를 들어 기준 위치로부터 반경 3km 내의 지역을 포함할 수 있다.Step 110 according to an embodiment may correspond to obtaining a list of places included in a regional range determined based on a reference location. The reference location may be determined as the location of the terminal, a location designated by a user, or a location set as a default. For example, a location corresponding to an address or place name input by the user may be determined as the reference location. The regional range determined based on the reference location may include a regional range within a predetermined distance from the reference location, for example, an area within a radius of 3 km from the reference location.

일 실시 예에 따른 장소들은 서버에 등록된 장소들에 해당할 수 있다. 서버에 등록된 장소들은 장소의 식별 정보 및 위치 정보가 서버에 저장된 장소들을 의미할 수 있다. 일 예로, 서버에 등록된 장소들은 카테고리에 관한 정보를 포함할 수 있다. 일 실시 예에 따르면, 특정 카테고리의 장소들은 유사한 유형으로 분류되는 장소들로, 예를 들어 음식점 카테고리에 해당하는 장소들, 카페 카테고리에 해당하는 장소들, 편의점 카테고리에 해당하는 장소들을 포함할 수 있다. 서버는 복수의 장소들의 식별 정보, 위치 정보 및 카테고리의 정보를 저장할 수 있다. Places according to an embodiment may correspond to places registered in the server. The places registered in the server may mean places where identification information and location information of the place are stored in the server. For example, places registered in the server may include category information. According to an embodiment, places of a specific category are places classified into similar types, and may include, for example, places corresponding to a restaurant category, places corresponding to a cafe category, and places corresponding to a convenience store category. . The server may store identification information of a plurality of places, location information, and category information.

일 실시 예에 따른 장소들의 목록을 획득하는 단계(110)는 사용자로부터 기준 위치의 정보를 수신하는 단계를 더 포함할 수 있다. 일 예로 사용자는 어플리케이션을 통해 기준 위치를 입력할 수 있으며, 서버는 사용자가 입력한 기준 위치를 수신할 수 있다. 보다 구체적으로, 사용자는 어플리케이션을 통해 기준 위치의 주소를 입력하거나, 현재 단말의 위치를 기준 위치로 입력하거나, 혹은 어플리케이션을 통해 표시된 지도 내에서 특정 위치를 선택하여 기준 위치로 입력할 수 있다. 예를 들어, 사용자가 어플리케이션을 통해 '판교역'을 검색하는 경우, '판교역'을 기준 위치로 하는 일정 지역 범위에 포함된 장소들의 목록이 획득될 수 있다.Acquiring the list of places 110 according to an embodiment may further include receiving information on a reference location from a user. For example, the user may input a reference position through an application, and the server may receive the reference position input by the user. More specifically, the user may input the address of the reference location through the application, input the current terminal location as the reference location, or select a specific location within the map displayed through the application and input it as the reference location. For example, when a user searches for 'Pangyo Station' through the application, a list of places included in a certain area with 'Pangyo Station' as a reference location may be obtained.

일 실시 예에 따르면, 장소들의 목록은 복수의 카테고리에 속하는 장소들을 포함할 수 있다. 예를 들어, 사용자가 어플리케이션을 통해 '판교역'을 검색하는 경우, '판교역'을 기준 위치로 하는 일정 지역 범위에 포함된 편의점, 음식점, 카페와 같이 다양한 카테고리에 속하는 장소들의 목록이 획득될 수 있다.According to an embodiment, the list of places may include places belonging to a plurality of categories. For example, when a user searches for 'Pangyo Station' through the application, a list of places belonging to various categories such as convenience stores, restaurants, and cafes included in a certain area with 'Pangyo Station' as the reference location will be obtained. can

일 실시 예에 따르면, 장소들의 목록을 획득하는 단계(110)는 사용자로부터 장소의 카테고리에 관한 정보를 수신하는 단계 및 기준 위치 및 특정 카테고리에 대응하는 장소들의 목록을 획득하는 단계를 포함할 수 잇다. 일 예로, 사용자는 어플리케이션을 통해 추천 대상이 되는 장소의 카테고리를 입력할 수 있다. 보다 구체적으로, 어플리케이션을 통해 제공되는 복수의 카테고리들 중 어느 하나를 선택하거나, 혹은 어플리케이션을 통해 제공되는 검색창에 카테고리 이름을 직접 입력할 수 있다. 예를 들어, 사용자가 어플리케이션을 통해 '음식점'을 검색하는 경우, 결정된 기준 위치에 대응하는 일정 지역 범위에 포함된 '음식점' 카테고리에 속하는 장소들의 목록이 획득될 수 있다.According to an embodiment, the step of obtaining a list of places 110 may include receiving information about a category of a place from a user and obtaining a reference location and a list of places corresponding to a specific category. . For example, the user may input a category of a place to be recommended through the application. More specifically, any one of a plurality of categories provided through the application may be selected, or a category name may be directly entered into a search box provided through the application. For example, when the user searches for 'restaurants' through the application, a list of places belonging to the 'restaurant' category included in a certain area corresponding to the determined reference location may be acquired.

일 실시 예에 따르면, 획득된 장소들의 목록은 사용자에 의해 수신된 카테고리에 관한 정보와 유사한 카테고리에 속하는 장소들을 더 포함할 수 있다. 예를 들어, 사용자가 어플리케이션을 통해 '맛집'을 검색하는 경우, 결정된 기준 위치에 대응하는 일정 지역 범위에 포함되며, 사용자에 의해 수신된 카테고리에 관한 정보인 '맛집'과 관련된 '음식점' 카테고리에 속하는 장소들 및 '카페' 카테고리에 속하는 장소들의 목록이 획득될 수 있다.According to an embodiment, the obtained list of places may further include places belonging to a category similar to the information about the category received by the user. For example, when a user searches for 'restaurant' through the application, it is included in a certain area range corresponding to the determined reference location, and is included in the 'restaurant' category related to 'restaurant' which is information about the category received by the user. A list of places belonging to and places belonging to the 'cafe' category may be obtained.

일 실시 예에 따른 단계(120)는 단계(110)에서 획득된 장소들 각각에 대응하여, 해당 장소의 관심도에 기초하여 퀄리티 스코어 및 변화량 스코어를 계산하는 단계를 포함할 수 있다.Step 120 according to an embodiment may include calculating a quality score and a change amount score based on the degree of interest of the corresponding place, corresponding to each of the places obtained in step 110 .

일 실시 예에 따른 관심도는 특정 장소에 대한 사용자들의 관심의 정도를 측정한 값으로, 예를 들어 서버에서 수집 가능한 특정 장소에 대한 데이터에 기초하여, 해당 장소에 대한 사용자들의 관심의 정도를 수치로 환산한 값을 포함할 수 있다.The degree of interest according to an embodiment is a value of measuring the degree of users' interest in a specific place, for example, based on data about a specific place that can be collected from a server, the degree of interest of users in the corresponding place is expressed as a numerical value. It may include converted values.

일 실시 예에 따르면, 특정 장소의 관심도는 특정 장소에 대한 검색량 및 특정 장소에 대한 클릭 수 중 적어도 하나에 기초하여 결정될 수 있다. 예를 들어, 특정 장소의 관심도는 특정 장소에 대한 검색량 값, 특정 장소에 대한 클릭 수의 값, 혹은 특정 장소에 대한 검색량 값과 클릭 수 값의 합으로 결정될 수 있다. 특정 장소에 대한 검색량은 서버에서 수집 가능한 해당 장소의 검색 횟수를 포함할 수 있으며, 예를 들어 어플리케이션을 통하여 해당 장소가 검색된 횟수, 서버와 연동된 웹사이트에서 해당 장소가 검색된 횟수를 포함할 수 있다. 특정 장소에 대한 클릭 수는 서버에서 수집 가능한 해당 장소의 클릭 횟수를 포함할 수 있으며, 예를 들어 어플리케이션을 통하여 해당 장소가 클릭된 횟수, 서버와 연동된 웹사이트에서 해당 장소가 클릭된 횟수를 포함할 수 있다.According to an embodiment, the degree of interest in a specific place may be determined based on at least one of a search amount for the specific place and the number of clicks on the specific place. For example, the degree of interest in a specific place may be determined as a search amount value for a specific place, a value of clicks for a specific place, or a sum of a search amount value and a click value for a specific place. The search volume for a specific place may include the number of searches of that place that can be collected from the server, for example, the number of times that place was searched for through an application, and the number of times that place was searched for on a website linked to the server. have. The number of clicks on a specific place may include the number of clicks on the corresponding place that can be collected from the server, for example, the number of clicks on the corresponding place through the application, and the number of clicks on the corresponding place on the website linked to the server can do.

이하에서, 특정 장소의 관심도는 특정 장소에 대한 검색량 및 특정 장소에 대한 클릭 수 중 적어도 하나에 기초하여 결정되는 경우를 예로 들어 설명하겠으나, 특정 장소의 관심도를 결정하는 방법을 한정하는 것은 아니며, 특정 장소의 관심도는 수치화 가능한 다양한 방법에 의해 결정될 수 있다.Hereinafter, a case in which the degree of interest of a specific place is determined based on at least one of a search amount for a specific place and the number of clicks for a specific place will be described as an example, but the method of determining the degree of interest in a specific place is not limited, The degree of interest in a specific place may be determined by various quantifiable methods.

일 실시 예에 따르면, 단계(120)의 이전 단계인 단계(110)는 장소들에 대한 관심도에 대응하는 시계열 데이터를 획득하는 단계를 더 포함할 수 있다. 예를 들어, 단계(110)는 장소들에 대한 클릭 수에 대응하는 시계열 데이터를 획득하는 단계 및 장소들에 대한 검색량에 대응하는 시계열 데이터를 획득하는 단계 중 적어도 하나를 더 포함할 수 있다. 시계열 데이터는 일정 시간 간격으로 배치된 데이터의 수열을 의미하는 것으로, 예를 들어 일별 시계열 데이터는 하루 간격으로 배치된 데이터의 수열을 포함할 수 있다.According to an embodiment, step 110 , which is a step before step 120 , may further include acquiring time series data corresponding to the degree of interest in places. For example, operation 110 may further include at least one of obtaining time series data corresponding to the number of clicks for places and obtaining time series data corresponding to a search amount for places. The time series data means a sequence of data arranged at regular time intervals. For example, daily time series data may include a sequence of data arranged at intervals of one day.

예를 들어, 도 2를 참조하면, 획득된 장소들 각각에 대응하는 관심도에 대한 11월 10일 내지 11월 19일 동안의 일별 시계열 데이터가 획득될 수 있다. 관심도에 대한 일별 시계열 데이터는 하루 단위로 획득된 관심도 값이 시간 순서에 따라 나열된 데이터를 포함할 수 있다. 상술한 바와 같이, 특정 장소에 대한 일별 관심도 값은 해당 장소에 대한 일별 검색량 및 일별 클릭 수 중 적어도 하나에 기초하여 결정될 수 있다. 다시 말해, 서버는 도 1의 단계(110)에 따라 장소들 각각을 식별하기 위한 ID 정보(place_id) 및 이름 정보(place_name)를 포함하는 장소들의 목록을 획득할 수 있으며, 획득된 각 장소에 대응하는 관심도에 대한 일별 시계열 데이터를 획득할 수 있다.For example, referring to FIG. 2 , daily time series data for November 10 to November 19 with respect to the degree of interest corresponding to each of the obtained places may be obtained. The daily time series data for the degree of interest may include data in which interest values acquired in units of one day are listed in time order. As described above, the daily interest value for a specific place may be determined based on at least one of a daily search amount and daily clicks for the corresponding place. In other words, the server may obtain a list of places including ID information (place_id) and name information (place_name) for identifying each of the places according to step 110 of FIG. 1 , and corresponding to each obtained place It is possible to obtain daily time series data for the degree of interest.

일 실시 예에 따르면, 서버는 개별 장소의 관심도에 대한 일정 범위의 일별 시계열 데이터를 저장할 수 있다. 예를 들어, 서버는 개별 장소의 관심도에 대한 최근 1개월 범위의 일별 시계열 데이터를 저장할 수 있다.According to an embodiment, the server may store daily time-series data of a certain range for the degree of interest of an individual place. For example, the server may store daily time-series data in the range of the most recent one month on the degree of interest of individual places.

일 실시 예에 따른 단계(120)는 단계(110)에서 획득된 장소들 각각에 대응하여, 해당 장소의 누적 관심도에 기초하여, 해당 장소의 퀄리티 스코어를 계산하는 단계 및 해당 장소의 관심도의 시간 단위 별 이동 평균 값들의 분포 및 기준 시간 단위의 이동 평균 값에 기초하여, 해당 장소의 변화량 스코어를 계산하는 단계를 포함할 수 있다. 다시 말해, 변화량 스코어 및 퀄리티 스코어는 장소 별로 계산될 수 있다.In step 120 according to an embodiment, corresponding to each of the places obtained in step 110 , based on the accumulated interest level of the corresponding place, calculating a quality score of the corresponding place and the time unit of the interest of the corresponding place The method may include calculating a change amount score of the corresponding place based on the distribution of the moving average values for each star and the moving average value of the reference time unit. In other words, the variance score and the quality score may be calculated for each location.

일 실시 예에 따른 개별 장소의 변화량 스코어 및 퀄리티 스코어를 계산하는 구체적인 동작은 도 4를 참조하여 설명한다.A detailed operation of calculating a change amount score and a quality score of an individual place according to an embodiment will be described with reference to FIG. 4 .

도 4를 참조하면, 일 실시 예에 따른 특정 장소의 퀄리티 스코어는 해당 장소에 대한 일정 기간 동안 누적 관심도 및 해당 장소의 기본 정보에 관한 점수 중 적어도 하나에 기초하여 계산(410)될 수 있다. 누적 관심도는 일정 기간 동안 획득된 관심도에 관한 데이터의 합으로 결정될 수 있다. 특정 장소의 기본 정보에 관한 점수는 해당 장소에 관한 보유 정보를 정량적인 수치로 변환한 것으로, 예를 들어 해당 장소에 관한 부가 정보(예: 영업시간, 메뉴, 시설 정보, 로드 뷰, 홈페이지 링크 등)의 양, 해당 장소에 관한 리뷰 정보의 양, 및 해당 장소에 관한 이미지 정보의 양에 기초하여 수치로 환산된 점수를 포함할 수 있다. 일 실시 예에 따르면, 특정 장소의 기본 정보에 관한 점수는 기본 정보에 포함된 항목들의 수치를 가중 합하여 결정될 수 있다. 예를 들어, 장소의 기본 정보에 관한 점수는 해당 장소에 관한 부가 정보의 양, 해당 장소에 관한 리뷰 정보의 양, 및 해당 장소에 관한 이미지 정보의 양을 가중 합하여 결정될 수 있다.Referring to FIG. 4 , a quality score of a specific place according to an embodiment may be calculated 410 based on at least one of a cumulative interest in the corresponding place for a certain period and a score related to basic information of the corresponding place ( 410 ). The cumulative interest level may be determined as a sum of interest-related data acquired for a certain period of time. The score for the basic information of a specific place is a quantitative number of information held about the place, for example, additional information about the place (e.g., business hours, menu, facility information, road view, website link, etc.) ), the amount of review information about the place, and the amount of image information about the place, it may include a score converted into a numerical value. According to an embodiment, a score regarding the basic information of a specific place may be determined by weighted summing values of items included in the basic information. For example, the score regarding the basic information of the place may be determined by weighting the amount of additional information about the place, the amount of review information about the place, and the amount of image information about the place.

일 실시 예에 따르면, 특정 장소의 퀄리티 스코어는 해당 장소에 대한 누적 관심도 및 해당 장소의 기본 정보에 관한 점수의 합에 기초하여 결정될 수 있다. 예를 들어, 특정 장소의 퀄리티 스코어는 해당 장소에 대한 누적 관심도 및 해당 장소의 기본 정보에 관한 점수를 단순 합한 값 혹은 가중 합한 값으로 결정될 수 있다. 다시 말해, 퀄리티 스코어는 일정 기간에 대응하는 관심도의 절대적인 크기 및 사용자에게 유용한 정보의 양에 기초하여 결정되는 스코어로, 누적 관심도가 높을수록, 기본 정보의 양이 많을 수록 퀄리티 스코어도 높게 결정될 수 있다.According to an embodiment, the quality score of a specific place may be determined based on the sum of the accumulated interest in the corresponding place and the score regarding basic information of the corresponding place. For example, the quality score of a specific place may be determined as a simple sum or a weighted sum of the accumulated interest in the corresponding place and the scores on basic information of the corresponding place. In other words, the quality score is a score determined based on the absolute magnitude of interest corresponding to a certain period and the amount of information useful to the user. The higher the cumulative interest, the higher the quality score can be determined. .

일 예로, 도 2를 참조하면, place_id가 111인 장소의 퀄리티 스코어는 해당 장소의 일별 관심도의 시계열 데이터의 합인 1645로, place_id가 112인 장소의 퀄리티 스코어는 해당 장소의 일별 관심도의 시계열 데이터의 합인 1390으로 결정될 수 있다. As an example, referring to FIG. 2 , the quality score of a place with place_id of 111 is 1645, which is the sum of time series data of daily interest of the corresponding place, and the quality score of a place with place_id of 112 is the sum of time series data of daily interest of the corresponding place. 1390 may be determined.

또 일 예로, 특정 장소의 퀄리티 스코어는 해당 장소의 일별 관심도의 시계열 데이터의 합에 비례하는 값, 해당 장소의 일별 관심도의 시계열 데이터의 합을 특정 범위의 값을 갖도록 정규화한 값, 혹은 장소들의 일별 관심도의 시계열 데이터의 합에 따른 분위수에 비례하는 값으로 결정될 수 있다. 상술한 예 외에도 특정 장소의 퀄리티 스코어는 해당 장소의 일별 관심도의 시계열 데이터의 합에 기초하여 다양한 방법으로 결정될 수 있다.As another example, the quality score of a specific place is a value proportional to the sum of the time series data of the daily interest of the corresponding place, a value obtained by normalizing the sum of the time series data of the daily interest of the corresponding place to have a value within a specific range, or daily of places It may be determined as a value proportional to a quantile according to the sum of time series data of interest. In addition to the above-described example, the quality score of a specific place may be determined in various ways based on the sum of time series data of daily interest in the corresponding place.

다시 도 4를 참조하면, 일 실시 예에 따른 특정 장소의 변화량 스코어는 해당 장소에 대한 관심도의 시간 단위 별 이동 평균 값들의 분포 및 기준 시간 단위의 이동 평균 값에 기초하여 결정될 수 있다. 관심도의 시간 단위 별 이동 평균 값들의 분포는 각 시간 단위에 대응하는 이동 평균 값을 관측 값 혹은 변량으로 하는 데이터의 집합이다. 예를 들어, 시간 단위는 일주일 단위를 포함할 수 있으며, 관심도의 시간 단위 별 이동 평균 값은 미리 정해진 범위의 관심도에 관한 일별 시계열 데이터에 기초하여 획득된 일주일 동안의 관심도의 평균 값들을 포함할 수 있다. 일 실시 예에 따르면, 시간 단위는 일주일로 설정됨으로써, 모든 요일에 대응하는 관심도에 관한 일별 시계열 데이터를 고려하여 변화량 스코어가 계산될 수 있다. 이하에서, 시간 단위는 일주일로 설정되는 경우를 예로 들어 설명하겠으나, 시간 단위는 일주일로 한정되는 것은 아니며, 분, 시간, 일 단위로 다양하게 설정될 수 있다.Referring again to FIG. 4 , the change score of a specific place according to an embodiment may be determined based on a distribution of moving average values for each time unit of interest in the corresponding place and a moving average value of a reference time unit. The distribution of moving average values for each time unit of interest is a set of data in which the moving average value corresponding to each time unit is an observation value or a variable. For example, the time unit may include a week unit, and the moving average value for each time unit of interest may include average values of interest for a week obtained based on daily time series data related to interest in a predetermined range. have. According to an embodiment, since the time unit is set to one week, the variation score may be calculated in consideration of daily time series data regarding the degree of interest corresponding to all days of the week. Hereinafter, a case in which the time unit is set to a week will be described as an example, but the time unit is not limited to a week, and may be variously set in units of minutes, hours, and days.

예를 들어, 도 3을 참조하면, 관심도의 시간 단위 별 이동 평균 값들의 분포는 11월 10일부터 11월 16일까지 일주일 단위(310)에 대응하는 관심도의 평균 값(1240/7), 11월 11일부터 11월 17일까지 일주일 단위(320)에 대응하는 관심도의 평균 값(1240/7), 11월 12일부터 11월 18일까지 일주일 단위(330)에 대응하는 관심도의 평균 값(1214/7), 11월 13일부터 11월 19일까지 일주일 단위(340)에 대응하는 관심도의 평균 값(1243/7)의 집합이다.For example, referring to FIG. 3 , the distribution of moving average values for each time unit of interest is the average value (1240/7) of interest corresponding to the unit of week 310 from November 10 to November 16, 11 The average value of interest (1240/7) corresponding to the weekly unit (320) from month 11 to November 17, the average value of interest corresponding to the weekly unit (330) from November 12 to November 18 ( 1214/7), is a set of average values (1243/7) of interest corresponding to a weekly unit (340) from November 13 to November 19.

일 실시 예에 따르면, 변화량 스코어 계산에 있어서, 시간 단위 별 이동 평균 값을 대신하여 시간 단위 별 시계열 데이터 값의 합을 이용할 수 있다. 예를 들어, 도 3을 참조하면, 일주일 단위에 대응하는 시계열 데이터의 합을 7로 나눈 평균 값 대신 일주일 단위에 대응하는 시계열 데이터의 합을 변화량 스코어 계산에 이용할 수 있다. 다시 말해, 이동 평균의 의미는 일부 집합의 데이터 값들의 합을 집합의 크기로 나눈 평균을 의미하지만, 실시 예에 따라 일부 집합의 데이터 값들의 합을 의미할 수도 있다.According to an embodiment, in calculating the variance score, the sum of time series data values for each time unit may be used instead of the moving average value for each time unit. For example, referring to FIG. 3 , instead of an average value obtained by dividing the sum of time series data corresponding to a week unit by 7, the sum of time series data corresponding to a week unit may be used to calculate the variation score. In other words, the moving average means an average obtained by dividing the sum of data values of some sets by the size of the set, but may also mean the sum of data values of some sets according to an embodiment.

일 실시 예에 따르면, 이동 평균은 단순 이동 평균, 누적 이동 평균, 가중 이동 평균, 지수 이동 평균과 같은 다양한 방식으로 계산된 이동 평균을 포함할 수 있다. 이하에서는 설명의 편의를 위하여 이동 평균은 단순 이동 평균으로 계산하여 설명한다.According to an embodiment, the moving average may include a moving average calculated in various ways such as a simple moving average, a cumulative moving average, a weighted moving average, and an exponential moving average. Hereinafter, for convenience of explanation, the moving average is calculated and described as a simple moving average.

일 실시 예에 따른 기준 시간 단위는 현재 시점에 대응하는 시간 단위로, 현재 시점은 장소 추천 방법이 수행되는 시점을 의미할 수 있다. 현재 시점에 대응하는 시간 단위는 현재 시점을 포함하는 시간의 직전 시간을 시간 단위의 종점으로 하는 시간 단위에 해당할 수 있다. 현재 시점을 포함하는 시간은 시간 단위가 일주일과 같이 복수의 일들에 대응하는 경우 일(day)에 해당할 수 있고, 시간 단위가 7시간과 같이 복수의 시간들에 대응하는 경우 시간(hour)에 해당할 수 있으며, 시간 단위가 7분과 같이 복수의 분들에 대응하는 경우 분(minute)에 해당할 수 있다. 예를 들어, 도 3을 참조하면, 시간 단위가 일주일이고, 현재 시점이 11월 20일에 포함되는 경우, 20일의 직전 일인 11월 19일을 종점으로 하는 일주일 단위(310)가 기준 시간 단위에 해당한다. 일 실시 예에 따르면, 현재 시점에 대응하는 시간 단위는 현재 시점을 포함하는 시간을 시간 단위의 종점으로 하는 시간 단위에 해당할 수 있다.The reference time unit according to an embodiment is a time unit corresponding to the current time point, and the current time point may mean a time point at which the place recommendation method is performed. The time unit corresponding to the current time may correspond to a time unit in which the time immediately preceding the time including the current time is the end point of the time unit. The time including the current time may correspond to a day when the time unit corresponds to a plurality of days, such as a week, and may correspond to a time when the time unit corresponds to a plurality of times, such as 7 hours. It may correspond to, and when the time unit corresponds to a plurality of minutes, such as 7 minutes, it may correspond to a minute. For example, referring to FIG. 3 , when the time unit is one week and the current time point is included in November 20, the week unit 310 having the end point of November 19, which is the day immediately preceding the 20th, is the reference time unit. corresponds to According to an embodiment, a time unit corresponding to the current time may correspond to a time unit in which a time including the current time is the end point of the time unit.

일 실시 예에 따르면, 변화량 스코어는 개별 장소의 관심도의 변화율을 활용하여, 최근 관심도의 증가 여부에 기초하여 결정될 수 있다. 개별 장소의 관심도의 변화율은 개별 장소의 시간 단위 별 이동 평균 값들의 분포에 기초하여 측정될 수 있다.According to an embodiment, the change score may be determined based on whether the interest level has recently increased by using a rate of change of the interest level of an individual place. The rate of change of the interest level of each place may be measured based on the distribution of moving average values for each time unit of the individual place.

다시 도 4를 참조하면, 일 실시 예에 따른 변화량 스코어를 계산하는 단계는 기준 시간 단위의 이전 시간 단위들의 이동 평균 값들의 평균 및 표준 편차를 계산하는 단계(420), 계산된 표준 편차 및 평균에 기초하여, 기준 시간 단위의 이동 평균 값의 표준 점수를 계산하는 단계(430), 및 표준 점수에 기초하여 변화량 스코어를 계산하는 단계(440)를 포함할 수 있다. 예를 들어, 도 3을 참조하면, 기준 시간 단위가 11월 19일까지 일주일 단위(310)인 경우, 기준 시간 단위의 이전 시간 단위들은 11월 18일까지 일주일 단위(320), 11월 17일까지 일주일 단위(330), 및 11월 16일까지 일주일 단위(340)를 포함할 수 있다.Referring back to FIG. 4 , the calculating of the variance score according to an embodiment includes calculating the average and standard deviation of the moving average values of the previous time units of the reference time unit ( 420 ), the calculated standard deviation and the average. Based on the step, calculating a standard score of the moving average value of the reference time unit ( 430 ), and calculating a variance score based on the standard score ( 440 ) may be included. For example, referring to FIG. 3 , when the reference time unit is a week unit 310 until November 19, previous time units of the reference time unit are a week unit 320 until November 18 and November 17 It may include a week unit 330 until November 16, and a week unit 340 until November 16.

일 실시 예에 따르면, 평균 및 표준 편차 계산의 대상은 기준 시간 단위의 이전 시간 단위들의 이동 평균 값들을 포함할 수 있으며, 평균 및 표준 편차 계산의 대상에서 기준 시간 단위의 이동 평균 값은 제외될 수 있다. 일 실시 예에 따른 관심도는 상한 값이 존재하지 않으며, 평균 및 표준 편차 계산의 대상이 되는 모집단의 수가 미리 정해진 개수로 제한되는 특성으로 인하여, 기준 시간 단위의 이동 평균 값이 평균 및 표준 편차에 과영향을 미칠 수 있다. 예를 들어, 기준 시간 단위의 이전 시간 단위들의 이동 평균 값들의 평균이 1이고, 기준 시간 단위의 이동 평균 값이 100인 경우, 기준 시간 단위의 이동 평균 값을 평균 및 표준 편차의 계산에 포함하여 계산된 표준 점수와 기준 시간 단위의 이동 평균 값을 평균 및 표준 편차의 계산에 포함하지 않고 계산된 표준 점수를 비교하면, 전자보다 후자의 표준 점수가 더 크게 계산된다. 전자의 경우 기준 시간 단위의 이동 평균 값이 평균 및 표준 편차에 과영향을 주어, 최근 관심도가 급격하게 증가한 경우임에도 표준 점수가 높게 나타나지 않을 수 있다. 이에, 표준 점수 계산을 위한 평균 및 표준 편차 계산의 대상에서 기준 시간 단위의 이동 평균 값을 제외함으로써, 기준 시간 단위의 이동 평균 값의 표준 점수에 대한 과영향을 방지할 수 있다. According to an embodiment, the target of calculating the average and standard deviation may include moving average values of previous time units of the reference time unit, and the moving average value of the reference time unit may be excluded from the target of calculating the average and standard deviation. have. The degree of interest according to an embodiment does not have an upper limit value, and due to the characteristic that the number of populations subject to calculation of the mean and standard deviation is limited to a predetermined number, the moving average value of the reference time unit exceeds the mean and standard deviation can affect For example, when the average of the moving average values of the previous time units of the reference time unit is 1 and the moving average value of the reference time unit is 100, the moving average value of the reference time unit is included in the calculation of the average and standard deviation. When the calculated standard score and the calculated standard score are compared without including the moving average value of the reference time unit in the calculation of the mean and standard deviation, the latter standard score is calculated to be larger than the former. In the former case, the moving average value of the reference time unit has an excessive influence on the average and standard deviation, so that the standard score may not appear high even when the interest level has recently increased sharply. Accordingly, by excluding the moving average value of the reference time unit from the target of calculating the average and standard deviation for calculating the standard score, it is possible to prevent an over-influence of the moving average value of the reference time unit on the standard score.

일 실시 예에 따르면, 평균 및 표준 편차 계산의 대상이 되는 이전 시간 단위들의 이동 평균 값들의 개수는 미리 정해질 수 있다. 예를 들어, 평균 및 표준 편차 계산의 대상이 되는 이전 시간 단위들은 기준 시간 단위의 직전 2개의 시간 단위들을 포함하도록 결정될 수 있다. 예를 들어, 도 3을 참조하면, 기준 시간 단위가 11월 19일까지 일주일 단위(310)인 경우, 기준 시간 단위의 이전 시간 단위들은 기준 시간 단위의 직전 2개의 시간 단위들인 11월 18일까지 일주일 단위(320) 및 11월 17일까지 일주일 단위(330)에 대응하는 이동 평균 값들을 대상으로 평균 및 표준 편차가 계산될 수 있다.According to an embodiment, the number of moving average values of previous time units to be calculated for the average and standard deviation may be predetermined. For example, previous time units subject to calculation of the mean and standard deviation may be determined to include two time units immediately preceding the reference time unit. For example, referring to FIG. 3 , when the reference time unit is a week unit 310 until November 19, previous time units of the reference time unit are until November 18, which are two time units immediately before the reference time unit. The average and standard deviation may be calculated with respect to the moving average values corresponding to the weekly unit 320 and the weekly unit 330 until November 17th.

일 실시 예에 따른 기준 시간 단위의 이동 평균 값의 표준 점수는 기준 시간 단위의 이전 시간 단위들의 이동 평균 값들의 평균 및 표준 편차에 기초하여 계산될 수 있다. 예를 들어, 기준 시간 단위의 표준 점수(std_score)는 아래의 수학식 1과 같이 나타낼 수 있다.According to an embodiment, the standard score of the moving average value of the reference time unit may be calculated based on the average and standard deviation of the moving average values of the previous time units of the reference time unit. For example, the standard score (std_score) of the reference time unit may be expressed as in Equation 1 below.

Figure pat00001
Figure pat00001

여기서, MAt-는 기준 시간 단위(t)의 이동 시간 평균, MAt-x는 기준 시간 단위의 x 이전 시간 단위의 이동 시간 평균, Average(x:y)는 x 내지 y의 값들의 평균, Std(x:y)는 x 내지 y의 값들의 표준 편차를 의미한다. k는 평균 및 표준 편차 계산의 대상이 되는 이전 시간 단위들의 이동 평균 값들의 개수에 따라 결정되는 값으로, 상술한 바와 같이 표준 편차 계산의 대상이 되는 이전 시간 단위들의 이동 평균 값들의 개수는 미리 정해질 수 있다.Here, MA t- is the moving time average of the reference time unit (t), MA tx is the moving time average of the time unit before x of the reference time unit, Average(x:y) is the average of values of x to y, Std( x:y) means the standard deviation of the values of x to y. k is a value determined according to the number of moving average values of previous time units subject to average and standard deviation calculation. As described above, the number of moving average values of previous time units subject to standard deviation calculation is predetermined. can be done

예를 들어, 도 3을 참조하면, 기준 시간 단위가 19일까지 일주일 단위(310)에 해당하고, k가 2인 경우, 이전 시간 단위들의 평균 및 표준 편차는 각각 아래의 수학식 2 및 3과 같이 계산될 수 있다. 수학식 2 및 3에서는 계산의 편의를 위해 일주일 단위의 일별 시계열 데이터의 합을 7로 나눈 이동 평균 대신 일주일 단위의 일별 시계열 데이터의 합에 기초하여 평균 및 표준 편차를 계산한다.For example, referring to FIG. 3 , when the reference time unit corresponds to the week unit 310 until the 19th, and k is 2, the average and standard deviation of the previous time units are respectively expressed by Equations 2 and 3 below and can be calculated together. In Equations 2 and 3, for convenience of calculation, the average and standard deviation are calculated based on the sum of the daily time series data of the week unit instead of the moving average obtained by dividing the sum of the daily time series data of the week unit by 7.

Figure pat00002
Figure pat00002

Figure pat00003
Figure pat00003

기준 시간 단위(310)의 표준 점수는 상기 수학식 1에 따라, 아래의 수학식 4와 같이 계산될 수 있다.The standard score of the reference time unit 310 may be calculated according to Equation 1 and Equation 4 below.

Figure pat00004
Figure pat00004

일 실시 예에 따르면, 표준 점수를 계산하기 위한 이전 시간 단위들의 이동 평균 값들의 표준 편차는 0이 되는 것을 방지하기 위해 보정될 수 있다. 일 예로, 표준 점수를 계산하는 단계는 표준 편차에 미리 정해진 값(예: 1)을 더하여 보정하는 단계 및 보정된 표준 편차 및 평균에 기초하여, 기준 시간 단위의 이동 평균 값의 표준 점수를 계산하는 단계를 포함할 수 있다. According to an embodiment, the standard deviation of the moving average values of previous time units for calculating the standard score may be corrected to prevent it from being zero. As an example, the step of calculating the standard score includes the step of correcting by adding a predetermined value (eg, 1) to the standard deviation, and calculating the standard score of the moving average value of the reference time unit based on the corrected standard deviation and average. may include steps.

예를 들어, 도 3을 참조하면, 상기 수학식 3에 따라 계산된 표준 편차 값에 1을 더하여 보정된 표준 편차 값에 기초하여, 아래의 수학식5와 같이 기준 시간 단위(310)의 표준 점수가 계산될 수 있다.For example, referring to FIG. 3 , based on the standard deviation value corrected by adding 1 to the standard deviation value calculated according to Equation 3, the standard score of the reference time unit 310 as shown in Equation 5 below. can be calculated.

Figure pat00005
Figure pat00005

일 실시 예에 따르면, 기준 시간 단위의 표준 점수는 이전 시간 단위들의 표준 편차가 작을수록 크게 결정되므로, 기준 시간 단위에 대응하는 관심도 값과 이전 시간 단위들의 평균의 차이가 클수록 크게 결정되므로, 이전 시간 단위들에 대응하는 관심도 값들에 비해 기준 시간 단위에 대응하는 관심도 값이 클수록 크게 결정될 수 있다. 다시 말해, 기준 시간 단위의 표준 점수는 최근 관심도가 크게 증가할수록 큰 값으로 계산될 수 있다.According to an embodiment, since the standard score of the reference time unit is determined as the standard deviation of the previous time units is smaller, the difference between the interest value corresponding to the reference time unit and the average of the previous time units is larger, so that the standard score of the previous time unit is larger. As the interest value corresponding to the reference time unit is greater than the interest values corresponding to the units, it may be determined to be larger. In other words, the standard score of the reference time unit may be calculated as a larger value as the recent interest level increases significantly.

일 실시 예에 따르면, 기준 시간 단위의 표준 점수에 기초하여 변화량 스코어가 결정될 수 있다. 표준 점수가 그대로 변화량 스코어로 변화량 스코어로 결정될 수도 있고, 표준 점수를 정규화한 점수가 변화량 스코어로 결정될 수 있다. 표준 점수를 정규화하는 과정은 이하에서 상술한다.According to an embodiment, the change amount score may be determined based on the standard score of the reference time unit. A standard score may be determined as a variance score as a variance score as it is, and a score obtained by normalizing the standard score may be determined as a variance score. The process of normalizing the standard score is detailed below.

일 실시 예에 따르면, 변화량 스코어를 계산하는 단계는 기준 시간 단위의 이동 평균 값이 기준 시간 단위의 이전 시간 단위들의 이동 평균 값들의 평균보다 작은 경우, 해당 장소의 변화량 스코어를 최소 값으로 설정하는 단계를 포함할 수 있다. 예를 들어, 기준 시간 단위의 이동 평균 값이 기준 시간 단위의 이전 시간 단위들의 이동 평균 값들의 평균보다 작은 경우, 해당 장소의 변화량 스코어는 최소 값 0으로 설정될 수 있다. 다시 말해, 기준 시간 단위의 이동 평균 값이 기준 시간 단위의 이전 시간 단위들의 이동 평균 값들의 평균보다 증가한 장소의 경우, 수학식 1에 따른 기준 시간 단위의 표준 점수가 계산되며, 계산된 표준 점수에 기초하여 변화량 스코어가 결정될 수 있다. 한편, 기준 시간 단위의 이동 평균 값이 기준 시간 단위의 이전 시간 단위들의 이동 평균 값들의 평균보다 감소하거나 동일한 장소의 경우, 수학식 1에 따른 표준 점수 계산 과정이 수행되지 않을 수 있으며, 변화량 스코어는 0으로 결정될 수 있다.According to an embodiment, the calculating of the variance score includes: when the moving average value of the reference time unit is smaller than the average of the moving average values of the previous time units of the reference time unit, setting the variance score of the corresponding place to a minimum value may include. For example, when the moving average value of the reference time unit is smaller than the average of the moving average values of previous time units of the reference time unit, the change amount score of the corresponding place may be set to a minimum value of 0. In other words, in the case of a place where the moving average value of the reference time unit is increased than the average of the moving average values of previous time units of the reference time unit, the standard score of the reference time unit according to Equation 1 is calculated, and the calculated standard score is Based on the variance score may be determined. On the other hand, in the case where the moving average value of the reference time unit is less than or equal to the average of the moving average values of the previous time units of the reference time unit, the standard score calculation process according to Equation 1 may not be performed, and the change score is It can be determined as 0.

도 4를 참조하면, 특정 장소에 대응하여 계산된 퀄리티 스코어 및 변화량 스코어에 기초하여 최종 스코어가 계산(450)될 수 있다. 최종 스코어는 장소 추천 대상을 선별하기 위한 기준이 될 수 있다. 최종 스코어를 계산하는 단계(450)의 구체적인 과정은 이하에서 상술한다.Referring to FIG. 4 , a final score may be calculated 450 based on the quality score and the variation score calculated for a specific place. The final score may be a criterion for selecting a place recommendation target. The specific process of calculating the final score ( 450 ) will be described in detail below.

다시 도 1을 참조하면, 일 실시 예에 따른 단계(130)는 장소들 각각에 대응하여 계산된 퀄리티 스코어 및 변화량 스코어에 기초하여, 장소들 중 적어도 하나의 추천 대상을 선별하는 단계를 포함할 수 있다.Referring back to FIG. 1 , step 130 according to an embodiment may include selecting at least one recommendation target from among the places based on the quality score and variation score calculated for each of the places. have.

일 실시 예에 따른 단계(130)는 장소 추천의 목적과 다른 목적에 관한 요인으로 인하여 관심도가 증가한 장소가 추천되는 것을 방지하기 위하여 아웃라이어(outlier)를 제거하는 단계를 포함할 수 있다. 장소 추천의 목적과 다른 목적에 관한 요인은 예를 들어, 장소 추천의 목적이 맛집을 추천하려는 목적인 경우 상표권 논쟁과 같은 해당 장소의 검색량을 증가시킬 수 있는 사회적 이슈의 발생을 포함할 수 있다.Step 130 according to an embodiment may include removing an outlier in order to prevent a place having an increased interest from being recommended due to a factor related to a purpose different from the purpose of the place recommendation. Factors related to the purpose of the place recommendation and other purposes may include, for example, when the purpose of the place recommendation is to recommend a restaurant, a social issue that may increase the search volume of the place, such as a trademark dispute, may include the occurrence.

일 실시 예에 따른 아웃라이어를 제거하는 구체적인 동작은 도 5를 참조하여 설명한다.A detailed operation of removing the outlier according to an embodiment will be described with reference to FIG. 5 .

도 5를 참조하면, 일 실시 예에 따른 추천 대상을 선별하는 단계(예: 도 1의 단계(130))는 장소들의 변화량 스코어들의 분위수(quantile)에 기초하여 획득된 변화량 스코어에 관한 제1 임계 값을 초과하는 장소를 아웃라이어(outlier)로 판단하는 단계(530) 및 아웃라이어로 판단된 장소의 변화량 스코어를 최소 값으로 설정하는 단계(540)를 더 포함할 수 있다.Referring to FIG. 5 , in the step of selecting a recommendation target (eg, step 130 of FIG. 1 ) according to an embodiment, a first threshold with respect to a variance score obtained based on a quantile of variance scores of places The method may further include determining ( 530 ) a place exceeding the value as an outlier, and setting ( 540 ) a change amount score of the place determined as an outlier to a minimum value.

분위수는 데이터의 크기 순서에 따른 위치 값으로, 크기 순서로 나열한 데이터의 등분 크기에 따라 구분될 수 있다. 예를 들어, 사분위수(quartile)는 크기 순서로 나열한 데이터를 4등분하는 관측 값으로, 1사분위수(lower quartile 혹은 Q1)는 크기 순서로 나열한 데이터의 25% 순위에 해당하는 값, 2사분위수(median 혹은 Q2)는 크기 순서로 나열한 데이터의 50% 순위에 해당하는 값, 3사분위수(upper quartile혹은 Q3)는 크기 순서로 나열한 데이터의 75% 순위에 해당하는 값, 4사분위수(Q4)는 크기 순서로 나열한 데이터의 100% 순위에 해당하는 값에 해당한다.A quantile is a position value according to the size order of the data, and may be classified according to the size of the equal parts of the data arranged in the size order. For example, a quartile is an observation value that divides data arranged in size order, and the first quartile (lower quartile or Q1) is a value corresponding to the 25% rank of the data arranged in size order, the second quartile (median or Q2) is the value corresponding to the 50% rank of the data arranged in size order, the third quartile (upper quartile or Q3) is the value corresponding to the 75% rank of the data arranged in the size order, the fourth quartile (Q4) corresponds to the value corresponding to the 100% rank of the data listed in order of size.

예를 들어, 변화량 스코어에 관한 제1 임계 값(T1)은 장소들의 변화량 스코어들의 분위수에 기초하여 아래의 수학식 6과 같이 계산될 수 있다.For example, the first threshold value T 1 for the variance score may be calculated as in Equation 6 below based on the quantiles of variance scores of places.

Figure pat00006
Figure pat00006

수학식 6에서, IQR(interquartile range)은 전체 데이터의 50%를 포함하는 범위로 Q3-Q1로 계산될 수 있다. a는 미리 정해진 값의 상수로, 예를 들어 2.5로 정해질 수 있다.In Equation 6, an interquartile range (IQR) may be calculated as Q3-Q1 as a range including 50% of the entire data. a is a constant of a predetermined value, for example, may be set to 2.5.

일 실시 예에 따르면, 장소들 중 변화량 스코어가 제1 임계 값(T1)을 초과하는 장소는 아웃라이어로 판단될 수 있으며, 아웃라이어로 판단된 장소의 변화량 스코어는 0으로 설정될 수 있다. 일 실시 예에 따르면, 장소들 중 변화량 스코어가 제1 임계 값(T1)을 초과하는 장소 뿐 아니라 변화량 스코어가 제1 임계 값(T1)과 동일한 장소도 아웃라이어로 판단될 수 있다.According to an embodiment, among the places, the place where the change score exceeds the first threshold value T 1 may be determined as an outlier, and the change score of the place determined as the outlier may be set to 0. According to an embodiment, not only places where the variance score exceeds the first threshold value T 1 , but also places where the variance score is equal to the first threshold value T 1 among places may be determined as outliers.

일 실시 예에 따르면, 아웃라이어로 판단하는 단계는 장소들의 변화량 스코어들을 로그 스케일로 변환하는 단계(510), 변환된 변화량 스코어들의 분위수에 기초하여, 변화량 스코어에 관한 제1 임계 값을 획득하는 단계(520), 및 장소들 중 변환된 변화량 스코어가 제1 임계 값을 초과하는 장소를 아웃라이어로 판단하는 단계(530)를 포함할 수 있다. 장소들의 변화량 스코어들을 로그 스케일로 변환하는 과정은 장소들의 변화량 스코어들에 로그를 취하는 과정을 포함할 수 있다. 일 실시 예에 따르면, 장소들의 변화량 스코어들을 로그 스케일로 변환하는 과정은 변화량 스코어들에 일정한 수를 더한 후 로그를 취하는 과정을 포함할 수 있다.According to an embodiment, the determining as an outlier may include converting variance scores of places into a log scale ( 510 ), and obtaining a first threshold value for variance score based on the quantiles of the transformed variance scores. ( 520 ), and determining ( 530 ) a place in which the converted variation score exceeds a first threshold value among the places as an outlier. Transforming the variance scores of the places to a log scale may include taking the logarithm of the variance scores of the places. According to an embodiment, the process of converting the variance scores of places into a log scale may include adding a certain number to the variance scores and then taking a logarithm.

예를 들어, 특정 장소의 변화량 스코어(v_score)가 로그 스케일로 변환된 변화량 스코어(v_score')는 아래의 수학식 7과 같이 나타낼 수 있다.For example, the change score (v_score') obtained by converting the change amount score (v_score) of a specific place into a log scale may be expressed as in Equation 7 below.

Figure pat00007
Figure pat00007

일 실시 예에 따르면, 로그 스케일로 변환된 변화량 스코어들의 분위수에 기초하여, 상술한 수학식 6에 따라 제1 임계 값을 획득하고, 장소들 중 변환된 변화량 스코어가 제1 임계 값을 초과하는 장소가 아웃라이어로 판단될 수 있다.According to an embodiment, a first threshold value is obtained according to Equation 6 above based on the quantiles of the variance scores converted to a log scale, and among places where the converted variance score exceeds the first threshold value may be considered as an outlier.

도 5에 도시되어 있지는 않으나, 일 실시 예에 따른 아웃라이어로 판단하는 단계는 장소들의 기준 시간 단위에 대응하는 관심도들에 기초하여, 관심도에 관한 제2 임계 값을 획득하는 단계를 더 포함할 수 있으며, 제1 임계 값을 초과하는 장소를 아웃라이어로 판단하는 단계(530)는 제1 임계 값 및 제2 임계 값에 기초하여 아웃라이어를 판단하는 단계를 포함할 수 있다. 다시 말해, 일 실시 예에 따른 아웃라이어로 판단하는 단계는 장소들의 변화량 스코어들의 분위수에 기초하여 변화량 스코어에 관한 제1 임계 값을 획득하는 단계, 장소들의 기준 시간 단위에 대응하는 관심도들에 기초하여, 관심도에 관한 제2 임계 값을 획득하는 단계 및 장소들 중 변화량 스코어가 제1 임계 값을 초과하고, 기준 시간 단위에 대응하는 관심도가 제2 임계 값을 초과하는 장소를 아웃라이어로 판단하는 단계를 포함할 수 있다. 제2 임계 값은 특정 값(예: 300)으로 미리 결정될 수 있다.Although not shown in FIG. 5 , the step of determining as an outlier according to an embodiment may further include acquiring a second threshold value regarding the degree of interest based on the degree of interest corresponding to the reference time unit of the places. In addition, the step 530 of determining the place exceeding the first threshold value as the outlier may include determining the outlier based on the first threshold value and the second threshold value. In other words, the determining as an outlier according to an embodiment includes: obtaining a first threshold value for the variance score based on the quantiles of the variance scores of the places; , obtaining a second threshold value for the degree of interest, and determining a place in which the variation score exceeds the first threshold value and the degree of interest corresponding to the reference time unit exceeds the second threshold value as an outlier may include. The second threshold value may be predetermined as a specific value (eg, 300).

예를 들어, 도 3을 참조하면, 특정 장소의 기준 시간 단위(310)에 대응하는 관심도는 기준 시간 단위(310)에 포함된 일별 시계열 데이터의 합인 1243에 해당할 수 있다. 제2 임계 값이 1243 미만(혹은 이하)인 경우, 해당 장소는 아웃라이어 판단 대상이 될 수 있으며, 해당 장소의 변화량 스코어와 제1 임계 값의 비교에 기초하여 아웃라이어로 판단될 수 있다. 한편, 제2 임계 값이 1243 이상(혹은 초과)인 경우, 해당 장소는 아웃라이어 판단 대상에 해당하지 않을 수 있으며, 해당 장소의 변화량 스코어에 관계없이 아웃라이어로 판단되지 않을 수 있다.For example, referring to FIG. 3 , the degree of interest corresponding to the reference time unit 310 of a specific place may correspond to 1243 which is the sum of time series data for each day included in the reference time unit 310 . When the second threshold value is less than (or less than) 1243, the corresponding place may be an outlier determination target, and may be determined as an outlier based on a comparison between the change amount score of the corresponding place and the first threshold value. On the other hand, when the second threshold value is 1243 or more (or more than), the corresponding place may not correspond to an outlier determination target, and may not be determined as an outlier regardless of the change amount score of the corresponding place.

일 실시 예에 따르면, 장소들 중 변화량 스코어가 제1 임계 값을 초과하거나 제1 임계 값과 동일한 장소 및 기준 시간 단위에 대응하는 관심도가 제2 임계 값을 초과하거나 제2 임계 값과 동일한 장소가 아웃라이어로 판단될 수 있다.According to an embodiment, among the places where the variance score exceeds the first threshold value or is equal to the first threshold value, and the place in which the degree of interest corresponding to the reference time unit exceeds the second threshold value or is equal to the second threshold value, among places It can be considered as an outlier.

다시 도 1을 참조하면, 일 실시 예에 따른 단계(130)에서 추천 대상은 최종 스코어에 기초하여 선별될 수 있다. 최종 스코어는 퀄리티 스코어 및 변화량 스코어에 기초하여 결정될 수 있다. 일 예로, 추천 대상을 선별하는 단계는 장소들 각각에 대응하여, 해당 장소의 퀄리티 스코어 및 해당 장소의 변화량 스코어를 합함으로써 해당 장소의 최종 스코어를 계산하는 단계 및 장소들의 최종 스코어들에 기초하여, 장소들 중 적어도 하나의 추천 대상을 선별하는 단계를 포함할 수 있다.Referring back to FIG. 1 , in step 130 according to an exemplary embodiment, a recommendation target may be selected based on a final score. The final score may be determined based on the quality score and the variance score. As an example, the step of selecting a recommendation target may include calculating a final score of the corresponding place by adding the quality score of the corresponding place and the variation score of the corresponding place corresponding to each of the places, and based on the final scores of the places, The method may include selecting at least one recommendation target from among the places.

일 실시 예에 따르면, 특정 장소의 최종 스코어는 해당 장소의 퀄리티 스코어 및 변화량 스코어의 단순 합 혹은 가중 합으로 결정될 수 있다. 일 예로, 최종 스코어를 계산하는 단계는 퀄리티 스코어에 대응하는 제1 가중치 및 변화량 스코어에 대응하는 제2 가중치에 기초하여, 해당 장소의 퀄리티 스코어 및 해당 장소의 변화량 스코어를 가중 합함으로써 해당 장소의 최종 스코어를 계산하는 단계를 포함할 수 있으며, 여기서 제2 가중치는 상기 제1 가중치보다 크게 설정될 수 있다. 일 실시 예에 따르면, 제1 가중치 및 제2 가중치 합은 1이 되도록 결정될 수 있다.According to an embodiment, the final score of a specific place may be determined as a simple sum or a weighted sum of a quality score and a variation score of the corresponding place. As an example, the calculating of the final score may include weighting and summing the quality score of the corresponding place and the variation score of the corresponding place based on the first weight corresponding to the quality score and the second weight corresponding to the variation score to determine the final score of the corresponding place. and calculating a score, wherein the second weight may be set to be greater than the first weight. According to an embodiment, the sum of the first weight and the second weight may be determined to be 1.

일 실시 예에 따르면, 최종 스코어를 계산함에 있어서, 변화량 스코어는 일정 범위의 값을 갖도록 정규화될 수 있다. 일 예로, 최종 스코어를 계산하는 단계는 장소들 각각에 대응하여 획득된 변화량 스코어를 일정 범위 내의 값을 갖도록 정규화하는 단계 및 장소들 각각에 대응하여, 해당 장소의 퀄리티 스코어 및 해당 장소의 정규화된 변화량 스코어를 가중 합함으로써 해당 장소의 최종 스코어를 계산하는 단계를 포함할 수 있다.According to an embodiment, in calculating the final score, the variation score may be normalized to have a value within a predetermined range. For example, calculating the final score may include normalizing the variation score obtained for each of the locations to have a value within a predetermined range, and corresponding to each of the locations, the quality score of the corresponding location and the normalized variation of the location. calculating a final score for the place by weighted summing the scores.

예를 들어, 장소들에 대응하는 변화량 스코어들은 0 이상 및 1 이하의 값을 갖도록 정규화될 수 있으며, 변화량 스코어(x)의 정규화된 변화량 스코어(x')는 아래의 수학식 8과 같이 나타낼 수 있다.For example, variance scores corresponding to places may be normalized to have values of 0 or more and 1 or less, and the normalized variance score (x') of variance score (x) can be expressed as Equation 8 below have.

Figure pat00008
Figure pat00008

일 실시 예에 따르면, 복수의 장소들 사이의 변화량 스코어들의 상대적 크기 관계가 정규화된 이후에도 유지될 수 있도록 복수의 장소들 사이의 변화량 스코어들의 정규화가 수행될 수 있다.According to an embodiment, normalization of the variance scores between the plurality of places may be performed so that the relative magnitude relationship of the variance scores between the plurality of places may be maintained even after being normalized.

일 실시 예에 따르면, 추천 대상을 선별하는 단계(130)는 장소들 각각에 대응하여, 해당 장소의 위치 및 기준 위치 사이의 거리를 계산하는 단계 및 장소들 각각에 대응하여 계산된 퀄리티 스코어, 변화량 스코어 및 거리에 기초하여, 장소들 중 적어도 하나의 추천 대상을 선별하는 단계를 포함할 수 있다.According to an embodiment, the step of selecting a recommendation target 130 may include calculating a distance between the location of the corresponding location and the reference location in response to each of the locations, and the quality score calculated in response to each of the locations, and the amount of change The method may include selecting at least one recommendation target from among the places based on the score and the distance.

예를 들어, 특정 장소의 최종 스코어(score)는 아래의 수학식 9와 같이 나타낼 수 있다.For example, the final score of a specific place may be expressed as in Equation 9 below.

Figure pat00009
Figure pat00009

수학식 9에서, q_score는 해당 장소의 퀄리티 스코어, v_score는 해당 장소의 변화량 스코어, d_score는 해당 장소의 위치 및 기준 위치 사이의 거리에 기초한 거리 스코어에 해당할 수 있다. 거리 스코어는 해당 장소의 위치 및 기준 위치 사이의 거리를 일정한 규칙에 따라 점수로 환산한 값에 해당할 수 있다. a, b 및 c는 각각 퀄리티 스코어에 대응하는 제1 가중치, 변화량 스코어에 대응하는 제2 가중치 및 거리 스코어에 대응하는 제3 가중치에 해당할 수 있다. 상술한 바와 같이 a보다 b의 값이 크게 결정될 수 있다.In Equation 9, q_score may correspond to the quality score of the corresponding place, v_score may correspond to the change amount score of the corresponding place, and d_score may correspond to a distance score based on the distance between the location of the corresponding place and the reference location. The distance score may correspond to a value obtained by converting the distance between the location of the corresponding place and the reference location into a score according to a certain rule. a, b, and c may correspond to a first weight corresponding to the quality score, a second weight corresponding to the variation score, and a third weight corresponding to the distance score, respectively. As described above, the value of b may be determined to be larger than that of a.

일 실시 예에 따르면, 장소들 각각에 대응하여 계산된 최종 스코어에 기초하여, 적어도 하나의 추천 대상이 선별될 수 있다. 예를 들어, 최종 스코어가 높은 순서에 따라 미리 정해진 개수의 장소가 추천 대상으로 선별될 수 있다. 일 실시 예에 따르면, 장소 추천을 요청한 시점이 포함된 시간 단위에 따라 해당 시간 단위에 대응하여 변화량 스코어 및 퀄리티 스코어가 계산되므로, 추천 대상의 장소는 장소 추천을 요청한 시점에 따라 다르게 선별될 수 있다. 예를 들어, 장소 추천을 요청한 시점의 날짜에 따라 추천 대상으로 선별된 장소가 달라질 수 있다.According to an embodiment, based on the final score calculated for each of the places, at least one recommendation target may be selected. For example, a predetermined number of places may be selected as recommendation targets according to the order of highest final score. According to an embodiment, since the variation score and the quality score are calculated corresponding to the time unit according to the time unit including the time of requesting the place recommendation, the recommended place may be selected differently depending on the time of requesting the place recommendation. . For example, a place selected as a recommendation target may vary according to the date when the place recommendation is requested.

일 실시 예에 따른 서버는 추천 대상으로 선별된 장소에 관한 정보를 사용자 단말에 제공할 수 있다. 예를 들어, 선별된 추천 장소에 관한 정보는 사용자 단말에 설치된 지도 어플리케이션 혹은 서버와 연동되는 지도 웹사이트의 사용자 인터페이스를 통해 제공될 수 있다.The server according to an embodiment may provide information about a place selected as a recommendation target to the user terminal. For example, information on the selected recommended place may be provided through a map application installed in the user terminal or a user interface of a map website interworking with a server.

도 6은 일 실시예에 따른 장소 추천 서비스를 제공하는 장치의 구성의 예시도이다.6 is an exemplary diagram of a configuration of an apparatus for providing a place recommendation service according to an embodiment.

도 6을 참조하면, 장치(600)는 프로세서(601), 메모리(603) 및 입출력 장치(605)를 포함한다. 장치(600)는 서버에 해당할 수 있으며, 실시 예에 따라 사용자 디바이스(예: 스마트폰, 퍼스널 컴퓨터, 태블릿 PC 등)를 포함할 수 있다.Referring to FIG. 6 , the device 600 includes a processor 601 , a memory 603 , and an input/output device 605 . The device 600 may correspond to a server, and may include a user device (eg, a smart phone, a personal computer, a tablet PC, etc.) according to an embodiment.

일실시예에 따른 장치(600)는 상술한 장소 추천 방법을 수행하는 장치 및/또는 장소 추천 서비스를 제공하는 장치를 포함할 수 있다. 프로세서(601)는 도 1 내지 도 5을 통하여 전술한 적어도 하나의 방법의 단계의 동작들을 수행할 수 있다. 예를 들어, 프로세서(601)는 상술한 장소 추천 방법의 각 동작을 수행할 수 있으며, 상술한 지도 어플리케이션을 통해 사용자 단말에 장소 추천 서비스를 제공하기 위한 동작들을 수행할 수 있다. 일 실시 예에 따르면, 프로세서(601)는 장소 추천 방법의 동작들을 수행하기 위한 데이터 및/또는 장소 추천 방법의 동작들을 수행함에 따라 발생한 데이터를 메모리(602) 또는 장치(600)에서 접근 가능한 외부 데이터베이스에 저장할 수 있다.The apparatus 600 according to an embodiment may include an apparatus for performing the above-described method for recommending a place and/or an apparatus for providing a service for recommending a place. The processor 601 may perform the operations of at least one method step described above with reference to FIGS. 1 to 5 . For example, the processor 601 may perform each operation of the above-described place recommendation method, and may perform operations for providing a place recommendation service to the user terminal through the above-described map application. According to an embodiment, the processor 601 stores data for performing the operations of the place recommendation method and/or data generated by performing the operations of the place recommendation method in the memory 602 or an external database accessible from the device 600 . can be stored in

메모리(603)는 상술한 장소 추천 방법과 관련된 정보를 저장할 수 있으며, 프로세서(601)의 동작 실행에 따라 발생한 데이터를 저장할 수 있다. 메모리(603)는 휘발성 메모리 또는 비휘발성 메모리일 수 있다.The memory 603 may store information related to the above-described method for recommending a place, and may store data generated according to the execution of an operation of the processor 601 . The memory 603 may be a volatile memory or a non-volatile memory.

일 측에 따른 장치(600)는 입출력 장치(605)를 통하여 외부 장치(예를 들어, 사용자 단말 또는 네트워크)에 연결되고, 데이터를 교환할 수 있다. 예를 들어, 장치(600)는 입출력 장치(605)를 통해 장소 추천의 요청을 수신할 수 있으며, 장소 추천을 위한 기준 위치에 관한 정보를 수신할 수 있다. 또 예를 들어, 장치(600)는 입출력 장치(605)를 통해 선별된 추천 장소를 사용자 단말에 제공할 수 있다. 선별된 추천 장소에 관한 정보는 사용자 단말에 설치된 지도 어플리케이션의 사용자 인터페이스를 통해 제공될 수 있다.The device 600 according to one side may be connected to an external device (eg, a user terminal or a network) through the input/output device 605 and exchange data. For example, the device 600 may receive a request for a place recommendation through the input/output device 605 , and may receive information about a reference location for the place recommendation. Also, for example, the device 600 may provide the recommended place selected through the input/output device 605 to the user terminal. Information on the selected recommended place may be provided through a user interface of a map application installed in the user terminal.

일 실시 예에 따르면, 메모리(703)는 상술한 장소 추천 방법이 구현된 프로그램을 저장할 수 있다. 프로세서(701)는 메모리(703)에 저장된 프로그램을 실행하고, 장치(700)를 제어할 수 있다. 프로세서(701)에 의하여 실행되는 프로그램의 코드는 메모리(703)에 저장될 수 있다.According to an embodiment, the memory 703 may store a program in which the above-described method for recommending a place is implemented. The processor 701 may execute a program stored in the memory 703 and control the device 700 . The code of the program executed by the processor 701 may be stored in the memory 703 .

이상에서 설명된 실시예들은 하드웨어 구성요소, 소프트웨어 구성요소, 및/또는 하드웨어 구성요소 및 소프트웨어 구성요소의 조합으로 구현될 수 있다. 예를 들어, 실시예들에서 설명된 장치, 방법 및 구성요소는, 예를 들어, 프로세서, 콘트롤러, ALU(arithmetic logic unit), 디지털 신호 프로세서(digital signal processor), 마이크로컴퓨터, FPGA(field programmable gate array), PLU(programmable logic unit), 마이크로프로세서, 또는 명령(instruction)을 실행하고 응답할 수 있는 다른 어떠한 장치와 같이, 범용 컴퓨터 또는 특수 목적 컴퓨터를 이용하여 구현될 수 있다. 처리 장치는 운영 체제(OS) 및 상기 운영 체제 상에서 수행되는 소프트웨어 애플리케이션을 수행할 수 있다. 또한, 처리 장치는 소프트웨어의 실행에 응답하여, 데이터를 접근, 저장, 조작, 처리 및 생성할 수도 있다. 이해의 편의를 위하여, 처리 장치는 하나가 사용되는 것으로 설명된 경우도 있지만, 해당 기술분야에서 통상의 지식을 가진 자는, 처리 장치가 복수 개의 처리 요소(processing element) 및/또는 복수 유형의 처리 요소를 포함할 수 있음을 알 수 있다. 예를 들어, 처리 장치는 복수 개의 프로세서 또는 하나의 프로세서 및 하나의 컨트롤러를 포함할 수 있다. 또한, 병렬 프로세서(parallel processor)와 같은, 다른 처리 구성(processing configuration)도 가능하다.The embodiments described above may be implemented by a hardware component, a software component, and/or a combination of a hardware component and a software component. For example, the apparatus, methods and components described in the embodiments may include, for example, a processor, a controller, an arithmetic logic unit (ALU), a digital signal processor, a microcomputer, a field programmable gate (FPGA). array), a programmable logic unit (PLU), a microprocessor, or any other device capable of executing and responding to instructions, may be implemented using a general purpose computer or special purpose computer. The processing device may execute an operating system (OS) and a software application running on the operating system. The processing device may also access, store, manipulate, process, and generate data in response to execution of the software. For convenience of understanding, although one processing device is sometimes described as being used, one of ordinary skill in the art will recognize that the processing device includes a plurality of processing elements and/or a plurality of types of processing elements. It can be seen that may include For example, the processing device may include a plurality of processors or one processor and one controller. Other processing configurations are also possible, such as parallel processors.

소프트웨어는 컴퓨터 프로그램(computer program), 코드(code), 명령(instruction), 또는 이들 중 하나 이상의 조합을 포함할 수 있으며, 원하는 대로 동작하도록 처리 장치를 구성하거나 독립적으로 또는 결합적으로(collectively) 처리 장치를 명령할 수 있다. 소프트웨어 및/또는 데이터는, 처리 장치에 의하여 해석되거나 처리 장치에 명령 또는 데이터를 제공하기 위하여, 어떤 유형의 기계, 구성요소(component), 물리적 장치, 가상 장치(virtual equipment), 컴퓨터 저장 매체 또는 장치, 또는 전송되는 신호 파(signal wave)에 영구적으로, 또는 일시적으로 구체화(embody)될 수 있다. 소프트웨어는 네트워크로 연결된 컴퓨터 시스템 상에 분산되어서, 분산된 방법으로 저장되거나 실행될 수도 있다. 소프트웨어 및 데이터는 컴퓨터 판독 가능 기록 매체에 저장될 수 있다.The software may comprise a computer program, code, instructions, or a combination of one or more thereof, which configures a processing device to operate as desired or is independently or collectively processed You can command the device. The software and/or data may be any kind of machine, component, physical device, virtual equipment, computer storage medium or device, to be interpreted by or to provide instructions or data to the processing device. , or may be permanently or temporarily embody in a transmitted signal wave. The software may be distributed over networked computer systems and stored or executed in a distributed manner. Software and data may be stored in a computer-readable recording medium.

실시예에 따른 방법은 다양한 컴퓨터 수단을 통하여 수행될 수 있는 프로그램 명령 형태로 구현되어 컴퓨터 판독 가능 매체에 기록될 수 있다. 컴퓨터 판독 가능 매체는 프로그램 명령, 데이터 파일, 데이터 구조 등을 단독으로 또는 조합하여 저장할 수 있으며 매체에 기록되는 프로그램 명령은 실시예를 위하여 특별히 설계되고 구성된 것들이거나 컴퓨터 소프트웨어 당업자에게 공지되어 사용 가능한 것일 수도 있다. 컴퓨터 판독 가능 기록 매체의 예에는 하드 디스크, 플로피 디스크 및 자기 테이프와 같은 자기 매체(magnetic media), CD-ROM, DVD와 같은 광기록 매체(optical media), 플롭티컬 디스크(floptical disk)와 같은 자기-광 매체(magneto-optical media), 및 롬(ROM), 램(RAM), 플래시 메모리 등과 같은 프로그램 명령을 저장하고 수행하도록 특별히 구성된 하드웨어 장치가 포함된다. 프로그램 명령의 예에는 컴파일러에 의해 만들어지는 것과 같은 기계어 코드뿐만 아니라 인터프리터 등을 사용해서 컴퓨터에 의해서 실행될 수 있는 고급 언어 코드를 포함한다. The method according to the embodiment may be implemented in the form of program instructions that can be executed through various computer means and recorded in a computer-readable medium. The computer readable medium may store program instructions, data files, data structures, etc. alone or in combination, and the program instructions recorded on the medium may be specially designed and configured for the embodiment, or may be known and available to those skilled in the art of computer software. have. Examples of the computer-readable recording medium include magnetic media such as hard disks, floppy disks and magnetic tapes, optical media such as CD-ROMs and DVDs, and magnetic such as floppy disks. - includes magneto-optical media, and hardware devices specially configured to store and execute program instructions, such as ROM, RAM, flash memory, and the like. Examples of program instructions include not only machine language codes such as those generated by a compiler, but also high-level language codes that can be executed by a computer using an interpreter or the like.

위에서 설명한 하드웨어 장치는 실시예의 동작을 수행하기 위해 하나 또는 복수의 소프트웨어 모듈로서 작동하도록 구성될 수 있으며, 그 역도 마찬가지이다.The hardware devices described above may be configured to operate as one or a plurality of software modules to perform the operations of the embodiments, and vice versa.

이상과 같이 실시예들이 비록 한정된 도면에 의해 설명되었으나, 해당 기술분야에서 통상의 지식을 가진 자라면 이를 기초로 다양한 기술적 수정 및 변형을 적용할 수 있다. 예를 들어, 설명된 기술들이 설명된 방법과 다른 순서로 수행되거나, 및/또는 설명된 시스템, 구조, 장치, 회로 등의 구성요소들이 설명된 방법과 다른 형태로 결합 또는 조합되거나, 다른 구성요소 또는 균등물에 의하여 대치되거나 치환되더라도 적절한 결과가 달성될 수 있다.As described above, although the embodiments have been described with reference to the limited drawings, a person skilled in the art may apply various technical modifications and variations based thereon. For example, the described techniques are performed in a different order than the described method, and/or the described components of the system, structure, apparatus, circuit, etc. are combined or combined in a different form than the described method, or other components Or substituted or substituted by equivalents may achieve an appropriate result.

그러므로, 다른 구현들, 다른 실시예들 및 특허청구범위와 균등한 것들도 후술하는 특허청구범위의 범위에 속한다.Therefore, other implementations, other embodiments, and equivalents to the claims are also within the scope of the following claims.

Claims (20)

서버에서 수행되는 장소 추천 방법에 있어서,
기준 위치에 대응하는 장소들의 목록을 획득하는 단계;
상기 장소들 각각에 대응하여,
해당 장소의 누적 관심도에 기초하여, 상기 해당 장소의 퀄리티 스코 어를 계산하는 단계; 및
상기 해당 장소의 관심도의 시간 단위 별 이동 평균 값들의 분포 및 기준 시간 단위의 이동 평균 값에 기초하여, 상기 해당 장소의 변화량 스코 어를 계산하는 단계; 및
상기 장소들 각각에 대응하여 계산된 상기 퀄리티 스코어 및 상기 변화량 스코어에 기초하여, 상기 장소들 중 적어도 하나의 추천 대상을 선별하는 단계
를 포함하는,
장소 추천 방법.
In the place recommendation method performed in the server,
obtaining a list of places corresponding to the reference location;
Corresponding to each of the above places,
calculating a quality score of the corresponding place based on the accumulated interest of the corresponding place; and
calculating a change amount score of the corresponding place based on a distribution of moving average values for each time unit of interest of the corresponding place and a moving average value of a reference time unit; and
selecting at least one recommendation target from among the places based on the quality score and the variation score calculated for each of the places;
containing,
How to recommend a place.
제1항에 있어서,
상기 추천 대상을 선별하는 단계는
상기 장소들의 변화량 스코어들의 분위수(quantile)에 기초하여 획득된 변화량 스코어에 관한 제1 임계 값을 초과하는 장소를 아웃라이어(outlier)로 판단하는 단계; 및
상기 아웃라이어로 판단된 장소의 변화량 스코어를 최소 값으로 설정하는 단계
를 더 포함하는,
장소 추천 방법.
According to claim 1,
The step of selecting the recommended target is
determining, based on a quantile of the variance scores of the places, a place exceeding a first threshold value for the obtained variance score as an outlier; and
Setting the change amount score of the place determined as the outlier to the minimum value
further comprising,
How to recommend a place.
제2항에 있어서,
상기 아웃라이어로 판단하는 단계는
상기 장소들의 변화량 스코어들을 로그 스케일로 변환하는 단계;
상기 변환된 변화량 스코어들의 분위수에 기초하여, 변화량 스코어에 관한 제1 임계 값을 획득하는 단계; 및
상기 장소들 중 변환된 변화량 스코어가 상기 제1 임계 값을 초과하는 장소를 아웃라이어로 판단하는 단계
를 포함하는,
장소 추천 방법.
3. The method of claim 2,
The step of determining the outlier is
converting the variance scores of the places to a log scale;
obtaining a first threshold value for the variance score based on the quantiles of the transformed variance scores; and
Determining a place where the converted change score exceeds the first threshold among the places as an outlier
containing,
How to recommend a place.
제2항에 있어서,
상기 아웃라이어로 판단하는 단계는
상기 장소들의 변화량 스코어들의 분위수에 기초하여 변화량 스코어에 관한 제1 임계 값을 획득하는 단계;
상기 장소들의 기준 시간 단위에 대응하는 관심도들에 기초하여, 관심도에 관한 제2 임계 값을 획득하는 단계; 및
상기 장소들 중 변화량 스코어가 제1 임계 값을 초과하고, 상기 기준 시간 단위에 대응하는 관심도가 제2 임계 값을 초과하는 장소를 아웃라이어로 판단하는 단계
를 포함하는,
장소 추천 방법.
3. The method of claim 2,
The step of determining the outlier is
obtaining a first threshold value for a variance score based on a quantile of variance scores of the places;
obtaining a second threshold value related to the degree of interest based on the degree of interest corresponding to the reference time unit of the places; and
determining, as an outlier, a place in which the variation score exceeds a first threshold value and the degree of interest corresponding to the reference time unit exceeds a second threshold value among the places;
containing,
How to recommend a place.
제1항에 있어서,
상기 변화량 스코어를 계산하는 단계는
상기 기준 시간 단위의 이전 시간 단위들의 이동 평균 값들의 평균 및 표준 편차를 계산하는 단계;
상기 표준 편차 및 상기 평균에 기초하여, 상기 기준 시간 단위의 이동 평균 값의 표준 점수를 계산하는 단계; 및
상기 표준 점수에 기초하여, 상기 변화량 스코어를 결정하는 단계
를 포함하는,
장소 추천 방법.
According to claim 1,
The step of calculating the variance score is
calculating an average and standard deviation of moving average values of previous time units of the reference time unit;
calculating a standard score of the moving average value of the reference time unit based on the standard deviation and the average; and
determining the variance score based on the standard score
containing,
How to recommend a place.
제5항에 있어서,
상기 표준 점수를 계산하는 단계는
상기 표준 편차에 미리 정해진 값을 더하여 보정하는 단계; 및
상기 보정된 표준 편차 및 상기 평균에 기초하여, 상기 기준 시간 단위의 이동 평균 값의 표준 점수를 계산하는 단계
를 포함하는,
장소 추천 방법.
6. The method of claim 5,
The step of calculating the standard score is
correcting by adding a predetermined value to the standard deviation; and
calculating a standard score of the moving average value of the reference time unit based on the corrected standard deviation and the average
containing,
How to recommend a place.
제1항에 있어서,
상기 변화량 스코어를 계산하는 단계는
상기 기준 시간 단위의 이동 평균 값이 상기 기준 시간 단위의 이전 시간 단위들의 이동 평균 값들의 평균보다 작은 경우, 상기 변화량 스코어를 최소 값으로 설정하는 단계
를 포함하는,
장소 추천 방법.
According to claim 1,
The step of calculating the variance score is
When the moving average value of the reference time unit is smaller than the average of the moving average values of previous time units of the reference time unit, setting the variation score to a minimum value;
containing,
How to recommend a place.
제1항에 있어서,
상기 추천 대상을 선별하는 단계는
상기 장소들 각각에 대응하여, 해당 장소의 퀄리티 스코어 및 상기 해당 장소의 변화량 스코어를 합함으로써 상기 해당 장소의 최종 스코어를 계산하는 단계; 및
상기 장소들의 최종 스코어들에 기초하여, 상기 장소들 중 적어도 하나의 추천 대상을 선별하는 단계
를 포함하는,
장소 추천 방법.
According to claim 1,
The step of selecting the recommended target is
corresponding to each of the places, calculating a final score of the corresponding place by summing the quality score of the corresponding place and the variation score of the corresponding place; and
selecting at least one of the places to be recommended based on the final scores of the places;
containing,
How to recommend a place.
제8항에 있어서,
상기 최종 스코어를 계산하는 단계는
상기 퀄리티 스코어에 대응하는 제1 가중치 및 상기 변화량 스코어에 대응하는 제2 가중치에 기초하여, 상기 해당 장소의 퀄리티 스코어 및 상기 해당 장소의 변화량 스코어를 가중 합함으로써 상기 해당 장소의 최종 스코어를 계산하는 단계
를 포함하고,
상기 제2 가중치는 상기 제1 가중치보다 크게 설정되는,
장소 추천 방법.
9. The method of claim 8,
The step of calculating the final score is
calculating the final score of the corresponding place by weighted summing the quality score of the corresponding place and the variation score of the corresponding place based on the first weight corresponding to the quality score and the second weight corresponding to the variance score
including,
the second weight is set to be greater than the first weight;
How to recommend a place.
제8항에 있어서,
상기 최종 스코어를 계산하는 단계는
상기 장소들 각각에 대응하여 획득된 변화량 스코어를 일정 범위 내의 값을 갖도록 정규화하는 단계; 및
상기 장소들 각각에 대응하여, 해당 장소의 퀄리티 스코어 및 상기 해당 장소의 정규화된 변화량 스코어를 가중 합함으로써 상기 해당 장소의 최종 스코어를 계산하는 단계
를 포함하는,
장소 추천 방법.
9. The method of claim 8,
The step of calculating the final score is
normalizing the change amount score obtained for each of the places to have a value within a predetermined range; and
corresponding to each of the places, calculating a final score of the corresponding place by weighted summing the quality score of the corresponding place and the normalized variation score of the corresponding place;
containing,
How to recommend a place.
제1항에 있어서,
상기 시간 단위는 일주일 단위를 포함하고,
상기 관심도의 시간 단위 별 이동 평균 값들은 미리 정해진 범위의 관심도에 관한 일별 시계열 데이터에 기초하여 획득된 일주일 동안의 관심도의 평균 값들을 포함하는,
장소 추천 방법.
According to claim 1,
The time unit includes a week unit,
The moving average values for each time unit of the interest include average values of the interest for a week obtained based on daily time series data about the interest in a predetermined range,
How to recommend a place.
제1항에 있어서,
상기 관심도는
특정 장소에 대한 검색량 및 상기 특정 장소에 대한 클릭 수 중 적어도 하나에 기초하여 결정되고,
상기 장소들의 목록을 획득하는 단계는
상기 장소들에 대한 클릭 수에 대응하는 시계열 데이터를 획득하는 단계; 및
상기 장소들에 대한 검색량에 대응하는 시계열 데이터를 획득하는 단계
중 적어도 하나를 더 포함하는,
장소 추천 방법.
According to claim 1,
The interest is
is determined based on at least one of a search amount for a specific place and a number of clicks for the specific place,
Obtaining a list of the places includes:
obtaining time series data corresponding to the number of clicks for the places; and
obtaining time series data corresponding to a search amount for the places;
further comprising at least one of
How to recommend a place.
제1항에 있어서,
상기 추천 대상을 선별하는 단계는
상기 장소들 각각에 대응하여, 해당 장소의 위치 및 상기 기준 위치 사이의 거리를 계산하는 단계; 및
상기 장소들 각각에 대응하여 계산된 상기 퀄리티 스코어, 상기 변화량 스코어 및 상기 거리에 기초하여, 상기 장소들 중 적어도 하나의 추천 대상을 선별하는 단계
를 포함하는,
장소 추천 방법.
According to claim 1,
The step of selecting the recommended target is
calculating a distance between a location of the corresponding location and the reference location corresponding to each of the locations; and
selecting at least one recommendation target from among the places based on the quality score, the variation score, and the distance calculated for each of the places;
containing,
How to recommend a place.
제1항에 있어서,
상기 장소들의 목록을 획득하는 단계는
사용자로부터 장소의 카테고리에 관한 정보를 수신하는 단계; 및
상기 기준 위치 및 상기 카테고리에 관한 정보에 기초하여, 상기 장소들의 목록을 획득하는 단계
를 포함하는,
장소 추천 방법.
According to claim 1,
Obtaining a list of the places includes:
receiving information about a category of a place from a user; and
obtaining a list of the places based on the reference location and the information about the category;
containing,
How to recommend a place.
제1항에 있어서,
상기 서버는 지도 어플리케이션 및 지도 웹사이트 중 적어도 하나를 제공하는 서버를 포함하는,
장소 추천 방법.
According to claim 1,
The server includes a server that provides at least one of a map application and a map website,
How to recommend a place.
하드웨어와 결합되어 제1항 내지 제15항 중 어느 하나의 항의 방법을 실행시키기 위하여 매체에 저장된 컴퓨터 프로그램.
16. A computer program stored on a medium in combination with hardware to execute the method of any one of claims 1 to 15.
기준 위치에 대응하는 장소들의 목록을 획득하고,
상기 장소들 각각에 대응하여,
해당 장소의 누적 관심도에 기초하여, 상기 해당 장소의 퀄리티 스코 어를 계산하고,
상기 해당 장소의 관심도의 시간 단위 별 이동 평균 값들의 분포 및 기준 시간 단위의 이동 평균 값에 기초하여, 상기 해당 장소의 변화량 스코 어를 계산하고,
상기 장소들 각각에 대응하여 계산된 상기 퀄리티 스코어 및 상기 변화량 스코어에 기초하여, 상기 장소들 중 적어도 하나의 추천 대상을 선별하는,
적어도 하나의 프로세서
를 포함하는,
서버.
Obtain a list of places corresponding to the reference location,
Corresponding to each of the above places,
Based on the accumulated interest of the place, calculate the quality score of the place,
Calculate the change amount score of the corresponding place based on the distribution of moving average values for each time unit of interest of the corresponding place and the moving average value of the reference time unit,
selecting at least one recommendation target from among the places based on the quality score and the variation score calculated for each of the places;
at least one processor
containing,
server.
제17항에 있어서,
상기 프로세서는,
상기 추천 대상을 선별함에 있어서,
상기 장소들의 변화량 스코어들의 분위수(quantile)에 기초하여 획득된 변화량 스코어에 관한 제1 임계 값을 초과하는 장소를 아웃라이어(outlier)로 판단하고,
상기 아웃라이어로 판단된 장소의 변화량 스코어를 최소 값으로 설정하는,
서버.
18. The method of claim 17,
The processor is
In selecting the recommended target,
determining as an outlier a place that exceeds a first threshold value for an obtained variance score based on a quantile of variance scores of the places;
Setting the change amount score of the place determined as the outlier to the minimum value,
server.
제17항에 있어서,
상기 프로세서는,
상기 변화량 스코어를 계산함에 있어서,
상기 기준 시간 단위의 이전 시간 단위들의 이동 평균 값들의 평균 및 표준 편차를 계산하고,
상기 표준 편차 및 상기 평균에 기초하여, 상기 기준 시간 단위의 이동 평균 값의 표준 점수를 계산하며,
상기 표준 점수에 기초하여, 상기 변화량 스코어를 결정하는,
서버.
18. The method of claim 17,
The processor is
In calculating the variance score,
calculating the average and standard deviation of the moving average values of previous time units of the reference time unit,
calculating a standard score of the moving average value of the reference time unit based on the standard deviation and the average,
determining the variance score based on the standard score,
server.
제17항에 있어서,
상기 프로세서는,
상기 추천 대상을 선별함에 있어서,
상기 장소들 각각에 대응하여, 해당 장소의 퀄리티 스코어 및 상기 해당 장소의 변화량 스코어를 합함으로써 상기 해당 장소의 최종 스코어를 계산하고,
상기 장소들의 최종 스코어들에 기초하여, 상기 장소들 중 적어도 하나의 추천 대상을 선별하는,
서버.

18. The method of claim 17,
The processor is
In selecting the recommended target,
corresponding to each of the places, calculating the final score of the corresponding place by summing the quality score of the corresponding place and the variation score of the corresponding place;
selecting at least one of the places to recommend based on the final scores of the places;
server.

KR1020210057338A 2021-05-03 2021-05-03 Method and apparatus for recommending places KR102570399B1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1020210057338A KR102570399B1 (en) 2021-05-03 2021-05-03 Method and apparatus for recommending places

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020210057338A KR102570399B1 (en) 2021-05-03 2021-05-03 Method and apparatus for recommending places

Publications (2)

Publication Number Publication Date
KR20220150081A true KR20220150081A (en) 2022-11-10
KR102570399B1 KR102570399B1 (en) 2023-08-25

Family

ID=84101732

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020210057338A KR102570399B1 (en) 2021-05-03 2021-05-03 Method and apparatus for recommending places

Country Status (1)

Country Link
KR (1) KR102570399B1 (en)

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20190124524A (en) * 2018-04-26 2019-11-05 충북대학교 산학협력단 Method and system for recommending point of interest

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20190124524A (en) * 2018-04-26 2019-11-05 충북대학교 산학협력단 Method and system for recommending point of interest

Also Published As

Publication number Publication date
KR102570399B1 (en) 2023-08-25

Similar Documents

Publication Publication Date Title
CN107315824B (en) Method and device for generating thermodynamic diagram
US10692151B1 (en) Homeowners insurance application process using geotagged photos
EP3471374B1 (en) Method and device for identifying type of geographic location at where user is located
US9877162B2 (en) Systems and methods for generating a user location history
US20170004404A1 (en) Demand prediction method, demand prediction apparatus, and non-transitory computer-readable recording medium
CN107430631B (en) Determining semantic place names from location reports
WO2014169139A1 (en) Method and device for testing multiple versions
CN110618982B (en) Multi-source heterogeneous data processing method, device, medium and electronic equipment
CN113268641B (en) User data processing method based on big data and big data server
WO2020150611A1 (en) Systems and methods for entity performance and risk scoring
CN114119146A (en) Recommendation method and device, electronic equipment and readable storage medium
US9842334B1 (en) Identifying risky transactions
CN107291835B (en) Search term recommendation method and device
WO2014099384A1 (en) Determining contact opportunities
CN113360790A (en) Information recommendation method and device and electronic equipment
KR102570399B1 (en) Method and apparatus for recommending places
US9092409B2 (en) Smart scoring and filtering of user-annotated geocoded datasets
CN112287208A (en) User portrait generation method and device, electronic equipment and storage medium
KR101852766B1 (en) Method and Apparatus for Searching Things for Sale
KR101663359B1 (en) Method and apparatus for providing updated news contents
CN113326436A (en) Method and device for determining recommended resources, electronic equipment and storage medium
CN112785197B (en) Information recommendation method, apparatus, computing device, medium and program product
KR102535651B1 (en) Method, device and system for selecting service tips corresponding to workers
KR102347187B1 (en) Electronic devices that analyze information on specific sites for AI marketing solutions and their operating methods
CN112214387B (en) Knowledge graph-based user operation behavior prediction method and device

Legal Events

Date Code Title Description
E902 Notification of reason for refusal
E701 Decision to grant or registration of patent right
GRNT Written decision to grant