Haggai Roitman, “Utilizing Pseudo-Relevance Feedback in Fusion-based Retrieval,” Proceedings of the 2018 ACM SIGIR International Conference on Theory of Information Retrieval (ICTIR '18), September 2018, p. 869-872, the disclosure of which is incorporated by reference herein, is submitted herewith and cited in an accompanying Information Disclosure Statement (IDS). The author of this paper is named as an inventor in the present application, and this paper was not published or otherwise made available to the public more than one year before the filing of the present application.
The present invention relates to the electrical, electronic and computer arts, and, more particularly, to improvements in processing data queries.
In fusion-based retrieval, several (base) ranked lists, each one retrieved from the same corpus by a different retrieval method, are combined together into a single aggregated (“fused”) list. In other words, a given query may be evaluated (over a given corpus) by several different retrieval methods. A fusion method then combines the various retrieved (ranked) lists into a single fused-list, which is returned as the final retrieval's outcome. More formally, q denotes a query and C denotes a corpus of documents. In fusion-based retrieval, query q is being evaluated over corpus C using several different retrieval methods. Examples of these retrieval methods may include, for example, term frequency-inverse document frequency (TF-IDF), Okapi BM25, divergence-from-randomness (DFR), and language-model-based methods.
={L1, L2, . . . , Lm} denotes a set of a set of m (>1) ranked lists, where each ranked list Li(∈) contains the top-k documents d (∈C) with the highest retrieval scores Si(d|q) according to the i-th retrieval method (i∈{1, 2 . . . , m}). ∪i=1mLi denotes the pool of documents available for fusion (e.g., all documents within ). A fusion method f takes as input an returns an aggregated (top-k) ranked list, hereinafter termed the fused-list and denoted Lf. Sf(d|q) denotes the aggregated (fused) score of document d∈.
As described in Rabinovich et al., “Utilizing relevance feedback in fusion-based retrieval,” Proceedings of the 37th international ACM SIGIR conference on Research & development in information retrieval (SIGIR '14), July 2014, p. 313-322 (hereinafter “Rabinovich”), the entire disclosure of which is incorporated by reference herein for all purposes, utilizing positive (true) relevance feedback was demonstrated to significantly improve retrieval quality in fusion-based retrieval. For example, Rabinovich's PoolRank approach involves re-ranking the pool of documents d∈ using relevance feedback associated with documents in the fused-list Lf.
However, Rabinovich's PoolRank requires that a user explicitly specify at least one example of a true relevant document for a given fused list: a true relevance model is then induced and used to rank the whole pool of candidate documents. As described in Rabinovich at 314: “we assume that a user scans the list she is presented with, Lfuse in our case, top down until she encounters r documents that are relevant to the information need she expressed using the query q. We use Rq[r](Lfuse) (henceforth Rq) to denote the set of these relevant documents . . . . The method then produces a query model, q;R
As previously noted, Rabinovich's PoolRank requires that a user explicitly specify at least one example of a true relevant document for a given fused list: a true relevance model is then induced and used to rank the whole pool of candidate documents. Yet, in many retrieval use-cases, no relevance feedback may be available, not even implicitly. Thus, there is a need for a technique which can provide improved result quality for fusion-based retrieval, in a manner similar to Rabinovich, but without requiring user-provided relevance feedback.
An illustrative embodiment includes a method for use with fusion-based retrieval. The method includes determining a pool of documents, wherein each of the pool of the documents is within at least one of a plurality of lists, each of the plurality of lists results from executing a specified query on a specified corpus, and the specified corpus comprises at least the pool of documents. The method further includes determining a first ranking of documents within the pool of documents based at least in part on first scores computed for respective documents within the pool of documents. The method also includes estimating relevance to the specified query at least of respective documents within the first ranking, wherein the relevance is estimated without user feedback regarding the relevance. The method further includes determining a second ranking of documents within the pool of documents based at least in part on second scores computed at least for respective documents within the first ranking of documents, wherein the second score for a given document is computed based at least in part on the estimated relevance of at least the given document.
As used herein, “facilitating” an action includes performing the action, making the action easier, helping to carry the action out, or causing the action to be performed. Thus, by way of example and not limitation, instructions executing on one processor might facilitate an action carried out by instructions executing on a remote processor, by sending appropriate data or commands to cause or aid the action to be performed. For the avoidance of doubt, where an actor facilitates an action by other than performing the action, the action is nevertheless performed by some entity or combination of entities.
One or more embodiments of the invention or elements thereof can be implemented in the form of a computer program product including a computer readable storage medium with computer usable program code for performing the method steps indicated. Furthermore, one or more embodiments of the invention or elements thereof can be implemented in the form of a system (or apparatus) including a memory, and at least one processor that is coupled to the memory and operative to perform exemplary method steps. Yet further, in another aspect, one or more embodiments of the invention or elements thereof can be implemented in the form of means for carrying out one or more of the method steps described herein; the means can include (i) hardware module(s), (ii) software module(s) stored in a computer readable storage medium (or multiple such media) and implemented on a hardware processor, or (iii) a combination of (i) and (ii); any of (i)-(iii) implement the specific techniques set forth herein.
These and other features and advantages of the present invention will become apparent from the following detailed description of illustrative embodiments thereof, which is to be read in connection with the accompanying drawings.
Embodiments of the present invention provide techniques which enhances fusion-based retrieval (e.g., increased result quality) without user-provided (true) relevance feedback, which is often unavailable in real-life usage cases. An illustrative embodiment of the present invention uses (estimated) pseudo-relevance feedback automatically generated from the fused-list rather than (true) relevance feedback provided by a user. An illustrative embodiment estimates the relevance labels of retrieved documents as accurately as possible, even when no relevance feedback data is available, then uses these estimates to derive better pseudo-feedback models that can be utilized to improve fusion-based retrieval. Illustrative embodiments provide a robust document relevance labeling approach based on pseudo-relevance feedback induced from the various base (initial) ranked-lists, rather than true relevance feedback provided by a user. Experimental results show that illustrative embodiments of the present invention provide improved result quality (e.g., up to 9%) for fusion-based retrieval using pseudo-relevance feedback.
Step 340 estimates relevance labels indicating which documents within fused-list Lf 330 are likely to be relevant to query q. Step 350 uses the estimated relevance labels 340 to determine a pseudo-relevance feedback set F. In contrast to Rq discussed above with reference to
In step 360, a pseudo-relevance feedback (PRF) model θR[F] is induced from pseudo-feedback documents set F 350 estimated in step 340. An illustrative embodiment may use the RM1 relevance (language) model discussed, for example, in Victor Lavrenko et al., “Relevance based language models,” Proceedings of the 24th annual international ACM SIGIR conference on Research and development in information retrieval (SIGIR '01), September 2001, p. 120-127 (hereinafter “Lavrenko”), the entire disclosure of which is incorporated by reference herein for all purposes. For a given word w (over some vocabulary), this model may be estimated from F:
Formally, let c(w, x) denote the occurrence count of word w in text x, and let |x|=Σw∈xc(w, x). The term
within Equation1 estimates the likelihood of word w given document d's (unsmoothed) language model. As discussed above with reference to step 340 within which it is computed, the term {circumflex over (p)}(d|q, R) within Equation1 estimates the relevance likelihood of document d∈F for query q.
Step 370 involves ranking the entire pool of candidate documents 310 based on the PRF model θR[F] induced in step 350. For example, in an illustrative embodiment, a PoolRank score of a given document d∈ may be calculated according to negative cross-entropy similarity: SPoolRank(d|q) exp(Σw {circumflex over (p)}(w|θR[F])log {circumflex over (p)}[μ](w|θd)
Similar to any other query-expansion approach, using θR[F] directly may incur query-drift risk as described in, e.g., Liron Zighelnic et al., “Query-drift prevention for robust query expansion,” Proceedings of the 31st annual international ACM SIGIR conference on Research and development in information retrieval (SIGIR '08), p. 825-826 (hereinafter “Zighelnic”), the entire disclosure of which is incorporated by reference herein for all purposes. The query-drift risk may be reduced by multiplying the PoolRank score by the original fusion score: S′PoolRank(d|q) SPoolRank(d|q)·Sf(d|q)
The aforementioned approach utilizing the RM1 model as described in Lavrenko and multiplying the PoolRank score by the original fusion score has been found to result in a much more robust query-expansion as compared to an alternative approach which instead utilizes the RM3 model as described in, e.g., Natali Soskin et al., “Navigating in the dark: Modeling uncertainty in ad hoc retrieval using multiple relevance models,” Proceedings of the 2nd International Conference on Theory of Information Retrieval: Advances in Information Retrieval Theory (ICTIR '09), Lecture Notes in Computer Science (LNCS) 5766, September 2009, p. 79-91 (hereinafter “Soskin”), the entire disclosure of which is incorporated by reference herein for all purposes.
Various instantiations of the relevance model in step 360 may be realized by changing the way in which the document relevance labels are estimated in step 340. PoolRank[QL] is a PoolRank variant applied with normalized query-likelihoods (QL) as document pseudo-relevance labels:
Here, p(q|d) denotes the query-likelihood of document d, which may be estimated as {circumflex over (p)}(q|d)=Πw∈q {circumflex over (p)}[μ] (w|θd)c(w,q) For a given word w and text x,
further denotes text x's Dirichlet smoothed language model with parameter μ. See, e.g., Chengxiang Zhai et al., “A study of smoothing methods for language models applied to ad hoc information retrieval,” Proceedings of the 24th annual international ACM SIGIR conference on Research and development in information retrieval (SIGIR '01), September 2001, p. 334-342, the entire disclosure of which is incorporated by reference herein for all purposes.
PoolRank[FS] is a PoolRank variant applied with normalized fusion-scores (FS) as document pseudo-relevance labels, calculated as
PoolRank[FS] uses relevance labels that directly depend on the fusion score Sf(d|q), which combines multiple ranker's scores. In comparison, PoolRank[QL] utilizes relevance labels that are estimated according to a single (and relatively naïve) score method, query-likelihood. Thus, PoolRank[FS] is more robust than PoolRank[QL].
As discussed above with reference to
The predicted quality of a reference list is basically an estimate of whether that list contains any relevant information for a given query, and thus may be computed using techniques for post-retrieval query performance processing (QPP), such as the Weighted Information Gain (WIG) QPP method described by Yun Zhou et al., “Query performance prediction in web search environments,” Proceedings of the 30th annual international ACM SIGIR conference on Research and development in information retrieval (SIGIR '07), July 2007, p. 543-550 (hereinafter “Zhou”), the entire disclosure of which is incorporated by reference herein for all purposes.
For a given reference list, which is assumed to be effective, the relevance of a given document (e.g., the likelihood of observing the document within that list) may be estimated according to the information gained by using it to “encode” the query-focused (relevant) part of the reference list compared to using the background (corpus) model for the same task. This estimate may be further normalized relative to the list's information diversity (e.g., the entropy of the list's centroid language model), thereby favoring lists that are more focused.
An illustrative embodiment may utilize a probabilistic fusion framework (PFF) described by, e.g., Yael Anava et al., “A probabilistic fusion framework,” Proceedings of the 25th ACM International on Conference on Information and Knowledge Management (CIKM '16), October 2016, p. 1463-1472, the entire disclosures of which is incorporated by reference herein for all purposes. A relevance label likelihood {circumflex over (p)}(d|q, R) for each document d∈ may be estimated as follows: {circumflex over (p)}PFF(d|q, R){circumflex over (p)}(d|Li, R) {circumflex over (p)}(Li|q, R) (hereinafter “Equation2”).
The term {circumflex over (p)}(Liq, R) within Equation2 is basically an estimate of whether list Li∈ contains any relevant information (R) for query q. As previously noted, such estimate may be computed using techniques for QPP, such as the WIG QPP method described by Zhou. The term {circumflex over (p)}(d|Li, R) within Equation2 estimates the likelihood that a (presumably) relevant list Li∈ will further include document d. An observation that
can facilitate derivation of the following estimator:
The numerator of the right side in Equation3 indicates the information gain from a reference list which is focused, while the denominator of the right side in Equation3 indicates the penalty when a reference list is too general. More particularly, the estimator {circumflex over (p)}(Li,R|d) (the numerator of the right side in Equation3) is given as the information gained by generating the reference model induced from list Li(denoted θR[L
The centroid language model may capture general topics covered by documents in the list.
Intuitively, the more a given list Li is focused towards the information need expressed in query q (i.e., there is higher relevance likelihood {circumflex over (P)}(w|θR[L
Step 440 estimates PFF-based document relevance labels {circumflex over (p)}PFF(d|q, R) as discussed above with reference to Equation2. Step 470 uses PFF-based document relevance labels 440 to directly re-rank the documents in the pool 410. The document relevance label 440 for each document d∈ can optionally be multiplied by the original fusion-score Sf(d|q) to reduce query draft-risk, as discussed above with reference to Zighelnic. Thus, in step 470, each document d∈ is scored (and re-ranked) according to SPFF(d|q){circumflex over (p)}PFF(d|q, R)·Sf(d|q)
In a manner similar to step 440 in
MultiRM is an exemplary approach which uses multiple relevance models as discussed in Soskin. MultiRM re-ranks documents d∈ according to {circumflex over (p)}(w|){circumflex over (p)}(w|θR[L
In comparison to PoolRank[QC] and PoolRank[FS], MultiRM, like PFFPoolRank and TSPoolRank, utilizes more focused relevance cues based on pseudo-relevance models that were induced from the various based ranked lists. More particularly, MultiRM, like PFFPoolRank and TSPoolRank, combines several base relevance models with each one induced from a pseudo-relevance labels set which is based on the top retrieved documents of a given base list Li∈. Unlike PFFPoolRank and TSPoolRank, MultiRM computes document relevance levels for a given base list Li∈ independently of the relevance labels in the other base lists (i.e., \{Li}). PFFPoolRank and TSPoolRank actually estimate pseudo-relevance labels for all documents d∈, where the label for each document depends on the relevance of all base ranked lists, thereby resulting in a more robust pseudo-relevance label estimation relative to MultiRM.
To evaluate the effectiveness of the methods, we used runs submitted to different tracks of TREC (Text REtrieval Conference) as the base ranked lists (e.g., 110, 310, 410, 510), with titles of TREC topics serving for queries, in a manner similar to that described in Rabinovich. Here, we used the ad hoc tracks of TREC3, TREC7, and TREC8; the Web tracks of TREC9 and TREC10; and the robust track of TREC12. On each track, we randomly sampled 30 subsets of 5 runs (rankers) each; each sampled run included at least 100 documents per each query.
Each subset's runs (ranked lists) were combined together using each of the fusion-based retrieval techniques (Basic, PoolRank[QC], PoolRank(FS), MultiRM, PFFPoolRank and TSPoolRank) implemented with each of four different basic fusion methods (i.e., instantiations of f 120, 320, 420, and/or 520), with each basic fusion method used to combine the same set of ranked lists (runs) in and obtain a fused list Lf. That is to say, each of the fusion-based retrieval techniques (Basic, PoolRank[QC], PoolRank(FS), MultiRM, PFFPoolRank and TSPoolRank) was repeated for each query with each of these four basic fusion methods. Thus, each fusion method was used to score all documents d∈ and to return the top-100 documents with the highest fusion score.
The first two basic fusion methods were CombSUM and CombMNZ. As a preliminary step, the document scores of each list were max-min-normalized.
The other two basic function methods were Borda and RRF. ranki(d) denotes the rank of document d∈Li. The Borda score of a given document is defined as the number of documents not ranked higher than it in the lists; formally: SBorda(d|q, )Σi=1m#{d′∈Li;ranki(d′)>ranki(d)}. See, e.g., H. P. Young, “An Axiomatization of Borda's kule,” Journal of Economic Theory, v. 9, n. 1, September 1974, p. 43-52, the entire disclosure of which is incorporated by reference herein for all purposes. The RRF score of a given document is calculated according to its reciprocal ranks, as follows:
with v=60. See, e.g., Gordon V. Cormack et al., “Reciprocal rank fusion outperforms condorcet and individual rank learning methods,” Proceedings of the 32nd international ACM SIGIR conference on Research and development in information retrieval (SIGIR '09), July 2009, p. 758-759, the entire disclosure of which is incorporated by reference herein for all purposes.
For each of the PRF-based fusion techniques (PoolRank[QC], PoolRank(FS), MultiRM, PFFPoolRank and TSPoolRank), the top-20 (i.e., l=20) documents were used as the pseudo-relevance documents set F. Each induced relevance model was further clipped at a top-100 terms cutoff. The Dirichlet parameter of smoothed document models was set to p=1000. The WIG QPP described in Zhou was used for as list effectiveness estimator for realizing {circumflex over (p)}(Li|q, R) within the MultiRM, PFFPoolRank and TSPoolRank methods, with the top-5 documents of each list Li∈ being used for the prediction.
As heretofore discussed, we evaluated fusion-based retrieval performance based on the top-100 documents in a given fused-list. Retrieval quality was measured (using TREC's relevance judgments) according to mean average precision at 100 (MAP@100) and precision at 10 (P@10). Each of the MAP@100 and P@10 values shown in table 600 represent an average retrieval quality obtained across the 30 samples. Bolded numbers denote the best accuracy among methods that use the same basic fusion method. Underlined numbers denote the overall best accuracy per track.
In table 600, we report statistically significant differences in quality using the two-tailed paired t-test computed at a 95% confidence level. The superscripts b, q, and f denote a statistically significant difference with Basic, PoolRank[QL], and PoolRank[FS], respectively. The subscripts i, p, and t denote a statistically significant difference with MultiRM, PFFPoolRank, and TSPoolRank, respectively.
The results in table 600 demonstrate that the ability to successfully apply pseudo-relevance feedback in fusion-based retrieval is highly dependent on the quality of the underlying pseudo-relevance labeling approach. As previously noted, PoolRank[FS] uses relevance labels that directly depend on the fusion score Sf(d|q), which combines multiple ranker's scores. In comparison, PoolRank[QL] utilizes relevance labels that are estimated according to a single (and relatively naïve) score method, query-likelihood. Thus, PoolRank[FS] is more robust than PoolRank[QL]. Table 600 shows that, in the majority of cases, the retrieval quality of PoolRank[QL] was inferior to that of the control Basic, while PoolRank[FS] significantly outperformed both PoolRank[QL] and Basic. This demonstrates that, in a fusion-based retrieval setting, a better approach for determining the pseudo-relevance label of a given document is to utilize all relevance cues that are available from the (initial) base ranked-lists.
MultiRM, PFFPoolRank, and TSPoolRank generally outperformed Basic, PoolRank[QL], and PoolRank[FS]. As discussed above, relative to PoolRank[QC] and PoolRank[FS], MultiRM, like PFFPoolRank and TSPoolRank, utilizes more focused relevance lists' cues. However, PFFPoolRank provided better quality than MultiRM in the majority of cases, and most notably on the Web and robust tracks. As discussed above, unlike MultiRM, PFFPoolRank uses relevance cues which are based on all reference lists.
Using PFF-based relevance labels, in most instances, results in a significant boost in retrieval quality of 2-9%. TSPoolRank has provided the overall best retrieval quality in table 600, demonstrating that its PRF model is enhanced by using more “accurate” relevance labels. This provides empirical evidence that, using illustrative embodiments of the present invention, of the a better pseudo-relevance feedback model may be induced with a more robust pseudo-labeling estimation approach which is better tailored to fusion-based retrieval.
One or more embodiments of the invention, or elements thereof, can be implemented, at least in part, in the form of an apparatus including a memory and at least one processor that is coupled to the memory and operative to perform exemplary method steps.
One or more embodiments can make use of software running on a general purpose computer or workstation. With reference to
Accordingly, computer software including instructions or code for performing the methodologies of the invention, as described herein, may be stored in one or more of the associated memory devices (for example, ROM, fixed or removable memory) and, when ready to be utilized, loaded in part or in whole (for example, into RAM) and implemented by a CPU. Such software could include, but is not limited to, firmware, resident software, microcode, and the like.
A data processing system suitable for storing and/or executing program code will include at least one processor 702 coupled directly or indirectly to memory elements 704 through a system bus 710. The memory elements can include local memory employed during actual implementation of the program code, bulk storage, and cache memories which provide temporary storage of at least some program code in order to reduce the number of times code must be retrieved from bulk storage during implementation.
Input/output or I/O devices (including but not limited to keyboards 708, displays 706, pointing devices, and the like) can be coupled to the system either directly (such as via bus 710) or through intervening I/O controllers (omitted for clarity).
Network adapters such as network interface 714 may also be coupled to the system to enable the data processing system to become coupled to other data processing systems or remote printers or storage devices through intervening private or public networks. Modems, cable modem and Ethernet cards are just a few of the currently available types of network adapters.
As used herein, including the claims, a “server” includes a physical data processing system (for example, system 712 as shown in
It should be noted that any of the methods described herein can include an additional step of providing a system comprising distinct software modules embodied on a computer readable storage medium; the modules can include, for example, any or all of the elements depicted in the block diagrams or other figures and/or described herein. The method steps can then be carried out using the distinct software modules and/or sub-modules of the system, as described above, executing on one or more hardware processors 702. Further, a computer program product can include a computer-readable storage medium with code adapted to be implemented to carry out one or more method steps described herein, including the provision of the system with the distinct software modules.
The present invention may be a system, a method, and/or a computer program product. 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.
The descriptions of the various embodiments of the present invention have been presented for purposes of illustration, but are not intended to be exhaustive or limited to the embodiments disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the described embodiments. The terminology used herein was chosen to best explain the principles of the embodiments, the practical application or technical improvement over technologies found in the marketplace, or to enable others of ordinary skill in the art to understand the embodiments disclosed herein.