The present disclosure relates to information retrieval based on user queries, and, more particularly, to a relevance model for a session search.
A session search can include multiple steps t as a user submits one or more queries to locate relevant information satisfying the user's information need. A search manager can be configured to provide the user with documents most relevant to the user's estimated information need.
Aspects of the present disclosure are directed to a method for modifying a search query to retrieve documents relevant to a user's information need. The method can include compiling session data comprising a first query, a second query, a first set of relevant documents for the first query, a set of user interactions with a subset of the first set of relevant documents, and a set of query changes between the first query and the second query. The method can further include generating a feedback model estimating a relevance of search terms to the user's information need based on the set of query changes and the set of user interactions with the subset of the first set of relevant documents. The method can further include generating a relevance model estimating a relevance of search terms to the user's information need based on the feedback model and a session relevance model. The method can further include modifying the second query based on the relevance model. The method can further include outputting a second set of relevant documents to a user interface responsive to executing the modified second query.
Aspects of the present disclosure are further directed toward a system including a search manager comprising a memory and a processor and communicatively coupled to a user interface and a set of nodes storing a corpus of data. The search manager can be configured to execute a session search configured to satisfy an information need by updating a relevance model of the information need responsive to receiving a reformulated query based on input to the user interface. The relevance model can be based on a session relevance model and a feedback model configured to estimate a relevance of respective search terms to the information need according to the reformulated query, a previous query, and a set of selected documents presented responsive to the previous query and selected based on input received from the user interface. The search manager can be further configured to modify the reformulated query based on the updated relevance model. The search manager can be further configured to present an updated set of relevant documents to the user interface responsive to executing the modified reformulated query and retrieving the updated set of relevant documents from the corpus of data.
Additional aspects of the present disclosure are directed toward a computer program product comprising a computer readable storage medium having program instructions embodied therewith. The program instructions can be executed by a processor to cause the processor to perform a method comprising compiling, for a session search, session data comprising a first query, a second query, a first set of relevant documents for the first query, a set of user interactions with a subset of the first set of relevant documents, and a set of query changes between the first query and the second query. The program instructions can be further configured to cause the processor to perform a method further comprising generating a feedback model estimating a relevance of search terms to an information need of the session search based on the set of query changes and the set of user interactions with the subset of the first set of relevant documents and generating a relevance model estimating a relevance of search terms to the information need based on the feedback model and a session relevance model. The program instructions can be further configured to cause the processor to perform a method further comprising modifying the second query based on the relevance model and outputting a second set of relevant documents to a user interface responsive to executing the modified second query.
The drawings included in the present application are incorporated into, and form part of, the specification. They illustrate embodiments of the present disclosure and, along with the description, serve to explain the principles of the disclosure. The drawings are only illustrative of certain embodiments and do not limit the disclosure.
While the present disclosure is amenable to various modifications and alternative forms, specifics thereof have been shown by way of example in the drawings and will be described in detail. It should be understood, however, that the intention is not to limit the present disclosure to the particular embodiments described. On the contrary, the intention is to cover all modifications, equivalents, and alternatives falling within the spirit and scope of the present disclosure.
Aspects of the present disclosure are directed toward information retrieval based on user queries in session searches. More particular aspects are directed toward modifying a user's current query to retrieve documents most relevant to a user's information need based on a relevance model for the session search. Aspects of the present disclosure generate a relevance model based on a session relevance model and a feedback model. The session relevance model uses historical data to generate a dynamic representation of the user information need prior to a current user query. The feedback model monitors user interactions (e.g., document impressions, clicks, and query reformulations) to better understand a user's information need at the current query. The relevance model can modify the user query to retrieve documents most relevant to the user's information need.
Aspects of the present disclosure provide numerous advantages. First, aspects of the present disclosure generate a feedback model to capture changes in a user's information need based on user interactions (e.g., document impressions, user clicks, and user query reformulations). Thus, aspects of the present disclosure are able to identify changes in a user's information need over the course of a session search and provide an estimation of the user's current information need. Second, aspects of the present disclosure moderate the importance of the session relevance model and the feedback model in the relevance model based on an information gain associated with the feedback model relative to the session relevance model. Thus, the relative importance of the two models is moderated by a logical calculation rather than an arbitrary parameter. Third, aspects of the present disclosure anchor the feedback model to a query model to avoid query drift. Fourth, aspects of the present disclosure outperform state-of-the-art alternative relevance models as described in further detail hereinafter with respect to
The aforementioned advantages are example advantages, and aspects of the present disclosure exist which may contain all, some, or none of the aforementioned advantages while remaining within the spirit and scope of the present disclosure.
Referring now to the figures,
Device 102 can be, but is not limited to, a computer, a laptop, a workstation, a cell phone, a tablet, or another user device capable of receiving search queries from a user and presenting search results to a user. Device 102 can execute an application and/or web browser capable of receiving a user query and providing relevant documents in response to the user query. User interface 104 can comprise, but is not limited to, alone or in combination, a monitor, a screen, a touch screen, a keyboard, a mouse, a microphone, a camera, and/or other input/output devices capable of receiving input from a user and/or presenting output to a user.
Corpus 106 contains any one or more of the following: documents, web pages, image files, video files, audio files, and so on. Although corpus 106 is shown as a single entity communicatively coupled to network 100, corpus 106 can be numerous entities (e.g., a plurality of nodes) representing, for example, information available on a distributed network such as, but not limited to, the internet, an intranet, a database, or a different collection of data.
Search manager 108 stores session data 110 and relevance model 112. Session data 110 comprises a session history generated by user interactions received from device 102 based on input to user interface 104. Session data 110 can comprise, for example, relevant documents, user clicks, and query reformulations. Relevant documents can comprise a subset of corpus 106 retrieved in response to a user query. User clicks can refer to user interactions with a subset of the relevant documents presented on user interface 104. Query reformulations can refer to added, removed, and retained search terms between any two queries, between any two sequential queries, or between a current query and a sequentially previous query, according to various embodiments.
Relevance model 112 uses information from session data 110 to identify a user's information need. Relevance model 112 is described in more detail hereinafter with respect to
Referring now to
Each CPU 205 retrieves and executes programming instructions stored in the memory 225 or storage 230. The interconnect 220 is used to move data, such as programming instructions, between the CPUs 205, I/O device interface 210, storage 230, network interface 215, and memory 225. The interconnect 220 can be implemented using one or more busses. The CPUs 205 can be a single CPU, multiple CPUs, or a single CPU having multiple processing cores in various embodiments. In some embodiments, a processor 205 can be a digital signal processor (DSP). Memory 225 is generally included to be representative of a random access memory (e.g., static random access memory (SRAM), dynamic random access memory (DRAM), or Flash). The storage 230 is generally included to be representative of a non-volatile memory, such as a hard disk drive, solid state device (SSD), removable memory cards, optical storage, or flash memory devices. In an alternative embodiment, the storage 230 can be replaced by storage area-network (SAN) devices, the cloud, or other devices connected to the search manager 200 via the I/O devices 210 or a communication network 250 via the network interface 215.
In some embodiments, the memory 225 stores instructions 260 and the storage 230 stores session data 232 and relevance model 240. However, in various embodiments, the instructions 260, the session data 232, and relevance model 240 are stored partially in memory 225 and partially in storage 230, or they are stored entirely in memory 225 or entirely in storage 230, or they are accessed over a network 250 via the network interface 215.
Session data 232 comprises query data 234, relevant documents 236, and feedback data 238. Query data 234 comprises queries received via I/O devices 212 through I/O device interface 210 or via network 250 through network interface 215 (e.g., from user device 102 of
Relevant documents 236 comprise documents retrieved from a corpus and identified as relevant to a given user query. In some embodiments, relevant documents 236 comprise the top-k documents for a given query. Relevant documents 236 are discussed in more detail hereinafter with respect to operation 308 of
Feedback data 238 comprises a measure of user interest in one or more of the relevant documents 236. Feedback data 238 can comprise, but is not limited to, user clicks on particular documents of the relevant documents 236, a measurement of time on which a user paused on a screen presenting a subset of the relevant documents 236, and documents saved to a user device from the relevant documents 236. In some embodiments, feedback data 236 further comprises biometric feedback data which can be received from, for example, a video camera on the user device configured to track eye movement of the user and determine a time the user spent reading one or more of the relevant documents 236.
In some embodiments, session data 232 stores, for each step in a session history having n steps, a tuple of data, St=Qt,Dt, Ct, for steps 1≤t≤n−1. The tuple of data comprises the query data 234 (denoted as Qt=(q1, q2, . . . , qt)), the relevant top-k documents 236 retrieved for the respective query (denoted as Dt=(Dq1[k],Dq2[k], . . . , Dqt[k])), and feedback data 238 (denoted as Ct=(Cq1, Cq2, . . . , Cqt)) indicating user interest with one or more of the relevant documents 236 (such as, for example, user clicks on one or more of the relevant documents 236).
Storage 230 further contains relevance model 240 which is based on session relevance model 242 and feedback model 244. Session relevance model 242 can estimate user information need at a current step t based on user queries generated in steps previous to step t. Feedback model 244 can estimate user information need at a current step t based on query reformulation between a previous step t−1 and the current step t, and further based on feedback data 238. Relevance model 240 is described in more detail hereinafter with respect to
The instructions 260 store processor executable instructions for various methods such as the methods shown and described hereinafter with respect to
In various embodiments, the I/O devices 212 can include an interface capable of presenting information and receiving input. For example, I/O devices 212 can receive input from a user and present information to a user interacting with search manager 200 and/or a device (e.g., device 102 of
In some embodiments, the network 250 is consistent with network 100 of
The method 300 starts at operation 302 by receiving a reformulated query (e.g., a new query that can be a query identical to a previous query or a query different from a previous query) based on user input (e.g., from user input to user device 102 of
In operation 304, the search manager updates a relevance model based on the reformulated query. Operation 304 is described in more detail hereinafter with respect to
In operation 306, the search manager modifies the reformulated query based on the relevance model. The search manager can modify the reformulated query using any number of techniques such as, but not limited to, applying a respective weight (e.g., a relevance factor) to each respective term in the reformulated query with terms identified as more relevant (based on the relevance model) having a higher weighting and terms identified as less relevant (based on the relevance model) having a lower weighting. The search manager can additionally, or alternatively, expand the query by adding related terms associated with search terms having a relevance score above a first threshold. A relevance factor can also be applied to added search terms based on the relevance model. The search manager can additionally, or alternatively, remove search terms having a relevance score below a second threshold.
In operation 308, the search manager presents the most relevant k documents (e.g., 10 documents) in response to executing the reformulated query modified in operation 306 against a corpus of data (e.g., corpus 106 of
In some embodiments, the most relevant k documents are presented as a list of hyperlinked titles with each title corresponding to a document and having a summary of the document adjacent to the hyperlinked title (e.g., an abstract, or a preview of the beginning of the document). As will be appreciated by one skilled in the art, the most relevant k documents can be presented in any number of similar or dissimilar arrangements as the arrangement previously described.
In operation 310, the search manager receives user feedback from the user interface. The user feedback can indicate user interest in particular documents of the most relevant k documents presented in operation 308. The user feedback can comprise, but is not limited to, user clicks on particular relevant documents and changes between the received query from operation 302 and another reformulated query the user generates based on the information provided to the user in operation 308.
Numerous other forms of feedback are contemplated, such as, but not limited to, an amount of time a particular document is presented on the user interface (e.g., the time a user spent reviewing a document after clicking on a hyperlink to that document, or a time a user spent on a portion of the list containing a subset of the most relevant k documents), biometric feedback such as an amount of time a user spent reading respective summaries based on eye-tracking received through a video camera attached to the user device, and so on. The user feedback collected in operation 310 can identify documents selected by the user as being particularly relevant to the user's information need. The selected documents can be intentionally selected by the user (e.g., responsive to user clicks) or unconsciously selected by the user (e.g., responsive to a time the user spent reading a summary of the selected document, where the user may be unaware that the time spent reading the summary constitutes user feedback to the search manager).
The search manager implementing the method 300 iterates through operations 302-310 until no reformulated queries are received and the session search ends.
The method 400 begins at operation 410 by compiling data from the session search. For a given session, a user's information need can be denoted as I. During the session, the user's information need can change as a result of knowledge gained during the session search. A change in a user's information need can be associated with changes to user queries at each step t in the session. Thus, a change in a user's information need can be defined as ΔItIt−1→It. ΔIt can be associated with changes in a user query. For example, changes from a previous query qt−1 to a current query qt can indicate a change in the user's information need.
At each step of the session search, a user can submit a new query, notated as qt. A search manager retrieves a set of top-k documents Dqt[k] from a corpus of documents. Each result can include a title, a link to the document, and a summary of the document. A user can click on one or more documents from the set of top-k documents Dqt[k]. The user's clicks can be stored as a set of clicked results notated by Cqt. At step t+1 the user can submit a new query based on the information gathered in the previous step. The process can iterate any number of times. The session history can be denoted by Sn-1 and can represent user queries, retrieved result documents, and clicked results. Thus, for each step, the search manager stores a tuple of information, notated as St=(Qt, Dt, Ct) in operation 410. Qt represents the series of queries submitted by a user (Qt=(q1, q2, . . . , qt)). Likewise, Dt represents the series of top-k results corresponding to each query (Dt=(Dq1[k], Dq2[k], . . . , Dqt[k])). Likewise, Ct represents user clicks corresponding to each set of retrieved results (Ct=(Cq1, Cq2, . . . , Cqt)).
Operation 410 can further compile query change data using changes in a current query relative to at least one previous query. In some embodiments, the at least one previous query is the sequentially previous query to the current query. Changes between queries comprise term retention, term addition, and term removal. Terms that are retained (i.e., appear in both queries) can be denoted as Δqt↔. Terms that are added (i.e., appear in the current query and not in the previous query) can be denoted as Δqt±. Terms that are removed (i.e., terms that appear in the previous query and not in the current query) can be denoted as Δqt−. Thus, each term of a set of terms w′ appearing in some vocabulary V and further appearing in at least one of the current query and the previous query can be categorized as either Δqt↔, Δqt+, or Δqt−. Thus, query reformulation for a given step t can be defined as Δqt ∈{Δqt↔, Δqt+, Δqt−}).
In operation 420, the search manager can generate a feedback model based on the compiled data. Feedback model θF
p(w|θF
In Equation 1, the term p[0](w|θd) is a Dirichlet smoothed language model of text x having parameter μ which can be defined according to Equation 2.
In Equation 2, the term tf (w,D) represents the number of appearances of term w in corpus D.
In Equation 1, the term Ft compiles all documents selected by the user to the current step in the session history (e.g., Ft=∪1≤j≤tCq
In Equation 1, the term p(Δqt) denotes the prior likelihood that the user will add, remove, or retain terms while reformulating a query from qt−1 to qt. These likelihoods can be pre-estimated based on historical data, or they can be estimated as each having an equal probability (i.e., a ⅓ probability a respective term is added, a ⅓ probability the respective term is removed, and a ⅓ probability the respective term is retained).
Operation 420 can further estimate a language model of the user's query at step t (denoted as θq
In Equation 1, the term p(d|θΔq
In Equation 3, the term p(Δqt|θd) estimates the relevance a changed query term has on the relevance of a document and can be defined according to Equation 4.
Equation 4 increases the estimated relevance of documents associated with added and retained query terms in a reformulated query and decreases the estimated relevance of documents associated with removed query terms in the reformulated query.
Equation 5 is a modification of Equation 1 and can be used, in some embodiments, to anchor the feedback model θFt to the query model θqt and thereby manage query drift (i.e., the inadvertent deviation from a user's information need as a result of query expansion).
p(w|θ′Ft)(1−λt)p[0](w|θq
Equation 5 uses anchoring parameter λt. Anchoring parameter λt can be defined by Equation 6.
λtλ·sim(qt,qn) Equation 6
In Equation 6, λ is a parameter between 0 and 1, inclusive. The similarity measure between qt and qn can be any one of numerous similarity measures. For example, the similarity measure can be semantic measures such as, but not limited to, Explicit Semantic Analysis, Word2Vec based Cosine similarity, and so on. In some embodiments, the similarity measure is an inverse document frequency (IDF) boosted Generalized-Jaccard similarity measure defined by Equation 7.
In equation 7, the numerator sums the products of a number of appearances of a given word appearing in both the current query and a previous query by the IDF factor for the given word. Likewise, the denominator sums the products of a number of appearances of each word appearing in either the current query and/or a previous query by the IDF factor for the given word. As shown in Equation 7, the numerator sums the products based on the number of appearances of the given word appearing in the query having the fewer number of appearances of the given word. In contrast, the denominator sums the products based on the number of appearances of the given word appearing in the query having the larger number of appearances of the given word.
IDF is a technique employed to manage terms that appear too often in a set of documents to have an identifiable relevance to a user's information need. In particular, IDF for a given term can be calculated by the log of a fraction having a numerator equal to the total number of documents in a corpus and a denominator equal to the number of documents in the corpus that contain the given term.
Thus, according to the λt definition provided in Equation 6, the more similar query qt is to current query qn, the more relevant is the query change (associated with the change in user's information need −ΔID) is assumed to be to the current user's information need (i.e., In). For example, if the difference between query qt and current query qn comprises one added search term, then the one added search term is associated with a higher relevance to the user's current information need. In contrast, if the difference between query qt and current query qn comprises three added search terms and four removed search terms, then it may be difficult to precisely estimate the user's current information need based on the significant difference between the two most recent queries.
In operation 430, the search manager generates a session relevance model θs
In operation 440, the search manager generates a relevance model using the session relevance model and the feedback model. In some embodiments, the relevance model is a first-order autoregressive model for estimating the relevance of terms that are most relevant to the user's information need. In some embodiments, the first-order autoregressive model is defined by Equation 8.
p(w|θs
In Equation 8, the term θs
In Equation 9, γ is a parameter between 0 and 1 inclusive, and DKL(θF
Thus, the method 400 can use the aforementioned equations to generate and/or update a relevance model for a session search.
The comparison methods also include two versions of the Relevance Model. The first version is a basic RM3 model, denoted RM3(qn), which is learned using the last query qn and the top-m retrieved documents as pseudo relevance feedback. The second Relevance Model, denoted RM3(Qn′), uses the pseudo information need Qn′ rather than qn.
The comparison methods also include two query aggregation methods—QA(uniform) and QA(decay). QA(uniform) is equivalent to submitting Qn′ as the query. QA(decay) applies an exponential decay approach to prefer recent queries to early ones (decay parameter γ=0.92).
The comparison methods also included three versions of the Query Change Model (QCM). The QCM parameters were set as α=2.2, β=1.8, ε=0.07, δ=0.4, and γ=0.92. The three QCM models included a basic QCM model, a QCM(SAT) model that utilized only “satisfied” clicks (clicks with a dwell time of at least 30 seconds), and a QCM(DUP) model which ignores duplicate queries within a session.
Finally, various implementations of aspects of the present disclosure are referred to as a Session Relevance Model (SRM). These include SRM(QC) and SRM(RM1) models. The SRM(RM1) model uses the RM1 document score (i.e., p(d|qn)) instead of the query-change driven score discussed in the feedback model in order to isolate the effect of the query-change driven score in the feedback model (see Equations 1-7 discussed with respect to operation 430). SRM(QC) includes the query change information used in the feedback model.
The testing was performed by retrieving the top-2000 documents with the highest query likelihood (QL) score given the last query qn. The retrieved documents were then re-ranked using the various baselines by multiplying their QL score with the score determined by each method. The document scores for the various language model methods were further determined using the KL-divergence score with each model clipped using a fixed cut-off of 100 terms. The TREC session track “trec_eval” tool was used for measuring retrieval performance, namely, normalized discounted cumulative gain (nDCG) @ 10 (i.e., the first 10 results), nDCG(@2000), normalized expected reciprocal ranking (nERR) @10, and mean reciprocal rank (MRR) of each baseline. The free parameters of RM3 and SRM were optimized using the TREC 2011 training set to maximize mean average precision (MAP). Statistical significance of the test results were measured using the paired two-tailed Student's t-test for 95% confidence.
As shown in
Furthermore, SRM models outperformed RM3 models by at least 14%, 7.0%, 9.8%, and 9.5% in nDCG@10, nDCG, nERR@10, and MRR respectively. Thus, using a session-context sensitive approach (as done with the SRM model) provides a significant benefit compared to an ad-hoc relevance modeling approach (i.e., one that only focuses on the last query in the session) as done with RM3.
Furthermore, SRM models outperformed QA and QCM variants by at least 18.5%, 6.1%, 15.1%, and 9.5% in nDCG@10, nDCG, nERR@10, and MRR respectively. Thus, using a query-expansion strategy based on the user's dynamic information need (as done with the SRM models) provides a significant benefit compared to various query aggregation and scoring schemes (e.g., QA and QCM models).
Furthermore, SRM(QC) outperformed SRM(RM1) by at least 2.3%, 1.0%, 2.5%, and 1.8% in nDCG@10, nDCG, nERR@10, and MRR respectively. Thus, using query change as relevance feedback improves performance by a statistically significant amount.
The present invention may be a system, a method, and/or a computer program product at any possible technical detail level of integration. The computer program product may include a computer readable storage medium (or media) having computer readable program instructions thereon for causing a processor to carry out aspects of the present invention.
The computer readable storage medium can be a tangible device that can retain and store instructions for use by an instruction execution device. The computer readable storage medium may be, for example, but is not limited to, an electronic storage device, a magnetic storage device, an optical storage device, an electromagnetic storage device, a semiconductor storage device, or any suitable combination of the foregoing. A non-exhaustive list of more specific examples of the computer readable storage medium includes the following: a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), a static random access memory (SRAM), a portable compact disc read-only memory (CD-ROM), a digital versatile disk (DVD), a memory stick, a floppy disk, a mechanically encoded device such as punch-cards or raised structures in a groove having instructions recorded thereon, and any suitable combination of the foregoing. A computer readable storage medium, as used herein, is not to be construed as being transitory signals per se, such as radio waves or other freely propagating electromagnetic waves, electromagnetic waves propagating through a waveguide or other transmission media (e.g., light pulses passing through a fiber-optic cable), or electrical signals transmitted through a wire.
Computer readable program instructions described herein can be downloaded to respective computing/processing devices from a computer readable storage medium or to an external computer or external storage device via a network, for example, the Internet, a local area network, a wide area network and/or a wireless network. The network may comprise copper transmission cables, optical transmission fibers, wireless transmission, routers, firewalls, switches, gateway computers and/or edge servers. A network adapter card or network interface in each computing/processing device receives computer readable program instructions from the network and forwards the computer readable program instructions for storage in a computer readable storage medium within the respective computing/processing device.
Computer readable program instructions for carrying out operations of the present invention may be assembler instructions, instruction-set-architecture (ISA) instructions, machine instructions, machine dependent instructions, microcode, firmware instructions, state-setting data, configuration data for integrated circuitry, or either source code or object code written in any combination of one or more programming languages, including an object oriented programming language such as Smalltalk, C++, or the like, and procedural programming languages, such as the “C” programming language or similar programming languages. The computer readable program instructions may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider). In some embodiments, electronic circuitry including, for example, programmable logic circuitry, field-programmable gate arrays (FPGA), or programmable logic arrays (PLA) may execute the computer readable program instructions by utilizing state information of the computer readable program instructions to personalize the electronic circuitry, in order to perform aspects of the present invention.
Aspects of the present invention are described herein with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems), and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer readable program instructions.
These computer readable program instructions may be provided to a processor 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 processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks. These computer readable program instructions may also be stored in a computer readable storage medium that can direct a computer, a programmable data processing apparatus, and/or other devices to function in a particular manner, such that the computer readable storage medium having instructions stored therein comprises an article of manufacture including instructions which implement aspects of the function/act specified in the flowchart and/or block diagram block or blocks.
The computer readable program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other device to cause a series of operational steps to be performed on the computer, other programmable apparatus or other device to produce a computer implemented process, such that the instructions which execute on the computer, other programmable apparatus, or other device implement the functions/acts specified in the flowchart and/or block diagram block or blocks.
The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods, and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of instructions, which comprises one or more executable instructions for implementing the specified logical function(s). In some alternative implementations, the functions noted in the blocks may occur out of the order noted in the Figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts or carry out combinations of special purpose hardware and computer instructions.
Embodiments of the present invention may also be delivered as part of a service engagement with a client corporation, nonprofit organization, government entity, internal organizational structure, or the like. These embodiments may include configuring a computer system to perform, and deploying software, hardware, and web services that implement, some or all of the methods described herein. These embodiments may also include analyzing the client's operations, creating recommendations responsive to the analysis, building systems that implement portions of the recommendations, integrating the systems into existing processes and infrastructure, metering use of the systems, allocating expenses to users of the systems, and billing, invoicing, or otherwise receiving payment for use of the systems.
Number | Name | Date | Kind |
---|---|---|---|
6006225 | Bowman | Dec 1999 | A |
6507841 | Riverieulx de Varax | Jan 2003 | B2 |
7398201 | Marchisio | Jul 2008 | B2 |
7440947 | Adcock | Oct 2008 | B2 |
7526470 | Karnawat et al. | Apr 2009 | B1 |
7814107 | Thirumalai | Oct 2010 | B1 |
7827125 | Rennison | Nov 2010 | B1 |
8001064 | Rennison | Aug 2011 | B1 |
8073869 | Li | Dec 2011 | B2 |
8645289 | Bennett | Feb 2014 | B2 |
8671093 | Chapelle et al. | Mar 2014 | B2 |
8725752 | Chakrabarti | May 2014 | B2 |
8856167 | Higgins | Oct 2014 | B2 |
8972391 | McDonnell et al. | Mar 2015 | B1 |
9411327 | Park | Aug 2016 | B2 |
9443028 | Song et al. | Sep 2016 | B2 |
9940365 | Zoryn | Apr 2018 | B2 |
20040267740 | Liu | Dec 2004 | A1 |
20060010117 | Bonabeau | Jan 2006 | A1 |
20060074883 | Teevan | Apr 2006 | A1 |
20070112738 | Livaditis | May 2007 | A1 |
20090282023 | Bennett | Nov 2009 | A1 |
20110004588 | Leitersdorf | Jan 2011 | A1 |
20110196739 | Zhang | Aug 2011 | A1 |
20120150854 | Song | Jun 2012 | A1 |
20120303651 | Tao | Nov 2012 | A1 |
20130204892 | Kumaran | Aug 2013 | A1 |
20140032311 | Cramer | Jan 2014 | A1 |
20140279991 | Gupta et al. | Sep 2014 | A1 |
20150286708 | Tao | Oct 2015 | A1 |
20150331906 | Riley et al. | Nov 2015 | A1 |
20170161396 | Hassanzadeh | Jun 2017 | A1 |
20170322930 | Drew | Nov 2017 | A1 |
20180040045 | Vaananen | Feb 2018 | A1 |
20180067910 | Alonso | Mar 2018 | A1 |
Entry |
---|
List of IBM Patents or Patent Applications Treated as Related, dated Dec. 19, 2017, 2 pages. |
Roitman et al., “Relevance Model for Session Search,” U.S. Appl. No. 15/848,129, filed Dec. 20, 2017. |
Accelerated Examination Support Document, dated Dec. 19, 2017, 29 pages. |
Wu, et al., “Improved Consistent Weighted Sampling Revisited”, Jun. 5, 2017, pp. 1-13, <https://arxiv.org/pdf/1706.01172>. |
Boscarino et al., “Implicit relevance feedback from a multi-step search process: a use of query-logs”, 5 pages. http://oai.cwi.nl./oai/asset/19758/19578B.pdf. |
Lavrenko et al., “Relevance-Based Language Models”, SIGIR'01, Sep. 9-12, 2001, New Orleans, LA, USA. 8 pages. |
Yang et al., “Dynamic Information Retrieval Modeling”, Synthesis Lectures on Information Concepts, Retrieval, and Services #49, 2016. 28 pages. |
Number | Date | Country | |
---|---|---|---|
20180329947 A1 | Nov 2018 | US |