Re-computing pre-computed query results
Pre-computed query results stored at a database server are re-computed by a computation machine. The pre-computed query results are composed of a plurality of shares. Each share includes a certain number of pre-computed query results. The computation resources of the computation machine needed to re-compute a pre-computed query result of a first share depend on whether or not other pre-computed query results of the first share are re-computed during a given time interval forming a current re-computation cycle. The computation machine receives a request to re-compute pre-computed query results of at least a first share, determines a number of pre-computed query results in the first share to be re-computed in the current re-computation cycle based on a Reinforcement Learning algorithm, and re-computes the determined number of pre-computed query results in the first share.
Latest Amadeus S.A.S. Patents:
- Device, system and method for reducing bandwidth usage by performing provider object adjustments at an intermediation server based on historical data
- Auxiliary control mechanisms for complex query processing
- Device, system and method for processing images that include amounts
- Context based computing resource intermediation engine
- Statistics-based dynamic database partitions
The present invention generally relates to database technology and, more specifically, is directed to re-computing pre-computed search results stored as database records.
BACKGROUNDA common problem in database technology is to ensure short response times to database queries or requests which require complex, long and resource-intensive processing, e.g., due to large volumes of data. For example, such computing-power consuming processing has to be performed in response to so-called “open queries” which contain only little input information (e.g., only one or two parameters out of a dozen possible parameters are specified and/or the specified value ranges of the parameters are broad) and, consequently, lead to a large number of results in general. Possibilities to speed up data processing by increasing hardware performance are limited. Thus, attention is drawn to improving the mechanisms underlying the complex, long and resource-intensive processing in order to respond to such queries.
One general approach to shorten response times is to prepare results to be returned in response to expected requests (e.g., by pre-computing or pre-collecting such results) and to maintain the corresponding query results in a pool of pre-computed query results. Requests are then actually not processed and responses on the basis of the large original data basis, but are directed to the pool of pre-computed query results.
Re-computing a large number of pre-computed query results is a task consuming a substantial amount of computation resources. Thus, re-computation mechanisms are sought to efficiently perform the re-computation of pre-computed query results.
SUMMARYAccording to an embodiment, a computation machine for re-computing pre-computed query results stored at a database server is provided. The pre-computed query results are composed of a plurality of shares. Each share includes a certain number of pre-computed query results. The computation resources of the computation machine needed to re-compute a pre-computed query result of a first share depend on whether or not other pre-computed query results of the first share are re-computed during a given time interval. The given time interval forms a current re-computation cycle. The computation machine is arranged to receive a request to re-compute pre-computed query results of at least a first share. The computation machine is further arranged to determine a number of pre-computed query results in the first share to be re-computed in the current re-computation cycle based on a Reinforcement Learning algorithm. The determined number of pre-computed search results is limited by the computation machine's computation resources available during the given time interval. The computation machine is further arranged to re-compute the determined number of pre-computed query results in the first share.
According to an embodiment, a corresponding method executed by a computation machine is provided. The method is directed to re-computing pre-computed query results stored at a database server. The pre-computed query results are composed of a plurality of shares. Each share includes a certain number of pre-computed query results. Computation resources of the computation machine needed to re-compute a pre-computed query result of a first share depend on whether or not other pre-computed query results of the first share are re-computed during a given time interval forming a current re-computation cycle. The method includes receiving a request to re-compute pre-computed query results of at least a first share and determining a number of pre-computed query results in the first share to be re-computed in the current re-computation cycle based on a Reinforcement Learning algorithm. The determined number of pre-computed search results are limited by the computation resources of the computation machine that are available during the given time interval. The method further includes re-computing the determined number of pre-computed query results in the first share during the re-computation cycle.
According to an embodiment, a computer program stored on a storage medium is provided which, when executed by a computation machine, equips the computation machine with the corresponding functionality set forth above.
The above summary may present a simplified overview of some embodiments of the invention in order to provide a basic understanding of certain aspects of the invention discussed herein. The summary is not intended to provide an extensive overview of the invention, nor is it intended to identify any key or critical elements, or delineate the scope of the invention. The sole purpose of the summary is merely to present some concepts in a simplified form as an introduction to the detailed description presented below.
The accompanying drawings, which are incorporated in and constitute a part of this specification, illustrate various embodiments of the invention and, together with the general description of the invention given above, and the detailed description of the embodiments given below, serve to explain the embodiments of the invention. Similar reference numbers generally indicate identical or functionally similar elements.
In order to be able to handle database queries or batch computation requests which require computations on the basis of large volumes of underlying data, search results corresponding to expected queries are generally pre-computed and stored as database records in a database. This database is queried by requesting entities (such as clients, applications, browsers installed on user terminals, etc.) in the course of a search and pre-computed search results fulfilling search criteria indicated by the query are returned to the client in response to the query. Subsequently, the term “query” is used as a general term including any type of information retrieval requests such as transactional queries, requests for batch computations and other forms.
The approach of pre-computing search results and storing them in the search platform accessible to querying clients leads to the general situation that the calculation data may change over time and, thus, the pre-computed search results get outdated or invalid (both terms are used synonymously herein). Pre-computed search results which are still up-to-date, i.e., which match the corresponding real-time computation equivalents (results which would be actually computed on demand without having pre-computed search results available), are called “accurate” pre-computed search results hereinafter. Thus, when the search platform keeping the pre-computed search results correctly represents the current state of the data domain underlying the cached query results, i.e., the calculation data, the pre-computed search results stored in the search platform are—in general—accurate.
Generally, to enable the search platform to return correct results, one wants to maintain a high degree of correlation between pre-computed search results which are provided to the querying entity in response to database queries and their real-time computation equivalents. At the same time, however, it is desirable to minimize computation resource consumption caused by re-computations, i.e., to avoid any unnecessary re-computations such as re-computation of still accurate cached query results. Computing resources are limited and, generally, there are not enough computing resources to re-compute all pre-computed search results at all times. Thus, a trade-off between pre-computed query results accuracy and utilization of the available computing power is to be found.
In order to render re-computation more efficient, metrics are defined to evaluate how “necessary” or “unnecessary” a re-computation is. For instance, it is not worth reshooting an entire massive pre-computation every day if less than half of the computed query results turn out to be outdated. On the other hand, if particular classes of query results are known to change frequently, re-computing them several times per day might be beneficial for the accuracy. Consequently, an effective way of assessing or estimating search result accuracy is needed, generally taking into account both the associated gain on accuracy and the cost of re-computation. To this end, some mechanisms model the decreasing validity of pre-computed query results over time. Two exemplary functions of this probable accuracy decreasing over time are depicted by
Often, considerations of re-computing pre-computed query results assume that re-computation of any pre-computed search result by the computation platform 3 requires substantially the same amount of computation resources irrespective of whether the pre-computed search results are computed separately, together with related pre-computed query results (e.g., same origin, destination and adjacent dates) or any other unrelated query results. In practice, however, this assumption cannot be made in general because, for example, certain pre-computed query results and/or their corresponding underlying calculation data are interrelated to each other. Re-computing such interrelated pre-computed query results together (i.e., within the same re-computation cycle) could include synergetic effects and may thus be more efficient than re-computing them separately. Thus, when interrelated pre-computed query results are re-computed together the computation costs per individual pre-computed query result is generally less than the computation cost per individual pre-computed query result required if they are re-computed separately, i.e., in different re-computation cycles.
To promote understanding of interrelated pre-computed search results, a particular example is given next. This example originates from a particular application of the distributed database environment 1 in the travel industry, i.e., the database 4 keeps travel-related pre-computed search results and makes them available to end users. The following example, however, is not supposed to limit the issue of interrelated pre-computed search results such a travel data application. Rather, similar or analog conditions allowing a synergetic and therefore more efficient re-computation of interrelated pre-computed search results are present in database systems independent from the content of pre-computed data sets. In general, it can be said that any process of re-computing pre-computed search results will aim at a mutualization of re-computation sub-tasks that have to be executed commonly for any pre-computed search result of a set of pre-computed search results. Thus, re-computing pre-computed search results together that have such re-computation sub-tasks in common is generally favorable over re-computing pre-computed search requests together which do not share similar re-computation sub-tasks.
In a particular embodiment, the pre-computed search requests are round-trip flight data records, each specifying a travel origin and destination and a departure and arrival date (or, alternatively to the arrival date, a stay duration relating to the departure date). In this example, the database 4 contains pre-computed round-trip travel recommendations for any origin-destination pair and any departure-arrival-date pair to be covered. Table 1 indicates a small excerpt from the pre-computed travel recommendations kept in database 4, the excerpt being travel recommendations for the city pair Nice-Boston (“NCE-BOS”) and for departure dates from 1st July to 5th July with maximum stay duration of five days, the abbreviation “pc-fr x” standing for “pre-computed travel recommendation number x”.
The re-computation of a particular pre-computed travel recommendation, for example pc-fr 9 relating to a departure date of 2nd July and a return date of 7th July, is roughly performed by the computation platform 3 by the following sub-tasks. The possible geographic routes between Nice and Boston including intermediate stops/change, for example: Nice-Paris-Boston, Nice-London-Boston, Nice-New York-Boston, Nice-Paris-New York-Boston, etc. are retrieved. All the possible flights, for example Air France 123 and Emirates 7123 on the leg Nice-Paris, Air France 456 and American Airlines 564 and United Airlines 125 on the leg Paris-New York, etc., on all the routes retrieved by activity 1 are found. This activity is performed for the outward part of the travel on the departure date 2nd Jul (sub-task 2a) and for the return part of the travel on the return date 7th July (sub-task 2b) because flights are generally not available on all days. The availability on all the flights determined by activities 2a and 2b, i.e., on 2nd Jul for the outbound part of the journey (=sub-task 3a) and on 7th Jul for the return part of the journey (=sub-task 3b), is checked. Fares are retrieved that can be applied to these flights on these dates. A typical fare is rule which yields a price for the whole journey. However, fares may also be valid for the outbound and for the inbound part of the journey on their respective dates in which case they can be retrieved once for the outbound part (=sub-task 4a) and once for the return part of the journey (=sub-task 4b). Fares have restrictions on the departure dates, on the return dates, on the flights to be applied on, and many others. Fares can be combined together, discounted in some specific cases and so on. The best solution, i.e., the connection with the best price, is kept, returned by the computation platform 3 and stored by the database 4 as pc-fr 9.
These sub-tasks are performed in a similar fashion for any pre-computed travel recommendation. When performing the re-computation for the whole set of pre-computed travel recommendations (pc-fr 0 to pc-fr 24), several re-computation sub-tasks can be mutualized. Executing sub-task 1 is necessary only once for the whole set of pre-computed travel recommendations pc-fr 0 to pc-fr 24 because all these pre-computed travel recommendations belong to the same origin-destination city pair Nice-Boston. Thus, sub-task 1 does not need to be re-done for every pre-computed search result pc-fr 0 to pc-fr 24.
The sub-tasks 2a, 3a and sub-task 4 are, on the other hand, specific to one departure date. They can therefore be re-used for all pre-computed travel recommendations relating to one and the same departure date. Table 2 indicates this for the pre-computed travel recommendations pc-fr 5 to pc-fr 9 relating to the departure date of 2nd July:
Likewise, the sub-tasks 2b, 3b and 4b are specific to one return date and, thus, are commonly performed for pre-computed travel recommendations relating to one and the same return date. This is illustrated by table 3 for the pre-computed travel recommendations pc-fr 9, pc-fr 13, pc-fr 17 and pc-fr 21, all of which refer to the return date of 7th July:
Thus, in summary, only a part of sub-task 4, namely retrieving such fares which are not valid for the whole outbound part of the travel and for the whole return part of the travel, but are specific for sub-sets or particular travel recommendations, has to be performed separately for each pre-computed travel recommendation, while the other sub-tasks can be performed in common for all pre-computed travel recommendations relating to the same origin-destination city pair (true for sub-task 1) or at least for pre-computed travel recommendations relating to the same departure date (sub-tasks 2a, 3a and 4a) or to the same return date (sub-tasks 2b, 3b and 4b). Consequently, the more pre-computed travel recommendations relate to one origin-destination city pair and the more pre-computed travel recommendations relate to one departure date and return date, respectively, the more computation resources can be spared by mutualizing these sub-tasks across the respective pre-computed flight requests.
This relationship between increasing synergetic effects with an increasing number of pre-computed travel recommendations relating to an origin-destination city pair and to one departure or return date is also visualized by
On the one hand,
In other words, the computation resources needed to re-compute a pre-computed search result i generally depend on whether or not other pre-computed search results related to the pre-computed search result i are re-computed during the same computation cycle. Thus, the computation resources to re-compute the pre-computed search results are not static, but vary with the selection of the set of pre-computed search results to be re-computed during the computation cycle.
Hence, a mechanism for dynamically determining an optimal number of pre-computed query results of a share to be re-computed during a computation cycle (briefly referred as “re-computation number” hereinafter) to optimize efficient utilization of re-computation resources is sought. At the same time, the mechanism should minimize wasting computation resources due to re-computing pre-computed query results which are still valid and do not need any re-computation. Furthermore, the mechanism should not compromise stability of the re-computation machine, but ensure its robustness.
The system 1 of
The re-computation controller 2 regularly triggers re-computation of pre-computed query results by sending 16 re-computation requests (possibly based on re-computation schedules 12) to the computation unit 3. For example, at some point of time, the re-computation controller 2 decides to re-compute one or more particular shares of pre-computed query results (also referred to as the “at least one first share”) and triggers a re-computation of this one or more shares. Each time the re-computation controller 2 requests 16 re-computation of certain pre-computed query results during a new computation cycle, the computation machine 3 retrieves relevant data from the self-tuning sub-system 6 to decide the policy to determine the number of pre-computed query results to be re-computed in the respective shares of pre-computed query results. A safe-guard mechanism process 22 provides a certain quality of the decision of the number of pre-computed query results to be re-computed which may lead to a potential dynamic realignment of the decision at the current instance and over time. An asynchronous process 24 collects from the statistics server sub-system 7 the statistics data from past re-computations (which have been posted 20 to the statistics server sub-system 7) to fine-tune the decisions over time. The re-computations of the computation machine 3 itself are based on further computation data, in the example of
There is no existing model that could be readily used to attribute an optimal re-computation number to a given share of pre-computed query results in order to re-compute the pre-computed query results of the share during a computation cycle. On the one hand, the synergistic effects of re-computing a number of related pre-computed query results depend on the specific use-case of the database system and the characteristics of the pre-computed query results in terms of their interrelation and decreasing validity over time. On the other hand, the optimal number of related pre-computed query results to be re-computed also depends on the re-computation strategy employed (e.g., always re-compute pre-computed query results with the least probability of being up-to-date). Furthermore, options may be included in computation triggers 16 from the re-computation controller 2 which have an—a priori unknown—influence which pre-computed query results may be more important to be valid/accurate than others.
In order to address these bars, it is therefore generally proposed herein to utilize a learning algorithm which dynamically optimizes the decision of the number pre-computed query results to be re-computed during a computation cycle over time, independent from the a priori unknown influences mentioned before. However, it does not seem possible to use a standard supervised learning algorithms, i.e., an algorithm that is solely based on the knowledge of an expert such as a Neural Network, since there is no knowledge of which re-computation number is optimal for a given share of pre-computed query results. Such algorithms would require to be trained on a database associating computation triggers 16 from the re-computation controller 2 with their best respective re-computation number for each share to be re-computed. However, the required expert knowledge is generally not available.
Another way to build this database would be to use a brute force approach to permute all possible re-computation numbers for a given computation trigger 16 from the re-computation controller 2. This could yield a determination which re-computation number is the most appropriate to the computation trigger 16. However, this approach has several drawbacks, as it would take a lot of time and hardware to gather all these statistics. Furthermore, this only establishes static re-computation numbers and there could therefore be discrepancies between current status of this database and the moment it is employed by the computation machine 3. This would expose the overall system 1 (
As a consequence, it is proposed to train the learning algorithm continuously in the course of processing each computation trigger 16 from the re-computation controller 2. An algorithm driven by trial and error appears to be suitable which rates the result of a decision of the re-computation number in response to receiving a computation trigger 16. The rating could, for example, utilize thresholds of a number of key performance indicators to judge the quality of the decision. Algorithms from the Reinforcement Learning family seem to be the most suited to this task.
Hence, the computation machine 3 is enhanced with the self-tuning module 6 implementing a Reinforcement Learning (RL) algorithm to determine an optimum number of pre-computed query results in a share to be re-computed during a computation cycle. More specifically, the computation machine 3 receives a request 16 to re-compute pre-computed query results of at least a first share. The computation machine 3, more specifically its self-tuning sub-system 6, determines a number of pre-computed query results in the first share to be re-computed in the current re-computation cycle based on a Reinforcement Learning algorithm. The determined number of pre-computed search results are limited by the computation machine's computation resources available during the given time interval. The computation machine 3 then re-computes the determined number of pre-computed query results in the first share during the computation cycle.
In some embodiments, the RL learning algorithm described herein considers key performance indicators (KPIs) and examines impacts of respective decisions of the number pre-computed query results to be re-computed during a computation cycle on the KPIs. Expert knowledge may be used to determine e.g., which options of computation triggers 16 from the re-computation controller 2 do not have an influence on the KPIs—this can be used to reduce the dimensionality of the learning space.
In some embodiments, the KPIs include one or more of the following factores: sum of numbers of pre-computed query results to be re-computed, elapsed time of re-computing the pre-computed query results to be re-computed in the given time interval, maximum computation resources to re-compute pre-computed query results indicated in the request, and maximum of memory required to re-compute pre-computed query results indicated in the request. In some embodiments, the values of the KPIs are aggregated to an aggregated value of KPIs as explained in more detail below. In some embodiments, the KPI may be hierarchically defined, with more general KPIs being composed of a number of more specific KPIs. This allows a fine-grained assessment of the technical effect, i.e., an efficient usage of computation resources due to an optimal number of pre-computed query results selected for re-computation. KPI aggregation is then at each hierarchy level, where the number of more specific KPIs are aggregated to form the more general KPI and the more general KPIs are aggregated to establish a common reward value for a certain action, as explained in more detail further below.
Before we turn to more detailed design options for a RL algorithm to solve the above-mentioned technical problem, we first give an overview of some concepts of Reinforcement Learning. Reinforcement Learning mechanisms are also described, for example, by the textbook “Reinforcement Learning” by Richard S. Sutton and Andrew G. Barto, published by the MIT Press in 1998. RL mechanisms utilize terms having an established meaning and are used herein in this established meaning to describe the algorithm for determining an optimal re-computation number, including (see
The goal of the agent is to maximize the rewards not immediate, but in the long run. A general feature of Reinforcement Learning is the trade-off between exploration and exploitation. In exploration mode, the agent tries out new kinds of actions to see how effective they are. The effectiveness of an action is immediately given by the reward returned to the agent in response to the selected action. In exploitation mode, the agent makes use of actions that are known to yield a high reward using of the history of rewards derived from the value function. More specifically, during each exploitation phase, the re-computation number is determined that is, according to expert knowledge database, currently known to yield the most rewards. The aim is to maximize the rewards on the long run (mathematically, this means that the sum of all rewards on an infinite lifespan is maximized). Generally, in exploitation mode, the algorithm tries to make profit of what it has learned, whereas the exploration mode can be considered as an “investment” to look for other opportunities to further optimize the determination of the re-computation number.
The agent continuously learns in exploration and in exploitation mode from its environment. However, exploration and exploitation should be balanced. Too strong a focus on either exploration or exploitation will yield poor results. The agent may explore to discover new strategies that could potentially yield a very high reward, but exploring too much may be dangerous because the agent never uses its knowledge of the environment. A strategy to balance these two modes to solve the particular technical problem discussed herein will be presented further below.
Some particularities of the reward function design to implement the computation machine 3 with the self-tuning sub-system 6 are described next. The main issue that should be avoided are technical rejects, i.e., failure states of the computation machine 3 caused by an inappropriate re-computation number which results in a rejection message to a computation trigger 16. Hence, a high penalty is attributed to the agent in such a case.
On the other hand, the agent should not over-react. It is possible to have instabilities of the computation machine 3 which could generate technical rejects and which are not due to the actions taken by the agent. To this end, in some embodiments, the re-computation numbers which ended in technical rejects (RcNbTR) are related to the re-computation numbers that did not end in a technical reject (RcNbOK). Hence, in some embodiments, the first term of the reward function is defined with the following formula:
with PENALTYTR(X)=exp(X), i.e. an exponential function.
Furthermore, a set of KPI thresholds is utilized in some embodiments. These KPI thresholds are limits that should not be exceeded by the actions of the agent. Therefore, these KPI thresholds should be wisely determined e.g., with the help of domain experts of the system 1 (
In order to increase safe actions by the agent, an additional level of safety is taken in some embodiments. The threshold is taken as a given percentage of the actual threshold from which a technical reject would actually be generated (“hard threshold”). This yields three possible states: acceptable (below the threshold), warning (above the threshold, but still below the hard threshold), and technical reject (above the hard threshold). In this way, a safety margin in introduced below the hard threshold:
THRESHOLDKPI
In response to determining that all KPIs are below their corresponding threshold after the agent has taken a certain agent, the reward value is positive. The closer a KPI is located to its threshold, the higher the attributed reward is. But if a KPI exceeds its threshold (“warning” state), the system is rewarded with a negative reward. A negative reward is also referred to as a penalty.
Optionally, the KPIs are normalized by their threshold to enable faster comparisons. So, in some embodiment, a second term of the reward function is given by:
where, for each KPI, the reward is positive (multiplied by a positive factor “positive reward” PR) if the threshold is kept, but negative (multiplied by a negative factor “negative reward” NR) if the threshold is exceeded:
The parameters MARGINTHRESHOLD(KPI
In summary, in some embodiments, the global reward function is defined as:
An example is given by
Some particularities of the value function design to implement the computation machine 3 with the self-tuning sub-system 6 are described next. As mentioned above, the value function is a table that associates a set of N possible actions, namely the number of pre-computed query results of a share to be re-computed during the computation cycle, Wi, with their estimated rewards. In some embodiments, estimated rewards associated by the value function are specified by a reward function of the Reinforcement Learning algorithm, such as the reward function example described above. As described above, the reward function may attribute an aggregated value of a plurality of key performance indicators to a corresponding selection of pre-computed query results of the least one first share.
In some embodiments, the value function is computed iteratively from a history of previously received rewards (indexed with k, which represents the kth iteration). The value function V of re-computation number Wi is therefore in some embodiments:
Vk+1(Wi)=Vk(Wi)+α(k+1)(Wi)*(REWARD(k+1)(Wi)−Vk(Wi))
where αk(Wi) is the learning speed parameter (or step-size parameter) used to process the reward after the kth selection of the re-computation number Wi.
In this regard, two Reinforcement Learning formulas are used to insure a convergence of the RL algorithm. The first formula provides that the learning steps are large enough to eventually overcome any initial conditions or random fluctuations:
The second one is given by:
Since the system 1 is non-stationary, i.e., the system's behavior will vary with time such that the optimal re-computation numbers will change, this second condition cannot be respected. Indeed, the system never completely converges because it needs to continually adapt to change that may occur.
In some embodiments, the learning speed parameter αk (Wi) is given a higher influence to the latest rewards and is adapted to the system's situation to provide further learning optimization, including the state of the environment and the mode of the RL algorithm. The current mode is either exploration or exploitation. As the decisions should be conservative in order to avoid failures, the learning should be performed less actively in exploration mode, i.e., the agent learns, but safely. Conversely, in exploitation mode, a modification of behavior has to be taken into account more quickly. The code load indicator indicates a recent software update for the computation machine 3. If the code load indicator is set to true, then the system has to learn more quickly as a code load can induce quick and real KPIs variation which do not indicate any system instability
The step-size parameter is then a function of a system's situation S (k) and a α constant:
The variables α, ER, and CL are tuned with an empirical approach (e.g., by using knowledge of a domain expert) to obtain the wished behavior.
The learning speed parameters should ensure that, in the case of one negative reward integration, the value function is not too much degraded, as it can be due to some system instability:
Vk+1(Wi)<Vk(Wi)
After SN successive negative rewards, the RL algorithm should force the system to quickly react and re-determines a new policy from where to start:
Vk+SN(Wi)<0
At this stage, the certainty of the value function is questionable. It is likely that the value function for other re-computation numbers is incorrect. So the first approach, could be to use a “brute approach” to arbitrarily set the new restart learning point to:
re-computation numberNew=DF·re-computation numberOld
where 0<DF<1 is a degradation factor.
In some embodiments, the request to re-compute pre-computed query results of at least a first share (=computation trigger 16 in the example of
In these embodiments, the computation machine 3 is optionally arranged to determine the number of pre-computed query results in the first share to be re-computed based on the indicated pre-computed query results of the at least first share. For example, the computation resources of the computation machine 3 may allow to re-compute 100 pre-computed query results in the next three computation cycles. In this situation, the computation platform is arranged to select an optimal number of pre-computed query results to be re-computed during the next computation cycle by splitting the portion of the first share defined by the number indicated in the request 16 into three slices, where the split results in slices which utilize the available computation resources in an optimal manner. Each of the three slices is re-computed during the next three (or three of the next) computation cycles. A further, more specific example of such split is given below.
More particularities of the Reinforcement Learning algorithm design to implement the computation machine 3 with the self-tuning sub-system 6 are described next with reference to
In parallel to these activities (
More details of the RL mode determination are described next. As explained in the introduction on Reinforcement Learning above, a balanced tradeoff is sought between these two modes.
Two known balancing methods are the Epsilon-Greedy strategy and the Softmax strategy. The Epsilon-Greedy strategy explores new strategies a given percentage of the time, and exploits the action with the highest reward the rest of the time (greedy action). For example, the system could explore 1% of the time (by choosing at random an action among the set of possible actions) and exploit the rest (99%) of the time (use the best rated action). The Softmax strategy addresses one drawback of the Epsilon, namely exploring by equally choosing among all actions. This means that it is as likely to choose the worst-appearing action as it is to choose the next-to-best action. In tasks where the worst actions are bad, this may be disadvantageous. The Softmax strategy therefore refines the Epsilon-Greedy strategy by varying the action probabilities as a graded function of estimated value.
The balancing strategy used in some embodiments herein is different from these two known strategies. At a general level, the computation machine 3 is arranged to retrieve an indication of pre-computed query results of the at least one first share which have been re-computed in a previous time interval, i.e., the last re-computation number as explained above. The computation machine 3 is further determined to apply an exploitation mode of the Reinforcement Learning algorithm or to apply an exploration mode of the Reinforcement Learning algorithm. In some embodiments, the computation machine 3 determines to apply either the exploitation mode of the Reinforcement Learning algorithm or to apply the exploration mode of the Reinforcement Learning algorithm determining the reward given by the value function for the pre-computed query results indicated by the retrieved indication and by determining a number of re-computation cycles to apply the exploitation mode of the Reinforcement Learning algorithm based on a comparison of the determined reward with a reward threshold. In some embodiments, the reward threshold is defined by given percentages of threshold values of respective ones of the plurality of key performance indicators for which re-computation during the given time interval would result in an error state of the computation machine. As described below, this introduces an additional safety net avoiding technical failure states of the computation machine 3 caused by the RL algorithm. The computation machine 3 applies the exploitation mode of the Reinforcement Learning algorithm during the current re-computation cycle and subsequent re-computation cycles as given by the determined number of re-computation cycles. A more detailed example will be described below.
In response to determining to apply the exploitation mode, the computation machine 3 of some embodiments is arranged to determine the number of pre-computed query results in the first share to be re-computed in the current computation cycle based on a value function of the Reinforcement Learning algorithm for the number of pre-computed query results indicated by the retrieved indication, the value function associating possible selections of pre-computed query results in the at least first share for re-computation with respective estimated rewards.
In some embodiments, the computation machine iteratively adapts the number of pre-computed query results indicated by the retrieved indication at least based on the number of pre-computed query results indicated by the retrieved indication, the value function of the Reinforcement Learning algorithm for the number of pre-computed query results indicated by the retrieved indication and the reward threshold. A more specific example how the computation machine 3 may determine a new re-computation number during the exploration mode in order to further optimize its actions is given below.
The balancing mechanism to switch between exploitation mode and exploration mode is supported by the fact that it is possible to “rank” the re-computation numbers. In other words, it uses the fact that up to a certain point, the greater the re-computation number, the greater the reward (and after some point, there is a failure). This helps to build an exploration policy: given a re-computation number that is acceptable (the KPIs are under the threshold), it can be decided to explore with a greater re-computation number (since it is known that a lower weight will not give any improvement of the reward).
It is also possible to decide how much the system can explore by using the difference between the value function of the current re-computation number and the maximum expected reward. To this end, it can be estimate how far the re-computation number is from the KPI threshold and use this estimation to decide to explore with a big or small step. This enables to reach a trade-off between the speed of convergence to the optimal re-computation number to apply to a given share and the risk of collecting low reward (in particular avoidance of technical rejects).
More specifically, the following case-based RL mode determination algorithm is used in some embodiments to find to the optimal re-computation number, while keeping the system 1 stable. If the value function for the last re-computation number is between 0 and 50% of the maximum aggregated reward resulting from all KPIs peeking at the their respective KPI threshold values (Max Reward), exploit C1 times and then explore a given number of times (e.g., one time) with a greater re-computation number (details of choosing this greater re-computation number will be detailed below). If the value function for the last re-computation number is between 50% and 75% of Max Reward, exploit C2>C1 Times and then explore one time with a greater re-computation number. If the value function for the last re-computation number is between 75% and 90% of Max Reward, exploit C3>C2 Times and then explore one time with a greater re-computation number. If the value function for the last re-computation number is between 90% and 100% of Max Reward, exploit C4>C3 of the time and then explore one time with a greater re-computation number. The C1, C2, C3 and C4 variables are to be tuned with an empirical approach to obtain the wished behavior (in terms of speed of convergence, for example).
In response to determining that the agent is allowed to explore in the current computation cycle, the greater re-computation number for the exploration is to be decided. It is assumed that the calculated reward for a given re-computation number is better when the KPIs after the decision for the given re-computation number is closer to the KPIs threshold than for the last re-computation number, and that the reward evolution is not proportional to the re-computation number (sub-additivity), e.g.:
REWARD(2*W)≤2*REWARD(W)
As, in some embodiments, the system has a conservative approach to avoid failure states, the convergence towards the best re-computation for a given share is done carefully in some embodiments, step by step. In some embodiments, the new re-computation number Wnew is given by:
where Vk (Wi) is the value function of the last exploited re-computation number Wk. This is a strictly positive value since the current RL mode is exploration mode that has been allowed by the comparison with the maximum reward. This approach is iteratively applied to determine the re-computation number for the next exploration phase. Over a multiple number of exploration phases, the respective employment of this formula in each of the exploration phases to determine Wnew forms an iterative approach bring the re-computation number closer and closer to the maximum aggregated reward REWARDMAX and, thus, to select the re-computation number in an optimized manner to efficiently use the available re-computation resources.
An example of this balancing selection between exploitation and exploration mode is given by
Initially (
In response to the computation machine 3 receiving another computation trigger 16 to re-computation pre-computed query results of the share in a next re-computation cycle (still
At the C2+1st re-computation of the share (
This alternating selection of one exploration followed by a number of exploitations is subsequently iterated in the same manner to determine the optimal re-computation number for this particular share (
At some point of time, a newly explored re-computation number might enter the warning zone, i.e., the KPI threshold for one or more KPIs is exceeded, yielding a negative reward value (
In the scenario of
Some details of the re-computation number readjustment are described next.
In some embodiments, the computation machine 3 does not have enough computation resources to re-compute a complete share or a part of the share which is requested to be re-computed by the re-computation controller 2 in a single re-computation cycle. In this embodiments, the mechanisms described herein can be employed to split the share or requested part of the share into optimal slices which are re-computed by the computation machine 3 over a plurality of computation cycles. Here, the re-computation number determined by the mechanisms described herein indicates the size of a slice to be re-computed in each cycle.
Furthermore, in some embodiments, the pre-computed query results are arranged in cells with two dimensions. One non-limiting example has already been mentioned above with reference to
wherein d is the departure day range (departure on the next d days, the first dimension) and s is the stay duration range (stay duration from 1 to s days, the second dimension) and W is an optimum weight recommended by the expert knowledge database (i.e., in current state of the RL algorithm, it is thought to yield the highest reward). However, depending on the departure date range and stay duration range requested in the computation trigger 16, this solution can lead to some small re-computation number slices at the end of the (part of the) share to be re-computed.
The following algorithm provides an improved split of the part of the share to be re-computed by the computation machine 3 into slices, each of the slice is to be re-computed over a plurality of computation cycles, namely to choose a parallelogram-shaped re-computation number as follows. A stay duration range s is determined that is close from √{square root over (W)} and which splits the stay duration range indicated in the request 16 from the re-computation controller 2 well into pieces as equal as possible. The highest possible re-computation number is determined being a square of s·d with the less non-full slice (i.e., the last slice of the part of the share to be re-computed is closest to the re-computation number, i.e., the size of the other slices), and with s>d in order to optimize the efficient usage of computation resources (if s>d, less departure dates have to be re-computed during each computation cycle, e.g., re-computing a square of 3d·15s is less costly than re-computing a square of 15d·3s).
The determined numbers s and d are set to
and thus have:
Implicitly, this algorithm considers that the stay duration range indicated in the request 16 is smaller than the departure date range indicated in the request and that indicated stay duration range is therefore the one that should be well split. If, on the other hand, the stay duration indicated in the request 16 is equal or greater than the departure day range, the same algorithm can be applied with exchanged indicated stay duration and indicated departure day range, and thus exchanged s and d).
As an example, the re-computation controller 2 requests the computation machine 3 to re-compute a particular share for the next 31 departure days with a stay duration range of 16 (i.e., all stay durations from 1 to 16 days). Hence, overall, a square of 31·16=496 pre-computed query results has to be re-computed. The computation platform has enough computation resources of re-computing 50 pre-computed query results per computation cycle.
The naive solution mentioned above would yield a re-computation number of 7d·7s=49 which would result in 8 slices of 7d·7s, as well as 7 non-full slices, namely 4 slices of 2d·7s, 2 slices of 7d·4s, and one final slice of 2d·4s, in order to complete re-compute all 496 pre-computed query results. The average re-computation number over these 15 computation cycles is only 33. The more sophisticated approach outlined above leads to a split of 6d·8s. This results in 12 slices, namely 11 slices of 6d·8s and one remaining non-full slice of 1d·7s, and an overall average re-computation number of 41.
The above approach can be generalized to other use-cases with the pre-computed query results having other dimensions or a different number of dimensions (e.g., three dimensions).
Finally,
In some examples, the instructions programmed to carry out the routines to determine the re-computation number are also stored on the static memory 106. When the instructions are executed, process data resides in the main memory 104 and/or the processor 102. The instructions may further be transmitted or received as a propagated signal through the network interface device 108 from/to a software server within a local area network or the Internet. The network interface device 108 may be a wireless network interface (such as a Wi-Fi and/or Bluetooth interface) and/or a 2G/3G/4G/5G mobile network interface.
The mechanisms to determine an optimal re-computation number described herein increase the efficiency of re-computing pre-computed query results which are composed of a plurality of shares with a respective certain number of pre-computed query results, wherein computation resources of the computation machine needed to re-compute a pre-computed query result of a first share depend on whether or not other pre-computed query results of the first share are re-computed during a given time interval forming a current re-computation cycle. Using a Reinforcement Learning algorithm in the manner described above optimizes the usage of the computation resources of the computation machine 3 by allowing to re-compute more pre-computed query results with the same amount of computation resources than without the algorithm. The mechanisms are independent from the particular use case of the computation machine and may be employed by any system which re-computes pre-computed query results having an interdependency in terms of the computation resources required to re-compute them, as exemplarily described above with reference to the example of
In general, the routines executed to implement the embodiments of the invention, whether implemented as part of an operating system or a specific application, component, program, object, module or sequence of instructions, or even a subset thereof, may be referred to herein as “computer program code,” or simply “program code.” Program code typically comprises computer readable instructions that are resident at various times in various memory and storage devices in a computer and that, when read and executed by one or more processors in a computer, cause that computer to perform the operations necessary to execute operations and/or elements embodying the various aspects of the embodiments of the invention. Computer readable program instructions for carrying out operations of the embodiments of the invention may be, for example, assembly language or either source code or object code written in any combination of one or more programming languages.
The program code embodied in any of the applications/modules described herein is capable of being individually or collectively distributed as a program product in a variety of different forms. In particular, the program code may be distributed using a computer readable storage medium having computer readable program instructions thereon for causing a processor to carry out aspects of the embodiments of the invention.
Computer readable storage media, which are inherently non-transitory, may include volatile and non-volatile, and removable and non-removable tangible media implemented in any method or technology for storage of information, such as computer-readable instructions, data structures, program modules, or other data. Computer readable storage media may further include random access memory (RAM), read-only memory (ROM), erasable programmable read-only memory (EPROM), electrically erasable programmable read-only memory (EEPROM), flash memory or other solid state memory technology, portable compact disc read-only memory (CD-ROM), or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium that can be used to store the desired information and which can be read by a computer. A computer readable storage medium should not be construed as transitory signals per se (e.g., radio waves or other propagating electromagnetic waves, electromagnetic waves propagating through a transmission media such as a waveguide, or electrical signals transmitted through a wire). Computer readable program instructions may be downloaded to a computer, another type of programmable data processing apparatus, or another device from a computer readable storage medium or to an external computer or external storage device via a communication network.
Computer readable program instructions stored in a computer readable medium may be used to direct a computer, other types of programmable data processing apparatus, or other devices to function in a particular manner, such that the instructions stored in the computer readable medium produce an article of manufacture including instructions that implement the functions/acts specified in the flowcharts, sequence diagrams, and/or block diagrams. The computer program instructions may be provided to one or more processors of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the one or more processors, cause a series of computations to be performed to implement the functions and/or acts specified in the flowcharts, sequence diagrams, and/or block diagrams.
In certain alternative embodiments, the functions and/or acts specified in the flowcharts, sequence diagrams, and/or block diagrams may be re-ordered, processed serially, and/or processed concurrently without departing from the scope of the invention. Moreover, any of the flowcharts, sequence diagrams, and/or block diagrams may include more or fewer blocks than those illustrated consistent with embodiments of the invention.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the embodiments of the invention. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof. Furthermore, to the extent that the terms “includes”, “having”, “has”, “with”, “comprised of”, or variants thereof are used in either the detailed description or the claims, such terms are intended to be inclusive in a manner similar to the term “comprising”.
While all of the invention has been illustrated by a description of various embodiments and while these embodiments have been described in considerable detail, it is not the intention of the Applicant to restrict or in any way limit the scope of the appended claims to such detail. Additional advantages and modifications will readily appear to those skilled in the art. The invention in its broader aspects is therefore not limited to the specific details, representative apparatus and method, and illustrative examples shown and described. Accordingly, departures may be made from such details without departing from the spirit or scope of the Applicant's general inventive concept.
Claims
1. A computation machine for re-computing pre-computed query results stored at a database server, the pre-computed query results composed of a plurality of shares, each share including a certain number of pre-computed query results, and wherein computation resources of the computation machine needed to re-compute a pre-computed query result of a first share depend on whether or not other pre-computed query results of the first share are re-computed during a given time interval forming a current re-computation cycle, the computation machine comprising:
- one or more processors; and
- a memory coupled with the one or more processors, the memory including program code that, when executed by the one or more processors, cause the computation machine to: receive a request to dynamically re-compute the pre-computed query results of the first share; retrieve, from a statistics server, an indication of the pre-computed query results of the first share which have been re-computed in a previous time interval; determine, based on the pre-computed query results of the first share which have been re-computed in the previous time interval, a number of pre-computed query results in the first share to be re-computed in the current re-computation cycle based on a Reinforcement Learning algorithm by applying an exploitation mode of the Reinforcement Learning algorithm or applying an exploration mode of the Reinforcement Learning algorithm based on a value function of the Reinforcement Learning algorithm for the number of pre-computed query results indicated by the retrieved indication, wherein the determined number of pre-computed query results is limited by the computation resources of the computation machine available during the given time interval, wherein the query results are limited based on an application of the exploitation mode or an application of the exploration mode of the Reinforcement Learning algorithm, wherein the value function is computed iteratively from a history of previously received rewards and is based on a learning speed parameter and a degradation factor; store the determined number of pre-computed query results in the first share in the statistics server for a subsequent determination of the number of pre-computed query results to be re-computed in a subsequent computation cycle; re-compute the determined number of pre-computed query results in the first share during the current re-computation cycle; and provide the re-computed determined number of pre-computed query results in the first share to the database server.
2. The computation machine of claim 1 wherein the request to dynamically re-compute the pre-computed query results of the first share indicates the pre-computed query results of the first share which are to be re-computed, and the computation machine is arranged to determine the number of the pre-computed query results in the first share to be re-computed based on the indicated pre-computed query results of the first share.
3. The computation machine of claim 1 wherein the program code causes the computation machine to determine the number of pre-computed query results in the first share to be re-computed by causing the computation machine to:
- in response to determining to apply the exploitation mode, determining the number of pre-computed query results in the first share to be re-computed in the current re-computation cycle based on the value function of the Reinforcement Learning algorithm for the number of pre-computed query results indicated by the retrieved indication, the value function associating possible selections of the pre-computed query results in the first share for re-computation with respective estimated rewards.
4. The computation machine of claim 3 wherein the estimated rewards associated by the value function are specified by a reward function of the Reinforcement Learning algorithm which attributes an aggregated value of a plurality of key performance indicators to a corresponding selection of pre-computed query results of the first share.
5. The computation machine of claim 4 wherein the aggregated value of the plurality of key performance indicators is based on a sum of numbers of the pre-computed query results to be re-computed, elapsed time of re-computing the pre-computed query results to be re-computed in the given time interval, maximum computation resources to re-compute the pre-computed query results indicated in the request, a maximum of memory required to re-compute the pre-computed query results indicated in the request, or a combination thereof.
6. The computation machine of claim 4 wherein the program code causes the computation machine to determine to apply the exploitation mode of the Reinforcement Learning algorithm or to apply the exploration mode of the Reinforcement Learning algorithm by causing the computation machine to:
- determine a reward given by the value function for the pre-computed query results indicated by the retrieved indication;
- determine a number of re-computation cycles to apply the exploitation mode of the Reinforcement Learning algorithm based on a comparison of the determined reward with a reward threshold; and
- apply the exploitation mode of the Reinforcement Learning algorithm during the current re-computation cycle and subsequent re-computation cycles given by the determined number of re-computation cycles.
7. The computation machine of claim 6 wherein the reward threshold is defined by given percentages of threshold values of respective ones of the plurality of key performance indicators for which re-computation during the given time interval would result in an error state of the computation machine.
8. The computation machine of claim 6 wherein the program code causes the computation machine to:
- in response to determining to apply the exploration mode, iteratively adapt the number of pre-computed query results indicated by the retrieved indication at least based on the number of pre-computed query results indicated by the retrieved indication, the value function of the Reinforcement Learning algorithm for the number of pre-computed query results indicated by the retrieved indication and the reward threshold.
9. A method for re-computing pre-computed query results stored at a database server, the pre-computed query results composed of a plurality of shares, each share including a certain number of pre-computed query results, and wherein computation resources of a computation machine needed to re-compute a pre-computed query result of a first share depend on whether or not other pre-computed query results of the first share are re-computed during a given time interval forming a current re-computation cycle, the method comprising:
- receiving, at the computation machine, a request to dynamically re-compute the pre-computed query results of the first share;
- retrieving, from a statistics server, an indication of the pre-computed query results of the first share which have been re-computed in a previous time interval;
- determining, by the computation machine and based on the pre-computed query results of the first share which have been re-computed in the previous time interval, a number of pre-computed query results in the first share to be re-computed in the current re-computation cycle based on a Reinforcement Learning algorithm by applying an exploitation mode of the Reinforcement Learning algorithm or applying an exploration mode of the Reinforcement Learning algorithm based on a value function of the Reinforcement Learning algorithm for the number of pre-computed query results indicated by the retrieved indication, wherein the determined number of pre-computed query results is limited by the computation resources of the computation machine available during the given time interval, wherein the query results are limited based on an application of the exploitation mode or an application of the exploration mode of the Reinforcement Learning algorithm, wherein the value function is computed iteratively from a history of previously received rewards and is based on a learning speed parameter and a degradation factor;
- storing, by the computation machine, the determined number of pre-computed query results in the first share in the statistics server for a subsequent determination of the number of pre-computed query results to be re-computed in a subsequent computation cycle;
- re-computing, by the computation machine, the determined number of pre-computed query results in the first share during the current re-computation cycle; and
- providing, by the computation machine, the re-computed determined number of pre-computed query results in the first share to the database server.
10. The method of claim 9 wherein the request to dynamically re-compute the pre-computed query results of the first share indicates the pre-computed query results of the first share which are to be re-computed, and the computation machine is arranged to determine the number of pre-computed query results in the first share to be re-computed based on the indicated pre-computed query results of the first share.
11. The method of claim 9 wherein determining the number of pre-computed query results in the first share to be re-computed comprises:
- in response to determining to apply the exploitation mode, determining the number of pre-computed query results in the first share to be re-computed in the current re-computation cycle based on the value function of the Reinforcement Learning algorithm for the number of pre-computed query results indicated by the retrieved indication, the value function associating possible selections of the pre-computed query results in the first share for re-computation with respective estimated rewards.
12. The method of claim 11 wherein the estimated rewards associated by the value function are specified by a reward function of the Reinforcement Learning algorithm which attributes an aggregated value of a plurality of key performance indicators to a corresponding selection of pre-computed query results of the first share.
13. The method of claim 12 wherein the aggregated value of the plurality of key performance indicators is based on a sum of numbers of the pre-computed query results to be re-computed, elapsed time of re-computing the pre-computed query results to be re-computed in the given time interval, maximum computation resources to re-compute the pre-computed query results indicated in the request, a maximum of memory required to re-compute the pre-computed query results indicated in the request, or a combination thereof.
14. The method of claim 12 wherein determining to apply the exploitation mode of the Reinforcement Learning algorithm or to apply the exploration mode of the Reinforcement Learning algorithm comprises:
- determining a reward given by the value function for the pre-computed query results indicated by the retrieved indication;
- determining a number of re-computation cycles to apply the exploitation mode of the Reinforcement Learning algorithm based on a comparison of the determined reward with a reward threshold; and
- applying the exploitation mode of the Reinforcement Learning algorithm during the current re-computation cycle and subsequent re-computation cycles given by the determined number of re-computation cycles.
15. The method of claim 14 wherein the reward threshold is defined by given percentages of threshold values of respective ones of the plurality of key performance indicators for which re-computation during the given time interval would result in an error state of the computation machine.
16. A computer program product for re-computing pre-computed query results stored at a database server, the pre-computed query results composed of a plurality of shares, each share including a certain number of pre-computed query results, and wherein computation resources of a computation machine needed to re-compute a pre-computed query result of a first share depend on whether or not other pre-computed query results of the first share are re-computed during a given time interval forming a current re-computation cycle, the computer program product comprising:
- a non-transitory computer-readable storage medium; and
- instructions stored on the non-transitory computer-readable storage medium that, when executed by one or more processors of the computation machine, cause the one or more processors to: receive a request to dynamically re-compute the pre-computed query results of the first share; retrieve, from a statistics server, an indication of the pre-computed query results of the first share which have been re-computed in a previous time interval; determine, based on the pre-computed query results of the first share which have been re-computed in the previous time interval, a number of pre-computed query results in the first share to be re-computed in the current re-computation cycle based on a Reinforcement Learning algorithm by applying an exploitation mode of the Reinforcement Learning algorithm or applying an exploration mode of the Reinforcement Learning algorithm based on a value function of the Reinforcement Learning algorithm for the number of pre-computed query results indicated by the retrieved indication, wherein the determined number of pre-computed query results is limited by the computation resources of the computation machine available during the given time interval, wherein the query results are limited based on an application of the exploitation mode or an application of the exploration mode of the Reinforcement Learning algorithm, wherein the value function is computed iteratively from a history of previously received rewards and is based on a learning speed parameter and a degradation factor; store the determined number of pre-computed query results in the first share in the statistics server for a subsequent determination of the number of pre-computed query results to be re-computed in a subsequent computation cycle; re-compute the determined number of pre-computed query results in the first share during the current re-computation cycle; and provide the re-computed determined number of pre-computed query results in the first share to the database server.
7707131 | April 27, 2010 | Chickering |
8429097 | April 23, 2013 | Sivasubramanian |
20040034633 | February 19, 2004 | Rickard |
20050234971 | October 20, 2005 | Folkert et al. |
20080256061 | October 16, 2008 | Chang |
20120209794 | August 16, 2012 | Jones, III |
20140280028 | September 18, 2014 | Ding et al. |
20150234890 | August 20, 2015 | Legrand |
20150310068 | October 29, 2015 | Pickens |
20150377849 | December 31, 2015 | Masson |
20170140053 | May 18, 2017 | Vorobev |
20170358285 | December 14, 2017 | Cabral |
2913764 | September 2015 | EP |
- Sutton et al., “Reinforcement Learning: An Introduction” MIT Press, Cambridge, MA, 1998.
- Krishnan et al., “Stale view cleaning”, Proceedings of the 41st International Conference on Very Large Data Bases, Kohala Coast, Hawaii, vol. 8, Issue 12, Aug. 2015, pp. 1370-1381.
- European Patent Office, International Search Report issued in International Application No. PCT/EP2019/051865 dated Mar. 7, 2019.
Type: Grant
Filed: Jan 25, 2018
Date of Patent: Feb 28, 2023
Patent Publication Number: 20190228094
Assignee: Amadeus S.A.S. (Biot)
Inventors: Jean-Philippe Aubry (Brookline, MA), Guillaume Le Grand (Le Cannet), Johann Marchi (Nice), Nicolas Legrand (Nice)
Primary Examiner: Syed H Hasan
Assistant Examiner: Anthony G Gemignani
Application Number: 15/879,654
International Classification: G06F 16/2455 (20190101); G06N 20/00 (20190101); G06F 16/2453 (20190101); G06F 16/903 (20190101);