SYSTEM AND METHOD FOR GENERATING IMPLICIT RATINGS USING USER-GENERATED CONTENT
20210287147 · 2021-09-16
Inventors
Cpc classification
G06F16/2379
PHYSICS
G06Q10/06312
PHYSICS
International classification
G06Q10/06
PHYSICS
Abstract
A system and method for generating implicit ratings using user generated content. A web and social media scraper collect and preprocesses online user generated content for ingestion by machine learning classifiers that provide a confidence score relating to the sentiment of a product. That score is then normalized to the requested score level and compared against a threshold subsequently determining the product's implicit rating. Explicit ratings may further inform the rating calculations to produce more accurate ratings or combined ratings.
Claims
1. A system for generating implicit ratings using user generated content, comprising: a computer system comprising a memory and a processor; a rating system application programming interface comprising a first plurality of programming instructions stored in the memory and operating on the processor, wherein the first plurality of programming instructions, when operating on the processor, causes the computer system to: receive a request for an implicit rating, wherein the request comprises a product or service to be rated and a rating normalization factor; and send the request to a web and social media scraper; a web and social media scraper comprising a second plurality of programming instructions stored in the memory and operating on the processor, wherein the second plurality of programming instructions, when operating on the processor, causes the computer system to: retrieve data comprising user generated content relating to the product or service; preprocess the data, wherein preprocessing prepares data for ingestion by a machine learning classifier; and send the preprocessed data to a machine learning engine; and a machine learning engine comprising a third plurality of programming instructions stored in the memory and operating on the processor, wherein the third plurality of programming instructions, when operating on the processor, causes the computer system to: analyze the preprocessed data for sentiment relating to the product or service; produce a confidence score, wherein the confidence score is a percentage of confidence from the machine learning classifier relating to the sentiment of the user generated content towards the product or service; sum all the confidence scores from each one of the user generated content; convert the summed confidence score to a rating, wherein the percentage of the confidence score equates to a specific number of rating units; normalize the rating using the rating normalization factor; and return the normalized rating to the origin of the request.
2. The system of claim 1, further comprising a database, wherein the database stores implicit ratings for use upon request.
3. The system of claim 1, wherein the machine learning engine comprises a machine learning classifier selected from the list comprising of natural language processing, computer vision, and facial recognition.
4. The system of claim 1, wherein the web and social media scraper further comprises machine learning classifiers designed to identify the requested product or service in user generated content.
5. A method for generating implicit ratings using user generated content, comprising the steps of: receiving a request for an implicit rating, wherein the request comprises a product or service to be rated and a rating normalization factor; retrieving data comprising user generated content relating to the product or service; preprocess the data, wherein preprocessing prepares data for ingestion by a machine learning classifier; analyzing the preprocessed data for sentiment relating to the product or service; producing a confidence score, wherein the confidence score is a percentage of confidence from the machine learning classifier relating to the sentiment of the user generated content towards the product or service; summing all the confidence scores from each one of the user generated content; converting the summed confidence score to a rating, wherein the percentage of the confidence score equates to a specific number of rating units; normalizing the rating using the rating normalization factor; and returning the normalized rating to the origin of the request.
6. The method of claim 5, further comprising a database, wherein the database stores implicit ratings for use upon request.
7. The method of claim 5, wherein the machine learning engine comprises a machine learning classifier selected from the list comprising of natural language processing, computer vision, and facial recognition.
8. The method of claim 5, wherein the web and social media scraper further comprises machine learning classifiers designed to identify the requested product or service in user generated content.
Description
DETAILED DESCRIPTION
[0051] The inventor has conceived and reduced to practice a system and method for generating implicit ratings using user generated content. A web and social media scraper collect and preprocesses online user generated content for ingestion by machine learning classifiers that provide a confidence score relating to the sentiment of a product. That score is then normalized to the requested score level and compared against a threshold subsequently determining the product's implicit rating. Explicit ratings may further inform the rating calculations to produce more accurate ratings or combined ratings.
[0052] According to one embodiment, a system and method for an implicit rating system comprises a web and social media scraper, a database, a machine learning engine, and an application programming interface (API). In general, the system may have two modes of operation: passive and active. Both modes of operation may run separately or at the same time. A passive mode operation occurs when there are no active requests for a rating of a specific product or service and involves scouring the world wide web for additional data points if and when the computing resources are available. A passive operation may be auto-triggered for products and services that need more data. During active modes of operation, a request for a rating (for a product or service) is received via the API and triggers the web and social media scraper to actively seek out content related to the request. The machine learning engine may assist in the searching of detecting of pertinent web content, such as computer vision to recognize products in videos that is otherwise not known through tagging, metadata, or other forms of text. According to one embodiment, the web and social media scraper comprises machine learning classifiers designed to identify products and services of interest to the implicit rating system. Data gathered is preprocessed for machine learning ingestion by the web and social media scraper before it is stored in a database/store.
[0053] The database may comprise any non-volatile or volatile storage medium. A time-series store is anticipated as one preferred type of database, as time-series data is valuable for sentiment and emotion analysis. The machine learning engine ingests said time-series data which relates to a specific product or service and detects contextual cues from humans or human communications as to the satisfaction level of the product or service as well as other types of emotions. Somatic markers, circumplex model of affect, and other quantitative emotion methods may be implemented into such algorithms for satisfaction levels as well as other psychological, marketing, and statistical methods. The machine learning engine detects the context by first determining the product or service, then determining the consumer in voice, text, video, or picture data, and lastly using natural language processing/reasoning and computer vision/facial recognition to determine the level of satisfaction. Confidence scoring of satisfaction level predictions is another aspect that may be used to improve the results of an implicit rating system.
[0054] Other anticipated aspects include using such an implicit rating system to determine the creditworthiness of businesses supplemental to financial metrics. Job performance, specifically for service related jobs such as wait staff, can benefit from such an implementation. An implicit rating system can be used as a recommender system, wherein implicit ratings inform the decision process that a typical recommender system uses. The machine learning engine could learn the optimal consumption time for meals. If the meal is not consumed within that timeframe, wait staff could be alerted to offer to reheat the meal. The machine learning may know the meal is not consumed by computer vision, by how much speaking is done, or by user uploaded content such as a picture comprising the meal.
[0055] Ratings generated by the system are output either to a third-party via an API, or to an in-house system ran on the same network or computing device as the implicit ratings system, or both. The ratings output may be used by the third-party in various ways, for example, the implicit rating may be combined with explicit ratings to form a single rating.
[0056] One or more different aspects may be described in the present application. Further, for one or more of the aspects described herein, numerous alternative arrangements may be described; it should be appreciated that these are presented for illustrative purposes only and are not limiting of the aspects contained herein or the claims presented herein in any way. One or more of the arrangements may be widely applicable to numerous aspects, as may be readily apparent from the disclosure. In general, arrangements are described in sufficient detail to enable those skilled in the art to practice one or more of the aspects, and it should be appreciated that other arrangements may be utilized and that structural, logical, software, electrical and other changes may be made without departing from the scope of the particular aspects. Particular features of one or more of the aspects described herein may be described with reference to one or more particular aspects or figures that form a part of the present disclosure, and in which are shown, by way of illustration, specific arrangements of one or more of the aspects. It should be appreciated, however, that such features are not limited to usage in the one or more particular aspects or figures with reference to which they are described. The present disclosure is neither a literal description of all arrangements of one or more of the aspects nor a listing of features of one or more of the aspects that must be present in all arrangements.
[0057] Headings of sections provided in this patent application and the title of this patent application are for convenience only, and are not to be taken as limiting the disclosure in any way.
[0058] Devices that are in communication with each other need not be in continuous communication with each other, unless expressly specified otherwise. In addition, devices that are in communication with each other may communicate directly or indirectly through one or more communication means or intermediaries, logical or physical.
[0059] A description of an aspect with several components in communication with each other does not imply that all such components are required. To the contrary, a variety of optional components may be described to illustrate a wide variety of possible aspects and in order to more fully illustrate one or more aspects. Similarly, although process steps, method steps, algorithms or the like may be described in a sequential order, such processes, methods and algorithms may generally be configured to work in alternate orders, unless specifically stated to the contrary. In other words, any sequence or order of steps that may be described in this patent application does not, in and of itself, indicate a requirement that the steps be performed in that order. The steps of described processes may be performed in any order practical. Further, some steps may be performed simultaneously despite being described or implied as occurring non-simultaneously (e.g., because one step is described after the other step). Moreover, the illustration of a process by its depiction in a drawing does not imply that the illustrated process is exclusive of other variations and modifications thereto, does not imply that the illustrated process or any of its steps are necessary to one or more of the aspects, and does not imply that the illustrated process is preferred. Also, steps are generally described once per aspect, but this does not mean they must occur once, or that they may only occur once each time a process, method, or algorithm is carried out or executed. Some steps may be omitted in some aspects or some occurrences, or some steps may be executed more than once in a given aspect or occurrence.
[0060] When a single device or article is described herein, it will be readily apparent that more than one device or article may be used in place of a single device or article. Similarly, where more than one device or article is described herein, it will be readily apparent that a single device or article may be used in place of the more than one device or article.
[0061] The functionality or the features of a device may be alternatively embodied by one or more other devices that are not explicitly described as having such functionality or features. Thus, other aspects need not include the device itself.
[0062] Techniques and mechanisms described or referenced herein will sometimes be described in singular form for clarity. However, it should be appreciated that particular aspects may include multiple iterations of a technique or multiple instantiations of a mechanism unless noted otherwise. Process descriptions or blocks in figures should be understood as representing modules, segments, or portions of code which include one or more executable instructions for implementing specific logical functions or steps in the process. Alternate implementations are included within the scope of various aspects in which, for example, functions may be executed out of order from that shown or discussed, including substantially concurrently or in reverse order, depending on the functionality involved, as would be understood by those having ordinary skill in the art.
Conceptual Architecture
[0063] Referring to
[0064] The business establishment 100 includes a menu 114 with a listing of a plurality of different food items that are available for order at the business establishment 100. A customer of the business establishment 100 is provided with the option of selecting one or more of the food items from the menu 114 to place a food order. In an embodiment, the food order management system 102 is configured to receive food orders entered manually by business establishment personnel via a food order management system input device. In an embodiment, the food order management system 102 is configured to receive food orders electronically via a food order management system network interface. In an embodiment, the food order management system 102 is configured to received food orders entered manually by business establishment personnel via a food order management system input device and electronically via a food order management system network interface.
[0065] Food items in a food order are prepared in the food preparation area 104 and the completed food orders are placed in the food order pick-up area 106. Upon the receipt of a food order from a dine-in customer, the food order management system 102 coordinates the preparation of the food items in the food order in the food preparation area 104 and generates a predicted food order ready time. Different food items in the food order may have different food item preparation times. The predicted food order ready time specifies when the prepared food order is expected to be placed in the food order pick-up area 106. In an embodiment, the food order management system 102 updates the predicted food order ready time based on the actual food item preparation time taken by food preparation personnel to prepare each of the food items in the food order in the food preparation area 104. Providing a predicted food order ready time at the time a food order is received may enable a waiter/waitress to inform a dine-in customer of when they can expect to receive the food items in their food order.
[0066] When a food order is received for delivery, the food items in the food order are prepared in the food order preparation area 104 and the completed food orders are placed in the food order pick-up area 106. Food packaging personnel pick up the complete food orders from the food order pick-up area 106 for packaging in the food packaging area 108. The packaged food orders are placed in the delivery order pick-up area 110. Delivery personnel pick up the packaged food from the delivery order pick-up area 110 for delivery to a food order delivery destination.
[0067] Upon the receipt of a food order for delivery, the food order management system 102 coordinates the preparation of the food items in the food order in the food preparation area 104, generates a predicted food order ready time, coordinates the packaging of the food items in the food order, generates a predicted packaged food order ready time, coordinates the delivery of the food order to the food order delivery destination, and generates a predicted food order delivery time. Different food items in the food order may have different food item preparation times and/or different food item packaging times.
[0068] The predicted food order ready time specifies when the prepared food order is expected to be placed in the food order pick-up area 106 for pick-up. The predicted food order ready time provides food packaging personnel with notice regarding when the food order will be available to be picked up from the food order pick-up area 106 for packaging in the food packaging area 108. The predicted packaged food order ready time specifies when the packaged food order is expected to be placed in the delivery order pick-up area 110 for pick-up by delivery personnel. The predicted food order delivery time specifies when the food order is expected to be delivered to the food order delivery destination. The food order management system 102 generates the predicted food order delivery time based on delivery route specific data associated with the delivery route.
[0069] In an embodiment, the food order management system 102 updates the predicted food order ready time based on the actual food item preparation time taken by food preparation personnel to prepare each of the food items the food order in the food preparation area 104. In an embodiment, the food order management system 102 updates the predicted packaged food order ready time based on one or more of the actual food item preparation time taken by food preparation personnel to prepare each of the food items the food order in the food preparation area 104 and the actual food item packaging time taken by food packaging personnel to package each of the food items in the food order in the food packaging area 108. In an embodiment, the food order management system 102 updates the predicted food order delivery time based on one or more of the actual food item preparation time taken by food preparation personnel to prepare each of the food items the food order in the food preparation area 104, the actual food item packaging time taken by food packaging personnel to package each of the food items in the food order in the food packaging area 108, and changes in delivery route specific data associated with the delivery route associated with delivering the food order to the food order delivery destination.
[0070] Referring to
[0071] In an embodiment, the food order management system 102 is configured to be communicatively coupled to a food preparation display in the food preparation area 104, a food order pick-up display in the food order pick-up area 106, a food packaging display in the food packaging area 108, and a delivery order pick-up display in the delivery order pick-up area 110 via the at least one output interface 210. In an embodiment, the at least one input device interface 206 is configured to be communicatively coupled one or more of a keyboard, a touchscreen, and a mouse. The food order management system 102 may include additional components that facilitate the operation of the food order management system 102. The food order management system 102 may include fewer than the described components.
[0072] In an embodiment the food order management system 102 is a centralized system. In an embodiment, the food order management system 102 is a distributed system. In an embodiment, the food item database 202 is disposed locally at the business establishment 100. In an embodiment, the food items database 202 is disposed at a location remote from the business establishment 100. In an embodiment, the food item database 202 is a component of the food order management system 102. In an embodiment, the food item database 202 is an independent database that is not a component of the food order management system 102. The food item database 202 is configured to store an estimated food item preparation time and an estimated food item packaging time for each food item on the menu 114.
[0073] In an embodiment, a food order processor 212, a food preparation coordinator 214, a food packaging coordinator 216, and a food delivery coordinator 218 are stored in the memory 204. In an embodiment, one or more of a delivery order availability coordinator 220, an advance food preparation coordinator 222, a food item complexity adjustor 224, and a personnel experience adjustor 226 are stored in the memory 204. Additional components may be stored in the memory 204 that facilitate the operation of the food order management system 102.
[0074] The food order processor 212 receives food orders that are placed at the food order management system 102 for processing. The business establishment 100 may provide one or more different options to a customer for placing a food order including food items selected from the menu 114.
[0075] In an embodiment, customers are provided with the option of placing food orders with business establishment personnel. The business establishment personnel manually enter the received food orders into the food order management system 102 via one or more input devices that are communicatively coupled to the at least one input device interface 206. For example, a customer may wish to dine at the business establishment 100. After the customer is seated in the dine-in seating area 112, the customer places a food order including food items selected from the menu 114 with business establishment personnel. An example of business establishment personnel is a waiter or a waitress. The waiter or waitress enters the food order into the food order management system 102. The food order is received by the food order processor 212.
[0076] In an embodiment, a customer is provided with the option of calling the business establishment 100 and placing food orders with business establishment personnel. The business establishment personnel manually enter the received food orders into the food order management system 102 via one or more input devices that are communicatively coupled to the at least one input device interface 206. For example, a customer may call the business establishment 100 to place a food order with food items selected from the menu 114 for delivery with business establishment personnel. The food order is received by the food order processor 212.
[0077] In an embodiment, a customer is provided with the option of placing food orders with food items selected from the menu 114 via a drive thru interface. For example, a customer may place a food order with food items selected from the menu 114 for pick-up at a drive thru window. Business establishment personnel that staff the drive thru manually enter the received food orders into the food order management system 102 via one or more input devices that are communicatively coupled to the at least one input device interface 206. The food order is received by the food order processor 212.
[0078] In an embodiment, a customer is provided with the option of placing a food order with food items selected from the menu 114 electronically via an establishment web site or online portal using a customer electronic device. The food order management system 102 is configured to be communicatively coupled to the establishment web site or online portal. Food orders placed via the establishment web site or online portal are received by the food order management system 102 via the at least one network interface 208. Examples of customer electronic devices that may be used to access the establishment web site or online portal to place a food order include, but are not limited to, a mobile computing device, a cell phone, a desktop computer, and a tablet. The food order is received by the food order processor 212.
[0079] In an embodiment, a customer is provided with the option of placing a food order with food items selected from the menu 114 electronically via a kiosk located within the business establishment 100. The food order management system 102 is configured to be communicatively coupled to the kiosk via one of the at least one network interface 208 or the at least one input device interface 206. The food order is received by the food order processor 212.
[0080] In an embodiment, each of the tables in the dine-in seating area 112 is equipped with a table order placement device. When a customer is seated at a table in the dine-in seating area 112, the customer is provided with the option of placing a food order with food items selected from the menu 114 electronically via the table order placement device. The food order management system 102 is configured to be communicatively coupled to each of the table order placement devices via the at least one network interface 208 or the at least one input device interface 206. The food order is received by the food order processor 212.
[0081] While a number of different options for placing a food order that is received by the food order management system 102 have been described, alternative mechanisms for placing of a food order may be used.
[0082] Upon the receipt of a food order at the food order management system 102, the food order processor 212 identifies the food items in the food order and determines whether the food order is a designated for dine-in at the business establishment 100 or for delivery to a food order delivery destination. If the food order is designated for delivery, the food order processor 212 identifies the food order delivery destination for the food order. The food order processor 212 provides the food order, the identified food items to the food order, and the designation of the food order as being for dine-in or for delivery to the food preparation coordinator 214.
[0083] Different food items often have different food item preparation times. The estimated food item preparation time for a food item is an estimate of the amount of time that it takes food preparation personnel in the food preparation area 104 to prepare the food item. The estimated food item preparation time for each food item on the menu 114 is stored in the food item database 202. In an embodiment, the estimated food item preparation time for a food item is based on an analysis of historical food item preparation times for that food item by the food order management system 102. The food order management system 102 tracks the actual food item preparation time that it takes to prepare the food item in the food preparation area 104 and updates the estimated food item preparation time for that food item in the food item database 202 in accordance with the tracked actual food item preparation times. In an embodiment, the food management system 102 employs time estimation algorithms to generate the estimated food item preparation times for the different food items and stores the generated estimated food item preparation times in the food item database 202.
[0084] The food preparation coordinator 214 receives the food order, the identified food items in the food order, and the designation of the food order as being for dine-in or for delivery from the food order processor 212. The food preparation coordinator 214 accesses the food item database 202 and retrieves the estimated food item preparation time for each of the food items in the food order from the food item database 202. The food preparation coordinator 214 generates an estimated food order preparation time for the food order based on the retrieved estimated food item preparation times for each of the food items in the food order.
[0085] The food preparation coordinator 214 identifies the earliest food preparation time available to prepare the food items in the food order in the food preparation area 104. The food preparation coordinator 214 tracks the number of pending food orders for dine-in and for delivery that are awaiting preparation or are scheduled to be prepared in the food preparation area 104. The food preparation coordinator 214 identifies the earliest available food order preparation time for the food order based on the number of pending food orders and the status of the pending food orders. The food preparation coordinator 214 assigns the identified food order preparation time to the food order. The food preparation coordinator 214 generates a predicted food order ready time for the food order based on the assigned food preparation time and the estimated food order preparation time.
[0086] In an embodiment, the food order management system 102 coordinates the preparation of the food items in the food preparation area 104 sequentially. In an embodiment, the food order management system 102 coordinates a parallel preparation of one or more food items in the food order in the food preparation area 104. The food preparation coordinator 214 identifies the earliest available food preparation times for each food item in the food order and assigns each of food items to individual food preparation times. The food preparation coordinator 214 generates the predicted food order ready time for the food order based on the food preparation times assigned to individual food items in the food order and the estimated food item preparation time for each food item in the food order.
[0087] The food preparation coordinator 214 tracks the actual food item food preparation time for the preparation of each of the food items in the food order as well as the food preparation times associated other food orders that are scheduled for preparation in the food preparation area 104. The food preparation coordinator 214 updates the predicted food order ready time based on one or both of the actual food item food preparation time for the preparation of each of the food items in the food order and the actual food order preparation times associated other food orders that are scheduled for preparation in the food preparation area 104. The food order management system 102 updates the estimated food item preparation times in the food item database 202 for each of the food items in the food order based on the actual food item preparation times tracked by the food preparation coordinator 214.
[0088] In an embodiment, the food order management system 102 is communicatively coupled to cameras and/or other types of sensors located in the food preparation area 104 via the at least one input device interface 206. The cameras and/or other types of sensors provide feedback to the food preparation coordinator 214 regarding the actual food item preparation time of food items in the food preparation area.
[0089] In an embodiment, the food order management system 102 includes a food item complexity adjustor 224. The food preparation coordinator 214 provides the food item complexity adjuster 224 with the food order, the food items in the food order, the estimated food item preparation times for each food item in the food order, the estimated food order preparation time for the food order, and the predicted food order ready time for the food order.
[0090] The food item complexity adjuster 224 identifies a food item complexity factor associated with each of the food items in the food order. The food item complexity factor for each food items identifies whether additional food item preparation time is needed for specific food items in the food order. For example, a food item having a routine complexity may have a food item complexity factor of one and a food item that is relatively more complex may have a food item complexity factor of two.
[0091] The food item complexity adjuster 224 adjusts the estimated food item preparation times for each of the food items in the food order by the food item complexity factor, generates an adjusted estimated food order preparation time based on the adjusted estimated food item preparations times for each of the food items in the food order. The food item complexity adjuster 224 updates the predicted food order ready time based on the adjusted estimated food order preparation time. The food item complexity adjuster 224 provides the food preparation coordinator 214 with the adjusted estimated food item preparation times for each of the food items in the food order, the adjusted estimated food order preparation time, and the updated predicted food order ready time.
[0092] In an embodiment, the food order management system 102 includes a personnel experience adjustor 226. The food preparation coordinator 214 provides the personnel experience adjustor 226 with the food order, the food items in the food order, the estimated food item preparation times for each food item in the food order, the estimated food order preparation time for the food order, and the predicted food order ready time. The personnel experience adjustor 226 assigns specific food preparation personnel to prepare specific food items in the food order. The personnel experience adjustor 226 identifies a personnel skill factor for each of the food preparation personnel assigned to prepare each food item in the food order. For example, a relatively more experienced food preparation personnel may have a personnel skill factor of 0.75 while a novice food preparation personnel may have a personnel skill factor of 1.5.
[0093] The personnel experience adjustor 226 adjusts the estimated food item preparation times for each of the food items in the food order by the personnel skill factor associated with the food preparation personnel assigned to prepare the food item and generates an adjusted estimated food item preparation time for each food item in the food order. The personnel experience adjustor 226 uses the adjusted estimated food item preparation times for the food items in the food order to generate an adjusted estimated food order preparation time and uses the adjusted estimated food order preparation time to generate an adjusted predicted food order ready time. The personnel experience adjustor 226 provides the food preparation coordinator 214 with the adjusted estimated food item preparation times for each of the food items in the food order, the adjusted estimated food order preparation time, and the updated predicted food order ready time to the food preparation coordinator 214.
[0094] If the food items in the food order were designated for a dine-in customer, the processor 200 issues a command to display the food order including the food items in the food order, the estimated food item preparation time for each of the food items in the food order, the estimated food order preparation time, and the predicted food order ready time on the food preparation display in the food preparation area 104 via an output device interface 210 and a command to display the food order including the food items in the food order and the predicted the food order ready time on the food pick-up display in the food order pick-up area 106 via an output device interface 210 at approximately the same time.
[0095] Referring to
[0096] As mentioned above, the food order processor 212 provides the food preparation coordinator 214 with a food order designation that designates the food order as being a food order for dine-in or for delivery. If the food order has been designated for delivery, the food preparation coordinator 214 provides the food order including the food items in the food order, the estimated food item preparation times for each of the food items in the food order, the estimated food order preparation time for the food order, and the predicted food order ready time to the food packaging coordinator 216.
[0097] Different food items often have different food item packaging times. The estimated food item packaging time for a food item is an estimate of the amount of time that it takes food packaging personnel in the food packaging area 108 to package the food item. The estimated food item packaging time for each food item on the menu 114 is stored in the food item database 202. In an embodiment, the estimated food item packaging time for a food item is based on an analysis of historical food item packaging times for that food item by the food order management system 102. The food order management system 102 tracks the actual food item packaging time that it takes to package the food item in the food packaging area 106 and updates the estimated food item packaging time for that food item in the food item database 202 in accordance with the tracked actual food item packaging times. In an embodiment, the food management system 102 employs time estimation algorithms to generate the estimated food item packaging times for the different food items and stores the generated estimated food item packaging times in the food item database 202.
[0098] The food packaging coordinator 216 accesses the food item database 202 and retrieves the estimated food item packaging time for each of the food items in the food order from the food item database 202. The food packaging coordinator 216 generates an estimated food order packaging time for the food order based on the retrieved estimated food item packaging times for each of the food items in the food order.
[0099] The food packaging coordinator 216 identifies the earliest food packaging time available following the predicted food order ready time to package the food items in the food order in the food packaging area 108. The food packaging coordinator 216 tracks the number of pending food orders that are awaiting packaging or are scheduled to be packaged in the food packaging area 108. The food packaging coordinator 216 identifies the earliest available food order packaging time for the food order based on the number of pending food orders and the status of the pending food orders. The food packaging coordinator 216 assigns the identified food order packaging time to the food order. In an embodiment, the food packaging coordinator 216 generates a predicted packaged food order ready time for the food order based on the assigned food packaging time and the estimated food order packaging time. In an embodiment, the food packaging coordinator 216 generates a predicted packaged food order ready time for the food order based on the assigned food packaging time and the estimated food item packaging times for each of the food items in the food order.
[0100] In an embodiment, the food order management system 102 coordinates the packaging of the food items in the food packaging area 108 sequentially. In an embodiment, the food order management system 102 coordinates a parallel packaging of one or more food items in the food order in the food packaging area 108. The food packaging coordinator 216 identifies the earliest available food packaging times for each food item in the food order and assigns each of food items to individual food packaging times. The food packaging coordinator 216 generates the predicted packaged food order ready time for the food order based on the food preparation times assigned to individual food items in the food order and the estimated food item preparation time for each food item in the food order.
[0101] The food packaging coordinator 216 tracks the actual food item packaging time for the packaging of each of the food items in the food order as well as the food packaging times associated other food orders that are scheduled for packaging in the food packaging area 108. The food packaging coordinator 216 updates the predicted packaged food order ready time based on one or both of the actual food item packaging time for the packaging of each of the food items in the food order and the actual food order packaging times associated other food orders that are scheduled for packaging in the food packaging area 108. The food order management system 102 updates the estimated food item packaging times in the food item database 202 for each of the food items in the food order based on the actual food item packaging times tracked by the food packaging coordinator 216.
[0102] In an embodiment, the food order management system 102 is communicatively coupled to cameras and/or other types of sensors located in the food packaging area 108 via the at least one input device interface 206. The cameras and/or other types of sensors provide feedback to the food packaging coordinator 216 regarding the actual food item packaging time of food items in the food packaging area 108.
[0103] The food packaging coordinator 216 provides the food delivery coordinator 218 with the food order including the food items in the food order, and the predicted packaged food order ready time for the food order. The food order delivery destination is received at the food delivery coordinator 218 from the food order processor 212. The food delivery coordinator 218 identifies a delivery route from the business establishment 100 to the food order delivery destination. In an embodiment, the food delivery coordinator 218 is communicatively coupled to the Internet via the at least one network interface 208. The food delivery coordinator 218 accesses an application via the Internet that is configured to generate a delivery route based on a food delivery coordinator 218 suppled starting location and a food delivery coordinator 218 supplied destination location. In an embodiment, the food delivery coordinator 218 identifies a delivery route that incorporates the delivery of multiple different food orders to different food order delivery destinations.
[0104] The food delivery coordinator 218 identifies the earliest delivery time available following the predicted packaged food order ready time for delivery of the food order to the food order delivery destination. The food delivery coordinator 218 tracks the number of pending food orders that are awaiting delivery or are scheduled to be delivered. The food delivery coordinator 218 identifies the earliest available delivery time for the food order based on the number of pending food orders and the status of the pending food orders. The food delivery coordinator 218 assigns the identified delivery time to the food order. The food delivery coordinator 218 receives delivery route specific data associated with the delivery route and the assigned delivery time for the food order. Examples of delivery route specific data include, but are not limited to, weather conditions and traffic conditions. In an embodiment, the food delivery coordinator 218 accesses one or more of weather and map/direction applications on the Internet via the at least one network interface 208 to retrieve the delivery route specific data.
[0105] The food delivery coordinator 218 generates a predicted food order delivery time indicating when the food order is expected to be delivered to the food order delivery destination based on the predicted packaged food order ready time, the delivery route, the assigned delivery time, and the delivery route specific data. The predicted food order delivery time is generated by the food delivery coordinator 218 at the time that the food order is received at the food order management system 102. In some cases, changes may occur in the delivery route specific data as the food order is being prepared and packaged by the business establishment 100. The food delivery coordinator 218 monitors the delivery route specific data for changes and updates the predicted food order delivery time based on any detected changes in the delivery route specific data. The food delivery coordinator 218 receives any adjustments to the predicted packaged food order ready time for the food order from the food packaging coordinator 216 and responsively updates the predicted food order delivery time based on the received adjustments. The food delivery coordinator 218 receives any adjustments to the predicted food order ready time for the food order from the food preparation coordinator 214 and responsively updates the predicted food order delivery time based on the received adjustments. In an embodiment, the food delivery coordinator 218 updates the predicted food order delivery time based on one or both of the actual food item preparation time for each of the food items in the food order and the actual food item packaging times for each food item in the food order.
[0106] In an embodiment, the food order management system 102 includes the delivery availability coordinator 220. In an embodiment, business establishment personnel are provided with the option of limiting the number of food orders that are accepted for delivery during a defined time period using the food order management system 102. Business establishment personnel define the time period and enter a maximum percentage of delivery food orders that will be accepted during the defined time period by the food order management system 102. The delivery availability coordinator 220 receives the defined time period and the maximum acceptable percentage of delivery orders for the defined time period. The delivery availability coordinator 220 maintains a running percentage of received food orders that are designated for delivery during the defined time period. When the delivery availability coordinator 220 determines that the percentage of total food orders designated for delivery has met the maximum allowable percentage for the defined time period, the delivery availability coordinator 220 generates an alert indicating that the maximum percentage of allowable food orders designated for delivery during the defined time period has been reached. In an embodiment, the delivery availability coordinator 220 disables the entry of additional food orders for delivery into the food order management system 102 once the maximum percentage of allowable food orders for delivery during the defined time period has been met.
[0107] In an embodiment, the delivery availability coordinator 220 reviews historical food order data designations to generate an estimated number of dine-in food orders typically received during a pre-defined business establishment operation time. The delivery availability coordinator 220 reviews the historical food order data to estimate the food preparation resources used to prepare food orders for dine-in customers during the pre-defined business establishment operation time and estimates food preparation resources available to handle food orders that are designated for delivery. The delivery availability coordinator 220 sets a maximum acceptable percentage of delivery orders for the pre-defined business establishment operation time based on the estimated food preparation resources available to handle food orders that are designated for delivery. The delivery availability coordinator 220 maintains a running percentage of received food orders that are designated for delivery during the pre-defined business establishment operation time. When the delivery availability coordinator 220 determines that the percentage of total food orders designated for delivery has met the maximum allowable percentage for the pre-defined business establishment operation time, the delivery availability coordinator 220 generates an alert indicating that the maximum percentage of allowable food orders designated for delivery during the pre-defined business establishment operation time has been reached. In an embodiment, the delivery availability coordinator 220 disables the entry of additional food orders for delivery into the food order management system 102 once the maximum percentage of allowable food orders for delivery during the pre-defined business establishment operation time period has been met.
[0108] In an embodiment, the delivery availability coordinator 220 adjust the maximum acceptable percentage of delivery orders for the pre-defined business establishment operation time based on one or more delivery related parameters that may impact the ratio of dine-in customers to food order delivery customers. Examples of such delivery related parameters include, but are not limited to weather conditions, traffic conditions, seasonal conditions (such as for example, expected tourism), the presence, opening, and/or closing of nearby restaurants. For example, inclement weather conditions may result in fewer dine-in customers but a greater number of delivery orders. In an embodiment, the delivery availability coordinator 220 includes a web crawler that identifies the recent status of the delivery related parameters and provides the recent status of the delivery related parameters to the delivery availability coordinator 220. The delivery availability coordinator 220 adjust the maximum acceptable percentage of delivery orders for the pre-defined business establishment operation time based on one or more received parameters.
[0109] In an embodiment, the food order management system 102 includes an advance food preparation coordinator 222. The advance food preparation coordinator 222 identifies food items on the menu 114, that can be prepared in advance. In an embodiment, the advance food preparation coordinator 222 reviews historical food preparation time data for the food preparation area 104 to identify business establishment operation time periods with relatively low usage of food preparation resources. The advance food preparation coordinator 222 assigns the preparation of one or more food items on the menu 114 that can be prepared in advance to the identified business establishment operation time periods with relatively low usage of food preparation resources.
[0110] In an embodiment, the advance food preparation coordinator 222 determines a batch size for the food items that are prepared in advance. The ingredient list for each of the food items on the menu 114 are stored in the food item database 222. The ingredient list includes the specific ingredients and the amount of each of the ingredients used to prepare the food item. The advance food preparation coordinator 222 retrieves the ingredient list for a food item that has been selected for advance preparation from the food item database 202. The advance food preparation coordinator 222 reviews an inventory of the ingredients used to prepare the food item available for use in the food preparation area 104. The advance food preparation coordinator 222 determines the batch size for the food item that has been selected for advance preparation based on the inventory of ingredients available to prepare the food item.
[0111] In an embodiment, advance food preparation coordinator 222 identifies the food items that can be prepared in advance and prioritizes the preparation of the food items that can be prepared in advance based on the order frequency of the food items. The advance food preparation coordinator 222 prioritizes the preparation of the food items that can be prepared in advance based on an analysis of historical food item order frequency data.
[0112]
[0113]
[0114] The payment module 1313 also coordinates with the reservations module 1311 and the orders module 1312 so that bill splitting, and other functions of payment maybe garnered. One example is that the reservations module informs the payment module which customers are seated at which tables. Some embodiments allow the payment module to directly communicate with the database 1320. The customer interaction module 1314 facilitates the customers interaction with the restaurant server 1310 via mobile devices 1330 such as smartphones, tablets, and e-readers, a website 1340, and via automated telephone calls (DTMF 1350).
[0115]
[0116] Micro-deals is one option that may be presented to a user using push notifications or simply by tapping the micro deals button 1410. Micro deals comprise discounts and incentives for customers to order and may be decided using predictive algorithms of inventory and stock or in times of slow business. Reservations 1420 is an option presented to a user such that they may make new reservations or change or cancel existing reservations. The order option 1430 allows a customer to place an order for food items. According to one embodiment, upon a customer clicking the order button 1430, a second menu will be displayed wherein the user may choose dine-in and be subsequently brought to the reservations menu 1420. In one embodiment, a waitlist option 1440 may be presented such that the user is presented with a series of options as disclosed in
[0117] Referring to
[0118]
[0119]
[0120]
[0121]
[0122]
[0123]
[0124] According to one embodiment, a machine learning engine performs analysis 2420 on the content 2410 producing a set of confidence scores relating to the positive, negative, or neutral sentiment of one or more pieces of content 2410. The range of sentiments may be increased in some embodiments. The sentiments of all the content are calculated 2430 comprising the steps of summing the implicit percentages, where negative sentiment results are treated as negative percentages and positive sentiment results are positive numbered percentages, equaling some numerical number representing all content sentiment. The larger the summation total is, the higher the rating and the more negative a summation total is, the more negative the rating is. The implicit ratings are then measured against a threshold 2440 to determine the number of stars received 2450. This threshold may be implemented as any range because each rating is normalized to a desired factor before output. The desired normalization factor is given in the API request. Additionally, the rating does not have to be stars, it may be numerical, lexiconic, symbolic, or any other such representation desired. Optionally, any explicit ratings available of the product are normalized to the same factor of the implicit score before both the normalized explicit rating and the normalized implicit rating are summed into a final rating that is output back to the requester. The order of summing, normalizing, and averaging is merely exemplary and deviations in the order of steps is trivial to those with ordinary skill in the art.
Detailed Description of Exemplazy Aspects
[0125] Referring to
[0126] The food order management system 102 generates an estimated food order preparation time based on the retrieved estimated food item preparation times for the food items in the food order at 706. The food order management system 102 assigns the food order to the earliest available food preparation time in the food preparation area 104 at 708 and generates a predicted food order ready time for the food order at 710. The predicted food order ready time is based on the assigned food preparation time and the estimated food order preparation time. The predicted food order ready time is the time when the completed food order is expected to be placed in the food order pick-up area 106.
[0127] The food order management system 102 issues a command to display the food order including the food items in the food order, the estimated food item preparation time for each of the food items in the food order, the estimated food order preparation time, and the predicted food order ready time on a food preparation display and to display the food order including the food items in the food order and the predicted food order ready time on a food order pick-up display at 712.
[0128] The food order management system 102 tracks the actual food item preparation times for each of the food items in the food order in the food preparation area 104 as each food item is being prepared at 714. The food order management system 102 adjusts the estimated food order preparation time and the predicted food order ready time for the food order to reflect any differences between the estimated food item preparation times and the actual food item preparation times for the food items in the food order at 716. The food order management system 102 updates the estimated food item preparation times for each of the food items in the food order in the food item database 204 based on the actual food item preparation times for the food items at 718.
[0129]
[0130] The food order management system 102 generates an estimated food order packaging time based on the retrieved estimated food item packaging times for the food items in the food order at 806. The food order management system 102 assigns the food order to the earliest available food packaging time in the food packaging area 108 at 808 and generates a predicted packaged food order ready time for the food order at 810. The predicted packaged food order ready time is based on the assigned food packaging time and the estimated food order packaging time. The predicted packaged food order ready time is the time when the packaged food order is expected to be placed in the delivery order area 110.
[0131] The food order management system 102 identifies a delivery route for the food order based on the food order delivery destination at 812 and assigns an earliest available delivery time for the delivery of the food order to the food order delivery destination at 814. The food order management system 102 receives delivery route specific data based on the identified delivery route and the received delivery route specific data at 816 and generates a predicted food order delivery time at 818. The predicted food order delivery time is the time that the food order is expected to be delivered to the food order delivery destination and is based on the predicted packaged food order ready time, the delivery route, the assigned delivery time, and the expected delivery route specific data.
[0132]
[0133] The food order management system 102 tracks the actual food preparation times for each of the food items in the food order in the food preparation area 104 as each food item is prepared, the actual food packaging times for each of the food items in the food order in the food packaging area 108 as each food item is packaged and any changes in the delivery route specific data at 822. The food order management system 102 adjusts the estimated food order packaging time, the predicted packaged food order ready time, and the predicted food order delivery time for the food order to reflect any changes in the delivery route specific data, differences between the estimated food item preparation times and the actual food item preparation times and/or differences between the estimated food item packaging times and the actual food item packaging times associated with the packaging of the food items at 824. The food order preparation system 102 updates the estimated food item packaging times for each of the food items in food item database 204 based on the actual food item packaging time for the food item at 826.
[0134]
[0135] The preliminary table turn-time estimate will suggest a particular group dynamic, but it is possible that actual group dynamics are different than expected. Group dynamics may be analyzed 1020 to determine whether they are as expected or predicted given the data retrieved at the previous step. Group dynamics may be obtained, for example, by comparing customer profiles obtained from each customer's mobile device 950 or stored in each customer's customer history data 962, or from manual inputs by restaurant staff. As one example, a comparison of the customer profiles for all of the customers at the table may indicate that, while they are there for a business meeting, they all have a strong interest in golf, which may lead them to stay at the table to discuss golf after the business meeting is concluded, leading to an automated table turn-time adjustment 1035. As another example, the table's server may notice that all of the members of the group are wearing shirts with logos of the local sports team, and that they've noticed that their team is playing a game being shown on the bar's television which may cause them to stay longer than expected. If the group dynamics are not as expected or predicted at an earlier stage 1030, the table's server may make a manual table turn-time adjustment 1035 to indicate the change in expected group dynamics, and the table turn-time may be updated, accordingly 1040.
[0136] Once the customers have ordered 1050, their orders may be checked 1060 against the customer history data 962 that was used to create the preliminary table turn-time estimate 1010. If the orders do not correspond to the customer history data 962, an adjustment may be made for special or unusual orders 1065. At this point, restaurant dynamics are checked 1070 to determine any known or predicted factors that may affect the table turn-time. Inputs may include data such as current prep time data 1041 and kitchen staff data 1042 from the food order management system 102, and server or wait staff data 1043 indicating the experience and efficiency of the staff. Final updates are made to the estimated table turn-time 1080, and restaurant and customer histories are updated in response 1090.
[0137]
[0138] The reservation is then analyzed to determine whether the reservation contains any special requests 1120, such as a request for seating at a table in front of the window or other special services the restaurant may offer, such as candle-lit dinners. If the reservation contains special requests, the reservation is tagged with any applicable special conditions 1130, such as a minimum order for that reservation or premium pricing like a surcharge for tables next to a window. The special request is then assigned priority 1140 such that the reservation is given priority over reservations that do not have a special request, and table assignments may be adjusted, accordingly. Table-by-table reservations data 921 are then retrieved, and the existing reservations shown in the data are checked to determine table availability for the requested reservation 1150. If reservations are available, but there are restrictions on the availability 1160, the reservation is tagged with restrictions 1170. As an example of a restriction on availability, a table may be available, but only for a time that is shorter than the standard table turn-time for that restaurant. The customer is then notified of any special conditions and restrictions associated with the requested reservation, if any, and the customer's approval of the special conditions and restrictions may optionally be required 1180. For example, it may be the case that a reservation contains a special request for a table by the window. A surcharge is applicable for reservation of window tables. A window table is available, but only for a 45 minute period. The customer is notified of the surcharge and availability restriction and the customer's approval of the availability restriction may be required. The notification may be by any means reasonably available in the situation, for example in person, by phone, by text message, or automatically through a website or an application running on the customer's mobile device 950. At this point, the requested reservation is allocated to a particular table for a particular time period 1190, and a number of updates are made to data, including updating the restaurant and customer histories 1191, updating the estimated table turn-times 1192, updating the table-by-table reservation data 1193, and updating the predicted schedule for subsequent time periods 1194, for example, subsequent days, weeks, or months.
[0139]
[0140]
[0141] Consider the initial state again 1701, where a customer is located somewhere other than the restaurant and now chooses order 1702 and subsequently dine-in 1705. The customer will then be brought to the menu option 1706 as before, however, now the waitlist algorithm 1200 will also work in parallel with the scheduling algorithm 1200 (via the reservations module) such that after the dine-in customer completes the food order, create new 1710 reservation will be presented to the customer, and the optimal time of arrival will be calculated at least based on waitlists, schedules, meal prep time, and customer travel time. If a reservation is successful and the customer wishes to change 1713 or cancel 1712 the existing 1711 reservation, an option to do so 1709 will be presented on the home screen of the application, according to one embodiment. Optionally, the make or manage reservation option 1709 may be displayed from the initial state of the application even when no existing reservation is made. To this end, the customer may make reservations without making predetermined food choices.
[0142] This diagram is merely exemplary. The order in which options are presented maybe altered and swapped to fit different applications or restaurant models. For example, the checkout option may be hidden from view unless an active reservation is found and subsequently presented on the home screen of the app or found under the make or manage reservation option, or both. Another example may comprise of having the make or manage reservation option on the home screen or place it under the order food option, or both. Therefore, it should be understood that the order of the steps may be done in any fashion as seen fit during implementation and the graphical layout and design of such as application may take many shapes and forms with the same overall intent for predictive algorithms and end-to-end contactless dining experience and management as disclosed herein.
[0143]
[0144] The data described in the above paragraph may be used to inform a first layer of machine learning algorithms 2020. Natural language processing algorithms 2021 allow the system to understand intentions and sentiments, facial recognition algorithms determine emotions and recognize faces, and actions algorithm 2023 may determine behaviors and mannerisms of customers as they move through physical space (blowing out birthday candles, arm-wrestling, eating fast or slow, laughing, etc.). The combination of these algorithms 2021-2023 may be used by graph-based neural networks 2030 to learn the true emotions 2031, relations 2032, and intentions 2033 of individuals which better allow the decision making of the system to choose the best candidates for notifications based on the context of the decision and business need. As an example, a customer may post a video on his or her feed claiming to thoroughly enjoy the food, however the natural language processing algorithm 2021 may detect voice inflections contrary to the sentiment spoken and a facial recognition algorithm 2022 may detect micro expressions of a fake smile. Analysis of conversations and all social media feeds are used to determine relations 2032 between patrons which may later be used to auto-notify groups of friends or family to visit an establishment.
[0145] An optional comparison layer 2040 may be used to cross-verify 2042 results from the machine learning algorithms of layer 1 2020 and layer 2 2030 by using existing databases 2041 containing voice inflection data, facial recognition patterns, and other existing data sources containing typical human behaviors.
[0146] An additional machine learning algorithm layer 2050 comprises an advertising algorithm 2052 informed with the emotions 2031, intentions 2033, and relations 2032 of patrons, as well as restaurant data 2051 comprising customer data 1321, staff data 1322, inventory data 1323, sales data 1324, meal prep times and data 1325, and real time feeds like weather 1326 may build a model that identifies the needs of the restaurant and patrons who have specific characteristics that can fill those needs, in order to benefit the establishment as well as provide personalized and useful advertisements for patrons containing historical media and content 2053 from the patrons social media feeds, online content, and customer profile.
[0147] As the system identifies restaurant needs and further identifies patrons who can fill those needs, those customers are sent notifications 2060 to their mobile devices. Customers may confirm or reject 2061 an offer to make a reservation or a deal given by the establishment via the system on his or her mobile device. Upon confirmation or rejection 2061 various modules within the system may be notified 2062. for example, if a customer accepts a reservation module will receive a notification 2062 as well as documenting it within the customer's profile. Notification 2062 of the rejection or confirmation also is fed back into the machine learning engine to better learn how to incentivize patrons.
[0148]
[0149] A first example of the algorithm may be where one or more staff members have called in sick 2122a. According to one embodiment where the system comprises a staffing and management module, or an embodiment where the attendance is recorded in the staff data 1322, or a combination of both, the absence of the staff member will trigger a search for patrons who through various advertisements may alleviate pressure off the short-handed staff. One such advertisement may be to identify patrons who typically frequent the establishment during this short-staffed time and offer them a discount for the next day, in the hopes they will not want to visit twice in a row.
[0150] A second example may be where an establishment has an overstock 2123a of a specific item, such as eggplant yakisoba. Such a quantity may be gleaned from the inventory data contained in the database. A trigger to identify patrons who typically enjoy eggplant yakisoba may be initiated. And according to one aspect, advertisements for 30% of eggplant yakisoba for the next two hours may be sent out to the identified patrons.
[0151] Yet a third example may comprise user configurations that desire weekly 2121a or monthly 2121b notifications of deals and opportunities. More advanced advertising algorithms may comprise monitoring users microphones and GPS devices to search for trigger words or spatial-activation boundaries respectively, such that notifications of advertisements and opportunities 2110 are generated based on passive monitoring and further customized via a customer's profile, social media feed, online content, and preferences. One example of passive monitoring advertisements may be if a patron passes by an establishment within 5 miles and he or she has not frequented in some specified time, a notification incentivizing them to visit may be generated. According to one aspect, the machine learning engine may identify one or two of the best posts on the user's feed to provide a nostalgic mechanism for incentivization. The ability for the machine learning engine to recognize the most memorable times at an establishment from a user's feed may be accomplished through the machine learning algorithms layer 2 2030 by scoring each post against a set of metrics such as elation, contentedness, happiness, etc.
[0152]
Hardware Architecture
[0153] Generally, the techniques disclosed herein may be implemented on hardware or a combination of software and hardware. For example, they may be implemented in an operating system kernel, in a separate user process, in a library package bound into network applications, on a specially constructed machine, on an application-specific integrated circuit (ASIC), or on a network interface card.
[0154] Software/hardware hybrid implementations of at least some of the aspects disclosed herein may be implemented on a programmable network-resident machine (which should be understood to include intermittently connected network-aware machines) selectively activated or reconfigured by a computer program stored in memory. Such network devices may have multiple network interfaces that may be configured or designed to utilize different types of network communication protocols. A general architecture for some of these machines may be described herein in order to illustrate one or more exemplary means by which a given unit of functionality may be implemented. According to specific aspects, at least some of the features or functionalities of the various aspects disclosed herein may be implemented on one or more general-purpose computers associated with one or more networks, such as for example an end-user computer system, a client computer, a network server or other server system, a mobile computing device (e.g., tablet computing device, mobile phone, smartphone, laptop, or other appropriate computing device), a consumer electronic device, a music player, or any other suitable electronic device, router, switch, or other suitable device, or any combination thereof. In at least some aspects, at least some of the features or functionalities of the various aspects disclosed herein may be implemented in one or more virtualized computing environments (e.g., network computing clouds, virtual machines hosted on one or more physical computing machines, or other appropriate virtual environments).
[0155] Referring now to
[0156] In one aspect, computing device 10 includes one or more central processing units (CPU) 12, one or more interfaces 15, and one or more busses 14 (such as a peripheral component interconnect (PCI) bus). When acting under the control of appropriate software or firmware, CPU 12 may be responsible for implementing specific functions associated with the functions of a specifically configured computing device or machine. For example, in at least one aspect, a computing device 10 may be configured or designed to function as a server system utilizing CPU 12, local memory 11 and/or remote memory 16, and interface(s) 15. In at least one aspect, CPU 12 may be caused to perform one or more of the different types of functions and/or operations under the control of software modules or components, which for example, may include an operating system and any appropriate applications software, drivers, and the like.
[0157] CPU 12 may include one or more processors 13 such as, for example, a processor from one of the Intel, ARM, Qualcomm, and AMD families of microprocessors. In some aspects, processors 13 may include specially designed hardware such as application-specific integrated circuits (ASICs), electrically erasable programmable read-only memories (EEPROMs), field-programmable gate arrays (FPGAs), and so forth, for controlling operations of computing device 10. In a particular aspect, a local memory 11 (such as non-volatile random access memory (RAM) and/or read-only memory (ROM), including for example one or more levels of cached memory) may also form part of CPU 12. However, there are many different ways in which memory may be coupled to system 10. Memory 11 may be used for a variety of purposes such as, for example, caching and/or storing data, programming instructions, and the like. It should be further appreciated that CPU 12 may be one of a variety of system-on-a-chip (SOC) type hardware that may include additional hardware such as memory or graphics processing chips, such as a QUALCOMM SNAPDRAGON™ or SAMSUNG EXYNOS™ CPU as are becoming increasingly common in the art, such as for use in mobile devices or integrated devices.
[0158] As used herein, the term “processor” is not limited merely to those integrated circuits referred to in the art as a processor, a mobile processor, or a microprocessor, but broadly refers to a microcontroller, a microcomputer, a programmable logic controller, an application-specific integrated circuit, and any other programmable circuit.
[0159] In one aspect, interfaces 15 are provided as network interface cards (NICs). Generally, NICs control the sending and receiving of data packets over a computer network; other types of interfaces 15 may for example support other peripherals used with computing device 10. Among the interfaces that may be provided are Ethernet interfaces, frame relay interfaces, cable interfaces, DSL interfaces, token ring interfaces, graphics interfaces, and the like. In addition, various types of interfaces may be provided such as, for example, universal serial bus (USB), Serial, Ethernet, FIREWIRE™, THUNDERBOLT™, PCI, parallel, radio frequency (RF), BLUETOOTH™, near-field communications (e.g., using near-field magnetics), 802.11 (WiFi), frame relay, TCP/IP, ISDN, fast Ethernet interfaces, Gigabit Ethernet interfaces, Serial ATA (SATA) or external SATA (ESATA) interfaces, high-definition multimedia interface (HDMI), digital visual interface (DVI), analog or digital audio interfaces, asynchronous transfer mode (ATM) interfaces, high-speed serial interface (HSSI) interfaces, Point of Sale (POS) interfaces, fiber data distributed interfaces (FDDIs), and the like. Generally, such interfaces 15 may include physical ports appropriate for communication with appropriate media. In some cases, they may also include an independent processor (such as a dedicated audio or video processor, as is common in the art for high-fidelity A/V hardware interfaces) and, in some instances, volatile and/or non-volatile memory (e.g., RAM).
[0160] Although the system shown in
[0161] Regardless of network device configuration, the system of an aspect may employ one or more memories or memory modules (such as, for example, remote memory block 16 and local memory 11) configured to store data, program instructions for the general-purpose network operations, or other information relating to the functionality of the aspects described herein (or any combinations of the above). Program instructions may control execution of or comprise an operating system and/or one or more applications, for example. Memory 16 or memories 11, 16 may also be configured to store data structures, configuration data, encryption data, historical system operations information, or any other specific or generic non-program information described herein.
[0162] Because such information and program instructions may be employed to implement one or more systems or methods described herein, at least some network device aspects may include nontransitory machine-readable storage media, which, for example, may be configured or designed to store program instructions, state information, and the like for performing various operations described herein. Examples of such nontransitory machine-readable storage media include, but are not limited to, magnetic media such as hard disks, floppy disks, and magnetic tape; optical media such as CD-ROM disks; magneto-optical media such as optical disks, and hardware devices that are specially configured to store and perform program instructions, such as read-only memory devices (ROM), flash memory (as is common in mobile devices and integrated systems), solid state drives (SSD) and “hybrid SSD” storage drives that may combine physical components of solid state and hard disk drives in a single hardware device (as are becoming increasingly common in the art with regard to personal computers), memristor memory, random access memory (RAM), and the like. It should be appreciated that such storage means may be integral and non-removable (such as RAM hardware modules that may be soldered onto a motherboard or otherwise integrated into an electronic device), or they may be removable such as swappable flash memory modules (such as “thumb drives” or other removable media designed for rapidly exchanging physical storage devices), “hot-swappable” hard disk drives or solid state drives, removable optical storage discs, or other such removable media, and that such integral and removable storage media may be utilized interchangeably. Examples of program instructions include both object code, such as may be produced by a compiler, machine code, such as may be produced by an assembler or a linker, byte code, such as may be generated by for example a JAVA™ compiler and may be executed using a Java virtual machine or equivalent, or files containing higher level code that may be executed by the computer using an interpreter (for example, scripts written in Python, Perl, Ruby, Groovy, or any other scripting language).
[0163] In some aspects, systems may be implemented on a standalone computing system. Referring now to
[0164] In some aspects, systems may be implemented on a distributed computing network, such as one having any number of clients and/or servers. Referring now to
[0165] In addition, in some aspects, servers 32 may call external services 37 when needed to obtain additional information, or to refer to additional data concerning a particular call. Communications with external services 37 may take place, for example, via one or more networks 31. In various aspects, external services 37 may comprise web-enabled services or functionality related to or installed on the hardware device itself. For example, in one aspect where client applications 24 are implemented on a smartphone or other electronic device, client applications 24 may obtain information stored in a server system 32 in the cloud or on an external service 37 deployed on one or more of a particular enterprise's or user's premises. In addition to local storage on servers 32, remote storage 38 may be accessible through the network(s) 31.
[0166] In some aspects, clients 33 or servers 32 (or both) may make use of one or more specialized services or appliances that may be deployed locally or remotely across one or more networks 31. For example, one or more databases 34 in either local or remote storage 38 may be used or referred to by one or more aspects. It should be understood by one having ordinary skill in the art that databases in storage 34 may be arranged in a wide variety of architectures and using a wide variety of data access and manipulation means. For example, in various aspects one or more databases in storage 34 may comprise a relational database system using a structured query language (SQL), while others may comprise an alternative data storage technology such as those referred to in the art as “NoSQL” (for example, HADOOP CASSANDRA™, GOOGLE BIGTABLE™, and so forth). In some aspects, variant database architectures such as column-oriented databases, in-memory databases, clustered databases, distributed databases, or even flat file data repositories may be used according to the aspect. It will be appreciated by one having ordinary skill in the art that any combination of known or future database technologies may be used as appropriate, unless a specific database technology or a specific arrangement of components is specified for a particular aspect described herein. Moreover, it should be appreciated that the term “database” as used herein may refer to a physical database machine, a cluster of machines acting as a single database system, or a logical database within an overall database management system. Unless a specific meaning is specified for a given use of the term “database”, it should be construed to mean any of these senses of the word, all of which are understood as a plain meaning of the term “database” by those having ordinary skill in the art.
[0167] Similarly, some aspects may make use of one or more security systems 36 and configuration systems 35. Security and configuration management are common information technology (IT) and web functions, and some amount of each are generally associated with any IT or web systems. It should be understood by one having ordinary skill in the art that any configuration or security subsystems known in the art now or in the future may be used in conjunction with aspects without limitation, unless a specific security 36 or configuration system 35 or approach is specifically required by the description of any specific aspect.
[0168]
[0169] In various aspects, functionality for implementing systems or methods of various aspects may be distributed among any number of client and/or server components. For example, various software modules may be implemented for performing various functions in connection with the system of any particular aspect, and such modules may be variously implemented to run on server and/or client components.
[0170] The skilled person will be aware of a range of possible modifications of the various aspects described above. Accordingly, the present invention is defined by the claims and their equivalents.