US20170270171A1 - Query Networks Evaluation System and Method - Google Patents
Query Networks Evaluation System and Method Download PDFInfo
- Publication number
- US20170270171A1 US20170270171A1 US15/469,898 US201715469898A US2017270171A1 US 20170270171 A1 US20170270171 A1 US 20170270171A1 US 201715469898 A US201715469898 A US 201715469898A US 2017270171 A1 US2017270171 A1 US 2017270171A1
- Authority
- US
- United States
- Prior art keywords
- query
- edges
- nodes
- network
- path
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
Images
Classifications
-
- G06F17/30545—
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/24—Querying
- G06F16/245—Query processing
- G06F16/2458—Special types of queries, e.g. statistical queries, fuzzy queries or distributed queries
- G06F16/2471—Distributed queries
Definitions
- the present invention relates to querying databases.
- the invention relates to networks, such as social networks, having potentially very large query sets whose size is of the same order as the size of the database on which they run.
- a social network is a social structure made of units such as individuals or organizations, known as ‘nodes’ which are connected via links representing friendship or the like, known as ‘edges’.
- Social networks may be supported by internet based social network services such as Facebook, Twitter, LinkedIn and the like.
- Databases are used for data management of social network services and users may take advantage of simple query languages such as SQL (Structured Query Language) to process their own data as well as that of their immediate contacts.
- SQL Structured Query Language
- Embodiments described herein disclose a database apparatus for storing a query-network comprising a set of nodes and a set of edges, where the edges connect pairs of nodes and wherein at least a subset of the nodes are each associated with at least one edge-defining query.
- edge-defining queries define a set of generated-edges to be added to the existing set of edges.
- set of generated-edges connect the node associated with its respective query with another node selected from the set of nodes.
- the database apparatus includes a subset of nodes associated with at least one edge-accepting query.
- the edge-accepting query defines a subset of generated-edges to be added to existing set of edges.
- the edge-defining query of the database apparatus may comprise a datalog rule.
- the database apparatus may comprise a plurality of storage units connected to a network.
- the database apparatus of may contain data pertaining to at least one of a group consisting of: a social network, a professional network, an academic network, or an item network.
- the method for fully evaluating a query network may comprise the steps of selecting a node from said subset of said nodes, evaluating the selected node according to the edge-defining query associated with said selected node, selecting another node from said subset of said nodes and repeating the evaluation if all members of the subset of nodes have been evaluated since a generated-edge was added to the set of edges then terminating the method.
- the method step of evaluating the selected node according to the edge-defining query associated with said selected node may comprises the substeps of adding to the set of edges the members of a set of generated-edges defined by the edge-defining query associated with said selected node repeatedly as long as the set of generated-edges is not an empty set, or if the set of generated-edges is an empty set, then selecting another node from the subset of nodes and repeating the evaluation.
- the method step of adding to the set of edges the members of a set of generated-edges defined by the edge-defining query associated with a selected node may further comprise validating that the edges are accepted by edge-accepting queries associated with target nodes.
- the method step of selecting another node from a subset of nodes and repeating the evaluation step may comprise the substeps of generating a subset of nodes which are connected to the previously selected node via a path containing less edges than the maximal radius of the query network and selecting a member of that subset.
- inventions teach a method for fully evaluating a query network, comprising the steps of partitioning the query network into a plurality of query sub-networks, fully evaluating each said query sub-network and merging the query sub-networks.
- More embodiments teach a method for selecting a group from a query network stored on a database apparatus, where the group comprises a set of nodes which are evaluated according to an edge-defining query associated with a selected node.
- Other embodiments teach a method for selecting a path from a query network stored on a database apparatus where the path comprises a set of edges which are used in an evaluation of an edge-defining query associated with a selected node.
- other embodiments teach a method for creating connections between nodes on a network stored on a database apparatus wherein the connections are formed between nodes that comprise a selected path or a selected group evaluated according to an edge-defining query associated with a selected node.
- FIG. 1 is a graphic representation of an embodiment of a sample social network
- FIG. 2 is a graphic representation of an embodiment of a Conjunctive Query or a policy defining which connections a participant in a social network would like to add himself;
- FIG. 3 is a graphic representation of an embodiment of a sample social network with edge-defining queries
- FIG. 4 is a graph-based representation used to formalize a model of a social network which will be referred to as a ‘query network’;
- FIGS. 5, 6, and 7 are graphic illustrations of embodiments of individual social network participant rules q a , q b and q c (respectively);
- FIG. 8 is a graphic representation of the fully-evaluated sample social network of FIG. 3 ;
- FIG. 9 is a graphic representation of an embodiment of a fully-evaluated query network
- FIG. 10 is a formal representation of an iterative method for evaluating a query network
- FIG. 11 is a formal representation of a Backward-Radius Triggering method for evaluating a query network
- FIG. 12A is a formal representation of a “Divide and Conquer” method for evaluating a query network
- FIG. 12B is a sample graphic representation of how the “Divide and Conquer” method for evaluating a query network operates
- FIG. 13 is a sample representation of an embodiment of a social network composed of a graph and two tables
- FIG. 14 is a sample “SELECT FROM PATH” query which refers to the embodiment of the social network illustrated in FIG. 13 ;
- FIG. 15 illustrates the “SELECT FROM PATH” syntax as can be used in a Social Query Language
- FIG. 16 illustrates the “SELECT FROM GROUP” syntax as can be used in a Social Query Language
- FIG. 17A is a sample “SELECT FROM GROUP” query which refers to the embodiment of the social network illustrated in FIG. 13 ;
- FIG. 17B is the result of the sample “SELECT FROM GROUP” query of FIG. 17A ;
- FIG. 18 illustrates the “group predicate” syntax as used by an embodiment of a Social Query Language.
- a participant in a social network is associated with some information (such as name, photograph, interests), and with a list of connections to other participants.
- a participant in the network may contribute to the social network not only data about himself, but also rules which automatically query, utilize and create network data.
- participants in a social network may define rules that automatically manage contact lists, send various announcements, filter messages or the like.
- a participant may want to perform an automated addition of connections, represented by network edges. Such automated addition of edges may be defined using a query associated to the node.
- a participant may want to query information about connection paths to a target participant, where the path and target participant meet certain criteria.
- FIG. 1 is a graphic representation of an embodiment of a social network 100 .
- Nodes 110 in the graphs model the network participants, and edges 120 between nodes represent links between participants. Directed edges are used, which are capable of modeling both networks with reciprocal relations (a situation where if ‘a’ lists ‘b’, then ‘b’ also lists ‘a’) and networks with non-reciprocal relations.
- FIG. 2 illustrates a graphic representation 200 of an embodiment of such a policy, representing a sample policy which connects a first node ‘n’ 210 with a second node ‘X’ 220 if there are two distinct participants ‘Y’ 230 and ‘Z’ 240 who are connected to both ‘n’ 210 and ‘X’ 220 .
- a path and a group are two structures with which useful queries and updates over social networks can be expressed.
- a group in a social network is a set of participants, represented graphically by nodes.
- a path is an ordered set of network participants in which every consecutive two are connected, or in graphic terms, a set of ordered edges connecting one node to another.
- FIG. 3 representing a sample social network.
- the participants of the network specify policies which define which connections they would like to add to themselves. Lisa would like to connect to every participant who is a friend of two distinct friends of hers. Bart, on the other hand, would like to connect to every participant who is connected to him through two distinct paths, such that one path is of length 2 edges and the other—of length 3.
- Lisa is not connected to Marge. However, Lisa is connected to Homer and Pluto, who are both connected to Marge. According to Lisa's query, the edge # 1 (Lisa, Marge) is added to the network as illustrated in FIG. 8 . Based on this added edge, Maggie became a participant to whom Bart is connected through two paths (a two-edge path through Mickey, and a three-edge path through Lisa and Marge). Edge #2 (Bart, Maggie) is therefore added to the network. Note that the addition of edge 2 is based on edge 1 and on original network edges. The addition of edge 2 renders Maggie, who is not connected to Lisa, as a participant who is connected to two distinct friends of Lisa. The edge # 3 (Lisa, Maggie), is therefore added. Note that edge 3 is added based on the original edges and edge 2 .
- edges in this example demonstrates the recursive nature of adding edges to the network. Lisa's query was evaluated and edge 1 was added. Based on this addition (but not based on it only), another evaluation of Lisa's query resulted in the addition of edge 3 .
- FIG. 4 showing an embodiment of a graph-based representation 400 used to formalize a model of a social network which will be referred to as a ‘query network’.
- every node 410 for example and without limitation node 4 , has a query 420 for example and without limitation q b associated with it.
- a query on node ‘n’ defines the nodes that the participant corresponding to ‘n’ would like to add to his connections list. In most social interactions, the query will make use of existing connections in order to create new ones.
- CQs are used to formalize relations of a particular node with other nodes.
- a CQ has a head and a body, both of which are built of atoms. Each atom is a predicate with parameters.
- a parameter can be either a variable or a constant.
- the predicates are relation names.
- a CQ adds to the relation corresponding to its head atom tuples that correspond to a satisfying substitution of the CQ variables.
- a Datalog query is a generalization of a CQ.
- a Datalog query (also called a program) is a set of rules, each of which is essentially a CQ. The result of one rule can be used by another rule in order to produce a new result and so on.
- a Datalog program can be recursive, which means that a predicate can be defined in terms of itself, either within the same rule or indirectly.
- the initial relations constitute the Extensional Database (EDB) and the derived relations form the Intentional Database (IDB).
- a social network can be represented as a Query Network—a graph-based model in which every node models a network participant and is associated with a datalog rule determining how new connections to other participants will be added.
- connections between two participants are formed only if both participants approve the connection.
- the participant who initiated a connection generally approves the formation of the connection, before the connection is formed, a further condition may be required that the target participant also approves the connection.
- connection-initiation queries connection-initiation queries
- connection-acceptance queries datalog rules representing a connection-initiation query
- proposal queries datalog rules representing a connection-acceptance query
- acceptance queries acceptance queries
- a proposal query associated with a network node n, q p (n), is a Datalog rule whose head is F a (n,X), where X is a variable.
- An acceptance query q a (n) is a Datalog rule whose head is F a (n,X).
- the agreement rule is: F + (n,X) ⁇ F a (Z,W), F a (Z,W).
- F a and F p are IDB relation which will contain edges that are candidates to be added to the network.
- F + is an IDB relation which will contain the additions to F 0 , which is an EDB relation.
- F is an IDB relation which will contain the additions to F 0 , which is an EDB relation.
- the body of the rules is composed of predicates corresponding to the relation F and the inequality predicate.
- one of the predicates be of the form F(n, Y), and that X, the variable in the rule head, appear in one of the F body predicates.
- one of the predicates be of the form F(Y, n), and that X, the variable in the rule head, appears in one of the F body predicates.
- n is the only constant in the query (that is, all the other arguments are variables).
- One embodiment of a query network evaluation method is an Iterative algorithm presented in FIG. 10 .
- a query network where only proposal queries are associated with each node, in each iteration, a single evaluation for each of the nodes in the network is performed. If a round is completed without adding any edge to F, the algorithm stops.
- a propose-accept evaluation method can be used. In an evaluation round, all proposal queries are evaluated. Acceptance queries are then evaluated only for the proposed nodes. Accepted proposals are then materialized as edges.
- Another embodiment of a query network evaluation method is an Iterative algorithm with exhaustive rounds. Instead of evaluating each node once, as stated in line 6 of FIG. 10 , each node is exhaustively evaluated. This may result in reducing the number of rounds necessary to fully evaluate a network.
- BRT Backward-Radius Triggering
- BRT takes k, the maximal radius in the network, as input. k is used as a bound on the backward radius of the nodes, and is assumed to be small in relation to the size of the network.
- k is used as a bound on the backward radius of the nodes, and is assumed to be small in relation to the size of the network.
- Pseudo-code for a BRT evaluation algorithm appears in FIG. 11 .
- All the nodes are put in the set R, and a single node evaluation is performed for every node n in R. This is in fact a round of network evaluation.
- the set R For every node n whose evaluation results in the addition of an edge (or multiple edges) to F, the set
- the Iterative algorithm performs, on the same network, 28 evaluations.
- the benefit of saving single rule evaluations comes at the price of computing the sets B(n, k).
- the Iterative algorithm also does not use k as input.
- DAC Divide and Conquer
- the DAC evaluation algorithm takes advantage of the clustered nature of social networks in order to partition query network into networks of more manageable size.
- social networks have a structure in which participants have more links to participants within their community than to individuals from other communities. The evaluated sub-networks are later merged together to form the fully-evaluated query network.
- Prior art algorithms for graph partitioning are used to partition the graph representing the query network to parts with a relatively small number of edges between them. Partitioning enables processing small, dense sub-networks, as it takes advantage of locality of reference and minimizes work for a merge step.
- a partitioning algorithm for a query network takes a query network, say (N, F 0 ), as input and produces a number of query networks as output. N is partitioned into (non-overlapping) sets of nodes. Each such set Ni, and the edges in F 0 between the nodes in Ni form a query network in the output. Crossing edges are edges in F 0 that are in none of the created networks.
- DAC takes a graph-partitioning algorithm and the number of parts to partition to as input.
- DAC takes k, the maximal radius of query in the network, as input.
- Pseudo code for DAC appears in FIG. 12A .
- the partition algorithm partitions the network into smaller networks. Every part is evaluated separately using the BRT evaluation algorithm (Line 2 ). Then, a match-making procedure is invoked (Line 4 ). Two networks such that the number of edges between them is maximal are matched. Then, the rest of the networks are considered, and another pair is matched and so on (see procedure mergePairs). Match making continues until less than two networks remain unmatched.
- Each pair is merged into one network (Line 7 ).
- the nodes of the new network are the union of the nodes of the networks being merged.
- the edges are the union of the edges of the networks being merged, as well as the crossing edges between the merged networks. Due to the addition of crossing edges, the merged network is not fully evaluated.
- the merge&eval procedure evaluates the merged network, first by evaluating all the nodes n that are sources of the cross edges and the nodes within ⁇ B(n, I)
- FIG. 12B illustrates a sample embodiment of a network evaluation procedure using DAC.
- a, c and e represent non-fully-evaluated networks
- b, d and f represent fully evaluated networks.
- k the maximal radius of query in the network
- k the maximal radius of query in the network
- k the maximal radius of query in the network
- k can be ascertained before starting the evaluation.
- DAC DAC
- k can be ascertained before evaluating each initial partition before any merge has been done on the first round and maintained for further evaluations as the maximum value of each merged pair.
- k for different parts may be lower than the global k.
- Embodiments of the query network and related embodiments of query network evaluation methods may be applied to other graphic representations of networks, such as but not limited to query networks where not all the nodes have a query associated with them, query networks where some nodes include more than one query, query networks with reciprocal relations (a situation where if ‘x’ lists ‘y’, then ‘y’ also lists ‘x’), query networks with non-reciprocal relations, query networks where node queries may include data querying in addition to relational querying, and usage of multiple, local bradius values instead of a single global bradius.
- SoQL query language for social networks
- SoQL adds new data types called Path and Group to the conventional SQL data types.
- Each may be an element in a tuple, and include subpaths, subgroups and paths within a group defined in a query. Creation of new data is also based on the path and group structures. Operators which specify conditions on a path or a group are defined. These include aggregation functionalities, as well as existential and universal quantifiers on nodes and edges in a path or a group, and on paths within a defined group.
- FIG. 13 illustrates an embodiment of a social network.
- the network is composed of a graph and two tables. Focus is set on seven participants and on the edges between them. An edge exists between two participants if they are on each other's connections list. For example, Bob # and Charlie # are on each other's connections list.
- Each node and each edge has a list of attributes. In this example, every node has the attributes name, company, e-mail, position and experience, and each edge has the attributes id and weight.
- the values of the nodes and edges attributes are given in Table T N and T F respectively in FIG. 13 .
- the id of each edge appears next to it.
- the weight associated with each edge is a number between 0 and 1.
- the weight of an edge (u,v) is the probability that if we ask one of participants u or v to introduce us to the other, they will agree to do that. For example, if we ask Bob to introduce us to Charlie, then the probability that Bob will agree is 0.7.
- the SoQL language enables practical utilization of social networks for various needs.
- Bob is looking for a new job. He currently works for ACME, and would like to apply for a position with HAL. He would like to use the connections in his social network in order to find a simple path in the network from him to a manager in HAL. After finding the path using a SELECT FROM PATH query, Bob plans to use a CONNECT USING PATH command in order to ask each of the participants along the retrieved path to introduce him to the next participant, ultimately connecting him to a HAL manager.
- the person at the end of the path should be a manager in HAL.
- the path should consist of at most four participants.
- FIG. 14 is an example of a SoQL query that Bob can use.
- the intuitive explanation of the query's semantics is as follows:
- the path itself and the count of its nodes are selected as output (Line 1 ).
- the path itself is composed of two paths, P 1 and P 2 .
- P 1 starts at the node representing Bob and finishes at X, a variable
- P 2 starts at X and finishes at Y (Lines 2 - 3 ).
- PATH is the alias of the whole path, in this case, the concatenation of P 1 and P 2 .
- Lines 6 - 7 use a path predicate to require that at most zero nodes in P 2 be with value ACME for the attribute company.
- Line 8 we requires that the length, in nodes, of P 1 be exactly two (i.e., one edge).
- Line 9 requires that the length, in nodes, of P 2 be four or less.
- Lines 8 - 9 use abbreviations for aggregation queries over paths.
- the query also retrieves the number of nodes in each retrieved path, and the results are to be ordered (descending) by the multiplication of the weights of the edges of P 2 .
- the latter value is 0.3 for Path a above, 0.16 for Path b and 0.765 for Path c. Therefore, the result of the query is the following binary relation:
- SoQL introduces to SQL will be introduced herein. These extensions including two types of SoQL commands: SELECT queries, which retrieve data, and CONNECT commands which use a path or a group in a process during which new data in the network may be created.
- a SELECT FROM PATH query returns a relation in which elements of a tuple are either a path or an aggregation over a path.
- the formal definitions and related examples listed hereinbelow relate to the syntax outline illustrated in FIG. 15 .
- a SELECT FROM GROUP query returns a relation in which elements of a tuple are either a group element, a path element between members of the group or an aggregation over a group or path.
- the syntax of a SELECT FROM GROUP query is illustrated in FIG. 16 . Elements with the same name as in SELECT FROM PATH have the same definition.
- FIG. 17A illustrates a sample SELECT FROM GROUP query that Bob will use to look for people who meet the following conditions:
- FIG. 17B shows the result of such query.
- the number of members in the retrieved group is predetermined to be four (including Bob).
- SoQL allows retrieving groups whose number of members is not predetermined.
- Lines 2 - 3 in the query listed in FIG. 14A define Bob as a subgroup with alias G 1 and X,Y and Z as all the distinct members of another subgroup with alias G 2 .
- X,Y and Z are distinct members of G 2 , a group containing them.
- the operators are the same operators we use for paths (i.e., ALL, ATMOST n, ATLEAST n, ALL EXCEPT UPTO n, MAJORITY).
- the node predicate which follows SATISFY in this case evaluates to true or false as defined for path operators.
- the group operator ALL is used over the nodes of G 2 .
- the group predicate uses the operator ALL SUBGROUPS(U,V) over G 2 .
- the path predicate evaluates to true on a path whose number of edges is at most 2. Note that the path is aliased as P 4 .
- the CONNECT USING PATH command specifies how to use paths in a one-column relation of paths in order to attempt to create a connection to the participant(s) at the end of the paths.
- the command can automate the process of asking each member of the path, say v, to introduce the first member of the path to the successor of v in the path, and so on, until the first member is introduced to the last member.
- a network participant p can only use paths in which p is the first member.
- R is the projection of the result of query in FIG. 14 on the first column (with type Path), the query that Bob will use is listed herein.
- each introduction includes the prefix of path used up to this introduction.
- Bob is introduced to Alice as a participant requesting to be connected to her. If Alice agrees, a connection between her and Bob is added, the attempt succeeds, and the command terminates.
- the paths using which the connection attempts will be done are given after FROM, as a one-column relation.
- the column is of type Path (the relation can be given explicitly or as a SELECT FROM PATH query). Being a relation, its tuples are ordered. The attempts to create the connections will be done using the paths in this order. After the first success, the command terminates (and other attempts stop). If the number of hours specified for TIMEOUT pass without a success, the command and all its attempts stop.
- the value for PARALLEL specifies how many paths can be explored in parallel. When the factor is 1, the result is sequential attempts, i.e., one path is explored at a time until failure or success. The operation is such that given a PARALLEL value of n, then only when, and if, all n attempts fail, another set of n is explored in parallel. The attempts continue until all input paths are exhausted or until the maximum number of attempts is reached.
- the CONNECT GROUP command specifies how to use groups from an input relation in order to attempt to create connections between all member pairs in the group.
- the command uses a one-column relation with a group element in each tuple. The command will address each of the group's prospective members with a proposal from the participant who issued the command to form a group with the rest of the group members. If all agree, the attempt succeeds and the group is formed, i.e., each member lists the other members as their connections in the network.
- CONNECT GROUP As in CONNECT USING PATH, some parameters for CONNECT GROUP can be set. Timeout, number of attempts and parallelism factor have a meaning identical to the meaning in CONNECT USING PATH.
- the command will try one group at a time, starting with ⁇ Bob, Eve, Frank, Gloria ⁇ . If an attempt fails, another attempt will be made with next group, up to three attempts.
- the timeout is two days.
- SoQL is built to allow formulating conditions over groups or paths whose size or length is not fixed, which may result in very large results, for example and without limitation formulating queries without setting a bound on the size of a GROUP.
- a practical approach for evaluating such queries include deployment parameters aiming to ensure the feasibility of evaluating SoQL queries, such as but not limited to the maximum number of tuples in the result, the maximal length of any path considered in the query, the maximal size of any group, and the maximal time to be spent on a single query evaluation.
- Paths using Joins can be performed with techniques used in relational databases. Paths starting at the node given as a constant in the query can be found by performing self-joins over F. Before every join, intermediary results with no potential to form a path are pruned. Top-k evaluations (based on relevant scoring functions) for this joins are also useful for avoidance of large intermediate results for these joins.
- the number of joins can be bounded by a deployment parameter, and may be affected by the other parameters as well.
- Finding Groups One method of evaluating SELECT FROM GROUP queries is to decompose, as much as possible, the group definition to several path definitions and evaluate the corresponding path queries. For example, since the query group always contains the participant issuing the query, paths from that participant to other participants can be found first and evaluated (using the techniques above or others). Then, other paths are processed. The results are joined based on variables that appear in more than one path. Note that complex considerations are required in this type of queries, such as the maximum number of group members and its effect on satisfying the group predicates used. Members in the query group not defined as a part of a path can be found using ordinary relational queries.
- the scope of the present invention is defined by the appended claims and includes both combinations and sub combinations of the various features described hereinabove as well as variations and modifications thereof, which would occur to persons skilled in the art upon reading the foregoing description.
Landscapes
- Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Computational Linguistics (AREA)
- Probability & Statistics with Applications (AREA)
- Software Systems (AREA)
- Mathematical Physics (AREA)
- Data Mining & Analysis (AREA)
- Databases & Information Systems (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Fuzzy Systems (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
A query network is disclosed, comprising sets of nodes and edges connecting pairs of nodes. The nodes of the query network are associated with edge-defining queries. A method is taught for fully evaluating such a query network. A language is further disclosed for constructing queries. The query network may be used to model a social network, a professional network or the like.
Description
- The present invention relates to querying databases. In particular the invention relates to networks, such as social networks, having potentially very large query sets whose size is of the same order as the size of the database on which they run.
- A social network is a social structure made of units such as individuals or organizations, known as ‘nodes’ which are connected via links representing friendship or the like, known as ‘edges’. Social networks may be supported by internet based social network services such as Facebook, Twitter, LinkedIn and the like.
- The increasing popularity of computer based social network services introduces the need to manage and query increasing amounts of data. Databases are used for data management of social network services and users may take advantage of simple query languages such as SQL (Structured Query Language) to process their own data as well as that of their immediate contacts.
- Traditional databases rely on the assumption that the size of a query is small and the data being queried is large. This approach sits well with the state of current social network services, in which the main social networking features of establishing and managing connections, or edges, between participants, or nodes, is performed manually.
- However, as the number of queries increases in size dramatically and connections management is constantly increasing in complexity, current query languages such as SQL lack concepts which are required for expression and querying of connection data.
- The need remains, therefore, for effective database evaluation methods for large query sets, whose size is of the same order as (or even larger than) the size of the database on which they run, and a query language including terminology to express connection-based queries. Embodiments described hereinbelow address this need.
- Embodiments described herein disclose a database apparatus for storing a query-network comprising a set of nodes and a set of edges, where the edges connect pairs of nodes and wherein at least a subset of the nodes are each associated with at least one edge-defining query.
- Optionally, edge-defining queries define a set of generated-edges to be added to the existing set of edges. Optionally, set of generated-edges connect the node associated with its respective query with another node selected from the set of nodes.
- Optionally, the database apparatus includes a subset of nodes associated with at least one edge-accepting query. Optionally, the edge-accepting query defines a subset of generated-edges to be added to existing set of edges.
- The edge-defining query of the database apparatus may comprise a datalog rule.
- The database apparatus may comprise a plurality of storage units connected to a network.
- The database apparatus of may contain data pertaining to at least one of a group consisting of: a social network, a professional network, an academic network, or an item network.
- Other embodiments teach a method for fully evaluating a query network stored on a database apparatus, such that all edges defined by edge-defining queries become members of the set of edges.
- The method for fully evaluating a query network may comprise the steps of selecting a node from said subset of said nodes, evaluating the selected node according to the edge-defining query associated with said selected node, selecting another node from said subset of said nodes and repeating the evaluation if all members of the subset of nodes have been evaluated since a generated-edge was added to the set of edges then terminating the method.
- The method step of evaluating the selected node according to the edge-defining query associated with said selected node, may comprises the substeps of adding to the set of edges the members of a set of generated-edges defined by the edge-defining query associated with said selected node repeatedly as long as the set of generated-edges is not an empty set, or if the set of generated-edges is an empty set, then selecting another node from the subset of nodes and repeating the evaluation.
- The method step of adding to the set of edges the members of a set of generated-edges defined by the edge-defining query associated with a selected node may further comprise validating that the edges are accepted by edge-accepting queries associated with target nodes.
- The method step of selecting another node from a subset of nodes and repeating the evaluation step may comprise the substeps of generating a subset of nodes which are connected to the previously selected node via a path containing less edges than the maximal radius of the query network and selecting a member of that subset.
- Other embodiments teach a method for fully evaluating a query network, comprising the steps of partitioning the query network into a plurality of query sub-networks, fully evaluating each said query sub-network and merging the query sub-networks.
- More embodiments teach a method for selecting a group from a query network stored on a database apparatus, where the group comprises a set of nodes which are evaluated according to an edge-defining query associated with a selected node. Other embodiments teach a method for selecting a path from a query network stored on a database apparatus where the path comprises a set of edges which are used in an evaluation of an edge-defining query associated with a selected node. In addition, other embodiments teach a method for creating connections between nodes on a network stored on a database apparatus wherein the connections are formed between nodes that comprise a selected path or a selected group evaluated according to an edge-defining query associated with a selected node.
- For a better understanding of the invention and to show how it may be carried into effect, reference will now be made, purely by way of example, to the accompanying drawings.
- With specific reference now to the drawing in detail, it is stressed that the particulars shown are by way of example and for purposes of illustrative discussion of the preferred embodiments of the present invention only, and are presented in the cause of providing what is believed to be the most useful and readily understood description of the principles and conceptual aspects of the invention. In this regard, no attempt is made to show structural details of the invention in more detail than is necessary for a fundamental understanding of the invention; the description taken with the drawing making apparent to those skilled in the art how the several forms of the invention may be embodied in practice.
- In the accompanying drawings,
-
FIG. 1 is a graphic representation of an embodiment of a sample social network; -
FIG. 2 is a graphic representation of an embodiment of a Conjunctive Query or a policy defining which connections a participant in a social network would like to add himself; -
FIG. 3 is a graphic representation of an embodiment of a sample social network with edge-defining queries; -
FIG. 4 is a graph-based representation used to formalize a model of a social network which will be referred to as a ‘query network’; -
FIGS. 5, 6, and 7 are graphic illustrations of embodiments of individual social network participant rules qa, qb and qc (respectively); -
FIG. 8 is a graphic representation of the fully-evaluated sample social network ofFIG. 3 ; -
FIG. 9 is a graphic representation of an embodiment of a fully-evaluated query network; -
FIG. 10 is a formal representation of an iterative method for evaluating a query network; -
FIG. 11 is a formal representation of a Backward-Radius Triggering method for evaluating a query network; -
FIG. 12A is a formal representation of a “Divide and Conquer” method for evaluating a query network; -
FIG. 12B is a sample graphic representation of how the “Divide and Conquer” method for evaluating a query network operates; -
FIG. 13 is a sample representation of an embodiment of a social network composed of a graph and two tables; -
FIG. 14 is a sample “SELECT FROM PATH” query which refers to the embodiment of the social network illustrated inFIG. 13 ; -
FIG. 15 illustrates the “SELECT FROM PATH” syntax as can be used in a Social Query Language; -
FIG. 16 illustrates the “SELECT FROM GROUP” syntax as can be used in a Social Query Language; -
FIG. 17A is a sample “SELECT FROM GROUP” query which refers to the embodiment of the social network illustrated inFIG. 13 ; -
FIG. 17B is the result of the sample “SELECT FROM GROUP” query ofFIG. 17A ; and -
FIG. 18 illustrates the “group predicate” syntax as used by an embodiment of a Social Query Language. - Social networks introduce new challenges to the world of database management and information retrieval. Typically, a participant in a social network is associated with some information (such as name, photograph, interests), and with a list of connections to other participants.
- It is a particular feature of embodiments described herein that a participant in the network, represented by a node, may contribute to the social network not only data about himself, but also rules which automatically query, utilize and create network data. For example, participants in a social network may define rules that automatically manage contact lists, send various announcements, filter messages or the like. A participant may want to perform an automated addition of connections, represented by network edges. Such automated addition of edges may be defined using a query associated to the node. A participant may want to query information about connection paths to a target participant, where the path and target participant meet certain criteria.
- It will be appreciated that existing query languages lack concepts for correct and effective examination of possible connection paths, and that traditional database evaluation methods such as referenced in the background will not meet the needs of social networks where each participant defines his own rules for connection management. The union of such rules may produce a huge query set, whose size is of the same order or even larger than the size of the set of participants in the network. This significantly diverges from the traditional assumption that queries are small and data is large.
- For the sake of clarity, a graph-based formalism will be used hereinbelow to model social networks, and to introduce concepts for expressing social networks queries. The terminology defined with these concepts will be referred to as Social Query Language (SoQL).
FIG. 1 is a graphic representation of an embodiment of asocial network 100.Nodes 110 in the graphs model the network participants, and edges 120 between nodes represent links between participants. Directed edges are used, which are capable of modeling both networks with reciprocal relations (a situation where if ‘a’ lists ‘b’, then ‘b’ also lists ‘a’) and networks with non-reciprocal relations. - Participants of a network can specify policies which define which connections they would like to add to themselves. In graphical representations of a policy, the variable in the head of a policy typically appears in a double circle.
FIG. 2 illustrates agraphic representation 200 of an embodiment of such a policy, representing a sample policy which connects a first node ‘n’ 210 with a second node ‘X’ 220 if there are two distinct participants ‘Y’ 230 and ‘Z’ 240 who are connected to both ‘n’ 210 and ‘X’ 220. - A path and a group are two structures with which useful queries and updates over social networks can be expressed. A group in a social network is a set of participants, represented graphically by nodes. A path is an ordered set of network participants in which every consecutive two are connected, or in graphic terms, a set of ordered edges connecting one node to another. Reference is now made to
FIG. 3 , representing a sample social network. In this sample, the participants of the network specify policies which define which connections they would like to add to themselves. Lisa would like to connect to every participant who is a friend of two distinct friends of hers. Bart, on the other hand, would like to connect to every participant who is connected to him through two distinct paths, such that one path is oflength 2 edges and the other—oflength 3. These two definitions of policies are illustrated graphically as queries qa (Lisa) inFIG. 5 and qb (Bart) inFIG. 6 . The rest of the participants (nodes) are associated with queries as shown inFIG. 3 . - Lisa is not connected to Marge. However, Lisa is connected to Homer and Pluto, who are both connected to Marge. According to Lisa's query, the edge #1 (Lisa, Marge) is added to the network as illustrated in
FIG. 8 . Based on this added edge, Maggie became a participant to whom Bart is connected through two paths (a two-edge path through Mickey, and a three-edge path through Lisa and Marge). Edge #2 (Bart, Maggie) is therefore added to the network. Note that the addition ofedge 2 is based onedge 1 and on original network edges. The addition ofedge 2 renders Maggie, who is not connected to Lisa, as a participant who is connected to two distinct friends of Lisa. The edge #3 (Lisa, Maggie), is therefore added. Note thatedge 3 is added based on the original edges andedge 2. - It is noted that the addition of edges in this example demonstrates the recursive nature of adding edges to the network. Lisa's query was evaluated and
edge 1 was added. Based on this addition (but not based on it only), another evaluation of Lisa's query resulted in the addition ofedge 3. - The union of individual participant rules qa, qb and qc as shown in
FIGS. 5, 6 and 7 respectively, typically constitutes a very large, recursive, Datalog program whose size is of the order of magnitude of the size of the data being queried (data whose size in a social network can easily exceed 1 TB). Traditional optimizers will be hard pressed to handle such queries, even if queries are ‘translated’ to SQL and their union is transformed to a very large SQL query. - Reference is now made to
FIG. 4 , showing an embodiment of a graph-basedrepresentation 400 used to formalize a model of a social network which will be referred to as a ‘query network’. In this embodiment, everynode 410, for example and withoutlimitation node 4, has aquery 420 for example and without limitation qb associated with it. A query on node ‘n’ defines the nodes that the participant corresponding to ‘n’ would like to add to his connections list. In most social interactions, the query will make use of existing connections in order to create new ones. - Reference is now made back to
FIG. 2 , showing a graphical representation of an embodiment of a single policy, also referred to as a Conjunctive Query (CQ) 200. As stated previously, CQs are used to formalize relations of a particular node with other nodes. A CQ has a head and a body, both of which are built of atoms. Each atom is a predicate with parameters. A parameter can be either a variable or a constant. The predicates are relation names. A CQ adds to the relation corresponding to its head atom tuples that correspond to a satisfying substitution of the CQ variables. - A Datalog query is a generalization of a CQ. A Datalog query (also called a program) is a set of rules, each of which is essentially a CQ. The result of one rule can be used by another rule in order to produce a new result and so on. A Datalog program can be recursive, which means that a predicate can be defined in terms of itself, either within the same rule or indirectly. The initial relations constitute the Extensional Database (EDB) and the derived relations form the Intentional Database (IDB).
- Formal definitions are presented hereinbelow:
-
- A Query Network—a directed graph (N, F0) where N (for Nodes) is a set of users. F0 (for Friends) is a set of directed edges between pairs of distinct elements of N.
- F0 ⊂(N×N)\{(n0,n0) such that n0 ∈ N}
- Every node n ∈ N has a query associated with it. The query defines edges of the form (n, .), which are edges such that n would like to add to the initial set of edges, F0, as defined next.
- A Query—A query associated with a network node n, q(n), is a Datalog rule of the following form. The rule's head is F+(n,X), where X is a variable. F+ is an IDB relation which will contain the additions to F0 which is an EDB relation. We define another relation, F, as F=F+ UF0. The body of the rule is composed of predicates corresponding to the relation F and the inequality predicate. We require that one of the predicates is of the form F(n, Y), and that X, the variable in the rule head must appear in one of the F body predicates. The latter requirement is typically added for safety. Further requirements follow the example.
- Example. The following query adds to F tuples of the form (n,X) where X is a friend of two distinct friends of n: F+(n,X)←F(n,Y),F(Y,X),F(n,Z),F(Z,X),Y≠Z, X≠n,Y≠n,Z≠n. It is assumed that unless otherwise specified, each two distinct variables imply an inequality predicate between them. It is further assumed that none of the variables is equal to n. Therefore, the query is abbreviated to:
- F+(n,X) F(n,Y),F(Y,X),F(n,Z),F(Z,X).
- For a query q(n) we also require that n is the only constant in the query (that is, all other arguments are variables).
- Query Graph. Let the Query Graph of a query q(n) be the graph whose nodes are the variables and n, the single constant in the query q(n), and in which a directed edge exists between two variables X and Y (respectively, a constant n and an argument Z) if a predicate F(X, Y) (respectively, F(n,Z)) occurs in the query body. In the graphical representation of the graph, the variable in the head of the rule appears in a double circle.
- The query graph corresponding to the query in the previous example is shown in
FIG. 2 .
- The query graph corresponding to the query in the previous example is shown in
- Radius—the radius of a query q is the number of edges in the longest path, that never traverses a node more than once, in the query graph corresponding to q. The radius of any query is very small relative to the size of the network.
- Backward Radius (bradius)—the bradius of a node n is the maximal distance from another node m such that the query q(m) can ‘sense’ the edges whose source is n. A formal definition follows herein
- ∃
- B(n,k)={m ∈ N·| | there exists a path of length k from m to n}and L(n, k)={b·| |δ ∈ B(n,k) and the radius of q(b) is at least k}.
- The bradius of node n is the maximal k such that L(n, k)≠Ø. Note that the bradius of any node is bounded by the maximal radius in the network.
-
FIG. 4 shows a representation of an embodiment of a small query network. Each node has an id (a number) and is associated with one query, either qa, qb or qc, whose query graphs also appear inFIGS. 5, 6 and 7 respectively. It is assumed that the head of the query is always F(n,X). The radius ofnode 2 is 3. The radius ofnode 4 is 2. The bradius ofnode 8 is 3. The bradius ofnode 2 is 1.
- Single Evaluation of a Node—the process of evaluating a node's query on a given network and subsequently adding a (possibly empty) set of nodes to F.
- Example: In the representation of the network illustrated in
FIG. 4 , a single evaluation of the query associated withnode 4, qb, inserts the edge (4, 8) to F.
- Example: In the representation of the network illustrated in
- Exhaustive Evaluation of a Node—The process of evaluating a single query, and this query only, repeatedly and until no edges can be added to F.
- Example:
node 2 in the network after the edge (4, 8) has been added to the original network. After a single evaluation of this node, (2, 6) is in F. Since (2, 6) is in F, another single evaluation ofnode 2 will result in the addition of (2, 8) to F. This is different than a single evaluation which adds two edges to F, since the addition of (2, 8) is done based on the edge (2,6) that is added in the first evaluation. - The network after evaluation is presented in
FIG. 9 . The new edges are dashed.
- Example:
- A Fully Evaluated Network—a network such that a round of evaluation applied to it will not add any edge to F.
FIG. 9 shows an embodiment of a fully evaluated network.
- A Query Network—a directed graph (N, F0) where N (for Nodes) is a set of users. F0 (for Friends) is a set of directed edges between pairs of distinct elements of N.
- A social network can be represented as a Query Network—a graph-based model in which every node models a network participant and is associated with a datalog rule determining how new connections to other participants will be added.
- It is a feature of some embodiments of the social networks that connections between two participants are formed only if both participants approve the connection. Although the participant who initiated a connection generally approves the formation of the connection, before the connection is formed, a further condition may be required that the target participant also approves the connection.
- Thus, a distinction may be made between connection-initiation queries and connection-acceptance queries. Formally, datalog rules representing a connection-initiation query will be referred to as ‘proposal queries’ and datalog rules representing a connection-acceptance query will be referred to as ‘acceptance queries’.
- Formal definitions for proposal and acceptance queries are presented hereinbelow:
- A proposal query associated with a network node n, qp(n), is a Datalog rule whose head is Fa(n,X), where X is a variable. An acceptance query qa(n) is a Datalog rule whose head is Fa(n,X). We define another Datalog rule, called the agreement rule, which not associated with any of the nodes. the agreement rule is: F+(n,X)ΔFa(Z,W), Fa(Z,W).
- Fa and Fp are IDB relation which will contain edges that are candidates to be added to the network. F+ is an IDB relation which will contain the additions to F0, which is an EDB relation. We define another relation, F, as F=F+ U F0. The body of the rules is composed of predicates corresponding to the relation F and the inequality predicate.
- In a proposal query, it is required that one of the predicates be of the form F(n, Y), and that X, the variable in the rule head, appear in one of the F body predicates.
- In an acceptance query, it is required that one of the predicates be of the form F(Y, n), and that X, the variable in the rule head, appears in one of the F body predicates.
- For a query qa(n) or qp(n) it is also required that n is the only constant in the query (that is, all the other arguments are variables).
- It is a further aim to demonstrate query network evaluation methods, which given a query network (N,F0) as input, construct the resulting fully evaluated query network (N, F).
- Query Network Evaluation Methods
- One embodiment of a query network evaluation method is an Iterative algorithm presented in
FIG. 10 . In a query network where only proposal queries are associated with each node, in each iteration, a single evaluation for each of the nodes in the network is performed. If a round is completed without adding any edge to F, the algorithm stops. - Referring back to
FIG. 8 , an illustration of the query network evaluation using the iterative algorithm is presented through the specific sample. In the first round of evaluation, evaluating the query associated with Lisa yields a result relation with one tuple, (Lisa, Marge). This tuple is added to F, and the stopFlag is toggled to indicate that the main while loop of the algorithm (lines 3 through 12) has to continue for at least another iteration. In this round, the evaluation of the rest of the nodes results in an empty result set. In the second round (respectively, third round), the evaluation of Bart's node (respectively, Lisa's node) resulted in the addition of the edge (Bart, Maggie) (respectively, (Lisa, Maggie)), while the evaluation of the rest of the nodes yields no new tuples. In the fourth round, none of the node evaluations resulted in a non-empty result, and the algorithm stops. - In this example, four rounds of evaluation resulted in 28 single node evaluations. Only three of these evaluations actually yield addition of an edge.
- In embodiments of the query-network where nodes are also associated with acceptance queries, a propose-accept evaluation method can be used. In an evaluation round, all proposal queries are evaluated. Acceptance queries are then evaluated only for the proposed nodes. Accepted proposals are then materialized as edges.
- Another embodiment of a query network evaluation method is an Iterative algorithm with exhaustive rounds. Instead of evaluating each node once, as stated in
line 6 ofFIG. 10 , each node is exhaustively evaluated. This may result in reducing the number of rounds necessary to fully evaluate a network. - Another embodiment of a query network evaluation method will be referred to as The Backward-Radius Triggering (BRT) evaluation algorithm. Typically, using this algorithm will reach a fully evaluated network by performing a significantly lower number of single node evaluations than when using the iterative algorithm.
- BRT takes k, the maximal radius in the network, as input. k is used as a bound on the backward radius of the nodes, and is assumed to be small in relation to the size of the network. In BRT, when an edge, say (u, v), is added, only nodes whose queries can ‘sense’ the addition are considered for another evaluation. These nodes are such that there exists a (directed) path, whose length is less than the backward radius, between them and the node u.
- Pseudo-code for a BRT evaluation algorithm appears in
FIG. 11 . First, all the nodes are put in the set R, and a single node evaluation is performed for every node n in R. This is in fact a round of network evaluation. For every node n whose evaluation results in the addition of an edge (or multiple edges) to F, the set -
- is computed and added to P. P replaces R and the evaluation continues until R is empty.
- Referring back to
FIG. 8 , an illustration of the query network evaluation using the BRT algorithm is presented through the specific sample. In this network, the maximal bradius k=3. If evaluated with the BRT algorithm, the first iteration will consider all the nodes for a single evaluation, and the edge (Lisa, Marge) will be added. B(Lisa, 1)={Bart} and B(Lisa, 2)=Ø. Therefore, P={Bart}. The evaluation of the single node in P results in the addition of the edge (Bart, Maggie), and at the end of this iteration, P={Lisa}. In the next iteration, the edge (Bart, Maggie) is added, and P={Bart}. In the next iteration, no edge is added. As a result, P=R=Ø and the algorithm stops. - In this example using the BRT algorithm, the total number of single-node evaluations is (broken by iteration) 7+1+1+1=10. As shown above, the Iterative algorithm performs, on the same network, 28 evaluations. The benefit of saving single rule evaluations comes at the price of computing the sets B(n, k). The Iterative algorithm also does not use k as input.
- Yet another embodiment of a query network evaluation method will be referred to as ‘Divide and Conquer’ (DAC). The DAC evaluation algorithm takes advantage of the clustered nature of social networks in order to partition query network into networks of more manageable size. Generally speaking, social networks have a structure in which participants have more links to participants within their community than to individuals from other communities. The evaluated sub-networks are later merged together to form the fully-evaluated query network.
- Prior art algorithms for graph partitioning are used to partition the graph representing the query network to parts with a relatively small number of edges between them. Partitioning enables processing small, dense sub-networks, as it takes advantage of locality of reference and minimizes work for a merge step. A partitioning algorithm for a query network takes a query network, say (N, F0), as input and produces a number of query networks as output. N is partitioned into (non-overlapping) sets of nodes. Each such set Ni, and the edges in F0 between the nodes in Ni form a query network in the output. Crossing edges are edges in F0 that are in none of the created networks.
- DAC takes a graph-partitioning algorithm and the number of parts to partition to as input. In addition, like BRT, DAC takes k, the maximal radius of query in the network, as input.
- Pseudo code for DAC appears in
FIG. 12A . First, the partition algorithm partitions the network into smaller networks. Every part is evaluated separately using the BRT evaluation algorithm (Line 2). Then, a match-making procedure is invoked (Line 4). Two networks such that the number of edges between them is maximal are matched. Then, the rest of the networks are considered, and another pair is matched and so on (see procedure mergePairs). Match making continues until less than two networks remain unmatched. - Each pair is merged into one network (Line 7). The nodes of the new network are the union of the nodes of the networks being merged. The edges are the union of the edges of the networks being merged, as well as the crossing edges between the merged networks. Due to the addition of crossing edges, the merged network is not fully evaluated. The merge&eval procedure evaluates the merged network, first by evaluating all the nodes n that are sources of the cross edges and the nodes within {B(n, I)| I<k} for each such node n, in order to include all the nodes in their backward radius. Like in BRT, any such node whose evaluation results in the addition of new edges triggers the evaluation of the nodes potentially in their backward radius and so on until a fix point is reached.
-
FIG. 12B illustrates a sample embodiment of a network evaluation procedure using DAC. In the figure, a, c and e represent non-fully-evaluated networks, and b, d and f represent fully evaluated networks. - In (a), a network partitioned into four parts is presented. Crossing edges # between the four parts are presented as well. In b, each of the four parts is fully evaluated, ignoring crossing edges. In (c), the matchmaking result is illustrated. The parts with maximal number of crossing edges between them were merged into pairs. Note that the pairs of networks are not yet evaluated. In (d), the merged and fully evaluated pairs are shown. Another matchmaking step is (e), and the fully evaluated network is (f).
- In the BRT and DAC algorithms, k (the maximal radius of query in the network) is given to the algorithm simply by way of simplicity, but need not be known in advance. If the BRT algorithm is used, k can be ascertained before starting the evaluation. If DAC is used, k can be ascertained before evaluating each initial partition before any merge has been done on the first round and maintained for further evaluations as the maximum value of each merged pair. k for different parts may be lower than the global k.
- Embodiments of the query network and related embodiments of query network evaluation methods may be applied to other graphic representations of networks, such as but not limited to query networks where not all the nodes have a query associated with them, query networks where some nodes include more than one query, query networks with reciprocal relations (a situation where if ‘x’ lists ‘y’, then ‘y’ also lists ‘x’), query networks with non-reciprocal relations, query networks where node queries may include data querying in addition to relational querying, and usage of multiple, local bradius values instead of a single global bradius.
- The need further remains for a query language for social networks (SoQL), which will enable participants to query paths and groups of participants which satisfy a set of conditions. SoQL adds new data types called Path and Group to the conventional SQL data types. Each may be an element in a tuple, and include subpaths, subgroups and paths within a group defined in a query. Creation of new data is also based on the path and group structures. Operators which specify conditions on a path or a group are defined. These include aggregation functionalities, as well as existential and universal quantifiers on nodes and edges in a path or a group, and on paths within a defined group.
- The following definitions are hereby introduced:
-
- A Social Network—a four-tuple (N, F, TN, TF). N, for nodes, is a set of nodes, each representing a network participant. F, for friends, is a set of undirected edges between distinct elements in N. An edge between nodes u and v represents that u and v list each other in their friends (or connections) list. We use a reciprocal friend model, which means that if participant a lists b as a friend, then b also lists a as a friend. TN and TF are relations, as defined below. It will be appreciated that non-reciprocal friend models may be preferred as suits requirements.
- Attributes—every node and edge of the network have attributes associated with values. Nodes in the network have similar attributes, the set of attributes associated with the nodes is called the nodes schema. Edges in the network have similar attributes, the set of attributed associated with the edges in called, the edges schema. For example and without limitation, a weight attribute may be included in the edges schema. The values of the attributes are organized in two relations, TN and TF. The attribute name always exists in the nodes schema, and is a unique key in TN. The attribute id has the same role with respect to TF.
- Path—a Path in the network is an ordered set of nodes (i.e., distinct elements in N), such that between every two successive nodes u and v, the undirected edge (u,v) exists in F. The relations P.nodes and P.edges with respect to the path P are the set of nodes and the set of edges appearing in the path P. The tuples in P.nodes are the tuples in TN corresponding to nodes in P. The tuples in P.edges are the tuples in TF corresponding to edges in P.
- Group—a group in the network is a set of nodes. We define the relation G.nodes with respect to a group G. The tuples in G.nodes are the tuples in TN corresponding to the nodes in G.
- Aggregation Queries over Paths and Groups—a condition on a path or on a group may have the form of an aggregation query over a path or a group. These queries conceptually query the relations Q.nodes and Q.edges where Q is a path or a group. COUNT(P1.nodes.*) is an example for such a query where P1 is a path. It is an abbreviation for the query: COUNT(*) FROM P1.nodes
- Generally, given an aggregation function f (e.g., max, min, avg, sum, mult) over an attribute ‘att’ in a relation ‘rel’ defined with respect to a path or a group Q and given a SQL predicate, then the query:
- SELECT f(a) FROM Q.rel WHERE predicate
- can be abbreviated as:
- f(Q.rel.att WHERE predicate).
- It will be appreciated that in contradistinction to traditional aggregation queries on relational data, which aggregate values from typically multiple tuples, aggregation queries over paths and groups aggregate values over one path or one group, i.e., over one element in one tuple.
-
FIG. 13 illustrates an embodiment of a social network. The network is composed of a graph and two tables. Focus is set on seven participants and on the edges between them. An edge exists between two participants if they are on each other's connections list. For example, Bob # and Charlie # are on each other's connections list. Each node and each edge has a list of attributes. In this example, every node has the attributes name, company, e-mail, position and experience, and each edge has the attributes id and weight. - The values of the nodes and edges attributes are given in Table TN and TF respectively in
FIG. 13 . The id of each edge appears next to it. The weight associated with each edge is a number between 0 and 1. In this example, it is assumed that the weight of an edge (u,v) is the probability that if we ask one of participants u or v to introduce us to the other, they will agree to do that. For example, if we ask Bob to introduce us to Charlie, then the probability that Bob will agree is 0.7. - The SoQL language enables practical utilization of social networks for various needs. Referring back to
FIG. 13 , it is possible that Bob is looking for a new job. He currently works for ACME, and would like to apply for a position with HAL. He would like to use the connections in his social network in order to find a simple path in the network from him to a manager in HAL. After finding the path using a SELECT FROM PATH query, Bob plans to use a CONNECT USING PATH command in order to ask each of the participants along the retrieved path to introduce him to the next participant, ultimately connecting him to a HAL manager. - Bob would like the path to satisfy a number of requirements:
- The person at the end of the path should be a manager in HAL.
- The path should consist of at most four participants.
- For privacy, the participants along the path, except for the first one, do not work for ACME, Bob's current employer.
- As output, Bob would like to have the path as well as the number of participants in the path, ordered by the value of the probability that the participants along the path would introduce Bob one to the other.
FIG. 14 is an example of a SoQL query that Bob can use. The intuitive explanation of the query's semantics is as follows: - The path itself and the count of its nodes are selected as output (Line 1). The path itself is composed of two paths, P1 and P2. P1 starts at the node representing Bob and finishes at X, a variable, and P2 starts at X and finishes at Y (Lines 2-3). PATH is the alias of the whole path, in this case, the concatenation of P1 and P2. In Lines 4-5, it is required that a node in the social network substituting Y have a company attribute with the value HAL and a position attribute with the value manager (
lines Line 8 we requires that the length, in nodes, of P1 be exactly two (i.e., one edge).Line 9 requires that the length, in nodes, of P2 be four or less. Lines 8-9 use abbreviations for aggregation queries over paths. - Among the paths satisfying these conditions, Bob may want to use paths through which he is likely to succeed in creating a connection to Y. Assuming that the probability that Bob will ask his immediate connection to introduce him to the next person on the path is 1, the probability of connecting to Y through a retrieved path is the multiplication of the weights on the edges of P2. In
Line 10, the result is ordered according to this value (descending values). - Assuming that the only participants in the network are the participants whose names are presented in
FIG. 13 , the set of paths returned by Bob's query is (note that this is not the result of the query): - Path a: (Bob, Charlie, Alice)
- Path b: (Bob, Dave, Eve, Alice)
- Path c: (Bob, Dave, Gloria, Alice)
- Note that the path (Bob, Dave, Eve, Frank, Gloria, Alice) is not returned by the query since its number of nodes is six, whereas paths satisfying the query illustrated in
FIG. 11 may have four nodes at most. - The query also retrieves the number of nodes in each retrieved path, and the results are to be ordered (descending) by the multiplication of the weights of the edges of P2. The latter value is 0.3 for Path a above, 0.16 for Path b and 0.765 for Path c. Therefore, the result of the query is the following binary relation:
- (Path c,4)
- (Path a,3)
- (Path b,4)
- The extensions that SoQL introduces to SQL will be introduced herein. These extensions including two types of SoQL commands: SELECT queries, which retrieve data, and CONNECT commands which use a path or a group in a process during which new data in the network may be created.
- SELECT Queries
- A SELECT FROM PATH query returns a relation in which elements of a tuple are either a path or an aggregation over a path. The formal definitions and related examples listed hereinbelow relate to the syntax outline illustrated in
FIG. 15 . -
- Path—The FROM PATH clause defines the query path. The path is composed of subpaths. <name> is a value of the attribute name of the first node in the path. Then, TO <var> AS <alias> indicates the name of the variable representing the last node in first subpath, and the alias, i.e., the unique name through which the subpath can be referred. Any successive TO <var> AS <alias> defines another subpath, starting at the last node of the previous subpath and ending at a node represented by <var>. The query path is the concatenation of the subpaths (in the order in which they appear in the query). PATH is always the alias of the query path.
- In
FIG. 15 , lines 2-3 define P1 and P2 which are subpaths of the query path. P1 starts at the node representing Bob and ends at X. P2 starts at X and ends at Y. Together, they form the query path.
- In
- Fields—Each field is either a path, an alias of a subpath or an aggregation function over the query path or a subpath.
- In
FIG. 15 ,Line 1 has two fields. The first is an aggregation function over the query path and the second is the query path itself.
- In
- Node Predicates—A node predicate specifies a condition on an attribute of a node, and evaluates to either true or false given a node in the network. The attribute is referred to through a variable (e.g., X.company), a constant (e.g., Bob.position) or within a path predicate, to be defined later on.
- In
FIG. 15 , the predicate inLine 5 in the query syntax sample is a node predicate.
- In
- Edge Predicates—An edge predicate specifies a condition on an attribute of an edge, and evaluates to either true or false given an edge in the network. The attribute is referred to through a variable, which always represents a node in the query path. If X is a variable, the edge preceding the node represented by X in the query path is referred to by X.pre-edge. The following edge is referred to by X.fol-edge. Example. The following edge predicate evaluates to true if the edge following X in the query path has attribute att with value val. X.fol-edge.att=‘val’
- Path Predicates—A path predicate specifies a condition on the query path or on a subpath, and evaluates to either true or false given a path in the network. A path predicate has the following structure: <path-predicate>:=<agg-path-predicate>|<path-operator>IN<path-alias>.nodes SATISFY(<node-predicates>)|<path-operator> IN<path-alias>.edges SATISFY(<edge-predicates>) <node-predicates>:=<node-predicate>|<node-predicate> OR <node-predicate>|<node-predicate> AND <node-predicate>|NOT<node-predicate> <edge-predicates>:=Boolean combinations with <edge-predicate>
- Aggregation Path Predicates—A path predicate can be of an aggregation path predicate type (element <agg-pathpredicate> above), which is an aggregation query over a path whose result is equated or compared to a constant or to another aggregation path or group query.
- Referring back to
FIG. 14 , the predicate inLine 8 in the query evaluates to true if the number of nodes in P2 is 2. The following aggregation path predicate evaluates to true if and only if the number of nodes in P1 is less than the number of the edges in P2 whose value for the attribute att is val.- COUNT(P1.nodes.*)>=COUNT(P2.edges.* WHERE att=‘val’)
- Referring back to
- Path Operators. A path operator (element <pathoperator> above) specifies a condition on the nodes or the edges in a path. If .nodes follows the path alias (element <path-alias> above), then the condition is on the nodes, expressed via a Boolean combination of node predicates. If .edges follows, the condition is on the edges, expressed via a Boolean combination of edge predicates.
- The path operators that can be used are:
- ALL. The path predicate using this operator evaluates to true if the predicate following SATISFY evaluates to true on every node/edge in the path referred to by the alias.
- ATMOST n. The path predicate using this operator evaluates to true if the predicate following SATISFY evaluates to true on at most n nodes/edges. The operator NOT is a shorthand for
ATMOST 0. - ATLEAST n. The path predicate using this operator evaluates to true if the predicate following SATISFY evaluates to true on at least n nodes/edges.
- ALL EXCEPT UPTO n. The path predicate using this operator evaluates to true if the predicate following SATISFY evaluates to true on all the nodes/edges, except for up to n.
- MAJORITY. The path predicate using this operator evaluates to true if the predicate following SATISFY evaluates to true on more than half of the nodes/edges in the path.
- Referring back to
FIG. 14 , Lines 6-7 contain a path predicate. The path operator isATMOST 0, the path alias is P2 and the node predicate is specified with the attribute company in the nodes schema.
- The path operators that can be used are:
- Order By. As in SQL, the output is sorted according to the ordered list of fields following ORDER BY. Ordering by a path or a group is done according to the lexicographic order of the string representation of that object. The string representation of a path (respectively, a group) is illustrated in the example in
FIG. 14 . Numeric values are descending.
- Path—The FROM PATH clause defines the query path. The path is composed of subpaths. <name> is a value of the attribute name of the first node in the path. Then, TO <var> AS <alias> indicates the name of the variable representing the last node in first subpath, and the alias, i.e., the unique name through which the subpath can be referred. Any successive TO <var> AS <alias> defines another subpath, starting at the last node of the previous subpath and ending at a node represented by <var>. The query path is the concatenation of the subpaths (in the order in which they appear in the query). PATH is always the alias of the query path.
- A SELECT FROM GROUP query returns a relation in which elements of a tuple are either a group element, a path element between members of the group or an aggregation over a group or path. The syntax of a SELECT FROM GROUP query is illustrated in
FIG. 16 . Elements with the same name as in SELECT FROM PATH have the same definition. -
FIG. 17A illustrates a sample SELECT FROM GROUP query that Bob will use to look for people who meet the following conditions: -
- The group consists of Bob and exactly three other distinct network members.
- There exists a path with up to three edges from Bob to each of the three other members of the group.
- There exists a path with up to two edges between every two of the three members of the group who are not Bob.
- Each of the three members who are not Bob has experience value of at least 5.
-
FIG. 17B shows the result of such query. - The number of members in the retrieved group is predetermined to be four (including Bob). However, SoQL allows retrieving groups whose number of members is not predetermined.
- Referring back to the sample in
FIG. 17A , suppose Bob is now interested in groups of either four or five members. However, if the retrieved group is of five members, then only three out of the four who are not Bob are required to have a path of up to three edges between them and Bob. The other two conditions still have to hold for all the members of the group who are not Bob, regardless of their number being four or five. That is, all have to have experience value of at least five, and a path of up to two edges exists between every two members who are not Bob. In order to retrieve such groups, referring back toFIG. 17 a, Lines 2 through 3 should be changed to: - FROM GROUP(Bob AS G1,
- DISTINCT(X,Y,Z) IN G2)
- And the following predicate to the WHERE clause starting in
line 7 should be added in order to ensure that the total number of members in G2 is no more than four: - and COUNT(GROUP.nodes.*)<=5,
- or equivalently:
- and COUNT(G2.nodes.*)<=4.
- The formal definitions listed hereinbelow relate to the syntax outline illustrated in
FIG. 16 , and the examples for each definition relate toFIG. 17A . -
- The Group—The FROM GROUP clause defines the query group which is a union of subgroups. Each subgroup has an alias and a list of distinct variable names and node names (element <nov> above). A subgroup G can either consist of exactly the members of the list (using the syntax AS G), or just contain them (using the syntax IN G). The participant issuing the query must be in the query group (i.e., appear as a constant name in one of the subgroups). Note that the number of members in a subgroup is not necessarily fixed in advance. Subgroup members within the DISTINCT operator represent distinct network participants.
- Lines 2-3 in the query listed in
FIG. 14A define Bob as a subgroup with alias G1 and X,Y and Z as all the distinct members of another subgroup with alias G2. In query (2), X,Y and Z are distinct members of G2, a group containing them. -
- Paths—The WITH PATH clause gives aliases to paths between members of the query group, to be referred in other parts of the query.
- Referring back to
FIG. 17 a, Line 7 (respectively, 8,9) has a path predicate corresponding to a path aliased in Line 4 (respectively, 5 ,6). Path predicates have the same semantics as in SELECT FROM PATH queries.
- Referring back to
- Fields—a field is either a GROUP, an alias of a subgroup or path or an aggregation function over a path, the query group or a subgroup.
- Group Predicates—a group predicate specifies a condition on the query group or a subgroup, and may refer to paths involving their members. A group predicate evaluates to either true or false given a group in the network. A group predicate structure is illustrated in
FIG. 18 . - Aggregation Group Predicates—similarly to aggregation path predicates in SELECT FROM PATH queries, an aggregation group predicate (element <agg-group-predicate> above) operates over the relation G.nodes defined with respect to a group or subgroup G, equated or compared to a constant or to another path or group aggregation query.
- Group Operators—a group operator (element <groupoperator> above) over a group G refers either to nodes in G or to paths involving members of G. If the operator is followed by IN G.nodes, then it refers to the group nodes. If the operator is followed by SUBGROUPS it refers to paths defined using the variables in SUBGROUPS. In a satisfying substitution, variables in SUBGROUPS can only be substituted by distinct nodes.
- Paths—The WITH PATH clause gives aliases to paths between members of the query group, to be referred in other parts of the query.
- When the operator refers to group nodes, the operators are the same operators we use for paths (i.e., ALL, ATMOST n, ATLEAST n, ALL EXCEPT UPTO n, MAJORITY). The node predicate which follows SATISFY in this case evaluates to true or false as defined for path operators.
- If the group operator refers to paths rather than nodes (i.e., followed by SUBGROUPS), then in the following SATISFY, paths are defined using the variables in SUBGROUPS and a path predicate is used for each path (element <p-a-predicate> above).
- When group operators refer to paths, their semantics are as follows:
-
- ALL SUBGROUPS—the group predicate using this operator evaluates to true if the Boolean combination of aliased path predicates (element <p-a-predicates> above) in SATISFY evaluates to true for every subgroup, i.e., for every substitution of distinct nodes for the variables following SUBGROUPS.
- ATLEAST n SUBGROUPS—the group predicate using this operator evaluates to true if there exist n distinct subgroups which satisfy the predicate in SATISFY.
- ALL EXCEPT UPTO n SUBGROUPS—the group predicate using this operator evaluates to true if all subgroups, except for up to n, satisfy the predicate in SATISFY.
- MAJORITY SUBGROUPS—the group predicate using this operator evaluates to true if more than half of the subgroups satisfy the predicate in SATISFY.
- Referring back to
FIG. 17 a, In Lines 10-11 of the first query in this section, the group operator ALL is used over the nodes of G2. In Lines 12-14, the group predicate uses the operator ALL SUBGROUPS(U,V) over G2. The path predicate evaluates to true on a path whose number of edges is at most 2. Note that the path is aliased as P4. - CONNECT COMMANDS
- Connect Using Path
- The CONNECT USING PATH command specifies how to use paths in a one-column relation of paths in order to attempt to create a connection to the participant(s) at the end of the paths. The command can automate the process of asking each member of the path, say v, to introduce the first member of the path to the successor of v in the path, and so on, until the first member is introduced to the last member. Typically, a network participant p can only use paths in which p is the first member.
- Referring back to
FIG. 13 , it is possible, for example and without limitation, that after retrieving paths that connect Bob to Alice, Bob would like to use the result in order to attempt to create a connection between himself and Alice. The attempt will be carried out by asking each network participant along the path to Alice to introduce Bob to the next participant. - If R is the projection of the result of query in
FIG. 14 on the first column (with type Path), the query that Bob will use is listed herein. -
1 CONNECT USING PATH 2 FROM R 3 WHERE TIMEOUT = 36, ATTEMPTS = 5, 4 PARALLEL = 2, HISTORY = true - In this example, the process that will be initiated is the following:
- A message from Bob to Charlie will be sent, asking Charlie to introduce Bob to Alice (first path). In parallel, a message from Bob to Dave will be sent, asking Dave to introduce Bob to Eve (second path). These are the beginnings of two attempts. The two can be performed in parallel since the query specifies PARALLEL=2.
- If Charlie or Dave refuse to make the connection, the corresponding attempt fails. If either or both agree, a message introducing Bob to the next member of the path is sent. At this point the attempt may fail again and so on. Since HISTORY=true, each introduction includes the prefix of path used up to this introduction. Eventually, Bob is introduced to Alice as a participant requesting to be connected to her. If Alice agrees, a connection between her and Bob is added, the attempt succeeds, and the command terminates.
- In this sample, the total number of attempts allowed is five since ATTEMPTS=5. If both attempts fail, there are three more attempts allowed. Therefore, another two can be started, in parallel. In our case, R contains one more path. An attempt based on that path is carried out.
- In this sample, if 36 hours pass, the command terminates and all attempts fail.
- The paths using which the connection attempts will be done are given after FROM, as a one-column relation. The column is of type Path (the relation can be given explicitly or as a SELECT FROM PATH query). Being a relation, its tuples are ordered. The attempts to create the connections will be done using the paths in this order. After the first success, the command terminates (and other attempts stop). If the number of hours specified for TIMEOUT pass without a success, the command and all its attempts stop. The value for PARALLEL specifies how many paths can be explored in parallel. When the factor is 1, the result is sequential attempts, i.e., one path is explored at a time until failure or success. The operation is such that given a PARALLEL value of n, then only when, and if, all n attempts fail, another set of n is explored in parallel. The attempts continue until all input paths are exhausted or until the maximum number of attempts is reached.
- Connect Using Group
- The CONNECT GROUP command specifies how to use groups from an input relation in order to attempt to create connections between all member pairs in the group. Similarly to CONNECT USING PATH, the command uses a one-column relation with a group element in each tuple. The command will address each of the group's prospective members with a proposal from the participant who issued the command to form a group with the rest of the group members. If all agree, the attempt succeeds and the group is formed, i.e., each member lists the other members as their connections in the network.
- As in CONNECT USING PATH, some parameters for CONNECT GROUP can be set. Timeout, number of attempts and parallelism factor have a meaning identical to the meaning in CONNECT USING PATH.
- For example and without limitation, referring back to
FIG. 17A , if R is the projection of the result of the query, the following query: -
1 CONNECT GROUP 2 FROM R 3 WHERE TIMEOUT = 48, ATTEMPTS = 3, 4 PARALLEL = 1 - The command will try one group at a time, starting with {Bob, Eve, Frank, Gloria}. If an attempt fails, another attempt will be made with next group, up to three attempts. The timeout is two days.
- With regard to the deployment and implementation of a SoQL engine, evaluation approaches are hereby introduced.
- SoQL is built to allow formulating conditions over groups or paths whose size or length is not fixed, which may result in very large results, for example and without limitation formulating queries without setting a bound on the size of a GROUP. A practical approach for evaluating such queries include deployment parameters aiming to ensure the feasibility of evaluating SoQL queries, such as but not limited to the maximum number of tuples in the result, the maximal length of any path considered in the query, the maximal size of any group, and the maximal time to be spent on a single query evaluation.
- With regard to finding Paths using Joins—computing query paths for centralized data can be performed with techniques used in relational databases. Paths starting at the node given as a constant in the query can be found by performing self-joins over F. Before every join, intermediary results with no potential to form a path are pruned. Top-k evaluations (based on relevant scoring functions) for this joins are also useful for avoidance of large intermediate results for these joins. The number of joins can be bounded by a deployment parameter, and may be affected by the other parameters as well.
- Finding Groups. One method of evaluating SELECT FROM GROUP queries is to decompose, as much as possible, the group definition to several path definitions and evaluate the corresponding path queries. For example, since the query group always contains the participant issuing the query, paths from that participant to other participants can be found first and evaluated (using the techniques above or others). Then, other paths are processed. The results are joined based on variables that appear in more than one path. Note that complex considerations are required in this type of queries, such as the maximum number of group members and its effect on satisfying the group predicates used. Members in the query group not defined as a part of a path can be found using ordinary relational queries. The scope of the present invention is defined by the appended claims and includes both combinations and sub combinations of the various features described hereinabove as well as variations and modifications thereof, which would occur to persons skilled in the art upon reading the foregoing description.
- In the claims, the word “comprise”, and variations thereof such as “comprises”, “comprising” and the like indicate that the components listed are included, but not generally to the exclusion of other components.
Claims (17)
1. A database apparatus storing a query-network comprising a set of nodes and a set of edges, said edges connecting pairs of said nodes wherein at least a subset of said nodes are each associated with at least one edge-defining query.
2. The database apparatus of claim 1 wherein said edge-defining query defines a set of generated-edges to be added to said set of edges.
3. The database apparatus of claim 2 wherein said set of generated-edges connect the node associated with said query with another node selected from said set of nodes.
4. The database apparatus of claim 2 wherein at least a subset of said nodes are associated with at least one edge-accepting query.
5. The database apparatus of claim 4 wherein said edge-accepting query defines a subset of generated-edges to be added to said set of edges.
6. The database apparatus of claim 1 wherein said query comprises a datalog rule.
7. The database apparatus of claim 1 comprising a plurality of storage units connected to a network.
8. The database apparatus of claim 1 wherein said database network contains data pertaining to at least one of a group consisting of: a social network, a professional network, an academic network and an item network.
9. A method for fully evaluating a query network stored on a database apparatus of claim 1 , such that all edges defined by said edge-defining queries are members of said set of edges.
10. The method of claim 9 comprising the steps:
step (a)—selecting a node from said subset of said nodes;
step (b)—evaluating the selected node according to the edge-defining query associated with said selected node;
step (c)—selecting another node from said subset of said nodes and repeating step (b); and
step (d)—if all members of said subset of said nodes have been evaluated since a generated-edge was added to said set of edges then terminating said method.
11. The method of claim 10 wherein said step (b) of evaluating the selected node according to the edge-defining query associated with said selected node, comprises the substeps:
step (b1)—adding to said set of edges the members of a set of generated-edges defined by the edge-defining query associated with said selected node;
step (b2)—if said set of generated-edges of step (b1) is not an empty set, then repeating step (b1); and
step (b3)—if said set of generated-edges of step (b1) is an empty set, then selecting another node from said subset of said nodes and repeating step (b).
12. The method of claim 11 wherein said step (b1) of adding to said set of edges the members of a set of generated-edges defined by the edge-defining query associated with said selected node further comprises validating that the edges are accepted by edge-accepting queries associated with target nodes.
13. The method of claim 10 wherein said step (c) of selecting another node from said subset of said nodes and repeating step (b), comprises the substeps:
step (c1)—generating a subset of nodes which are connected to the previously selected node via a path containing less edges than the maximal radius of the query network; and
step (c2)—selecting a member of said subset.
14. The method of claim 9 comprising:
step (I)—partitioning said query network into a plurality of query sub-networks;
step (II)—fully evaluating each said query sub-network; and
step (III)—merging said query sub-networks.
15. A method for selecting a group from said query network stored on a database apparatus of claim 1 , said group comprising a set of nodes which are evaluated according to an edge-defining query associated with a selected node.
16. A method for selecting a path from said query network stored on a database apparatus of claim 1 , said path comprising a set of edges which are used in an evaluation of an edge-defining query associated with a selected node.
17. A method for creating connections between nodes on a network stored on a database apparatus of claim 1 , wherein said connections are formed between nodes that comprise a selected path or a selected group evaluated according to an edge-defining query associated with a selected node.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US15/469,898 US20170270171A1 (en) | 2008-12-29 | 2017-03-27 | Query Networks Evaluation System and Method |
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US14105708P | 2008-12-29 | 2008-12-29 | |
US12/648,546 US9607052B2 (en) | 2008-12-29 | 2009-12-29 | Query networks evaluation system and method |
US15/469,898 US20170270171A1 (en) | 2008-12-29 | 2017-03-27 | Query Networks Evaluation System and Method |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/648,546 Continuation US9607052B2 (en) | 2008-12-29 | 2009-12-29 | Query networks evaluation system and method |
Publications (1)
Publication Number | Publication Date |
---|---|
US20170270171A1 true US20170270171A1 (en) | 2017-09-21 |
Family
ID=43221450
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/648,546 Active 2030-01-08 US9607052B2 (en) | 2008-12-29 | 2009-12-29 | Query networks evaluation system and method |
US15/469,898 Abandoned US20170270171A1 (en) | 2008-12-29 | 2017-03-27 | Query Networks Evaluation System and Method |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/648,546 Active 2030-01-08 US9607052B2 (en) | 2008-12-29 | 2009-12-29 | Query networks evaluation system and method |
Country Status (1)
Country | Link |
---|---|
US (2) | US9607052B2 (en) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10445808B2 (en) * | 2015-07-01 | 2019-10-15 | Walmart Apollo, Llc | Apparatus to query a relational database using text-based queries |
Families Citing this family (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8874477B2 (en) | 2005-10-04 | 2014-10-28 | Steven Mark Hoffberg | Multifactorial optimization system and method |
EP2271036B1 (en) * | 2009-06-22 | 2013-01-09 | Semiocast | Method, system and architecture for delivering messages in a network to automatically increase a signal-to-noise ratio of user interests |
US8732208B2 (en) * | 2010-04-19 | 2014-05-20 | Facebook, Inc. | Structured search queries based on social-graph information |
US8661009B2 (en) * | 2010-06-03 | 2014-02-25 | International Business Machines Corporation | Dynamic real-time reports based on social networks |
US20130024439A1 (en) * | 2011-07-20 | 2013-01-24 | Microsoft Corporation | Modeling search in a social graph |
US20150026158A1 (en) * | 2012-01-31 | 2015-01-22 | Kent State University | Systems, methods, and software for unified analytics environments |
US9367880B2 (en) | 2013-05-03 | 2016-06-14 | Facebook, Inc. | Search intent for queries on online social networks |
US9367625B2 (en) * | 2013-05-03 | 2016-06-14 | Facebook, Inc. | Search query interactions on online social networks |
US9367536B2 (en) | 2013-05-03 | 2016-06-14 | Facebook, Inc. | Using inverse operators for queries on online social networks |
US9547433B1 (en) * | 2014-05-07 | 2017-01-17 | Google Inc. | Systems and methods for changing control functions during an input gesture |
Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20090164895A1 (en) * | 2007-12-19 | 2009-06-25 | Yahoo! Inc. | Extracting semantic relations from query logs |
Family Cites Families (26)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4823306A (en) * | 1987-08-14 | 1989-04-18 | International Business Machines Corporation | Text search system |
US6785673B1 (en) * | 2000-02-09 | 2004-08-31 | At&T Corp. | Method for converting relational data into XML |
US7805440B2 (en) * | 2001-04-11 | 2010-09-28 | International Business Machines Corporation | System and method for simplifying and manipulating k-partite graphs |
US6946715B2 (en) * | 2003-02-19 | 2005-09-20 | Micron Technology, Inc. | CMOS image sensor and method of fabrication |
WO2004068300A2 (en) * | 2003-01-25 | 2004-08-12 | Purdue Research Foundation | Methods, systems, and data structures for performing searches on three dimensional objects |
US7289947B2 (en) * | 2004-06-10 | 2007-10-30 | International Business Machines Corporation | Finding and removing performance bottlenecks in large systems |
US7698267B2 (en) * | 2004-08-27 | 2010-04-13 | The Regents Of The University Of California | Searching digital information and databases |
US7523117B2 (en) * | 2005-05-04 | 2009-04-21 | West Virginia University Research Corporation | Method for data clustering and classification by a graph theory model—network partition into high density subgraphs |
US20060253476A1 (en) * | 2005-05-09 | 2006-11-09 | Roth Mary A | Technique for relationship discovery in schemas using semantic name indexing |
US7958120B2 (en) * | 2005-05-10 | 2011-06-07 | Netseer, Inc. | Method and apparatus for distributed community finding |
US8503995B2 (en) * | 2005-09-14 | 2013-08-06 | Jumptap, Inc. | Mobile dynamic advertisement creation and placement |
US8874477B2 (en) * | 2005-10-04 | 2014-10-28 | Steven Mark Hoffberg | Multifactorial optimization system and method |
US20070185868A1 (en) * | 2006-02-08 | 2007-08-09 | Roth Mary A | Method and apparatus for semantic search of schema repositories |
JP2007304685A (en) * | 2006-05-09 | 2007-11-22 | Hitachi Ltd | Retrieval system and program for software component |
US7752243B2 (en) * | 2006-06-06 | 2010-07-06 | University Of Regina | Method and apparatus for construction and use of concept knowledge base |
US7596597B2 (en) * | 2006-08-31 | 2009-09-29 | Microsoft Corporation | Recommending contacts in a social network |
US20090077001A1 (en) * | 2006-11-02 | 2009-03-19 | William Macready | Integrating optimization directly into databases |
US8024328B2 (en) * | 2006-12-18 | 2011-09-20 | Microsoft Corporation | Searching with metadata comprising degree of separation, chat room participation, and geography |
EP1990741A1 (en) * | 2007-05-10 | 2008-11-12 | Ontoprise GmbH | Reasoning architecture |
US20090089078A1 (en) * | 2007-09-28 | 2009-04-02 | Great-Circle Technologies, Inc. | Bundling of automated work flow |
US7933916B2 (en) * | 2008-02-28 | 2011-04-26 | Microsoft Corporation | Querying nonSQL data stores with a SQL-style language |
US8744976B2 (en) * | 2008-04-28 | 2014-06-03 | Yahoo! Inc. | Discovery of friends using social network graph properties |
US8161050B2 (en) * | 2008-11-20 | 2012-04-17 | Microsoft Corporation | Visualizing hyperlinks in a search results list |
US8917913B2 (en) * | 2011-09-22 | 2014-12-23 | International Business Machines Corporation | Searching with face recognition and social networking profiles |
US20130085866A1 (en) * | 2011-10-04 | 2013-04-04 | Ilya Levitis | Floating smartphone icon messaging system |
US8769556B2 (en) * | 2011-10-28 | 2014-07-01 | Motorola Solutions, Inc. | Targeted advertisement based on face clustering for time-varying video |
-
2009
- 2009-12-29 US US12/648,546 patent/US9607052B2/en active Active
-
2017
- 2017-03-27 US US15/469,898 patent/US20170270171A1/en not_active Abandoned
Patent Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20090164895A1 (en) * | 2007-12-19 | 2009-06-25 | Yahoo! Inc. | Extracting semantic relations from query logs |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10445808B2 (en) * | 2015-07-01 | 2019-10-15 | Walmart Apollo, Llc | Apparatus to query a relational database using text-based queries |
Also Published As
Publication number | Publication date |
---|---|
US9607052B2 (en) | 2017-03-28 |
US20100306271A1 (en) | 2010-12-02 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20170270171A1 (en) | Query Networks Evaluation System and Method | |
Ronen et al. | SoQL: A language for querying and creating data in social networks | |
US12074955B2 (en) | Systems and methods for matching electronic activities with record objects based on entity relationships | |
US20230252330A1 (en) | Systems and methods for blast electronic activity detection | |
US20150032738A1 (en) | Confidently adding snippets of search results to clusters of objects | |
US20100312820A1 (en) | Identifying and recommending connections across multiple online services | |
US20060088038A1 (en) | Relationship definition and processing system and method | |
Massacci et al. | Hierarchical hippocratic databases with minimal disclosure for virtual organizations | |
US20200250164A1 (en) | Systems and methods for determining dataset intersection | |
Mpinda et al. | Evaluation of graph databases performance through indexing techniques | |
Liao et al. | An overlap graph model for large‐scale group decision making with social trust information considering the multiple roles of experts | |
US11153255B2 (en) | Enhancing online contents based on digital alliance data | |
US11550792B2 (en) | Systems and methods for joining datasets | |
US10339139B2 (en) | Computer system and methods for performing data-driven coordination | |
Benjamin | Sara TAKI | |
Tifrea-Marciuska | Personalised search for the social semantic web | |
Wenzel et al. | Preference-driven dynamic group formation in online social networks | |
Kaddoura et al. | ASP-SSN: AN EFFECTIVE APPROACH FOR LINKING SEMANTIC SOCIAL NETWORKS |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: TECHNION RESEARCH & DEVELOPMENT FOUNDATION LTD., I Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:SHMUELI, ODED;RONEN, ROYI;SIGNING DATES FROM 20120116 TO 20120122;REEL/FRAME:045570/0001 |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NON FINAL ACTION MAILED |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |