KR20150073854A - Dynamic travel planner - Google Patents
Dynamic travel planner Download PDFInfo
- Publication number
- KR20150073854A KR20150073854A KR1020140182717A KR20140182717A KR20150073854A KR 20150073854 A KR20150073854 A KR 20150073854A KR 1020140182717 A KR1020140182717 A KR 1020140182717A KR 20140182717 A KR20140182717 A KR 20140182717A KR 20150073854 A KR20150073854 A KR 20150073854A
- Authority
- KR
- South Korea
- Prior art keywords
- travel
- destination
- graph
- request
- price
- Prior art date
Links
- 238000000034 method Methods 0.000 claims abstract description 29
- 238000004590 computer program Methods 0.000 abstract description 9
- 230000004308 accommodation Effects 0.000 description 25
- 238000012545 processing Methods 0.000 description 17
- 230000010006 flight Effects 0.000 description 13
- 238000004891 communication Methods 0.000 description 12
- 238000010586 diagram Methods 0.000 description 10
- 230000006870 function Effects 0.000 description 5
- 238000005516 engineering process Methods 0.000 description 3
- 238000007493 shaping process Methods 0.000 description 3
- 238000004458 analytical method Methods 0.000 description 2
- 230000008901 benefit Effects 0.000 description 2
- 238000001914 filtration Methods 0.000 description 2
- 235000012054 meals Nutrition 0.000 description 2
- 230000008569 process Effects 0.000 description 2
- 230000004044 response Effects 0.000 description 2
- 230000009471 action Effects 0.000 description 1
- 230000001413 cellular effect Effects 0.000 description 1
- 238000007726 management method Methods 0.000 description 1
- 230000005055 memory storage Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000008520 organization Effects 0.000 description 1
- 238000012552 review Methods 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- 230000000153 supplemental effect Effects 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION 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/00—Information and communication technology [ICT] specially adapted for implementation of business processes of specific business sectors, e.g. utilities or tourism
- G06Q50/10—Services
- G06Q50/14—Travel agencies
Landscapes
- Business, Economics & Management (AREA)
- Tourism & Hospitality (AREA)
- Health & Medical Sciences (AREA)
- Economics (AREA)
- General Health & Medical Sciences (AREA)
- Human Resources & Organizations (AREA)
- Marketing (AREA)
- Primary Health Care (AREA)
- Strategic Management (AREA)
- Physics & Mathematics (AREA)
- General Business, Economics & Management (AREA)
- General Physics & Mathematics (AREA)
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
본 발명은 여행 요청에 대한 적어도 하나의 여행 솔루션을 결정하는 방법, 시스템 및 컴퓨터 프로그램 제품에 관한 것이다. 출발지, 적어도 하나의 목적지 및 적어도 하나의 시간 제약을 지시하는 여행 요청이 수신된다. 상기 여행 요청에 기초하여, 출발지 및 적어도 하나의 목적지를 포함하는 여행 경로가 적어도 하나의 시간 제약에 적어도 부분적으로 기초하여 수립된다. 적어도 하나의 시간 제약에 적어도 부분적으로 기초하여 각 여행 경로에 대해 적어도 하나의 후보 여행 솔루션이 결정된다. 적어도 하나의 후보 여행 솔루션에 대한 가격 및 이용가능성에 적어도 부분적으로 기초하여 여행 요청에 대한 적어도 하나의 여행 솔루션이 결정된다. The present invention relates to a method, system and computer program product for determining at least one travel solution for a travel request. A travel request is received that indicates the origin, at least one destination, and at least one time constraint. Based on the travel request, a travel route comprising the origin and the at least one destination is established based at least in part on at least one time constraint. At least one candidate travel solution is determined for each travel route based at least in part on at least one time constraint. At least one travel solution for the travel request is determined based at least in part on the price and availability for the at least one candidate travel solution.
Description
본 발명은 일반적으로 컴퓨터 및 컴퓨터 소프트웨어에 관한 것으로, 보다 상세하게는 여행을 계획(planning)하고 예약(reservation)을 수행하는 방법, 시스템 및 컴퓨터 프로그램 제품에 관한 것이다. The present invention relates generally to computer and computer software, and more particularly to a method, system, and computer program product for planning a trip and performing a reservation.
컴퓨터 기술이 여행 예약 뿐아니라 이와 연관된 데이터를 관리하고 지원하기 위해 여행 산업에서 점점 더 많이 사용되고 있다. 구체적으로, 제3자 예약 대리인, 예를 들어, 여행 대리점 및/또는 고객(예를 들어, 여행자)은 종종 GDS (Global Distribution System)와 같은 여행 예약 시스템과 인터페이싱하는 컴퓨터 기반 디바이스를 사용하여, 고객에 대한 여행 배열 및/또는 여행 관련된 서비스를 부킹(book)한다. 이러한 여행 예약 시스템과 통신하는 예약 단말을 사용하여 여행 관련된 서비스를 예약할 때, 여행사 직원 및/또는 고객은 클라이언트 디바이스와 여행 예약 시스템 사이에 예약 세션(session)을 개시하여 예약 세션 동안 고객에 대한 여행 관련된 서비스(예를 들어, 항공편, 호텔, 철도 교통, 식사 예약 등)에 대응하는 하나 이상의 여행 상세 항목(travel inventory item)을 부킹할 수 있다. Computer technology is increasingly used in the travel industry to manage and support travel reservations as well as associated data. Specifically, a third party reservation agent, e.g., a travel agency and / or customer (e.g., traveler), often uses a computer-based device to interface with a travel reservation system, such as Global Distribution System (GDS) And / or travel related services to the user. When booking a travel-related service using a reservation terminal that communicates with such a travel reservation system, the travel agent and / or customer may initiate a reservation session between the client device and the travel reservation system, One or more travel inventory items corresponding to related services (e.g., flights, hotels, railroad transportation, meals reservations, etc.).
컴퓨터 기술이 여행 예약을 관리 및 지원하는데 점점 더 많이 사용되고 있으므로, 개선된 컴퓨터 기반 여행 계획 및 예약 시스템, 및 여행 관련된 서비스를 부킹하는 개선된 방법 및 컴퓨터 프로그램 제품에 대한 지속적인 요구가 이 기술 분야에 존재한다. As computer technology is increasingly used to manage and support travel reservations, there is a continuing need in the art for improved computer-based travel planning and scheduling systems, and improved methods for booking travel-related services and computer program products do.
본 발명의 실시예는 일반적으로 여행 요청에 대한 하나 이상의 여행 솔루션을 생성하는 방법, 시스템 및 컴퓨터 프로그램 제품을 포함한다. 본 발명의 실시예에 따라, 출발지, 하나 이상의 목적지 및 하나 이상의 시간 제약(time constraint)을 지시하는 여행 요청이 수신될 수 있다. 상기 하나 이상의 시간 제약에 기초하여, 상기 출발지 및 상기 하나 이상의 목적지를 포함하는 여행 경로(travel path)를 수립할 수 있다. 상기 하나 이상의 시간 제약에 적어도 부분적으로 기초하여, 각 여행 경로에 대해 하나 이상의 후보 여행 솔루션(candidate travel solution)이 결정될 수 있다. 일반적으로, 각 후보 여행 솔루션은 상기 여행 요청을 만족하는, 항공편, 호텔 숙박, 차량 렌탈, 철도 티켓 등과 같은 여행 서비스에 대한 복수의 가격 책정된 여행 상세 항목을 포함한다. 상기 하나 이상의 후보 여행 솔루션에 대한 상기 가격 및 이용가능성에 기초하여, 본 발명의 실시예는 상기 여행 요청에 대한 적어도 하나의 여행 솔루션을 결정할 수 있다. Embodiments of the present invention generally include methods, systems, and computer program products for creating one or more travel solutions for travel requests. According to an embodiment of the present invention, a travel request may be received that indicates a departure location, one or more destinations, and one or more time constraints. Based on the one or more time constraints, a travel path including the origin and the one or more destinations may be established. Based on the at least one time constraint at least in part, one or more candidate travel solutions can be determined for each travel route. Typically, each candidate travel solution includes a plurality of priced travel details for travel services, such as flights, hotel accommodations, vehicle rental, rail tickets, etc., that satisfy the travel request. Based on the price and availability for the one or more candidate travel solutions, an embodiment of the invention may determine at least one travel solution for the travel request.
본 명세서에 포함되고 본 명세서의 일부를 구성하는 첨부 도면은 본 발명의 여러 실시예를 도시하고, 앞서 제시된 본 발명의 일반적인 설명과 아래에 제공되는 실시예의 상세한 설명과 함께, 본 발명의 실시예를 설명하는 역할을 한다.
도 1은 본 발명의 실시예에 따른 하나 이상의 예약 시스템, 하나 이상의 상세 시스템 및 하나 이상의 클라이언트 디바이스의 블록도.
도 2는 도 1의 예약 시스템의 블록도.
도 3은 도 1의 예약 시스템, 상세 시스템 및 클라이언트 디바이스의 일부 하드웨어 및 소프트웨어 성분(component)의 블록도.
도 4는 도 1 내지 도 3의 시스템에 의해 수행되어 본 발명의 일부 실시예에 따라 여행 요청에 대한 하나 이상의 여행 솔루션을 생성할 수 있는 동작 시퀀스를 도시하는 흐름도.
도 5a 내지 도 5g는 도 1 내지 도 3의 시스템에 의해 사용되어 여행 요청에 대한 하나 이상의 여행 그래프(travel graph)를 결정할 수 있는 예시적인 여행 그래프 형상(graph shape)을 도시하는 도면.
도 6a 내지 도 6m은 본 발명의 일부 실시예에 따라 도 1 내지 도 3의 시스템에 의해 결정될 수 있는 예시적인 여행 요청 및 여행 그래프를 도시하는 도면.
도 7a 내지 도 7d는 본 발명의 일부 실시예에 따라 도 1 내지 도 3의 시스템에 의해 결정될 수 있는 예시적인 여행 그래프 및 여행 경로를 도시하는 도면.
도 8a 내지 도 8b는 본 발명의 일부 실시예에 따라 도 1 내지 도 3의 시스템에 의해 결정될 수 있는 예시적인 여행 경로를 도시하는 도면.
도 9a 내지 도 9d는 도 1 내지 도 3의 시스템에 의해 수행되어 여행 요청에 대한 하나 이상의 여행 솔루션을 결정할 수 있는 동작 시퀀스를 도시하는 순서도.
도 10은 예약 시스템과 인터페이스하며 본 발명의 실시예에 따라 여행 요청을 생성하는 클라이언트 디바이스의 디스플레이에 출력될 수 있는 예시적인 그래픽 유저 인터페이스의 개략도. BRIEF DESCRIPTION OF THE DRAWINGS The accompanying drawings, which are incorporated in and constitute a part of this specification, illustrate several embodiments of the invention and, together with a general description of the invention given above and the detailed description of the embodiments given below, It serves to explain.
1 is a block diagram of one or more reservation systems, one or more detailed systems, and one or more client devices in accordance with an embodiment of the present invention.
Figure 2 is a block diagram of the reservation system of Figure 1;
Figure 3 is a block diagram of some of the hardware and software components of the reservation system, detail system, and client device of Figure 1;
Figure 4 is a flow diagram illustrating an operational sequence that may be performed by the system of Figures 1-3 to create one or more travel solutions for a travel request in accordance with some embodiments of the present invention.
Figures 5A-5G illustrate exemplary travel graph shapes that may be used by the system of Figures 1-3 to determine one or more travel graphs for travel requests.
Figures 6A-6M illustrate exemplary travel requests and travel graphs that may be determined by the system of Figures 1-3 according to some embodiments of the present invention.
Figures 7A-7D illustrate exemplary travel graphs and travel paths that may be determined by the system of Figures 1-3 in accordance with some embodiments of the present invention.
Figures 8A-8B illustrate exemplary travel paths that may be determined by the system of Figures 1-3 according to some embodiments of the present invention.
9A-9D are flow diagrams illustrating an operational sequence performed by the system of FIGS. 1-3 to determine one or more travel solutions for a travel request;
10 is a schematic diagram of an exemplary graphical user interface that interfaces with a reservation system and can be output to a display of a client device that generates a travel request according to an embodiment of the present invention.
본 발명의 실시예는 여행 요청에 대한 하나 이상의 여행 솔루션을 결정하는 시스템, 방법 및 컴퓨터 프로그램 제품을 제공한다. 본 발명의 일부 실시예에 따라, 각 여행 솔루션은 출발지 및 하나 이상의 목적지를 포함할 수 있고, 여기서 각 여행 솔루션은 출발지 및 하나 이상의 목적지와 연관된 여행 서비스(예를 들어, 항공편 티켓, 차량 렌탈, 철도 여행 티켓, 숙박, 택시 서비스, 식사 예약 등)에 대한 여행 상세 항목을 제공할 수 있다. 더욱이, 각 여행 솔루션은 유저에 의해 내부에 포함된 각 여행 상세 항목을 동시에 예약할 수 있다. 일반적으로, 수신된 여행 요청은 출발지, 하나 이상의 목적지, 하나 이상의 시간 제약, 여행자(즉, 유저) 선호도 및/또는 여행 서비스를 계획하고 부킹하는데 고려될 수 있는 다른 정보를 지시할 수 있다. 출발지, 하나 이상의 목적지, 하나 이상의 시간 제약 및/또는 유저 선호도에 기초하여, 본 발명의 실시예는 여행 요청을 만족하는, 부킹/예약될 수 있는 출발지 및 하나 이상의 목적지에 대한 여행 서비스(예를 들어, 항공편, 차량 렌탈, 철도 여행, 페리(ferry) 등)에 대한 여행 상세 항목을 포함하는 하나 이상의 여행 솔루션을 결정할 수 있다. 일반적으로, 여행 솔루션은 하나 이상의 시간 제약을 충족하고, 원하는 숙박 및/또는 서비스를 포함하고, 임의의 지시된 유저 선호도에 대응한다. Embodiments of the present invention provide a system, method and computer program product for determining one or more travel solutions for a travel request. In accordance with some embodiments of the present invention, each travel solution may include a departure location and one or more destinations, where each travel solution includes travel services associated with the departure location and one or more destinations (e.g., flight tickets, Travel tickets, accommodation, taxi services, meal reservations, etc.). Moreover, each travel solution can simultaneously book each trip detail item contained therein by the user. In general, the received travel request may indicate a departure location, one or more destinations, one or more time constraints, a traveler (i.e., user) preference, and / or other information that may be considered for planning and booking the travel service. Based on the origin, the one or more destinations, the one or more time constraints, and / or the user preferences, embodiments of the present invention can be used to provide travel services (e.g., , Travel details for flights, car rentals, rail travel, ferry, etc.). In general, a travel solution meets one or more time constraints, includes desired accommodation and / or services, and corresponds to any indicated user preference.
예를 들어, 여행자에 대한 여행 요청이 출발지, 제1 목적지, 제2 목적지, 및 여행자가 2개의 목적지로 여행하기를 원하는 2주 기간(two week period)을 지시하는 경우, 본 발명의 실시예는 출발지로부터 제1 목적지로 가는 여행 서비스, 제1 목적지로부터 제2 목적지로 가는 여행 서비스, 및 제2 목적지로부터 출발지로 다시 가는 여행 서비스에 대한 여행 상세 항목을 포함하는 하나 이상의 여행 솔루션을 결정할 수 있고, 여기서 여행 솔루션은 여행자가 원하는 2주 기간 내에 있는 것이다. 이 예에서, 여행자가 제1 목적지에서 호텔 숙박을 요구한 경우, 여행 솔루션은 제1 목적지에서의 호텔 예약을 더 포함할 수 있다. 여행자가 특정 체인의 또는 유형의 호텔을 선호하는 경우, 호텔 예약은 선호되는 체인의 또는 유형의 호텔일 수 있다. 나아가, 여행자가 특정 여행자가 제1 목적지에서 있기를 원하는 특정 날수(range of days)를 지시하는 경우, 여행 솔루션은 여행자가 이 특정 날수 동안 제1 목적지에 있을 수 있는 여행 및 숙박 시설을 포함할 수 있다. 게다가, 여행 요청은 여행자가 한정된 범위 이하의 거리(예를 들어, 200 마일) 및/또는 지속시간(예를 들어, 6 시간) 동안 (즉, 렌트 차량을) 드라이브하기를 선호하는 것을 지시할 수 있고, 여행 솔루션은 여행 거리 및/또는 지속시간이 출발지, 제1 목적지 및/또는 제2 목적지 사이에서 여행자의 선호도를 충족하는 경우 적어도 하나의 차량 렌탈 여행 서비스를 포함할 수 있다. 그리하여, 이 예에서 도시된 바와 같이, 본 발명의 실시예는 여행자에 대한 여행 및 숙박 서비스를 계획하여 각각 스케줄하는 하나 이상의 여행 솔루션을 결정할 수 있고, 여행자는 부킹할 특정 여행 솔루션을 선택하여 특정 여행 솔루션의 여행 및 숙박 서비스에 대한 여행 상세 항목의 일부 또는 전부를 동시에 부킹할 수 있다. For example, if a travel request for a traveler indicates a departure, a first destination, a second destination, and a two week period when the traveler wishes to travel to two destinations, Determine one or more travel solutions including travel details for the travel service from the departure point to the first destination, the travel service from the first destination to the second destination, and the travel service to the departure from the second destination, The travel solution here is within a two week period that travelers want. In this example, if the traveler has requested hotel accommodation at the first destination, the travel solution may further include hotel reservation at the first destination. If a traveler prefers a particular chain or type of hotel, the hotel reservation may be a hotel of the preferred chain or type. Further, if a traveler indicates a particular range of days for which a particular traveler wishes to be at the first destination, the travel solution may include travel and accommodation where the traveler may be at the first destination for this particular number of days have. In addition, the travel request may indicate that the traveler prefers to drive for a distance (e.g., 200 miles) and / or duration (e.g., 6 hours) below a limited range And the travel solution may include at least one car rental travel service if the travel distance and / or duration meets a traveler's preference between the origin, the first destination and / or the second destination. Thus, as shown in this example, embodiments of the present invention can determine one or more travel solutions for scheduling travel and accommodation services for travelers, respectively, and the traveler can select specific travel solutions to be bookmarked, You can book some or all of the trip details for the travel and accommodation services of the solution at the same time.
이제 도면 및 구체적으로 도 1을 참조하면, 본 도면은 본 발명의 실시예에 따라 하나 이상의 디바이스 및/또는 시스템을 도시하는 블록도를 제공한다. 도 1에 도시된 바와 같이, 예약 시스템(102)은 하나 이상의 서버로 구현될 수 있다. 예약 시스템(102)은 통신 네트워크(103)에 연결될 수 있고, 여기서 통신 네트워크(103)는 인터넷, 로컬 영역 네트워크(LAN), 광역 네트워크(WAN), 셀룰러 음성/데이터 네트워크, 하나 이상의 고속 버스 연결 및/또는 다른 유형의 통신 네트워크를 포함할 수 있다. 클라이언트 디바이스(104)는 통신 네트워크(103)에 연결될 수 있어, 고객 또는 예약 직원(예를 들어, 여행사 또는 다른 여행 예약 서비스)은 예약 시스템(102)과 여행 계획 및 예약 세션을 초기화(initialize)하여 여행 요청 및/또는 다른 관련 데이터를 예약 시스템(102)에 통신할 수 있다. 클라이언트 디바이스(104)는 퍼스널 컴퓨팅 디바이스, 태블릿 컴퓨터, 씬 클라이언트(thin client) 단말, 스마트폰 및/또는 다른 컴퓨팅 디바이스일 수 있다. Referring now to the drawings and specifically to FIG. 1, this Figure provides a block diagram illustrating one or more devices and / or systems in accordance with an embodiment of the present invention. As shown in FIG. 1, the
하나 이상의 여행 상인의 하나 이상의 상세 시스템(106)에 대한 하나 이상의 서버가 통신 네트워크(103)에 연결된다. 예약 시스템(102)은 여행 상세 항목이 부킹되는 각 상세 시스템(106)과 통신 네트워크(103)를 통해 상세 세션을 초기화할 수 있다. 본 발명의 실시예에 따라, 예약 직원 또는 고객(즉, 여행자)은 여행 계획 및 예약 세션에서 클라이언트 디바이스(104)를 사용하여 예약 시스템(102)과 인터페이싱하며 여행 요청 데이터를 제공할 수 있다. 이어서, 예약 시스템은 일반적으로 이용가능성 결정(예를 들어, 항공편, 철도 티켓, 호텔 룸, 이벤트 티켓 등)을 요구하는 여행 상세 항목을 제공하는 각 여행 상인의 각 상세 시스템(106)과 인터페이싱하며 부킹 요청에 대한 이용가능성 결정을 요구하는 각 여행 상세 항목에 대한 이용가능성을 결정할 수 있다. 게다가, 본 발명의 일부 실시예에 따라, 일부 상세 시스템(106)은 이용가능성 결정, 예를 들어, 레스토랑 예약, 택시 서비스, 비-제한적인 이용가능성 이벤트/위치 입장 티켓 등을 요구하지 않는 서비스의 부킹을 관리할 수 있다. 더욱이, 예약 시스템(102) 및 상세 시스템(106)이 본 명세서에서 별개의 개체로 설명되었으나, 본 발명은 이것으로 제한되지 않는다. 일부 실시예에서, 예약 시스템(102) 또는 상세 시스템(106)에 대해 설명된 여러 하드웨어, 소프트웨어 성분 및/또는 동작 시퀀스는 예약 시스템(102) 및/또는 상세 시스템(106) 상에 구현될 수 있다. 나아가, 이해되는 바와 같이, 일부 실시예에서 예약 시스템(102) 및 상세 시스템(106)은 GDS의 성분일 수 있다. One or more servers for one or more
아래에 보다 상세히 설명된 바와 같이, 본 발명의 실시예에 따라, 예약 시스템은 유저(즉, 여행자 또는 여행사 직원)가 정보를 입력할 수 있는 인터페이스를 생성하고 이 정보를 사용하여 본 발명의 실시예에 따라 하나 이상의 여행 솔루션을 결정하는데 사용될 수 있는 여행 요청을 생성할 수 있다. 일반적으로, 이 인터페이스는 클라이언트 디바이스(104), 예를 들어, 퍼스널 컴퓨터, 휴대용 전자 디바이스(예를 들어, 스마트폰, 태블릿, 랩탑 등) 또는 이 인터페이스를 제공하는 서버와 인터페이싱하도록 구성된 단말을 통해 액세스될 수 있다. 이 실시예에 따라, 유저는 출발지, 하나 이상의 목적지, 하나 이상의 시간 제약 및/또는 하나 이상의 유저 선호도를 입력할 수 있다. 이 입력 정보에 기초하여, 여행 요청이 생성될 수 있고, 하나 이상의 여행 솔루션은 여행 요청의 컨텐츠에 기초하여 동적으로 결정될 수 있다. 유저 선호도는, 예를 들어, 선호되는 여행 방법(예를 들어, 항공편, 철도 여행, 렌탈 차량 등), 한정된 거리 또는 지속시간을 초과하지 않는 여행에 선호되는 여행 방법, 선호되는 여행 상인 등을 포함할 수 있다. As described in more detail below, according to an embodiment of the present invention, the reservation system creates an interface through which a user (i.e., a traveler or a travel agent) can enter information, To generate a travel request that can be used to determine one or more travel solutions. Typically, this interface is accessed through a
도 2는 예약 시스템(102)의 하나 이상의 서버의 성분을 도시하는 블록도를 제공한다. 예약 시스템(102)은 적어도 하나의 하드웨어-기반 마이크로프로세서를 포함하는 적어도 하나의 프로세서(122) 및 상기 적어도 하나의 프로세서(122)에 연결된 메모리(124)를 포함한다. 메모리(124)는 예약 시스템(102)의 메인 저장매체를 포함하는 랜덤 액세스 메모리(RAM) 디바이스, 및 임의의 보충 레벨의 메모리, 예를 들어, 캐시 메모리, 비-휘발성 또는 백업 메모리(예를 들어, 프로그래밍가능한 메모리 또는 플래시 메모리), 판독 전용 메모리 등을 나타낼 수 있다. 게다가, 메모리(124)는 여행 및 예약 시스템(102) 내 어디엔가 물리적으로 위치된 메모리 저장매체, 예를 들어, 마이크로프로세서 내 임의의 캐시 메모리, 및 예를 들어, 대용량 저장 디바이스 상에 저장되거나 또는 예약 시스템(102)에 연결된 다른 컴퓨터 상에 저장된 가상 메모리로 사용되는 임의의 저장 용량을 포함하는 것으로 고려될 수 있다. FIG. 2 provides a block diagram illustrating the components of one or more servers of
유저 또는 운영자와 인터페이싱하기 위해, 예약 시스템(102)은 하나 이상의 유저 입력/출력 디바이스, 예를 들어, 키보드, 포인팅 디바이스, 디스플레이, 프린터 등을 포함하는 유저 인터페이스(126)를 포함할 수 있다. 한편, 데이터는 통신 네트워크(103)에 연결된 네트워크 인터페이스(128)를 통해 다른 컴퓨터 또는 단말(예를 들어, 클라이언트 디바이스(104), 상세 시스템(106))로 통신되거나 이 다른 컴퓨터 또는 단말로부터 통신될 수 있다. 예약 시스템(102)도, 예를 들어, 내부 하드 디스크 저장 디바이스, 외부 하드 디스크 저장 디바이스, 외부 데이터베이스, 저장 영역 네트워크 디바이스 등일 수 있는 하나 이상의 대용량 저장 디바이스와 통신할 수 있다. To interface with a user or operator, the
예약 시스템(102)은 일반적으로 운영 시스템(130)의 제어 하에 동작하며, 예를 들어, 예약 모듈(132), 트립 계획 모듈(134), 및 이용가능성 및 가격 모듈(136)을 포함하는, 여러 컴퓨터 소프트웨어 애플리케이션, 성분, 프로그램, 객체, 모듈, 엔진, 데이터 구조 등을 실행하고 이에 의존한다. 일반적으로, 예약 모듈(132)은 하나 이상의 여행 상인 시스템(예를 들어, 상세 시스템(106))과 인터페이싱하며 수신된 데이터에 기초하여 여행 서비스를 예약하도록 구성될 수 있다. 트립(trip) 계획 모듈(134)은 수신된 여행 요청을 분석하는 동작과, 여행 요청에 지시되거나 및/또는 여행 요청과 연관된 유저 프로파일에 지시된 제약 및 선호도를 충족하는 여행 요청에 대한 하나 이상의 여행 솔루션을 결정하는 동작을 수행하도록 구성될 수 있다. The
이용가능성 및 가격 모듈(136)은 상세 시스템(106)에 질문하는 동작과, 이용가능성 및 가격 데이터베이스(138)에서 여러 유형의 여행 서비스(예를 들어, 항공편 티켓, 철도 여행 티켓 등)의 여러 여행 상세 항목에 대한 가격 및 이용가능성 정보를 저장하는 동작을 수행하도록 구성될 수 있다. 일반적으로, 이용가능성 및 가격 데이터베이스(138)에 저장된 정보는 트립 계획 모듈(134)에 의해 액세스될 수 있어, 트립 계획 모듈은 관련 여행 서비스의 하나 이상의 여행 상세 항목에 대한 이용가능성 및 가격 정보에 적어도 부분적으로 기초하여 하나 이상의 여행 솔루션을 결정할 수 있다. 나아가, 메모리(124)는 유저 프로파일에서 유저(예를 들어, 고객 또는 예약 직원)에 대한 정보를 저장하는 유저 프로파일 데이터베이스(140)를 포함할 수 있다. 예를 들어, 유저 프로파일 데이터베이스(140)는 고객과 연관된 유저 프로파일에서 고객에 대한 여행 선호도를 저장할 수 있다. 예를 들어, 유저 프로파일은 고객이 특정 유형의 또는 체인의 호텔, 특정 항공사, 특정 렌탈 카 회사 등을 선호하는 것을 지시할 수 있다. 게다가, 유저 프로파일은 고객이 여행의 유형(예를 들어, 항공편, 차량 렌탈, 철도 여행, 페리 등)을 선호하거나, 여행 지속시간 및/또는 거리가 미리 한정된 값 아래에 있는 경우 (즉, 렌트 차량을) 드라이브하기를 선호하거나 및/또는 다른 여행 선호도를 선호하는 것을 지시할 수 있다. 본 발명의 일부 실시예에서, 여행 요청은 특정 유저 프로파일을 식별하는 정보를 포함할 수 있다. 이들 실시예에서, 트립 계획 모듈(134)은 유저 프로파일 데이터베이스(140)에 액세스하여 유저의 선호도에 적어도 부분적으로 기초하여 하나 이상의 여행 솔루션을 결정할 수 있다. 일부 실시예에서, 여행 요청은 하나 이상의 유저 선호도를 포함할 수 있다. The availability and
더욱이, 여러 애플리케이션, 성분, 프로그램, 객체, 모듈, 엔진 등은 예를 들어, 컴퓨터 프로그램의 기능을 구현하는데 요구되는 처리를 네트워크를 통해 다수의 컴퓨터에 할당할 수 있는 분배된 또는 클라이언트-서버 컴퓨팅 환경에서 통신 네트워크(103)를 통해 예약 시스템(102)에 연결된 다른 컴퓨터 내 하나 이상의 프로세서에서 실행될 수 있다. 예를 들어. 예약 시스템(102) 및/또는 예약 시스템(102)의 모듈에 포함된 것으로 본 명세서에서 설명된 기능 중 일부는 하나 이상의 서버에 구현될 수 있다. 본 발명의 실시예에 따라, 모듈(132-136) 및/또는 다른 모듈/애플리케이션은 예약 시스템(102)의 하나 이상의 서버에서 실행될 수 있고, 모듈(132-136)을 통해 예약 시스템(102)의 프로세서(122)는 본 발명의 실시예에 따른 동작을 수행할 수 있다. Moreover, it should be understood that various applications, components, programs, objects, modules, engines, and the like may be, for example, distributed or client-server computing environments that can allocate processing required to implement the functions of a computer program to multiple computers over a network May be executed on one or more processors in another computer connected to the
여행 및 예약 시스템(102)의 메모리(124)는, 일반적으로, 예를 들어, 이용가능성 및 가격 데이터베이스(138)와 유저 프로파일 데이터베이스(140)를 포함하는 하나 이상의 데이터베이스를 저장할 수 있다. 데이터베이스(138,140)는 데이터를 포함하고 이 데이터를 저장하고 조직하는 데이터 구조를 지원할 수 있다. 구체적으로, 데이터베이스(138,140)는, 관계 데이터베이스, 계층 데이터베이스, 네트워크 데이터베이스 및/또는 이들의 조합을 포함하지만 이들로 제한되지 않는 임의의 데이터베이스 조직 및/또는 구조로 배열될 수 있다. 예약 시스템(102)의 처리 유닛에서 명령으로 실행되는 컴퓨터 소프트웨어 애플리케이션 형태의 데이터베이스 관리 시스템을 사용하여 질문에 응답하여 데이터베이스(138,140)의 레코드에 저장된 정보 또는 데이터에 액세스할 수 있고, 여기서 질문은 운영 시스템(130), 다른 애플리케이션 및/또는 하나 이상의 모듈(132-136)에 의해 동적으로 결정되고 실행될 수 있다. The
이용가능성 및 가격 데이터베이스(138)는 항공편, 철도 티켓 등과 같은 여행 서비스에 대한 여행 상세 항목에 대한 이용가능성 및 가격 정보를 저장할 수 있다. 본 발명의 실시예에 따라, 이용가능성 및 가격 모듈(136)은 저장된 정보를 주기적으로 업데이트하여 트립 계획 모듈(134)이 최신 정보를 액세스할 수 있게 한다. 최신의 이용가능성 및 가격 정보를 유지하는 것에 의해, 본 발명의 실시예는 계획 단계(즉, 여행 그래프 결정, 여행 경로 수립, 개별 요청 가격 책정 등) 동안 각 여행 서비스에 대한 가격 및 이용가능성 정보에 대한 분석 동안 상세 시스템(106)에 질문할 필요 없이 하나 이상의 이용가능성 및 가격 제한된 여행 서비스를 포함할 수 있는 하나 이상의 여행 솔루션을 가격 책정하고 스케줄링할 수 있다. 유저 프로파일 데이터베이스(140)는 하나 이상의 유저 프로파일을 저장할 수 있고, 여기서 각 유저 프로파일은 예약 시스템의 여행 고객(즉, 여행자/유저)에 대응할 수 있다. 일반적으로, 각 유저 프로파일은 여행 고객과 연관된 정보를 저장하는 계정(account)을 생성한 여행 고객에 대응할 수 있다. 예를 들어, 유저 프로파일은 여행 고객에 대한 연락 정보(예를 들어, 이메일 주소, 모바일 전화 번호 등), 여행 고객에 대한 지불 정보, 승객 이름 레코드(passenger name record)에 포함된 정보, 여행자의 선호도 및/또는 다른 정보를 저장할 수 있다. Availability and
이제 도 3을 참조하면, 이 도면은 예약 시스템(102), 트립 계획 모듈(134), 이용가능성 및 가격 모듈(136), 및/또는 이용가능성 및 가격 데이터베이스(138)의 하드웨어 및 소프트웨어 성분을 도시하는 블록도를 제공한다. 일반적으로, 도 3에 도시된 하드웨어 및 소프트웨어 성분은 하나 이상의 분배된 처리 시스템(예를 들어, 서버)에서 구현될 수 있다. 도시된 바와 같이, 하나 이상의 클라이언트 디바이스(104)는 오케스트레이터(orchestrator)(200)와 통신할 수 있다. 일반적으로, 오케스트레이터(200)는 클라이언트 디바이스(104)로부터 여행 요청을 수신하는 동작, 여행 요청에 대한 하나 이상의 여행 그래프를 결정하는 동작, 수신된 여행 요청에 대응하는 여행 경로를 결정/수립하는 동작, 여행 경로 및 여행 요청에 기초하여 서브-요청을 생성하는 동작, 및 서브-요청에 대한 대답(reply)을 수집하여 하나 이상의 여행 솔루션을 결정하는 동작을 수행하도록 구성될 수 있고, 이 하나 이상의 여행 솔루션은 클라이언트 디바이스(104)에 통신될 수 있다. 일반적으로, 하나 이상의 오케스트레이터(200)는 예약 시스템(102)에서 하드웨어 및 소프트웨어로 구현될 수 있고, 여기서 각 오케스트레이터(200)는 수신된 여행 요청을 관리하며 복수의 클라이언트 디바이스(104)로부터 복수의 여행 요청을 동시에 처리할 수 있다. Referring now to FIG. 3, this drawing illustrates the hardware and software components of
각 오케스트레이터(200)는 이용가능성 및 가격 데이터베이스(138)의 복수의 인스턴스(instance)에 연결된 복수의 컴퓨팅 성분(204)을 포함할 수 있는 컴퓨팅 그리드(202)와 통신할 수 있다. 일반적으로, 각 컴퓨팅 성분(204)은 분배된 처리 시스템의 일부(예를 들어, 하이퍼-스레디드(hyper-threaded) 처리 유닛의 처리 스레드, 다중-코어 프로세서의 처리 유닛 등), 또는 다른 알려진 컴퓨팅 디바이스, 예를 들어, 서버, 다중-노드 데이터 처리 시스템의 처리 노드 등을 포함할 수 있다. 각 컴퓨팅 성분(204)은 이용가능성 및 가격 데이터베이스(138)의 인스턴스에 연결되거나 및/또는 일부 컴퓨팅 성분(204)들 사이에 공유될 수 있는 이용가능성 및 가격 데이터베이스(138)의 하나 이상의 인스턴스를 포함하는 처리 클러스터에 연결될 수 있다. 일반적으로, 예약 시스템(102)은, 하나 이상의 처리 유닛 및 하나 이상의 메모리 자원을 포함하는 분배된 처리 시스템이어서 도 2의 이용가능성 및 가격 데이터베이스(138)의 복수의 인스턴스를 예약 시스템(102)에 저장할 수 있어 컴퓨팅 그리드(202)의 컴퓨팅 성분(204)이 이용가능성 및 가격 데이터베이스(138)에 동시에 액세스하는 것이 예약 시스템(102)에 의해 지원될 수 있다. 일반적으로, 컴퓨팅 그리드(202)는 오케스트레이터(200)로부터 서브-요청을 수신하도록 구성될 수 있고, 컴퓨팅 그리드(202)의 컴퓨팅 성분(204)은 이용가능성 및 가격 데이터베이스(138)의 연관된 인스턴스에 질문하는 것에 의해 수신된 서브-요청과 관련된 여행 서비스의 하나 이상의 여행 상세 항목에 대한 가격 및 이용가능성을 결정할 수 있다. Each
컴퓨팅 그리드(202)는 복수의 컴퓨팅 성분(204)으로 구성된 공급 그리드(feed grid)(206)에 연결된다. 전술된 바와 같이, 컴퓨팅 성분(204)은 일반적으로 분배된 처리 시스템의 일부분을 포함한다. 공급 그리드(206)의 컴퓨팅 성분(204)은, 하나 이상의 여행 상인의 하나 이상의 상세 시스템(106)에 질문하여 여행 상인의 여행 서비스의 여행 상세 항목에 대한 최신의 가격 및 이용가능성 데이터를 결정하는 것에 의해 예약 시스템(102)의 이용가능성 및 가격 데이터베이스(138)를 유지하도록 구성될 수 있다. 예를 들어, 공급 그리드(206)의 컴퓨팅 성분(204)은 하나 이상의 여행 상인의 여정(journey) 계획 시스템(208), 스케줄링 시스템(210), 및/또는 가격 및 이용가능성 시스템(212)에 질문하여 여행 상인에 의해 제시(offered)되는 여행 서비스의 여행 상세 항목에 대한 가격 및 이용가능성 관련된 정보를 결정할 수 있다. 공급 그리드(206)는 상세 시스템(106)으로부터 검색된 가격 및 이용가능성 정보에 기초하여 이용가능성 및 가격 데이터베이스(138)에 저장된 이용가능성 및 가격 관련된 정보를 업데이트할 수 있다. 일반적으로, 도 3은 하드웨어 및 소프트웨어 성분의 예시적인 구성을 도시한다. 본 발명에 따른 실시예는, 예를 들어, 하나 이상의 여행 상인에 대해 더 많거나 더 적은 컴퓨팅 성분(204), 이용가능성 및 가격 데이터베이스(138)의 더 많거나 더 적은 인스턴스, 더 많거나 더 적은 오케스트레이터(200), 더 많거나 더 적은 상세 시스템(106) 등을 포함하는 상이한 구성의 하드웨어 및 소프트웨어 성분을 포함할 수 있다. The
도 4는 본 발명의 실시예에 따라 예약 시스템(102)에 의해 수행되어 수신된 여행 요청에 대한 하나 이상의 여행 솔루션을 결정할 수 있는 동작 시퀀스를 도시하는 흐름도(300)를 제공한다. 본 발명의 일부 실시예에 따라, 여행 요청은 복수의 목적지(즉, 다수의-목적지)를 포함할 수 있고, 이들 실시예에서, 각 여행 솔루션은 여행 요청의 각 목적지를 포함할 수 있다. 예시된 바와 같이, 예약 시스템(102)은 여행자와 연관된 여행 요청을 수신할 수 있다(블록 302). 여행 요청은 일반적으로 출발지, 하나 이상의 목적지, 적어도 하나의 시간 제약 및/또는 여행자 선호도를 포함한다. 시간 제약에 대해, 여행 요청은 여행자가 여행하기를 원하는 날짜 범위, 여행자가 특정 위치에 있기를 원하는 날짜, 여행자가 각 위치에서 있기를 원하는 최소/최대 날수 및/또는 다른 시간 제약을 지시할 수 있다. 예를 들어, 여행 요청은, 여행자가 6월달에 여행하기를 원하는 것과, 전체 여행 시간이 2주 이하이어야 하는 것을 지시할 수 있다. 다른 예로서, 여행 요청은 여행자가 적어도 2일 동안 제1 목적지에 있기를 원하는 것을 지시할 수 있다. Figure 4 provides a flowchart 300 illustrating an operational sequence that can be performed by
여행 요청에 기초하여, 예약 시스템(102)은 출발지 및 하나 이상의 목적지를 포함하는 하나 이상의 여행 그래프를 결정할 수 있다(블록 304). 일반적으로, 여행 그래프는, 출발지에서 시작하고 여행 요청의 각 목적지를 거쳐 지나가는 루트(route)에 대응한다. 일부 실시예에서, 여행 요청이 왕복 트립(round trip)에 대한 것이라면, 여행 그래프의 여행 루트는 출발지로 리턴할 수 있다. 나아가, 본 발명의 실시예는 여행 요청의 출발지 및 각 목적지의 여행 특성에 기초하여 여행 요청에 대한 하나 이상의 여행 그래프를 결정할 수 있다. 예를 들어, 지시된 목적지가 저비용 여행 허브(예를 들어, 저비용 항공사가 항공편을 제시하는 공항)인 경우, 예약 시스템은 출발지와 하나 이상의 목적지 사이를 여행하는데 가능한 경우 저비용 항공편 제시를 사용하는 여행 그래프를 결정할 수 있다. 다른 예로서, 여행 요청이 국제 여행을 포함하는 경우(예를 들어, 출발지 및 목적지가 상이한 국가에 위치된 경우), 예약 시스템은 국제 여행을 제한하는 여행 루트를 정하는 여행 그래프를 결정할 수 있다. Based on the travel request, the
하나 이상의 여행 그래프 및 임의의 시간 제약에 기초하여, 예약 시스템(102)은 하나 이상의 대응하는 여행 경로를 수립할 수 있다(즉, 여행 그래프를 분석하고 및 결정할 수 있다)(블록 306). 일반적으로, 여행 경로는 여행 요청을 만족하는 여행 서비스/숙박(예를 들어, 항공편, 철도 교통, 호텔 숙박, 차량 렌탈 등)의 조합에 대응한다. 각 여행 경로를 수립한 후, 예약 시스템(102)은 각 여행 경로에 대한 서브-요청을 생성한다(블록 308). 도 3에 대하여 전술된 바와 같이, 예약 시스템(102)의 오케스트레이터(200)는 처리를 위해 컴퓨팅 그리드(202)에 통신될 수 있는 서브-요청을 생성할 수 있다. 본 발명의 실시예에 따라, 각 여행 경로에 대해, 예약 시스템은 컴퓨팅 그리드에 질문하는데 사용될 수 있는 서브-요청을 생성한다(블록 310). 일반적으로, 각 서브-요청은 여행 경로, 날짜 범위(여행 요청에 제공된 것) 및 임의의 여행자 선호도를 포함한다. 예약 시스템(102)의 컴퓨팅 그리드는 각 수신된 서브-요청에 기초하여 하나 이상의 개별 요청을 생성한다(블록 312). 일반적으로, 각 개별 요청은 여행 요청에 제공된 날짜 범위에서 각 가능한 날짜에 대한 서브-요청의 인스턴스이다. 각 개별 요청은 컴퓨팅 그리드의 컴퓨팅 성분에 의해 처리되어 개별 요청에 대응하는 여행 서비스의 여행 상세 항목에 대한 가격 및 이용가능성 정보를 결정할 수 있고(블록 314), 각 개별 요청에 대한 가격은 대응하는 여행 상세 항목의 가격 및 이용가능성 정보에 기초하여 결정될 수 있다(블록 316). Based on the one or more travel graphs and any time constraints, the
각 개별 요청에 대해 결정된 가격에 기초하여, 예약 시스템은 하나 이상의 여행 솔루션을 결정할 수 있다(블록 318). 일반적으로, 각 가격 책정된 개별 요청은 여행 요청에 대한 후보 여행 솔루션으로 고려될 수 있고, 여기서 각 개별 요청은 여행 요청을 만족하는 여행 서비스에 대한 가격 책정된 여행 상세 항목을 포함한다. 본 발명의 일부 실시예에 따라, 예약 시스템은 가격, 이용가능성, 예약 직원 선호도 및/또는 여행자 선호도에 기초하여 후보 여행 솔루션을 분류(sort)하고 필터링하여 후보 여행 솔루션으로부터 하나 이상의 여행 솔루션을 결정할 수 있다. 예를 들어, 여행자가 지상 여행보다 항공 여행을 선호하는 경우, 시스템은 후보 여행 솔루션을 필터링하여 더 많은 지상 여행을 포함하는 후보 여행 솔루션을 무시할 수 있다. 다른 예로서, 예약 시스템은 최저 비용 옵션을 리턴하도록 구성될 수 있고, 이러한 실시예에서, 예약 시스템은 복수의 후보 여행 솔루션을 필터링하여 복수 개 중에서 최저 비용 여행 솔루션을 여행 요청에 대한 여행 솔루션으로 결정할 수 있다. 여행 솔루션은 예약 시스템(102)으로부터 클라이언트 디바이스로 리턴될 수 있고(블록 320), 유저는 리턴된 여행 솔루션 중 하나의 여행 솔루션을 리뷰하고 부킹할 수 있다. Based on the price determined for each individual request, the reservation system may determine one or more travel solutions (block 318). Generally, each priced individual request can be considered as a candidate travel solution for a travel request, where each individual request includes a pricing trip detail for the travel service that satisfies the travel request. According to some embodiments of the present invention, the reservation system may sort and filter the candidate travel solution based on price, availability, reservation employee preference and / or traveler preference to determine one or more travel solutions from the candidate travel solution have. For example, if a traveler prefers air travel over land travel, the system can filter the candidate travel solution and ignore the candidate travel solution, including more ground travel. As another example, the reservation system may be configured to return the lowest cost option, in which the reservation system filters the plurality of candidate travel solutions to determine the lowest cost travel solution among the plurality of travel solutions as a travel solution for the travel request . The travel solution can be returned from the
이제 도 5a 내지 도 5g를 참조하면, 이들 도면은 여행 요청에 대해 결정될 수 있는 예시적인 여행 그래프를 제공한다. 이 예시적인 여행 그래프에서, 루트는 출발지 위치('A'로 표시)로부터 복수의 목적지 위치(예를 들어, 'B', 'C', ... 'G')를 거쳐 계획된다. 전술된 바와 같이, 여행 그래프는 여행 요청의 출발지 및 하나 이상의 목적지의 여행 특성에 적어도 부분적으로 기초하여 결정될 수 있다. 그리하여, 도 5a 내지 도 5g에 제공된 예시적인 그래프는 본 발명의 일부 실시예에서 사용될 수 있는 (즉, 위치들 사이에 루트를 정하는) 그래프의 유형과 그래프 형상을 반영한다. 더욱이, 그래프 형상은 일반적으로 여행 요청에 포함된 목적지의 수에 기초하여 스케일가능할 수 있다. 도 5a를 참조하면, 이 예시적인 여행 그래프(400)는 원형 그래프 형상을 도시하고 - 여기서 여행 루트는 출발지(402)(즉, 위치 'A')에서 시작하고, 각 목적지(404-414)(즉, 위치 'B', 'C', 'D', 'E', 'F', 'G')를 거쳐 지나간 후 출발지(402)로 리턴한다. 일반적으로, 도 5a의 예시적인 여행 그래프(400)와 같은 원형 그래프는 리턴 요금, 저비용 여행 허브, 대규모 여행 허브 등을 사용하여 획득될 수 있는 임의의 가격/여행 잇점을 고려하지 않는다. Referring now to Figures 5A-5G, these figures provide exemplary travel graphs that can be determined for trip requests. In this exemplary travel graph, the route is planned through a plurality of destination locations (e.g., 'B', 'C', ... 'G') from a source location (indicated by 'A'). As described above, the travel graph can be determined based at least in part on the travel characteristics of the origin of the trip request and one or more destinations. Thus, the exemplary graphs provided in Figures 5A-5G reflect the graph shape and the type of graph that can be used in some embodiments of the present invention (i.e., roots between positions). Moreover, the graph shape may generally be scalable based on the number of destinations included in the travel request. 5A, this
도 5b는 라켓(racket) 그래프 형상을 도시하는 예시적인 여행 그래프(440)를 제공하고 - 여기서 여행 루트는 출발지(442)(즉, 위치 'A')에서 시작하고, 제1 목적지(444)(즉, 위치 'B')로 가고, 각 나머지 목적지(446-454)(즉, 위치 'C', 'D', 'E', 'F', 'G')로 가고 나서, 제1 목적지(444)로 리턴하고, 이어서 리턴 요금 여행 서비스(예를 들어, 왕복 트립 항공편의 리턴 구간)를 통해 제1 목적지(444)(위치 B)로부터 출발지(442)(위치 A)로 리턴한다. 일반적으로, 이 예에서 도시된 그래프의 유형은 국제 여행을 포함하는 여행 요청을 고려할 때 본 발명의 실시예에 따라 사용될 수 있다. 예를 들어, 출발지가 프랑스의 니스(Nice)이고 여행 요청이 미국에 목적지를 포함하는 경우, 제1 목적지는 뉴욕일 수 있다. 나머지 목적지까지 여행은 국내 항공편, 철도 여행, 버스 여행 및/또는 렌탈 차량을 포함할 수 있고, 여행자는 뉴욕으로 리턴하여, 프랑스의 니스와 뉴욕 사이에 왕복 트립 티켓의 리턴 구간을 사용하여 프랑스, 니스로 다시 여행할 수 있다. Figure 5b provides an
도 5c는 "항상 되돌아오는(all the way back) 그래프" 형상을 도시하는 예시적인 여행 그래프(480)를 제공하고 - 여기서 여행 루트는 출발지(482)(즉, 위치 'A')에서 시작하고, 각 목적지(484-494)(위치 'B', 'C', 'D', 'E', 'F', 'G')로 가고, 리턴 요금 여행 서비스를 통해 각 목적지(484-494)로부터 이전의 목적지(484-494)로 다시 되돌아와서 출발지(482)로 리턴한다. 일반적으로, 도 5c에 예로서 도시된 여행 그래프의 형상은 여행 요청과 관련된 것으로 결정될 수 있고, 여기서 리턴 요금 여행 서비스는 하나 이상의 목적지들 사이에 제시될 수 있어서 하나 이상의 목적지로 여행하고 나서 이 목적지로부터 되돌아 여행하는 리턴 여행 구간을 스케줄링할 수 있다. Figure 5c provides an
도 5d는 여행 상인이 긴 도중하차(layover)를 허용하는 경우 사용될 수 있는 그래프 형상을 도시하는 예시적인 그래프를 제공하고 - 여기서 여행 루트는 출발지(522)(위치 'A')에서 시작하고 제1 목적지(524)(위치 'B'), 제2 목적지(526)(위치 'C')로 가서, 이후 출발지(522)로 리턴한다. 이 예에서, 여행 상인의 비지니스 규칙이 여행자가 원하는 시간 기간 동안 제1 목적지(524)에 남을 수 있을 만큼 충분히 긴 도중하차를 허용하는 경우, 여행 그래프의 여행 루트는 제1 목적지(524)에서 도중하차를 가지는 왕복 트립 여행 서비스를 제공할 수 있다. Figure 5d provides an exemplary graph that illustrates a graph shape that can be used when a traveling trader allows long layover - where the travel route begins at origin 522 (location 'A') and the first To the destination 524 (location 'B'), the second destination 526 (location 'C'), and then returns to the
도 5e는 성형(star) 그래프 형상을 도시하는 예시적인 여행 그래프(560)를 제공하고 - 여기서 여행 루트는 출발지(562)(위치 'A')에서 시작해서, 각 목적지(564-574)(위치 'B', 'C', 'D', 'E', 'F', 'G')로 가고, 출발지(562)와 각 목적지(564-574) 사이에 리턴 요금 여행 서비스를 사용하여 여행자가 각 목적지(564-574)에서 이후 출발지(562)로 리턴하고 출발지(562)로부터 각 목적지(564-574)로 출발한다. 일반적으로, 도 5e의 예시적인 여행 그래프(560)와 같은 여행 그래프는 (출발지와 같은) 위치가 저비용 여행 허브, 대규모 여행 허브이고, 및/또는 더 낮은 가격 및/또는 보다 빈번한 여행 서비스를 제시하는 경우 사용될 수 있다. 일반적으로, 본 발명의 실시예는 출발지 및/또는 하나 이상의 목적지의 여행 특성에 기초하여 성형 그래프를 사용할 수 있는 것으로 결정할 수 있다. 이 예에서, 출발지(562)는 저비용 또는 대규모 여행 허브일 수 있고, 출발지(562)를 통해 여행 루트를 정하는 것이 바람직하거나 및/또는 비용 효과적일 수 있다. Figure 5e provides an
도 5f는 확장된 성형 그래프 형상을 도시하는 예시적인 여행 그래프(600)를 제공하고 - 여기서 여행 루트는 출발지(602)(위치 'A')에서 시작해서, 제1 목적지(604)(위치 'B ')로 가서, 이 제1 목적지(604)로부터 각 후속하는 목적지(606-614)(위치 'C', 'D', 'E', 'F', 'G')로 가고, 이후 제1 목적지(604)로 리턴한 후 각 후속하는 목적지(606-614)로 여행한다. 이 그래프 형상에서, 여행 루트는 제1 목적지(604)와 각 후속하는 목적지(606-614) 사이에 리턴 요금 여행 서비스를 사용할 수 있고, 또는 제1 목적지(604)는 저비용 여행 허브, 대규모 여행 허브이거나, 및/또는 더 낮은 가격/더 효율적인 여행 서비스를 제시할 수 있다. 일반적으로, 도 5f의 예시적인 여행 그래프(600)와 같은 여행 그래프 형상은 여행 요청이 대규모 여행 허브, 저비용 여행 허브 등이 아닌 출발지를 포함하는 경우 또는 여행 요청이 출발지로부터 복수의 목적지로 국제 여행을 포함하는 경우, 목적지가 공통 지역 또는 국가에 위치될 수 있는 경우 사용될 수 있다. 예를 들어, 도 5f의 예시적인 여행 그래프(600)를 참조하면, 출발지(602)가 프랑스의 니스인 경우, 제1 목적지(604)는 뉴욕이고, 다른 목적지(606-614)는 미국에 위치되고, 예시적인 여행 그래프는 나머지 목적지로 가는 국내 여행을 위한 허브로 뉴욕을 사용하는 여행 솔루션을 결정할 수 있다. Figure 5f provides an
도 5g는 혼합된 그래프 형상(즉, 도 5a 내지 도 5f에 도시된 그래프 형상의 일부의 조합)을 도시하는 예시적인 여행 그래프(620)를 제공한다. 일반적으로 예시적인 여행 그래프(620)로 도시된 바와 같이, 본 발명의 실시예에 따라, 여행 요청에 대해 결정된 하나 이상의 여행 그래프는 일반적으로 본 명세서에 설명된 여행 그래프의 여러 유형/형상의 조합일 수 있다. 전술된 바와 같이, 여행 요청에 대해 결정된 여행 그래프의 적어도 일부분의 유형/형상은 여행 요청의 출발지 및/또는 하나 이상의 목적지의 여행 특성에 적어도 부분적으로 기초할 수 있다. 도 5g에 도시된 바와 같이, 여행 그래프에 의해 나타낸 여행 루트는 출발지(622)(위치 'A')에서 시작해서, 제1 목적지(624)(위치 'B')를, 복수의 목적지(626-634)(위치 'C', 'D', 'E', 'I', 'J')로 여행하고 이로부터 되돌아 여행하는 허브로 사용하는 확장된 성형 그래프 유형이 포함된다. 제4 목적지(630)(위치 E)에서, 여행 그래프는 제4 목적지(630)(위치 E)에서 시작해서 복수의 목적지(636-640)(위치 'F', 'G', 'H')를 거쳐 지나가서 제4 목적지(630)(위치 E)로 리턴하고, 이후 제1 목적지(624)(위치 B)로 리턴하는 원형 여행 그래프 형상을 포함한다. 그리하여, 예시적인 여행 그래프에 포함된 위치 'E', 'F', 'G' 및 'H'(630, 636-640)를 포함하는 원형 유형 그래프는, 예를 들어, 위치 그룹이 근접해 있고 렌탈 카를 그룹의 각 위치들 사이의 여행을 위해 렌탈할 수 있는 경우 결정된 여행 그래프의 일부로 결정될 수 있다. FIG. 5G provides an
도시된 바와 같이, 여행 루트가 위치 'E', 'F', 'G', 'H'(630, 626-640)에서 원형 그래프 루트 후에 제1 목적지(624)(위치 B)로 리턴하면 루트는 확장된 성형 그래프 부분의 나머지 위치(632, 634)(위치 I, J)로 연속된다. 도시된 바와 같이, 확장된 성형 그래프 부분의 마지막 목적지(634)(위치 J)는, 복수의 위치(644-652)(위치 'L', 'M', 'N', 'O', 'S')로 여행하고 이로부터 되돌아 여행하는 허브로서 10번째 목적지(642)(위치 'K')를 갖는 제2 확장된 성형 그래프 부분에 연결될 수 있다. 나아가, 14번째 목적지(650)(위치 'O')에서 항상 되돌아오는 그래프 형상은 14번째 목적지(위치 'O')에서 시작할 수 있고 루트는 3개의 추가적인 목적지(654-658)(위치 'P', 'Q', 'R')로 가서 리턴 요금 여행 서비스를 사용하여 14번째 목적지(위치 'O')로 리턴할 수 있다. As shown, when the travel route returns to the first destination 624 (location B) after the circular graph route at locations 'E', 'F', 'G', 'H' (630, 626-640) Are continued to the remaining
도 5g에 예로서 도시된 바와 같이, 여행 요청에 대해 결정된 여행 그래프는 여러 유형의 그래프 형상의 조합일 수 있고, 여기서 이러한 조합은 출발지 및 하나 이상의 목적지의 여행 특성에 적어도 부분적으로 기초하여 이루어질 수 있다. 출발지 및 하나 이상의 목적지의 여행 특성은 위치가 저비용 여행 허브인지 여부, 위치가 대규모 여행 허브인지 여부, 위치가 여행 요청의 다른 위치에 대해 국제 여행을 요구하는지 여부, 하나 이상의 다른 위치에 대해 하나 이상의 위치의 근접 정도, 이 위치에서 또는 그 부근에서 여행 서비스를 제공하는 여행 상인, 위치에서 제시되는 여행 서비스의 유형(예를 들어, 공항, 철도역 등의 존재), 및/또는 여행 계획에 고려될 수 있는 다른 특성을 일반적으로 포함한다. As illustrated by way of example in FIG. 5G, the travel graph determined for the travel request can be a combination of several types of graph shapes, where such combinations can be made based at least in part on the departure location and the travel characteristics of one or more destinations . The travel characteristics of the departure location and one or more destinations may include whether the location is a low cost travel hub, whether the location is a large travel hub, whether the location requires international travel for another location of the travel request, one or more locations A travel trader providing travel services at or near the location, a type of travel service offered at the location (e.g., presence of an airport, railway station, etc.), and / Other properties are generally included.
이제 도 6a 내지 도 6m을 참조하면, 이들 도면은 본 발명의 실시예에 따라 여행 요청에 대한 여행 그래프를 결정하는 것을 도시하는 예를 제공한다. 도 6a는 예시적인 여행 요청(700)을 도시하고, 여기서 여행 요청은 출발지(702)(위치 'A') 및 3개의 목적지(704-708)(위치 'B', 'C', 'D')를 포함한다. 예를 위해, 출발지(702)(위치 A)는 국제 공항이고 위치 B 목적지(704)는 위치 C 목적지(706)로 가서 이로부터 오는 여행 서비스에 대한 저비용 허브이다. 도 6b 내지 도 6d에 도시된 바와 같이, 출발지(702)는 국제 공항이므로 (및 출발지와 임의의 목적지(704-708) 사이에 국제 여행이 요구되므로), 출발지(702)로부터 위치 B 목적지(704)(즉, 도 6b의 '서브-그래프 B'(710)), 위치 C 목적지(706)(즉, 도 6c의 '서브-그래프 C'(712)) 및 위치 D 목적지(708)(즉, 도 6d의 '서브-그래프 D'(714))로 가는 왕복 트립 여행이 고려될 수 있다. 각 리턴 트립 가능성은 여행 요청과 관련된 가능한 여행 그래프를 결정할 수 있는 서브-그래프(710-714)로 고려될 수 있다. Referring now to Figures 6A-6M, these Figures provide an example illustrating the determination of a travel graph for a travel request in accordance with an embodiment of the present invention. 6A illustrates an
일반적으로, 하나 이상의 여행 그래프는 각 서브-그래프에 기초하여 결정될 수 있다. 이 예에서, 도 6b 내지 도 6d의 서브-그래프(710-714)에 도시된 바와 같이 출발지(702)와 목적지(704-708) 사이에 3개의 가능한 루트가 이루어질 수 있다. 본 발명의 실시예는 3개의 목적지(704-708) 사이에 루트 가능성을 분석하여 여행 요청에 대한 여행 그래프를 결정할 수 있다. 전술된 바와 같이, 여행 요청에 대한 여행 그래프를 결정할 때 선택되는 루트 가능성은 출발지 및 하나 이상의 목적지의 여행 특성에 적어도 부분적으로 기초할 수 있다. 그리하여, 이 예에서, 위치 B 목적지(704)와 위치 C 목적지(706) 사이에 제시되는 저비용 여행 서비스를 통해 여행 요청에 대한 여행 그래프를 결정할 때를 분석할 하나 이상의 그래프 형상을 선택할 수 있다. In general, one or more travel graphs may be determined based on each sub-graph. In this example, there are three possible routes between the
도 6e 내지 도 6m은 본 발명의 실시예에 따라 시스템에 의해 수행되어 위치 B 목적지(704)(즉, 도 6b에 도시된 서브-그래프 B(710))에서 시작하는 서브-그래프의 분석에 적어도 부분적으로 기초하여 여행 그래프를 결정하는 예시적인 분석을 도시한다. 이제 도 6e를 참조하면, 설명된 바와 같이, 저비용 여행 서비스는 위치 B와 위치 C 사이에 제시되고, 그리하여 저비용 여행 서비스로 고려되는 그래프 형상이 도 6e의 서브-그래프('서브-그래프 B-C-B'(716)로 표시)에 도시된 바와 같이 위치 B(704)와 위치 C(706) 사이에 구현될 수 있다. 유사하게, 도 6f는 다른 서브-그래프('서브-그래프 B-C-X-C-B'로 표시)(718)를 반영하고, 여기서 위치 C(706)로 가는 루트를 정한 후, 루트는 다른 그래프 형상/목적지(이 예에서 'X'로 표시)(730)에 더 연결된 후 리턴 요금 여행 서비스를 통해 위치 B(704)로 리턴될 수 있다. 도 6g는 위치 B 목적지(704)로부터 위치 D 목적지(708)로 가는 루트를 더 포함하는, 출발지(702)로부터 위치 B 목적지(704)(즉, 도 6b의 서브-그래프 B(710))로 가는 여행/리턴 루트에 기초하여 서브-그래프('서브-그래프 B-D'로 표시)(740)의 도시된 예를 제공한다. 이 예에서, 위치 B 목적지(704) 및 위치 D 목적지(708)에 대한 여행 특성은 저비용 여행 서비스 또는 리턴 요금 여행 서비스가 이들 사이에 이용가능하지 않는 것을 지시한다. 그리하여, 위치 B 목적지(704)와 위치 D 목적지(708) 사이에 루트는 간단한 일방향 연결이다. Figures 6E-6M illustrate an example of a sub-graph that is performed by the system in accordance with an embodiment of the present invention to analyze at least the sub-graph starting at location B destination 704 (i.e. sub-graph
도 6e 내지 도 6g에 도시된 예시적인 서브-그래프(716, 718, 740)는 예약 시스템(102)에 의해 더 분석되어 목적지(704-708)의 여행 특성에 기초하여 목적지들(704-708) 사이에 가능한 루트를 결정할 수 있다. 도 6h는 도 6e의 서브-그래프 B-C-B(716)에 기초하여 가능한 루트를 더 분석하는 예시적인 서브-그래프('서브-그래프 B-C-B-D'로 표시)(750)를 제공한다. 전술된 바와 같이, 위치 B(704) 및 위치 D(708)의 여행 특성은 이들 사이에 임의의 유리한 루트(즉, 저비용 여행 서비스, 리턴 요금 여행 서비스 등)를 지시하지 않아서, 그리하여, 위치 B(704)로부터 위치 D(708)로 간단한 연결이 포함된다. 도 6i는 도 6g의 서브-그래프 B-D(740)에 기초하는 예시적인 서브-그래프('서브-그래프 B-D-C'로 표시)(752)를 제공한다. 서브-그래프 B-D-C(752)에서, 위치 C(706) 및 위치 D(708)의 여행 특성은 이들 사이에 임의의 유리한 여행 서비스(예를 들어, 저비용 여행 서비스, 대규모 허브 여행 서비스, 리턴 요금 여행 서비스 등)를 전혀 지시하지 않으므로, 서브-그래프 B-D-C(752)는 위치 D(708)와 위치 C(706) 사이에 간단한 연결을 포함한다. 도 6j는 도 6f의 서브-그래프 B-C-X-C-B(718)에 기초한 예시적인 서브-그래프(754)('서브-그래프 B-C-D-C-B'로 표시)를 제공한다. 이 서브-그래프(754)에서, 도 6f의 서브-그래프(718)로부터 연결될 필요가 있는 유일한 나머지 위치는 위치 D(708)이다. 나아가, 서브-그래프(754)는 위치 C(706)와 위치 B(704) 사이에 저비용 여행 서비스로 인해 위치 D(708)로부터 위치 C(706)로 가는 리턴 루트를 포함한다. The
일반적으로, 각 목적지로 가는 루트를 정하는 서브-그래프가 수립되었다면, 본 발명의 실시예는 가상 시작점으로 다시 가는 루트를 정하는 서브-그래프를 수립할 수 있다(즉, 도 6b의 서브-그래프 B에 기초한 서브-그래프에 대해, 연결이 위치 B(704)로 가는 루트를 정하지 않는 임의의 서브-그래프에서 구현된다). 예를 들어, 도 6k를 참조하면, 이 도면은 도 6h의 서브-그래프 B-C-B-D(750)에 기초한 예시적인 서브-그래프(756)('서브-그래프 B-C-B-D-B'로 표시)를 제공한다. 도시된 바와 같이, 리턴 연결은 위치 D(708)로부터 위치 B(704)로 구현되어 서브-그래프(756)는 모든 다른 목적지(706, 708)로 여행한 후 위치 B(704)로 리턴하는 루트를 포함하여 리턴 요금 여행 서비스를 위치 B(704)와 출발지(702)(즉, 위치 A) 사이에서 사용할 수 있다. 유사하게, 도 6l은 도 6i의 서브-그래프 B-D-C(752)에 기초한 예시적인 서브-그래프(758)를 제공한다. 도시된 바와 같이, 리턴 연결은 위치 C(706)로부터 위치 B(704)로 가는 것으로 구현되고 서브-그래프(758)는 모든 다른 목적지(706, 708)로 여행한 후 위치 B(704)로 리턴하는 루트를 포함하여 리턴 요금 여행 서비스를 위치 B(704)와 출발지(702)(즉, 위치 A) 사이에서 사용할 수 있다. In general, if a sub-graph defining the route to each destination has been established, embodiments of the present invention may establish a sub-graph that determines the route to the virtual starting point again (i.e., sub-graph B of FIG. 6B Graph, a connection is implemented in any sub-graph that does not route to location B 704). For example, referring to FIG. 6K, this figure provides an exemplary sub-graph 756 (shown as sub-graph B-C-B-D-B) based on
마지막으로, 본 발명의 실시예는 표준 서브-그래프를 결정할 수 있고, 여기서 이 표준 서브-그래프는 각 목적지(704-708)를 거쳐 가는 루트에서 원형 그래프 형상을 포함할 수 있다. 도 6m은 본 발명의 실시예에 의해 결정될 수 있는 표준 서브-그래프(760)('B-C-D-C'로 표시)를 제공한다. 게다가, 도 6l에 도시된 바와 같이 동일한 서브-그래프인 다른 표준 서브-그래프가 생성될 수 있다. 본 발명의 일부 실시예에 따라, 여행 특성 및 상이한 그래프 형상의 위치들 사이에 각 가능한 루트를 분석할 때 동일한 루트를 구비하는 일부 서브-그래프를 결정할 수 있다. 이러한 중복 서브-그래프는 폐기될 수 있다. 그리하여, 이 예를 위해 결정된 서브-그래프와 관련하여, 도 6b의 서브-그래프 B(710)에 대해, 다음 여행 그래프를 결정할 수 있고, 여기서 문자는 위치를 지시하고 그 순서는 여행 루트, 즉 (도 6m의 서브-그래프(760)에 기초하여) A-B-C-D-B-A; (도 6l의 서브-그래프(758)에 기초하여) A-B-D-C-B-A; (도 6k의 서브-그래프(756)에 기초하여) A-B-C-B-D-B-A; 및 (도 6j의 서브-그래프(754)에 기초하여) A-B-C-D-C-B-A를 지시한다. 도 6c의 서브-그래프 C 및 도 6d의 서브-그래프 D를 분석하여 유사한 여행 그래프를 결정할 수 있다. 나아가, (출발지로 가고 이로부터 되돌아오는 여행은 국제 여행일 수 있으므로) 도 5b의 라켓 그래프 형상에 기초하여 여행 그래프를 결정할 수 있다. 본 발명의 실시예는 원형 그래프 형상, 즉 A-B-C-D-A; A-B-D-C-A; A-C-B-D-A; A-C-D-B-A; A-D-B-C-A; 및 A-D-C-B-A를 사용하여 다음 여행 그래프(즉, 표준 그래프)를 결정할 수 있다. 일반적으로, 여행 특성 및/또는 유저 선호도가 2개 이상의 목적지들 사이에 차량 여행(즉, 렌탈 카 여행 서비스)을 허용하는 경우 이 표준 여행 그래프를 결정할 수 있다. Finally, embodiments of the present invention may determine a standard sub-graph, where the standard sub-graph may include a circular graph shape at the route going through each destination 704-708. Figure 6m provides a standard sub-graph 760 (denoted as 'B-C-D-C') that may be determined by embodiments of the present invention. In addition, other standard sub-graphs that are the same sub-graph as shown in Figure 61 may be generated. In accordance with some embodiments of the present invention, some sub-graphs having the same route can be determined when analyzing each possible route between traveled features and locations of different graph shapes. This redundant sub-graph can be discarded. Thus, with respect to the sub-graph determined for this example, for
도 6a 내지 도 6m에 제공된 예는 여행 요청의 출발지 및 하나 이상의 목적지에 기초하여 여행 그래프를 결정하는 것을 도시하지만, 본 발명의 일부 실시예는 일반적으로 위치 위치로 가는 여행/위치로부터 되돌아오는 여행과 연관된 그래프의 적어도 일부를 저장할 수 있다. 예를 들어, 본 발명의 일부 실시예에서, 여행 그래프를 결정할 때 뉴욕, 시카고 및 보스톤 사이에 루트를 포함하는 여행 그래프의 일부를 예약 시스템(102)의 오케스트레이터에 의해 저장하고 액세스할 수 있어서, 뉴욕, 시카고 및 보스톤을 포함하는 여행 요청이 수신된 경우, 예약 시스템(102)은 미리 컴퓨팅된 부분을 사용하여 여행 그래프를 결정할 수 있다. Although the examples provided in Figures 6A through 6M illustrate determining a travel graph based on the origin of a trip request and one or more destinations, some embodiments of the present invention generally include a trip back from a trip / location to a location location, And may store at least a portion of the associated graph. For example, in some embodiments of the present invention, some of the travel graphs including routes between New York, Chicago, and Boston may be stored and accessed by the orchestrator of
예로서 도시된 바와 같이, 본 발명의 실시예에 따라, 오케스트레이터(200)를 구현하는 예약 시스템(102)은 그래프 형상에 기초한 여행 그래프(예를 들어, 도 5a 내지 도 5g에 제공된 것 또는 예약 시스템에서 한정된 다른 것) 및/또는 수신된 여행 요청에 포함된 출발지 및 하나 이상의 목적지의 여행 특성을 결정할 수 있다. 결정된 여행 그래프에 기초하여, 예약 시스템(102)의 오케스트레이터(200)는 하나 이상의 여행 경로를 수립할 수 있고, 이 여행 경로를 사용하여 예약 시스템(102)의 컴퓨팅 그리드의 컴퓨팅 성분에 의해 처리될 하나 이상의 서브-요청을 여행 경로에 기초하여 생성할 수 있다. 컴퓨팅 그리드는 각 서브-요청을 분석하고, 여행 요청의 여행 그래프 및 임의의 시간 제약에 기초하여 개별 요청을 연산할 수 있고, 각 개별 요청은 컴퓨팅 그리드의 컴퓨팅 성분에 의해 가격 책정될 수 있다. As illustrated by way of example, and in accordance with an embodiment of the present invention, a
이제 도 7a 내지 도 7d를 참조하면, 이들 도면은 호텔 및 차량 렌탈 옵션을 여행 그래프로 구현하는 예시적인 도시를 제공한다. 이 예에서, 상대적인 날짜 및 최소 및 최대 체류 시간 제약을 포함시켜 여행 그래프를 사용하여 여행 경로를 결정할 수 있다. 도 7a는 출발지(802)(위치 'A') 및 3개의 목적지(804-808)(위치 'B', 'C', 'D')를 포함하는 예시적인 여행 그래프(800)를 제공한다. 이 예에서, 최소 체류 및 최대 체류(809)를 위한 시간 제약(즉, 최소 2일 체류 및 최대 3일 체류)은 위치 B 목적지(804)와 연관된다. 이 예에서, 항공편(810-818)(각각 'F1', 'F2', 'F3', 'F4', 'F5'로 표시)은 출발지(802)로부터 위치 B 목적지로 제시될 수 있다. 각 항공편(810-818)은 서비스 날짜 및 가격을 포함하고: 'F1(1, 10)'은 항공편 F1(810)이 10의 비용으로 날짜 1에 제시되는 것을 지시하고; 'F2(2, 15)'는 항공편 F2(812)이 15의 비용으로 날짜 2에 제시되는 것을 지시하고; 'F3(3, 10)'은 항공편 F3(814)이 10의 비용으로 날짜 3에 제시되는 것을 지시하고; 'F4(4, 13)'는 항공편 F4(816)이 13의 비용으로 날짜 4에 제시되는 것을 지시하고; 및 'F5(5, 19)'는 항공편 F5(818)이 19의 비용으로 날짜 5에 제시되는 것을 지시한다. Referring now to Figures 7A-7D, these figures provide an exemplary illustration of a hotel and vehicle rental option implemented as a travel graph. In this example, the travel path can be determined using the travel graph including the relative date and the minimum and maximum residence time constraints. Figure 7A provides an
나아가, 이 예는 위치 B 목적지(804)에서 호텔 숙박이 요구되는 것을 지시한다. 그리하여, 출발지(802)로부터 위치 B 목적지(804)로 가는 항공편의 출발 날짜 및 체류 길이(최소 및 최대 체류(809)를 기억하며)에 기초하여, 상이한 가격 및 이용가능성을 고려할 수 있다. 이 예에서, 호텔 숙박(820-836)(각각 'H6', 'H7', 'H8', 'H9', 'H1O', 'H11', 'H12', 'H13' 및 'H14'로 표시)은 위치 B 목적지(804)에서 제공될 수 있다. 각 호텔 숙박(820-836)은 서비스 날짜 및 가격을 포함하고: 'H6(1/2, 20)'은 호텔 숙박이 20의 가격으로 날짜 1의 밤부터 날짜 2의 아침까지인 것을 지시하고; 'H7(2/3, 25)'은 호텔 숙박이 25의 가격으로 날짜 2의 밤부터 날짜 3의 아침까지인 것을 지시하고; 'H8(3/4, 27)'은 호텔 숙박이 27의 가격으로 날짜 3의 밤부터 날짜 4의 아침까지인 것을 지시하고; 'H9(4/5, 21)'는 호텔 숙박이 21의 가격으로 날짜 4의 밤부터 날짜 5의 아침까지인 것을 지시하고; 'H10(5/6, 20)'은 호텔 숙박이 20의 가격으로 날짜 5의 밤부터 날짜 6의 아침까지인 것을 지시하고; 'H11(2/3, 25)'은 25의 가격으로 호텔 숙박이 날짜 2의 밤부터 날짜 3의 아침까지 인것을 지시하고; 'H12(3/4, 27)'는 호텔 숙박이 27의 가격으로 날짜 3의 밤부터 날짜 4의 아침까지인 것을 지시하고; 'H13(4/5, 21)'은 호텔 숙박이 21의 가격으로 날짜 4의 밤부터 날짜 5의 아침까지인 것을 지시하고; 및 'H14(5/6, 20)'는 호텔 숙박이 20의 가격으로 날짜 5의 밤부터 날짜 6의 아침까지인 것을 지시한다. Further, this example indicates that hotel accommodation is required at
출발지(802)로부터 위치 B 목적지(804)로 가는 여행 날짜 및 호텔 숙박에 기초하여, 경로는 상이한 항공편(850-858)(각각 'F15', 'F16', 'F17', 'F18' 및 'F19'로 표시)을 포함할 수 있다. 위치 B 목적지(804)와 위치 C 목적지(806) 사이의 각 항공편(850-858)은 서비스 날짜 및 가격을 포함하는데: 'F15(2, 30)'는 항공편 F15(850)이 30의 비용으로 날짜 2에 제시되는 것을 지시하고; 'F16(3, 31)'은 항공편 F16(852)이 31의 비용으로 날짜 3에 제시되는 것을 지시하고; 'F17(4, 39)'은 항공편 F17(854)이 39의 비용으로 날짜 4에 제시되는 것을 지시하고; 'F18(5, 33)'은 항공편 F18(856)이 33의 비용으로 날짜 5에 제시되는 것을 지시하고; 및 'F19(6, 36)'는 항공편 F19(858)이 36의 비용으로 날짜 6에 제시되는 것을 지시한다. F15 ',' F16 ',' F18 ', and' F18 ', respectively, based on the travel dates and hotel stays from
도 7b는 (대시 라인으로 도시된) 결정된 여행 경로(900)를 갖는 도 7a의 여행 그래프(800)를 도시한다. 이 예에서, 여행 경로는 항공편 F3(814), 호텔 숙박 H8(824) 및 H13(834) 및 항공편 F18(856)을 포함한다. 여행 경로(900)의 각 선택된 여행 서비스에 포함된 값에 기초하여, 비용은 (F3 + H8 + H13 + F18) = 10 + 27 + 21 + 33 = 91로 계산될 수 있다. 유사하게, 도 7c는 (대시 라인으로 도시된) 결정된 경로(910)를 갖는 도 7a의 여행 그래프(800)를 도시한다. 이 예에서, 여행 경로는 항공편 F3(814), 호텔 숙박 H8(824), H13(834), H14(836) 및 항공편 F19(858)를 포함한다. 여행 경로(910)의 각 선택된 여행 서비스에 포함된 비용 값에 기초하여, 비용은 (F3 + H8 + H13 + H14 + F19) =10 + 27 + 21 + 20 + 36 = 114로 계산될 수 있다. 도 7d는 호텔 숙박이 요구되지 않아서 호텔 숙박 비용이 0으로 조절된 도 7a의 여행 그래프(800)를 도시한다. FIG. 7B shows the
도 7a 내지 도 7d에 제공된 예에 도시된 바와 같이, 여행 경로는 여행 요청의 여행 그래프 및 하나 이상의 시간 제약에 적어도 부분적으로 기초하여 결정될 수 있다. 일반적으로, 여행 경로는 여행 요청을 만족하지만 특정 날짜를 반드시 고려해야 하는 것은 아니지만 일반적으로 여행 서비스가 적절히 스케줄링될 수 있는 상대적인 날짜를 포함하는 여행 서비스의 조합이다. 도 8a 내지 도 8b는 여행 요청에 대한 여행 그래프에 기초하여 결정될 수 있는 예시적인 여행 경로를 제공한다. 도 8a는 출발지(위치 'A')(952), 제1 목적지(위치 'B')(954) 및 제2 목적지(위치 'C')(956)를 포함하는 여행 요청에 대해 결정될 수 있는 여행 경로(950)를 도시한다. 도시된 바와 같이, 최소 체류 및 최대 체류 시간 제약(958)은 위치 B 목적지(954)와 연관된다. 여행 경로(950)는 항공편 'F'이 출발지(952)로부터 위치 B 목적지(954)로 날짜 'D'에 일어나는 것을 지시하는 항공편 'F(D)'(960)을 포함한다. 위치 B 목적지(954)에 대한 최소 체류 요구조건(958)에 기초하여, 여행 경로는 2일의 호텔 숙박, 즉 날짜 'D'에 호텔 체류 'H'를 위한 'H(D)'(962); 및 날짜 'D+1'에 호텔 체류를 위한 'H(D+1)'(964)를 포함한다. 여행 경로는 제1 호텔 숙박 H(D)(962)으로 인해 날짜 D에 'B(D)'(966)에서 위치 B 목적지(954)에 남아 있고, 여행 경로는 제2 호텔 숙박 H(D+1)(964)로 인해 'B(D+1)'(968)에 위치 B 목적지(954)에 남아 있다. 위치 B 목적지(즉, B(D+1)(968))에서 둘째 날 밤 체류 후, 항공편 'F(D+2)'(970)은 위치 B 목적지(954)와 위치 C 목적지(956) 사이에 여행하기 위해 날짜 D+2에 구현된다. 도 8a에 도시된 여행 경로(950)는 A-B-B1-C로 기술될 수 있다. As shown in the example provided in Figures 7A-7D, the travel path can be determined based at least in part on the travel graph of the travel request and one or more time constraints. In general, a travel route satisfies a travel request but does not necessarily consider a specific date, but is generally a combination of travel services that includes a relative date on which the travel service can be scheduled appropriately. Figures 8A-8B provide exemplary travel paths that can be determined based on a travel graph for a travel request. Figure 8A illustrates a trip that can be determined for a travel request that includes a departure location (location 'A') 952, a first destination (location 'B') 954 and a second destination (location 'C') 956
도 8b는 동일한 최소 체류 및 최대 체류 시간 제약(958)을 포함하는 출발지(952), 위치 B 목적지(954) 및 위치 C 목적지(956)를 포함하는 여행 요청에 대해 결정될 수 있는 여행 경로(1000)를 도시한다. 도 8a의 여행 경로(950)에 비해, 이 여행 경로(1000)는 호텔 숙박 'H(D+2)'(1004)로 인해 위치 B 목적지(954)(즉, 'B(D+2)'(1002))에서 추가적인 체류를 포함한다. 위치 B 목적지(954)에서 추가적인 체류로 인해, 여행 경로(1000)는 위치 B 목적지(954)로부터 위치 C 목적지(956)로 가는 항공편 'F(D+3)'(1006)을 포함한다. 도 8b에 도시된 여행 경로(1000)는 A-B-B1-B2-C로 기술될 수 있다. Figure 8b illustrates a
도 9a 내지 도 9d는 본 발명의 일부 실시예에 따라 예약 시스템(102)에 의해 수행되어 클라이언트 디바이스(104)로부터 수신된 여행 요청에 대해 하나 이상의 여행 솔루션을 결정할 수 있는 동작을 도시하는 예시적인 순서도(1100)를 제공한다. 이 예에서, 예약 시스템(102)은 위치 A의 출발지; 위치 B 및 C의 목적지; 위치 B에서 2일 및 위치 C에서 1일의 최소 체류 요구조건; 위치 B에서 3일 및 위치 C에서 1일의 최대 체류 요구조건; 9월 1일의 시작 날짜; 및 9월 10일의 종료 날짜를 지시하는 여행 요청(1102)을 수신할 수 있다. 예약 시스템(102)의 오케스트레이터(200)는 여행 요청에 대한 하나 이상의 여행 그래프를 결정할 수 있다(블록 1104). 이 예에서, 여행 그래프는 A-B-C; A-C-B; A-B-A-C-A; 및 A-B-C-B-A를 포함한다. 결정된 여행 그래프에 기초하여, 오케스트레이터(200)는 하나 이상의 여행 경로를 수립할 수 있다(블록 1106). 이 예에서, 여행 경로는 A-B-B1-C-A, A-B-B1-B2-C-A, A-C-B-B1-A, A-C-B-B1-B2-A, A-B-B1-A-C-A, A-B-B1-A-C-A, A-B-B1-B2-A-C-A, A-B-C-B-A, A-B-B1-C-B-A, A-B-C-B-B1-A를 포함한다. 예로서 도시된 바와 같이, 여행 요청에 대해 수립된 일부 여행 경로는 특정 위치에서 비-연속적인 체류를 포함할 수 있다. 예를 들어, 여행 경로 A-B-B1-C-B-A는 위치 B 목적지에서 2일밤을 포함하고, 이후 위치 C 목적지로 여행하고 나서, 추가적인 1박을 위해 B 목적지로 리턴한다. 9A-9D illustrate an exemplary flow diagram illustrating an operation that may be performed by
여행 경로에 기초하여, 오케스트레이터(200)는 처리를 위해 컴퓨팅 그리드(202)에 통신될 수 있는 각 여행 경로에 대한 적어도 하나의 서브-요청을 결정한다(블록 1108). 예를 들어, 오케스트레이터는 'SR1(A-B-B1-C-A, 9월 1일 → 10일)인 여행 경로 A-B-B1-C-A에 대한 서브-요청, 'SR2(A-B-B1-B2-C-A, 9월 1일 → 10일)인 여행 경로 A-B-B1-B2-C-A에 대한 서브-요청 등을 결정할 수 있다. 컴퓨팅 그리드(202)는 각 서브-요청을 수신하고 및 각 수신된 서브-요청에 대해 하나 이상의 개별 요청을 결정할 수 있다(블록 1110). 예를 들어, SR1 서브-요청에 대해, 컴퓨팅 그리드(202)는 개별 요청: 'IR1(SR1, 시작: 9월 1일)', 'IR2 (SR1, 시작 9월 2일)', 'IR3 (SR1, 시작 9월 3일)', 'IR4 (SR1, 시작 9월 4일)' 및 'IR5 (SR1, 시작 9월 5일)'을 결정할 수 있다. 일반적으로, 개별 서브-요청은 서브-요청의 각 가능한 시작 날짜에 대해 결정될 수 있다. 개별 요청은 다른 수신된 서브-요청에 대해 유사하게 결정될 수 있다. 컴퓨팅 그리드(202)는 개별 요청(1112)을 갖는 이용가능성 및 가격 데이터베이스(138)에 질문할 수 있고, 컴퓨팅 그리드(202)는 각 개별 요청에 대한 가격을 결정하고(블록 1114) 및 이 가격(1116)을 개별 요청을 발신한 컴퓨팅 그리드(202)의 컴퓨팅 성분으로 리턴할 수 있다. 후보 여행 솔루션이라고 언급될 수 있는 가격 책정된 개별 요청(1118)은 오케스트레이터(200)로 리턴될 수 있다. 오케스트레이터는 가격(예를 들어, 최소 가격 정렬), 여행자 선호도(예를 들어, 여행자의 선호도에 기초하여 정렬 및/또는 필터링), 비지니스 규칙(예를 들어, 여행 유형, 특정 여행 상인의 선호 등), 및/또는 시스템이 후보 여행 솔루션을 동적으로 정렬 및/또는 필터링하여 여행 요청에 대응하는 여행 솔루션을 결정하도록 구현될 수 있는 다른 유형의 규칙에 적어도 부분적으로 기초하여 수신된 후보 여행 솔루션을 정렬 및/또는 필터링할 수 있다(블록 1120). 후보 여행 솔루션을 정렬 및/또는 필터링하고 여행 요청을 위한 여행 솔루션을 결정한 후, 예약 시스템(102)은 응답(1122)을 클라이언트 디바이스(104)에 통신할 수 있다. Based on the travel path, the
도 10은 예약 시스템(102)에 의해 생성되고 클라이언트 디바이스(104)에 의해 액세스될 수 있는 그래픽 유저 인터페이스(1200)의 예시적인 도시를 제공하며, 유저(예를 들어, 여행자, 여행사 직원 등)는 이 그래픽 유저 인터페이스(1200)를 통해 정보를 입력할 수 있다. 일반적으로, 클라이언트 디바이스(104)는 예약 서버(102)가 그래픽 유저 인터페이스(1200)를 제공하는 인터넷 주소로 네비게이션하는 것에 의해 통신 네트워크(103)를 통해 그래픽 유저 인터페이스(1200)에 액세스할 수 있다. 다른 예로서, 그래픽 유저 인터페이스(1200)는 여행사를 위한 예약 시스템과 클라이언트 디바이스(104) 사이에 전용 인터페이스일 수 있다. 도시된 바와 같이, 그래픽 유저 인터페이스(1200)를 통해 유저는 출발지 위치(1202), 하나 이상의 목적지(1204), 각 목적지(1206)에서 최소 체류 시간 제약, 각 목적지(1208)에서 최대 체류 시간 제약, 호텔 숙박이 각 목적지(1210)에서 요구되는지 여부, 차량 렌탈이 각 목적지(1212)에서 요구되는지 여부, 여행자가 특정 목적지(1214)에 있기를 원하는 임의의 특정 날짜, 여행이 완료되어야 하는 날짜 범위(1216), 선호되는 교통 모드(1218), 여행을 위한 최대 지속시간(1220), 여행자에 관한 정보(1222), 및/또는 본 발명의 실시예에 따라 하나 이상의 여행 솔루션을 결정하는데 사용될 수 있는 다른 정보를 지시하는 데이터를 입력할 수 있다. 그래픽 유저 인터페이스(1200)를 통해 관련 정보를 입력한 후, 유저는 정보를 제출하여 입력 정보에 적어도 부분적으로 기초하여 여행 요청을 생성할 수 있다. 10 provides an exemplary illustration of a
일반적으로, 운영 시스템 또는 특정 애플리케이션, 성분, 프로그램, 객체, 모듈 또는 명령 시퀀스의 일부, 또는 심지어 서브세트로 구현되었든지 여부에 상관없이, 본 발명의 실시예를 구현하도록 실행되는 루틴은 본 명세서에서 "컴퓨터 프로그램 코드" 또는 간단히 "프로그램 코드"라고 언급된다. 프로그램 코드는 일반적으로 컴퓨터 내 여러 메모리 및 저장 디바이스에서 여러 곳에 상주하는 하나 이상의 명령을 포함하고, 상기 명령은, 컴퓨터 내 하나 이상의 프로세서에 의해 판독되어 실행될 때, 이 컴퓨터로 하여금 본 발명의 여러 측면을 구현하는 단계 또는 요소를 실행하는데 필요한 단계를 수행한다. 더욱이, 본 발명은 완전히 기능적인 컴퓨터 및 컴퓨터 시스템의 상황에서 설명되었으나, 이 기술 분야에 통상의 지식을 가진 자라면 본 발명의 여러 실시예가 여러 형태의 프로그램 제품으로 분배될 수 있고 본 발명은 실제로 분배를 수행하는데 사용되는 컴퓨터 판독가능한 매체의 특정 유형에 상관없이 동등하게 적용될 수 있다는 것을 이해할 수 있을 것이다.In general, routines executed to implement embodiments of the present invention, whether implemented as an operating system or a particular application, component, program, object, module, or portion of a command sequence, or even a subset, Quot; computer program code "or simply" program code ". The program code typically includes one or more instructions resident in various memory and storage devices in a computer, and the instructions, when read and executed by one or more processors in the computer, cause the computer to perform various aspects of the invention Perform the steps necessary to implement the step or element to implement. Moreover, while the present invention has been described in the context of fully functional computer and computer systems, those of ordinary skill in the art will recognize that many embodiments of the present invention may be distributed in various types of program products, It will be appreciated that the invention is equally applicable regardless of the particular type of computer readable medium used to carry out the invention.
본 명세서에 설명된 애플리케이션/모듈 중 어느 것으로 구현된 프로그램 코드는 여러 상이한 형태의 프로그램 제품으로 개별적으로 또는 집합적으로 분배될 수 있다. 특히, 프로그램 코드는 컴퓨터 판독가능한 저장 매체를 포함할 수 있는 컴퓨터 판독가능한 매체 및 통신 매체를 사용하여 분배될 수 있다. 본질적으로 비-일시적인 것인 컴퓨터 판독가능한 저장 매체는, 컴퓨터-판독가능한 명령, 데이터 구조, 프로그램 모듈, 또는 다른 데이터와 같은 정보를 저장하기 위해 임의의 방법 또는 기술로 구현된 휘발성 및 비-휘발성, 및 이동식 및 비-이동식 유형적인 매체를 포함할 수 있다. 컴퓨터 판독가능한 저장 매체는 RAM, ROM, 소거가능한 프로그래밍가능한 판독 전용 메모리(EPROM), 전기적으로 소거가능한 프로그래밍가능한 판독 전용 메모리(EEPROM), 플래쉬 메모리 또는 다른 솔리드 스테이트 메모리 기술, 휴대용 콤팩트 디스크 판독 전용 메모리(CD-ROM), 또는 다른 광 저장매체, 자기 카세트, 자기 테이프, 자기 디스크 저장매체 또는 다른 자기 저장 디바이스, 또는 컴퓨터에 의해 판독될 수 있고 원하는 정보를 저장하는데 사용될 수 있는 임의의 다른 매체를 더 포함할 수 있다. 통신 매체는 컴퓨터 판독가능한 명령, 데이터 구조 또는 다른 프로그램 모듈을 구현할 수 있다. 예로서, 비제한적으로, 통신 매체는 유선 매체, 예를 들어 유선 네트워크 또는 직접-유선 연결, 및 무선 매체, 예를 들어 음향, RF, 적외선 및 다른 무선 매체를 포함할 수 있다. 상기한 바의 임의의 조합도 컴퓨터 판독가능한 매체의 범위 내에 포함될 수 있다.Program codes embodied in any of the applications / modules described herein may be distributed individually or collectively to a number of different types of program products. In particular, the program code may be distributed using a computer-readable medium and a communication medium, which may include a computer-readable storage medium. A computer-readable storage medium, which is essentially non-volatile, includes volatile and nonvolatile, nonvolatile, nonvolatile, nonvolatile, nonvolatile, nonvolatile, nonvolatile, And removable and non-removable tangible media. The computer readable storage medium may be any of a variety of storage devices including but not limited to RAM, ROM, erasable programmable read only memory (EPROM), electrically erasable programmable read only memory (EEPROM), flash memory or other solid state memory technology, CD-ROM), or other optical storage media, magnetic cassettes, magnetic tape, magnetic disk storage media or other magnetic storage devices, or any other medium that can be read by a computer and used to store the desired information can do. The communication medium may embody computer readable instructions, data structures, or other program modules. By way of example, and not limitation, communication media may include wired media, e.g., wired networks or direct-wired connections, and wireless media such as acoustic, RF, infrared and other wireless media. Any combination of the above may also be included within the scope of computer readable media.
컴퓨터, 다른 유형의 프로그래밍가능한 데이터 처리 장치 또는 다른 디바이스를 특정 방식으로 기능시킬 수 있는 컴퓨터 프로그램 명령이 컴퓨터 판독가능한 매체에 저장되어, 컴퓨터 판독가능한 매체에 저장된 명령을 통해 흐름도 및/또는 블록도의 블록 또는 블록들에 지정된 기능/동작을 구현하는 명령을 포함하는 제조 물품을 생성할 수 있다. Computer program instructions that may be stored on a computer-readable medium, such as a computer, a processor, or other type of programmable data processing apparatus or other device capable of functioning in a particular manner may be stored on a computer readable medium, Or < / RTI > instructions that implement the function / action specified in the blocks.
컴퓨터 프로그램 명령은, 컴퓨터, 다른 프로그래밍가능한 데이터 처리 장치 또는 다른 디바이스로 로딩되어, 이 컴퓨터, 다른 처리 장치, 또는 다른 디바이스에서 수행될 수 있는 일련의 연산을 실행시키는 것에 의해 흐름도 및/또는 블록도의 블록 또는 블록들에 지정된 기능/동작을 구현하는 하나 이상의 공정을 제공하는 컴퓨터로 구현된 공정을 생성할 수 있다. The computer program instructions may be loaded into a computer, other programmable data processing apparatus, or other device to cause a computer to execute a sequence of operations that may be performed on the computer, another processing device, A computer-implemented process that provides one or more processes that implement the functions / operations specified in the blocks or blocks.
본 명세서에 사용된 용어는 특정 실시예를 예시하려는 것일 뿐, 본 발명을 이들 실시예로 제한하려고 의도된 것이 전혀 아니다. 본 명세서에 사용된 바와 같이, "하나" 및" 상기" 라는 단수 용어는, 달리 명시적인 언급이 없는 한, 복수의 형태를 포함하는 것으로 의도된다. 본 명세서에 사용될 때 "포함하는" 및/또는 "구비하는" 이라는 용어는, 언급된 특징, 숫자, 단계, 동작, 요소 및/또는 성분이 존재하는 것을 의미하는 것일 뿐, 하나 이상의 다른 특징, 숫자, 단계, 동작, 요소, 성분 및/또는 그룹이 존재하거나 추가되는 것을 배제하는 것은 아닌 것으로 이해된다. 나아가, "포함하는", "구비하는", "가지는", "있는", "구성된"이라는 용어 또는 이들의 변형어가 상세한 설명이나 청구범위에 사용되는 경우, 이들 용어는 "포함하는" 이라는 용어와 유사한 방식으로 포괄적인 의미로 의도된 것으로 이해된다.The terminology used herein is for the purpose of illustrating particular embodiments and is not intended to limit the invention to these embodiments at all. As used herein, the singular terms "a" and "said" are intended to include the plural forms unless the context clearly dictates otherwise. As used herein, the term "comprising" and / or "comprising" means that there is a stated feature, number, step, operation, element and / , Steps, operations, elements, components, and / or groups are not intended to be < / RTI > Further, when the terms "comprising", "having", "having", "having", "consisting", or variations thereof are used in either the detailed description or the claims, It is to be understood that the same is intended in a broad sense.
본 발명은 모두 여러 실시예를 설명하는 것으로 예시되었고, 이들 실시예는 상당히 상세히 설명되었으나, 이것이 첨부된 청구범위를 이러한 상세사항으로 제한하거나 한정하는 것으로 출원인이 의도한 것은 전혀 아니다. 추가적인 잇점과 변형은 이 기술 분야에 통상의 지식을 가진 자에게는 용이하게 일어날 수 있을 것이다. 그리하여 더 넓은 측면에서 본 발명은 도시되거나 설명된 특정 상세, 대표적인 장치와 방법 및 예시적인 예로 제한되지 않는다. 따라서, 본 출원인의 일반적인 발명 개념의 사상과 범위를 벗어남이 없이 이 상세사항에서 벗어남이 있을 수 있을 것이다.While the present invention has been illustrated and described in considerable detail, it is not intended that the applicant intend to limit or limit the appended claims to such detail. Additional advantages and modifications will readily occur to those of ordinary skill in the art. Thus, in a broader aspect, the invention is not limited to the specific details, representative apparatus and method, and illustrative examples shown or described. Accordingly, these details may be deviated from the details of the inventor's general inventive concept without departing from the spirit and scope thereof.
Claims (20)
출발지, 적어도 하나의 목적지, 및 적어도 하나의 시간 제약을 지시하는 여행 요청을 수신하는 단계;
상기 적어도 하나의 시간 제약에 적어도 부분적으로 기초하여 상기 출발지 및 상기 적어도 하나의 목적지를 포함하는 복수의 여행 경로를, 적어도 하나의 프로세서에서, 수립하는 단계;
상기 적어도 하나의 시간 제약에 적어도 부분적으로 기초하여 각 여행 경로에 대한 적어도 하나의 후보 여행 솔루션을 결정하는 단계; 및
각 여행 경로에 대한 상기 적어도 하나의 후보 여행 솔루션의 가격 및 이용가능성에 적어도 부분적으로 기초하여 상기 여행 요청에 대한 적어도 하나의 여행 솔루션을, 적어도 하나의 프로세서에서, 결정하는 단계를 포함하는 것을 특징으로 하는 방법. CLAIMS 1. A method for determining at least one travel solution,
Receiving a travel request indicating a departure location, at least one destination, and at least one time constraint;
Establishing in the at least one processor a plurality of travel paths comprising the source and the at least one destination based at least in part on the at least one time constraint;
Determining at least one candidate travel solution for each travel path based at least in part on the at least one time constraint; And
Determining at least one travel solution for the travel request in at least one processor based at least in part on the price and availability of the at least one candidate travel solution for each travel path, How to.
상기 적어도 하나의 시간 제약에 적어도 부분적으로 기초하여 상기 출발지 및 상기 적어도 하나의 목적지를 포함하는 복수의 여행 경로를, 적어도 하나의 프로세서에서, 수립하는 단계는,
상기 적어도 하나의 목적지의 여행 특성에 적어도 부분적으로 기초하여 상기 출발지 및 상기 적어도 하나의 목적지에 대한 적어도 하나의 여행 그래프를 결정하는 단계를 포함하고,
상기 복수의 여행 경로는 적어도 하나의 여행 그래프에 적어도 부분적으로 기초하여 수립되는 것을 특징으로 하는 방법. The method according to claim 1,
Establishing in the at least one processor a plurality of travel paths comprising the source and the at least one destination based at least in part on the at least one time constraint,
Determining at least one travel graph for the origin and the at least one destination based at least in part on the travel characteristics of the at least one destination,
Wherein the plurality of travel paths are established based at least in part on at least one travel graph.
상기 적어도 하나의 목적지의 상기 여행 특성에 적어도 부분적으로 기초하여 상기 출발지 및 상기 적어도 하나의 목적지에 대한 상기 적어도 하나의 여행 그래프를 결정하는 단계는,
상기 적어도 하나의 목적지가 저비용 여행 서비스를 제시하는지 여부를 결정하는 단계; 및
상기 적어도 하나의 목적지에 대한 저비용 여행 허브와 연관된 적어도 하나의 여행 그래프 형상을 결정하는 단계를 포함하는 것을 특징으로 하는 방법. 3. The method of claim 2,
Wherein determining the at least one travel graph for the origin and the at least one destination based at least in part on the travel characteristics of the at least one destination comprises:
Determining whether the at least one destination presents a low cost travel service; And
Determining at least one travel graph shape associated with the low cost travel hub for the at least one destination.
상기 적어도 하나의 목적지의 적어도 하나의 여행 특성은 저비용 여행 허브, 국제 여행 허브, 리턴 요금 여행 허브, 긴 도중하차(layover) 여행 허브 또는 이들의 임의의 조합을 포함하는 것을 특징으로 하는 방법. 3. The method of claim 2,
Wherein the at least one travel characteristic of the at least one destination comprises a low cost travel hub, an international travel hub, a return fare travel hub, a long layover travel hub, or any combination thereof.
상기 적어도 하나의 시간 제약에 적어도 부분적으로 기초하여 각 여행 경로에 대한 상기 적어도 하나의 후보 여행 솔루션을 결정하는 단계는,
각 여행 경로에 대응하는 여행 서비스의 복수의 여행 상세 항목에 대한 가격 및 이용가능성을 결정하는 단계를 포함하고,
각 여행 경로에 대한 상기 적어도 하나의 후보 여행 솔루션은 각 여행 경로에 대응하는 복수의 여행 상세 항목에 대한 가격 및 이용가능성에 적어도 부분적으로 기초하는 것을 특징으로 하는 방법. The method according to claim 1,
Wherein determining the at least one candidate travel solution for each travel path based at least in part on the at least one time constraint comprises:
Determining a price and availability for a plurality of travel detail items of the travel service corresponding to each travel route,
Wherein the at least one candidate travel solution for each travel route is based at least in part on price and availability for a plurality of trip details items corresponding to each travel route.
각 여행 경로에 대응하는 상기 복수의 여행 상세 항목에 대한 상기 가격 및 상기 이용가능성을 결정하는 단계는,
적어도 하나의 시간 제약에 적어도 부분적으로 기초하여 각 여행 경로에 대한 적어도 하나의 서브-요청을 생성하는 단계; 및
미리 결정된 가격 및 이용가능성 데이터베이스를 유지하는 컴퓨팅 그리드에 각 서브-요청을 질문하여 복수의 여행 상세 항목에 대한 가격 및 이용가능성을 결정하는 단계를 포함하는 것을 특징으로 하는 방법. 6. The method of claim 5,
Wherein the step of determining the price and the availability for the plurality of trip detail items corresponding to each travel route comprises:
Generating at least one sub-request for each travel path based at least in part on at least one time constraint; And
Requesting each sub-request to a computing grid that maintains a predetermined price and availability database to determine price and availability for a plurality of travel detail items.
상기 적어도 하나의 시간 제약은 상기 적어도 하나의 목적지에 원하는 최소 체류 기간을 포함하고, 상기 여행 경로는 적어도 하나의 목적지에 원하는 최소 체류 기간에 적어도 부분적으로 기초하여 수립되는 것을 특징으로 하는 방법. The method according to claim 1,
Wherein the at least one time constraint comprises a desired minimum residence time at the at least one destination and the travel path is established based at least in part on a desired minimum residence time at the at least one destination.
상기 적어도 하나의 시간 제약은 여행에 지정된 날짜 범위, 적어도 하나의 목적지에 지정된 최소 체류 기간, 적어도 하나의 목적지에 지정된 최대 체류 기간, 지정된 리턴 날짜, 적어도 하나의 목적지에 있기 위해 지정된 날짜, 여행 순서에서 적어도 하나의 목적지에 지정된 위치, 또는 이들의 임의의 조합을 포함하는 것을 특징으로 하는 방법. The method according to claim 1,
Wherein the at least one time constraint comprises a date range specified in the trip, a minimum stay period specified in at least one destination, a maximum stay period specified in at least one destination, a specified return date, a date specified to be in at least one destination, A location specified in at least one destination, or any combination thereof.
상기 여행 요청은 호텔이 적어도 하나의 목적지에 요구되는지 여부를 지시하고, 상기 여행 경로는 호텔이 적어도 하나의 목적지에 요구되는지 여부에 적어도 부분적으로 기초하여 수립되는 것을 특징으로 하는 방법. The method according to claim 1,
Wherein the travel request indicates whether a hotel is required for at least one destination and the travel route is established based at least in part on whether a hotel is required for at least one destination.
상기 적어도 하나의 목적지는 복수의 목적지이고, 상기 복수의 여행 경로의 각 여행 경로는 상기 복수의 목적지를 포함하고, 여행 요청에 대한 각 여행 솔루션은 출발지 및 복수의 목적지에 대응하는 여행 서비스에 대한 가격 책정된 여행 상세 항목을 포함하는 것을 특징으로 하는 방법. The method according to claim 1,
Wherein the at least one destination is a plurality of destinations, each travel route of the plurality of travel routes includes the plurality of destinations, each travel solution for a travel request includes a price for a travel service corresponding to a departure location and a plurality of destinations, ≪ / RTI > wherein said travel details item comprises a travel details item that has been booked.
상기 복수의 여행 경로의 특정 여행 경로는 복수의 목적지 중 다른 목적지로부터 복수의 목적지 중 특정 목적지로 리턴 연결을 포함하는 것을 특징으로 하는 방법. 11. The method of claim 10,
Wherein the specific travel path of the plurality of travel paths includes a return connection from another one of the plurality of destinations to a specific one of the plurality of destinations.
상기 복수의 여행 경로 중 특정 여행 경로는 다른 목적지로 여행하기 전에 특정 목적지에서의 제1 체류 기간 및 다른 목적지로부터 리턴 연결 후에 특정 목적지에서의 제2 체류 기간을 포함하는 것을 특징으로 하는 방법. 12. The method of claim 11,
Wherein a particular one of the plurality of travel paths includes a first stay period at a particular destination and a second stay period at a particular destination after a return connection from another destination before traveling to another destination.
상기 여행 요청은 차량 렌탈이 적어도 하나의 목적지에 요구되는지 여부를 지시하고, 상기 여행 경로는 차량 렌탈이 적어도 하나의 목적지에 요구되는지 여부에 적어도 부분적으로 기초하여 수립되는 것을 특징으로 하는 방법. The method according to claim 1,
Wherein the travel request indicates whether a car rental is required for at least one destination and the travel route is established based at least in part on whether car rental is required for at least one destination.
적어도 하나의 프로세서; 및
프로그램 코드;를 포함하고,
상기 프로그램 코드는, 상기 적어도 하나의 프로세서에 의해 실행될 때, 상기 적어도 하나의 프로세서로 하여금,
출발지, 적어도 하나의 목적지, 및 적어도 하나의 시간 제약을 지시하는 여행 요청을 수신하는 동작,
상기 적어도 하나의 시간 제약에 적어도 부분적으로 기초하여 상기 출발지 및 상기 적어도 하나의 목적지를 포함하는 복수의 여행 경로를 수립하는 동작,
상기 적어도 하나의 시간 제약에 적어도 부분적으로 기초하여 각 여행 경로에 대한 적어도 하나의 후보 여행 솔루션을 결정하는 동작, 및
각 여행 경로에 대한 상기 적어도 하나의 후보 여행 솔루션에 대한 가격 및 이용가능성에 적어도 부분적으로 기초하여 여행 요청에 대한 적어도 하나의 여행 솔루션을 결정하는 동작을 수행하도록 구성된 것을 특징으로 하는 시스템. A system for determining at least one travel solution,
At least one processor; And
Program code,
Wherein the program code, when executed by the at least one processor, causes the at least one processor to:
Receiving a travel request indicating a departure location, at least one destination, and at least one time constraint;
Establishing a plurality of travel paths comprising the origin and the at least one destination based at least in part on the at least one time constraint;
Determining at least one candidate travel solution for each travel path based at least in part on the at least one time constraint; and
And determine at least one travel solution for the travel request based at least in part on the price and availability for the at least one candidate travel solution for each travel route.
실행시 상기 프로세서로 하여금 적어도 하나의 시간 제약에 적어도 부분적으로 기초하여 출발지 및 적어도 하나의 목적지를 포함하는 복수의 여행 경로를 수립하는 동작을 수행하도록 구성된 상기 프로그램 코드는,
실행시 상기 프로세서로 하여금 상기 적어도 하나의 목적지의 여행 특성에 적어도 부분적으로 기초하여 출발지 및 적어도 하나의 목적지에 대한 적어도 하나의 여행 그래프를 결정하는 동작을 수행하도록 구성된 프로그램 코드를 포함하고, 상기 복수의 여행 경로는 적어도 하나의 여행 그래프에 적어도 부분적으로 기초하여 수립되는 것을 특징으로 하는 시스템. 15. The method of claim 14,
Wherein the program code is configured to cause the processor to perform a plurality of travel paths comprising a source and at least one destination based at least in part on at least one time constraint,
And program code configured to cause the processor to, upon execution, perform an operation of determining at least one travel graph for the origin and at least one destination based at least in part on the travel characteristics of the at least one destination, Wherein the travel path is established based at least in part on at least one travel graph.
실행시 상기 프로세서로 하여금, 적어도 하나의 목적지의 여행 특성에 적어도 부분적으로 기초하여 출발지 및 적어도 하나의 목적지에 대한 적어도 하나의 여행 그래프를 결정하는 동작을 수행하도록 구성된 상기 프로그램 코드는,
실행시 상기 프로세서로 하여금 적어도 하나의 목적지가 저비용 여행 서비스를 제시하는지 여부를 결정하는 동작, 및 적어도 하나의 목적지에 대한 저비용 여행 허브와 연관된 적어도 하나의 여행 그래프 형상을 결정하는 동작을 수행하도록 구성된 프로그램 코드를 포함하는 것을 특징으로 하는 시스템. 16. The method of claim 15,
The program code being configured to cause the processor to perform at least one travel graph determination for a source and at least one destination based at least in part on the travel characteristics of the at least one destination,
The method comprising: determining, at runtime, the processor to determine whether at least one destination presents a low cost travel service; and determining a program configured to perform at least one travel graph shape associated with the low cost travel hub for the at least one destination Code. ≪ / RTI >
상기 적어도 하나의 목적지의 적어도 하나의 여행 특성은 저비용 여행 허브, 국제 여행 허브, 리턴 요금 여행 허브, 긴 도중하차(layover) 여행 허브, 또는 이들의 임의의 조합을 포함하는 것을 특징으로 하는 시스템. 16. The method of claim 15,
Wherein the at least one travel feature of the at least one destination comprises a low cost travel hub, an international travel hub, a return fare travel hub, a long layover travel hub, or any combination thereof.
실행시 상기 프로세서로 하여금 적어도 하나의 시간 제약에 적어도 부분적으로 기초하여 각 여행 경로에 대한 적어도 하나의 후보 여행 솔루션을 결정하는 동작을 수행하도록 구성된 상기 프로그램 코드는,
실행시 상기 프로세서로 하여금, 각 여행 경로에 대응하는 여행 서비스의 복수의 여행 상세 항목에 대한 가격 및 이용가능성을 결정하는 동작을 수행하도록 구성된 프로그램 코드를 포함하고, 각 여행 경로에 대한 적어도 하나의 후보 여행 솔루션은 각 여행 경로에 대응하는 복수의 여행 상세 항목에 대한 가격 및 이용가능성에 적어도 부분적으로 기초하여 결정되는 것을 특징으로 하는 시스템. 15. The method of claim 14,
The program code configured to perform, at run time, the processor to determine at least one candidate travel solution for each travel path based at least in part on at least one time constraint,
And program code configured to cause the processor to, at run time, perform an operation of determining a price and availability for a plurality of trip detail items of a travel service corresponding to each travel route, wherein at least one candidate for each travel route Wherein the travel solution is determined based at least in part on the price and availability for a plurality of travel detail items corresponding to each travel route.
실행시 상기 프로세서로 하여금 각 여행 경로에 대응하는 복수의 여행 상세 항목에 대한 가격 및 이용가능성을 결정하는 동작을 수행하도록 구성된 상기 프로그램 코드는, 실행시 상기 프로세서로 하여금,
적어도 하나의 시간 제약에 적어도 부분적으로 기초하여 각 여행 경로에 대한 적어도 하나의 서브-요청을 생성하는 동작, 및
미리 결정된 가격 및 이용가능성 데이터베이스를 유지하는 컴퓨팅 그리드에 각 서브-요청을 질문하여 복수의 여행 상세 항목에 대한 가격 및 이용가능성을 결정하는 동작을 수행하도록 구성된 프로그램 코드를 포함하는 것을 특징으로 하는 시스템. 19. The method of claim 18,
The program code being configured to cause the processor to, upon execution, perform an operation of determining a price and availability for a plurality of trip detail items corresponding to each travel path,
Generating at least one sub-request for each travel path based at least in part on at least one time constraint; and
And program code configured to query each sub-request to a computing grid that maintains a predetermined price and availability database to perform operations to determine price and availability for a plurality of travel detail items.
상기 컴퓨터 판독가능한 저장 매체에 저장된 프로그램 코드;를 포함하고,
상기 프로그램 코드는, 실행시, 적어도 하나의 프로세서로 하여금,
적어도 하나의 목적지의 여행 특성에 적어도 부분적으로 기초하여 출발지 및 적어도 하나의 목적지에 대한 적어도 하나의 여행 그래프를 결정하는 동작을 수행하도록 구성되고, 복수의 여행 경로는 적어도 하나의 여행 그래프에 적어도 부분적으로 기초하여 수립된 것을 특징으로 하는 프로그램 제품. A computer readable storage medium; And
And program code stored in the computer readable storage medium,
The program code, when executed, causes at least one processor to:
Determining at least one travel graph for a departure location and at least one destination based at least in part on the travel characteristics of the at least one destination, wherein the plurality of travel paths are configured to, at least in part, ≪ / RTI >
Applications Claiming Priority (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US14/135,943 | 2013-12-20 | ||
EP13290321.2 | 2013-12-20 | ||
EP13290321.2A EP2887278A1 (en) | 2013-12-20 | 2013-12-20 | Dynamic travel planner |
US14/135,943 US20150178642A1 (en) | 2013-12-20 | 2013-12-20 | Dynamic travel planner |
Publications (1)
Publication Number | Publication Date |
---|---|
KR20150073854A true KR20150073854A (en) | 2015-07-01 |
Family
ID=53477193
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1020140182717A KR20150073854A (en) | 2013-12-20 | 2014-12-17 | Dynamic travel planner |
Country Status (3)
Country | Link |
---|---|
KR (1) | KR20150073854A (en) |
AU (1) | AU2014277801A1 (en) |
CA (1) | CA2875143A1 (en) |
-
2014
- 2014-12-11 CA CA2875143A patent/CA2875143A1/en not_active Abandoned
- 2014-12-17 KR KR1020140182717A patent/KR20150073854A/en active Search and Examination
- 2014-12-19 AU AU2014277801A patent/AU2014277801A1/en not_active Abandoned
Also Published As
Publication number | Publication date |
---|---|
CA2875143A1 (en) | 2015-06-20 |
AU2014277801A1 (en) | 2015-07-09 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20150178642A1 (en) | Dynamic travel planner | |
JP7289348B2 (en) | Method and server for providing fare availability, e.g. airfare availability | |
Agatz et al. | Optimization for dynamic ride-sharing: A review | |
US20080183512A1 (en) | System and method for estimating seat value | |
US20150294238A1 (en) | Travel planning system | |
US20190318274A1 (en) | Discovering and reserving travel solutions | |
US20150286960A1 (en) | Media input reservation system | |
US20160321764A1 (en) | Method of and system for planning and redistributing congested flows based on integrated calendar information | |
KR20150021447A (en) | Contextualized travel offers | |
US20210279823A1 (en) | Pre-event triggers for extended travel management systems | |
US20100145740A1 (en) | Method and system for displaying interlining travel recommendations | |
US20170053217A1 (en) | System and method for increasing utilization of capacity limited and perishable events | |
KR20150116385A (en) | Media input reservation system | |
JP5837835B2 (en) | Flight plan creation device | |
KR20150117209A (en) | Travel planning system | |
KR20160034223A (en) | Corporate recognition for travel related services | |
US11668575B2 (en) | Pre-event triggers for travel management systems | |
KR20150073854A (en) | Dynamic travel planner | |
ES2824472T3 (en) | Search query processing | |
EP2930673A1 (en) | Travel planning system | |
KR20160034226A (en) | Corporate recognition for travel related services | |
EP2887278A1 (en) | Dynamic travel planner | |
KR102223499B1 (en) | Journey planning method and system | |
ES2908559T3 (en) | System and method to determine a set of routes, in a computerized environment | |
KR20140111994A (en) | Alternative travel recommendations |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PA0109 | Patent application |
Patent event code: PA01091R01D Comment text: Patent Application Patent event date: 20141217 |
|
A201 | Request for examination | ||
PA0201 | Request for examination |
Patent event code: PA02012R01D Patent event date: 20150619 Comment text: Request for Examination of Application Patent event code: PA02011R01I Patent event date: 20141217 Comment text: Patent Application |
|
PG1501 | Laying open of application | ||
PC1202 | Submission of document of withdrawal before decision of registration |
Comment text: [Withdrawal of Procedure relating to Patent, etc.] Withdrawal (Abandonment) Patent event code: PC12021R01D Patent event date: 20190111 |