The present disclosure relates to a method for identifying denial constraints, the denial constraints being used in multiple applications, including but not limited to for use in reviewing data, sanity checking data, identifying errors and/or correcting errors in data stored in a database.
As businesses generate and consume data more than ever, it is critical to enforce and maintain the quality of the data assets. One in three business leaders does not trust the information used to make decisions, since establishing trust in data becomes a challenge as the variety and the number of sources grow. For example, in healthcare domains, inaccurate or incorrect data may threaten patient safety. Therefore, data review, validation and/or cleaning is a task towards improving data quality, which is estimated to account for 30%-80% of the cost of a typical data warehouse project.
Integrity constraints (ICs), originally designed to improve the quality of a database schema, have been recently repurposed towards improving the quality of data, either through checking the validity of the data at points of entry, or by cleaning the data at various points during the processing pipeline. Traditional types of ICs, such as key constraints, check constraints, functional dependencies (FDs), and their extension conditional functional dependencies (CFDs) have been proposed for data quality management. However, there is still a large space of ICs that cannot be captured using the aforementioned types.
Suppose that the following constraints hold: (1) there cannot exist two persons who have the same area code and phone; (2) there cannot exist two persons who live in the same zip code with different states; (3) there cannot exist a person who lives in Los Angeles but not in California; (4) there cannot exist two persons who live in the same state, but one person earns less salary and has higher tax rate at the same time; and (5) there cannot exist any person whose single tax exemption is greater than salary.
Constraints (1), (2), and (3) can be expressed as a key constraint, an FD, and a CFD.
Since Constraints (4) and (5) involve order predicates (>, <), and (5) compares different attributes in the same predicate, they cannot be expressed by FDs and CFDs. However, they can be expressed in first-order logic:
∀tα,tβ∈r,┐(tα·ST=tβ·STtα·SAL<tβ·SALtα·TR>tβ·TR) c4:
∀tα∈r,┐(tα·SAL<tα·STX) c5:
Since first-order logic is more expressive, Constraints (1)-(3) can also be expressed as follows:
∀tα,tβ∈r,┐(tα·AC=tβ·ACtα·PH=tβ·PH) c1:
∀tα,tβ∈r,┐(tα·ZIP=tβ·ZIPtα·ST≠tβ·ST) c2:
∀tα,tβ∈r,┐(tα·CT=‘Los Angeles’tα·ST≠‘CA’)· c3:
The more expressive power an IC language has, the harder it is to exploit, for example, in automated data cleaning algorithms or in writing SQL queries for consistency checking. There is an infinite space of business rules up to ad-hoc programs for enforcing correct application semantics and business logic. There is a need to achieve a balance between the expressive power of ICs to deal with a broader space of business rules and, the restrictions required to ensure adequate static analysis of ICs and the development of effective cleaning and discovery algorithms.
Denial Constraints (DCs), are a universally quantified first order logic formalism, that can express all constraints in Example 1 since DCs are more expressive than key constraints, FDs, and CFDs. DCs serve as a good compromise between expressiveness and complexity for the following reasons: (1) DCs are defined on predicates that can be easily expressed in SQL queries for consistency checking; (2) DCs have been proven to be a useful language for data cleaning in many aspects, such as data repairing, consistent query answering, and expressing data currency rules; and (3) while static analysis of DCs is un-decidable, it is possible to develop a set of sound inferences rules and a linear implication testing algorithm for DCs that enable an efficient adoption of DCs as an IC language.
Conventional methods which use DCs as a language formalism for data quality management do not, however, provide a suitable method for acquiring DCs. While DCs can be obtained by consulting domain experts, this is a time consuming and expensive process which requires expertise in the constraint language at hand. Moreover, such rules can introduce mistakes due to human error, or the rules may even be impossible to design when an expert for a new domain is not available.
The present disclosure seeks to provide an improved method for identifying denial constraints.
According to one aspect of the present disclosure, there is provided a method of identifying denial constraints, the denial constraints being for use with a database schema R, the method comprising: generating a predicate space P for an instance I in the schema R, generating an evidence set EviI which comprises sets of satisfied predicates in the predicate space P for each instance I, identifying a minimal set of predicates for the evidence set EviI, and identifying valid denial constraints from the minimal set by inverting the predicates in the minimal set.
According to one or more embodiments described herein, generating the predicate space P comprises: for each attribute in the schema R, adding equality predicates describing equality and inequality between two tuples on an attribute and adding cross column predicates for joinable column pairs, for each numerical attribute in the schema R, adding order predicates describing greater than, greater than or equal to, less than or equal to, or less than between two tuples on an attribute, and adding cross column order predicates for comparable column pairs.
According to one or more embodiments described herein, the predicate space P is generated using the algorithm:
According to one or more embodiments described herein, the evidence set EviI is generated using the algorithm:
According to one or more embodiments described herein, the method further comprises dividing the space of the valid denial constraints into a plurality of subspaces that each comprise a first predicate P1.
According to one or more embodiments described herein, the method further comprises dividing the plurality of subspaces into a plurality of further subspaces that each comprise a second predicate P2.
According to one or more embodiments described herein, the method further comprises ordering the valid denial constraints in a taxonomy tree according to the predicates in each denial constraint.
According to one or more embodiments described herein, the method further comprises searching for denial constraints by searching the taxonomy tree from the bottom-up.
According to one or more embodiments described herein, the method further comprises pruning branches from the taxonomy tree which comprise valid denial constraints identified by the search and performing a further search of the taxonomy tree from the bottom-up.
According to one or more embodiments described herein, the method further comprises providing a scoring function to provide a ranking of discovered denial constraints.
According to one or more embodiments described herein, the scoring function comprises assigning an interestingness score Inter(φ) to each denial constraint φ, the score Inter(φ) being a weighted combination of the succinctness and coverage of each denial constraint φ.
According to one or more embodiments described herein, a U-Precision metric is provided which identifies whether a denial constraint is schema-conforming:
where the discovered DCs are denoted by Σs and Σu is the DCs in Σs that are verified as gold standard.
According to one or more embodiments described herein, the succinctness is defined as:
According to one or more embodiments described herein, the coverage is defined as:
According to one or more embodiments described herein, approximate DCs are identified by: given a relational schema R and instance I, finding a minimal cover Σ of valid DCs, where a DC φ is valid if the percentage of violations of φ on I, i.e., number of violations of φ on I divided by total number of tuple pairs |I|(|I|−1), is within a threshold ∈.
According to another aspect of the present disclosure, there is provided a system operable to identify denial constraints, the denial constraints being for use with a database schema R, the system comprising: a mechanism operable to generate a predicate space P for an instance I in the schema R, a mechanism operable to generate an evidence set EviI which comprises sets of satisfied predicates in the predicate space P for each instance I, a mechanism operable to identify a minimal set of predicates for the evidence set EviI, and to identify valid denial constraints from the minimal set by inverting the predicates in the minimal set.
The embodiments set forth in the drawings are illustrative and exemplary in nature and not intended to limit the subject matter defined by the claims. The following detailed description of the illustrative embodiments can be understood when read in conjunction with the following drawings, where like structure is indicated with like reference numerals and in which:
1.1 Challenges with Identifying Denial Constraints
Three main technical challenges hinder the adoption of DCs as an efficient IC language and in discovering DCs from an input data instance:
(1) Theoretical Foundation
The necessary theoretical foundations for DCs as a constraint language are missing. Armstrong Axioms and their extensions are at the core of state-of-the-art algorithms for inferring FDs and CFDs, but there is no similar foundation for the design of tractable DCs discovery algorithms.
Consider the following constraint, c6, which states that there cannot exist two persons who live in the same zip code and one person has a lower salary and higher tax rate.
∀tα,tβ∈r,┐(tα·ZIP=tβ·ZIPtα·SAL<tβ·SALtα·TR>tβ·TR)c6 c6:
is implied by c2 and c4: if two persons live in the same zip code, by c2 they would live in the same state and by c4 one cannot earn less and have higher tax rate in the same state.
In order to systematically identify implied DCs (such as c6), for example, to prune some redundant DCs, a reasoning system for DCs needs to be built.
(2) Space Explosion
Consider a Functional Dependency (FD) discovery on schema R, let |R|=m. Taking an attribute as the right hand side of an FD, any subset of remaining m−1 attributes could serve as the left hand side. Thus, the space to be explored for FDs discovery is m*2′−1. Now consider discovering DCs involving at most two tuples; a predicate space needs to be defined, upon which the space of DCs is defined. The structure of a predicate consists of two different attributes and one operator. Given two tuples, we have 2 m distinct attributes; and six operators (=, ≠, >, ≦, <, ≧) are allowed. Therefore, the size of the predicate space P is: |P|=6*2 m*(2m−1). Any subset of the predicate space could constitute a DC. Therefore, the search space for DCs discovery is of size 2|P|.
Evidently, DCs discovery has a much larger space to explore, further justifying the need for a reasoning mechanism to enable efficient pruning, as well as the need for an efficient discovery algorithm.
(3) Ranking and Overfitting
Conventional model discovery algorithms suffer from the problem of overfitting; DCs discovered on the input instance I of schema R may not hold on future data of R. A discovered DC is said to be schema-conforming if it not only applies to current data, but also on future, unseen data. This is illustrated below in Example 3.
Consider DC c7 on Table 1 shown in
∀tα,tβ∈r,┐(tα·FN=tβ·FNtα·GD≠tβ·GD) c7:
Even if c7 is true on current data, common knowledge suggests that it does not hold in general.
Since the quality of ICs is crucial for data quality, discovered ICs are usually verified by domain experts for their validity. Statistical measures may be used to rank constraints and assist in the verification step for specific cases. For example, for CFDs it is possible to count the number of tuples that match their tableaux. Similar support measures are used for association rules.
Unfortunately, discovered DCs are more difficult to verify and rank than previous formalisms for three reasons: (1) similarly to FDs, it not possible to only count constants to measure support; (2) given the explosion of the space, the number of discovered DCs is much larger than the size of discovered FDs; (3) the semantics of FDs/CFDs is much easier to understand compared to DCs.
However, by looking carefully at the sample data, different kinds of evidence can be exploited to estimate if a DC is schema-conforming. For example, while both pairs of tuples t4, t7 and t2, t6 do not violate c2, it is clear that t4, t7 gives more support for c2.
Looking at the available data, the applicants see that there are two kinds of evidence that we can exploit to rank DCs effectively. The first one is the size of the constraints. Shorter DCs are easier to read and follow the Occam's razor principle: among competing hypotheses, the one making fewer assumptions is preferred. The second one is the support coming from the data. Every discovered DC holds on the entire dataset, and we cannot just count constants as for CFDs, therefore a more sophisticated definition of coverage is needed. For example, the measure should capture that c2 has more coverage than c7, because the pairs of tuples t4; t7 and t1; t8 give more support than any other pairs of tuples for c2, while c7 has only one pair t1; t6.
1.2 Discovering Denial Constraints
Given the DCs discovery problem and the above challenges, different embodiments of the present disclosure invention seek to provide the following three contributions:
1. A formal problem definition of discovering DCs. Static analysis for DCs is described below with three axioms that serve as the basis for an implication testing algorithm as well as for a DCs discovery algorithm. Determining whether a set of DCs implies another DC is un-decidable in general, an algorithm is therefore described below with linear time complexity for implication testing.
2. A DCs discovery algorithm, known as FASTDC, is described below. FASTDC starts by building a predicate space and calculates evidence sets for the predicate space. The connection between discovering minimal DCs and finding minimal set covers is then established for evidence sets. A depth-first search (DFS) strategy is employed for finding minimal set covers and DC axioms are used for branch pruning. In order to handle datasets that may have data errors, we extend the algorithm to discover approximate DCs.
3. A rank-based method which is a solution to the overfitting problem is described below and presents a novel scoring function for a DC. The scoring function is known herein as the “interestingness” of a DC which combines succinctness and coverage measures of discovered DCs in order to enable their ranking and pruning based on thresholds, thus reducing the cognitive burden for human verification.
The techniques are verified on real-life and synthetic data. The discussion below demonstrates that FASTDC is bound by the number of tuples |I| and by the number of DCs, and that the polynomial part with respect to |I| can be easily parallelized. The implication testing algorithm is shown to substantially reduce the number of DCs in the output, thus reducing users' effort in verifying discovered DCs.
1.3 Outline
Related technology is initially discussed below (Section 2). DCs and the problem definition of discovering DCs are then defined (Section 3), followed by their static analysis (Section 4). Details of the discovery algorithm FASTDC (Section 5) and of a scoring function (Section 6) are then described. Finally, an experimental study of the techniques (Section 7) is discussed.
2. Related Technology
The technology of an embodiment of the disclosure has similarities to several bodies of work: static analysis of FDs and CFDs, dependency discovery, and scoring of ICs. Whenever a dependency language is proposed, the static analysis should be investigated, including logical implication, consistency checking, and finite axiomatization. Static analysis for FDs is known and can be done in linear time with respect to the number of FDs. Three inferences rules are proven to be sound and complete.
Conditional functional dependencies (CFDs) were proposed when implication and consistency problems were shown to be intractable. In addition, a set of sound and complete inference rules were also provided, which were later simplified. Though denial constraints have been used for data cleaning as well as consistent query answering, static analysis has been done only for special fragments, such as currency rules. Dependency discovery has long been a subject of interest in communities of database, knowledge discovery and machine learning. Among the various topics of constraint discovery, FDs discovery attracted the most attention and whose methodology can be divided into schema-driven, top-down approaches and instance-driven, bottom-up approaches.
TANE is a representative for the schema-driven approach. It adopts a level-wise candidate generation and pruning strategy and relies on a linear algorithm for checking the validity of FDs. TANE is sensitive to the size of the schema. FASTFD is a representative for the instance-driven approach. It first computes agree-sets from data, then adopts a heuristic-driven depth first search algorithm to search for covers of agree-sets. FASTFD is sensitive to the size of the instance. Both algorithms were extended for discovering CFDs, which also includes a fast algorithm for constant CFDs discovery.
Another element of discovering ICs is to measure the importance of ICs according to a scoring function. In FDs discovery, the statistical correlations for each column pair are examined to discover soft FDs. In CFDs discovery some measures have been proposed, including support, which is defined as the percentage of the tuples in the data that match the pattern tableaux, conviction, and χ2 test. However, none of these measures the extent to which the discovered ICs will conform to unseen data. Interest measures for CFDs are based on the matching of constant patterns in the input data, that is designed to reduce the amount of CFDs in the output. Therefore, the schema-conforming scoring function of an embodiment of the disclosure is fundamentally different from previously proposed scoring functions for discovered ICs.
3. Denial Constraint and Discovery Problem
In this section, the syntax and semantics of DCs are first reviewed. Then, minimal DCs are defined and the discovery problem for DCs is described.
3.1 Denial Constraints (DCs)
Syntax: Consider a database schema of the form S=(U,R,B) where U is a set of database domains, R is a set of database predicates or relations, and B is a set of finite built-in operators. In this paper, B={=, <, >, ≠, ≦, ≧,}. B must be negation closed to define the inverse of operator φ as φ.
The subset of integrity constraints identified by denial constraints (DCs) is supported over relational databases. Tuple based DC notation is used of the form:
∀tα,tβ,tγ, . . . ∈R,┐(P1 . . . Pm) φ:
where P1 is of the form v1φv2 or v1φc with v1, v2∈tx·A, x∈{α, β, γ, . . . }, A ∈R, and c is a constant. For the sake of simplicity, the above notation assumes there is only one relation R in R.
For a DC φ, if ∀P1, i∈[1, m] is of the form v1φv2 then such DC is called a variable denial constraint (VDC), otherwise, φ is a constant denial constraint (CDC).
The inverse of predicate P: v1 φ1 v2 is
Semantics: Intuitively, a DC states that all the predicates cannot be true at the same time, otherwise there is a violation. Single-tuple constraints (such as SQL CHECK constraints), FDs, and CFDs are special cases of unary and binary denial constraints with equality and inequality predicates. Given a database instance I of schema S and a DC φ, if I satisfies φ, one writes I |=φ, and one says that φ is a valid DC. If there is a set of DC Σ, I |=Σ if and only if ∀φ∈Σ, I |=φ. Σ implies φ, i.e., Σ|=φ, if for every instance I of S, if I |=Σ, then I |=φ.
The following description focuses on DCs with at most two tuples but it is to be appreciated that other embodiments of the disclosure are configured to operate on DCs with more than two tuples. DCs involving more tuples are, however, less likely in real life and incur bigger predicate space to search, as shown below in Section 5.
The universal quantifier for DCs with at most two tuples is ∀tα, tβ. Universal quantifiers are omitted in the description below for simplicity purposes. The notations we use in the description are summarised below in Table 7.
3.2 Problem Definition
In this subsection, trivial, minimal, and symmetric DCs are defined initially, and then the problem statement of discovering DCs is discussed.
Trivial, Minimal and Symmetric DC.
A DC ┐(P1 . . . Pn) is said to be trivial if it is satisfied by any instance. In the description below, only nontrivial DCs are considered unless otherwise specified.
DC φi is said to be set-minimal, or minimal, if φ2, such that φ1 |=φ2, φ2|=φ1 and φ2·Pres∪φ1·Pres.
The symmetric DC of a DC φ1 is a DC φ2 by substituting tα with tβ, and tβ with tα.
THEOREM 1. If φ1 and φ2 are symmetric DCs, then φ1 |=φ2 and φ2|=φ1.
Example 4 described below illustrates above definitions.
Consider three additional DCs for Table 1.
┐(tα·SAL=tβ·SALtα·SAL>tβ·SAL) c10:
┐(tα·PH=tβ·PH)) c11:
∀tα,tβ∈r,┐(tα·STtα·SAL>tβ·SALtα·TR<tβ·TR) c12:
c10 is a trivial DC, since there cannot exist two persons that have the same salary, and one's salary is greater than the other. If tuple tx in Table 1 is removed, c11 becomes a valid DC, making c1 no longer minimal. c12 and c4 are symmetric DCs.
A canonical cover of DCs on r is a set of minimal DCs on r, such that it is equivalent to all DCs that hold on r.
Problem Statement.
Given a relational schema R and an instance I, the discovery problem for DCs is to find a canonical cover of DCs that hold on I. Since the number of DCs that hold on a dataset is usually very big, the problem of ranking DCs with an objective function is described below in Section 6.
4. Static Analysis of Dcs
Since DCs subsume FDs and CFDs, it is natural to ask whether one can perform reasonings the same way as FDs or CFDs. Is there a sound and complete inference system for DCs? How hard is it to determine if a set of DCs implies another DC? These questions are relecant to discovering DCs because an inference system is needed for pruning DCs, and implication testing is required to reduce the number of DCs in the output.
4.1 Inference System
Armstrong Axioms for FDs are the fundamental building blocks for implication analysis for FDs. In this section three symbolic inference rules for DCs, denoted as I, analogous to Armstrong Axioms are discussed.
1. Triviality: ∀Pi, Pj if
2. Augmentation: If ┐(P1 . . . Pn) is a valid DC, then ┐(P1 . . . PnQ) is also a valid DC
3. Transitivity: If ┐(P1 . . . PnQ1) and ┐(R1 . . . RmQ2) are valid DCs, and Q2∈Imp(
Triviality states that if there are two predicates that cannot be true at the same time in a DC (
Augmentation states that if a DC is valid, adding more predicates will always result in a valid DC.
Transitivity states that if there are two DCs and two predicates (one in each DC) that cannot be false at the same time (Q2 ∈Imp(
Since FDs are a subset of DCs, and Armstrong Axioms for FDs are well understood, we list in Table 3 (
Inference system I is a syntactic way of checking whether a set of DCs Σ implies a DC φ. It is sound in that if by using I a DC φ can be derived from Σ, i.e., Σ├I φ then Σ implies φ, i.e., Σφ. The completeness of I dictates that if Σ, then Σ├Iφ. We identify a specific form of DCs, for which I is complete. The specific form requires that each predicate of a DC is defined on two tuples and on the same attribute, and that all predicates must have the same operator θ except one that must have the reverse of θ.
Theorem 2.
The inference system I is sound for DCs. It is also complete for VDCs of the form ∀tα, tβ∈r, ┐(P1 . . . PmQ), where P1=tα·Aiθtβ·Ai, ∀i∈[1, m] and Q=tα·B
A formal proof of Theorem 2 is set out in
However, the discussion of the experiments indicates that, the axioms have an impact on the pruning power of the implication test and of the FASTDC algorithm.
The partial completeness result for the inference system has no implication on the completeness of the discovery algorithms described in Section 5. However, the experiments discuss that, although not complete, the inference system I has a huge impact on the pruning power of the implication test and of the FASTDC algorithm.
4.2 Implication Problem
Implication testing refers to the problem of determining whether a set of DC Θ implies another DC φ. It has been established that the complexity of the implication testing problem for DCs is coNP-Complete. Given the intractability result, a linear algorithm is described below for implication testing in order to reduce the number of DCs in the discovery algorithm output.
In order to devise an efficient implication testing algorithm, the concept of closure is defined in Definition 1 for a set of predicates W under a set of DCs Σ. A predicate P is in the closure if adding
The closure of a set of predicates W, with respect to a set of DCs Σ, is a set of predicates, denoted as CloΣ(W), such that ∀P∈CloΣ(W), Σ|=┐(W
Algorithm 1 calculates the partial closure of W under Σ, whose proof of correctness is set out in
Consider Σ={c1, . . . , c6} and W={tα·ZIP=tβ·ZIP, tα·SAL<tβ·SAL}.
The initialization step in Lines (1-3) results in CloΣ (W)={tα·ZIP=tβ·ZIP, tα·SAL<tβ·SAL, tα·SAL tβ·SAL}. Now all predicates but one tα·ST≠tβ·ST in c2 are in the closure, the implied predicates of the reverse of tα·ST≠tβ·ST are added to the closure. CloΣ(W)={tα·ZIP=tβ·ZIP, tα·SAL<tβ·SAL, tα·SAL≦tβ·SAL, tα·ST=tβ·ST}. Now c4 is ready (Line 22), the implied predicates of the reverse tα·TR>tβ·TR are added. The closure now is CloΣ(W)={tα·ZIP=tβ·ZIP, tα·SAL<tβ·SAL, tα·SAL≦tβ·SAL, tα·TR≦tβ·TR}. No more DCs are in the queue (Line 16). Taking the reverse of tα·TR≦tβ·TR, the result is Σ|=c7.
Algorithm 2 below tests whether a DC φ is implied by a set of DCs Σ by computing the closure of φ·Pres in φ under ┌, which is Σ enlarged with symmetric DCs. If there exists a DC φ in ┌, whose predicates are a subset of the closure, φ is implied by Σ. The proof of soundness of Algorithm 2 is set out below in
Consider a database with two numerical columns, High (H) and Low (L). Consider two DCs c14, c15:
∀tα,(tα·H<tα·L) c14:
∀tα,tβ(tα·H>tβ·Htβ·L>tα·H) c15:
The implication testing algorithm identifies how c15 is implied by c14. Let Σ={c14} and W=c15·Pres. ┌={c14, c16}, where c16: ∀tβ,(tβ·H<tβ·H)
Clo┌(W)={tα·H>tβ·H, tβ·L>tα·H, tβ·H<tα·H}, because tβ·H<tα·H is implied by {tα·H>tβ·H, tβ·L>tα·H} through basic algebraic transitivity (Line 3). Since c16·Pres⊂Clo┌(W), thus the implication holds.
5. DCs Discovery Algorithm
This section describes the instance-driven discovery algorithm, FASTDC. FASTDC starts by analyzing the schema R to build a predicate space P. Given P, a space of candidate DCs is defined, which is of size 2|P|. Since checking each candidate DC against the input instance is quadratic in the number of tuples, it is unfeasible to validate each candidate DC individually. A method is described below that relies on evidence built from the input instance I for efficient discovery of only valid minimal DCs.
5.1 FASTDC
Algorithm 3 below describes a procedure for discovering minimal DCs. Since a DC is composed of a set of predicates, a predicate space P is built based on schema R (Line 1). Any subset of P could be a set of predicates for a DC.
It is not feasible to validate each candidate DC directly over I, due to the quadratic complexity of checking all tuple pairs. For this reason, evidence is extracted from I in a way that enables the reduction of DCs discovery to a search problem that computes valid minimal DCs without checking each candidate DC individually.
The evidence that is extracted is composed of sets of satisfied predicates in P, one set for every pair of tuples (Line 2). For example, assume two satisfied predicates for one tuple pair: tα·A=tβ·A and tα·B=tβ·B. The set of satisfied predicates is used to derive the valid DCs that do not violate this tuple pair. In the example, if attributes A, B are of type string, there are five DCs that hold on that tuple pair, including ┐(tα·A≈tβ·A) and ┐(tα·A=tβ·Atα·B≠tβ·B). Let EviI be the sets of satisfied predicates for all pairs of tuples, deriving valid minimal DCs for I corresponds to finding the minimal sets of predicates for EviI (Line 3). For each minimal set, which is known as minimal cover (X in Algorithm 3), a valid minimal DC is derived by inverting each predicate in it (Lines 4-5). Finally, (lines 6-8) implied DCs are removed from Σ using Algorithm 2.
Section 5.2 describes the detailed procedure for building the predicate space P. Section 5.3 formally defines EviI, gives a theorem that reduces the problem of discovering all minimal DCs to the problem of finding all minimal covers for EviI, and presents a procedure for building EviI. Section 5.4 describes a search procedure for finding minimal covers for EviI. In order to reduce the execution time, the search is optimized with a dynamic ordering of predicates and branch pruning based on the axioms we developed in Section 4. In order to enable further pruning, Section 5.5 introduces an optimization technique that divides the space of DCs and performs DFS on each subspace.
5.2 Building the Predicate Space
Given a database schema R and an instance I, a predicate space P is built from which DCs can be formed as described below in Algorithm 4. For each attribute in the schema, two predicates are added which describe equality and inequality between two tuples on that attribute (Lines 1-2). In the same way, for each numerical attribute, order predicates are added (Lines 3-4). Every pair of attributes in R, are joinable if one can define equality predicates (=, ≠) on them, and comparable if one can define order predicates (>, ≦, <, ≧) on them. Cross column predicates are added for joinable column pairs (Lines 6-8). Cross column order predicates are added for comparable column pairs (Lines 10-12).
Consider a small Employee Table with three attributes: Employee ID (I), Manager ID (M), and Salary(S).
The following predicate space P can be built:
5.3 Evidence Set
This section, defines the formal definition of EviI. A theorem is described that transforms the problem of minimal DCs discovery into the problem of searching for minimal set covers for EviI. Finally, a procedure is described for computing EviI. For example, the evidence set for the table in Example 7 is EviI={{P2, P3, P5, P8, P10, P12, P14}, {P2, P3, P6, P8, P9, P12, P14}, {P2, P3, P6, P7, P10, P11, P13}}.
The minimal cover for EviI is a set of predicates, that intersect with every SAT (tx,ty) in EviI.
A set of predicates X⊂P is a minimal cover for EviI if ∀E∈EviI, x∩E≠Ø, and Y⊂X, s·t·∀E∈EviI, Y∩E≠Ø.
Theorem 3 transforms the problem of minimal DCs discovery into the problem of searching for minimal set covers for EviI.
THEOREM 3. ┐(
Proof. Consider X⊂P, which is a cover of EviI. According to the definition, EviI represents all the pieces of evidence that might violate DCs. For any E∈EviI, there exists X∈X, X∈E; thus
Example 8 shows an application of Theorem 3.
Consider EviI built for the table in Example 7.
X1={P2} is a minimal cover, thus ┐(P2), i.e., ┐(tα·I=tβ·I) is a valid DC, which states I is a key.
X2={P10, P14} is another minimal cover, thus ┐(
Algorithm 5 presents the procedure for building EviI. This operation is sensitive to the size of the database, with a complexity of O(|P|×|r|2). However, the expensive loop (Lines 1-2) is easy to parallelize since each iteration is independent of each other. On a single machine with multi-core CPU, multi-thread computation is used. On a cluster, the task is distributed to all machines. The effect of parallelization will be demonstrated in Section 7.
5.4 DFS for Minimal Covers
Algorithm 6 below presents the depth-first search (DFS) procedure for minimal covers for EviI (Lines 9-10 are described later in Section 5.5). The evidence denoted by Evicurr set is not covered so far. Initially Evicurr=EviI. Whenever a predicate P is added to the cover, the elements that contain P, i.e., Evinext={E|E∈EcurrP∉E} are removed from Evicurr (Line 21). There are two base cases to terminate the search:
(i) when the search reaches a point where there are no more candidate predicates to include in the cover, but the current evidence set is still not empty (Lines 12-14); and
(ii) when the current evidence set is empty, the current path is a cover. After checking the minimality of the cover (Line 16), it is added to the set of all minimal covers MC (Lines 15-18).
The search procedure is speeded up by two important optimizations: dynamic ordering of predicates when descending down the search tree and branching pruning based on the axioms developed in Section 4.
Opt1: Dynamic Ordering.
Instead of fixing the order of predicates when descending down the tree, the remaining candidate predicates, denoted as >curr, are ordered based on the number of remaining evidence set they cover. Formally, the cover of P is ordered with respect to Evi as Cov(P, Evi)=|{P∉E|E∈Evi}|. And P>Q if Cov(P, Evi)>Cov(Q, Evi), or Cov(P, Evi)=Cov(Q, Evi) and P appears before Q in the preassigned order in the predicate space.
Consider the initial evidence set for the table in Example 7. The cover for each predicate is computed, such as Cov(P2, EviI)=3, Cov(P8, EviI)=2, Cov(P9, EviI)=1, etc. The initial ordering for all predicates according to EviI is >init=P2>P3>P6>P8>P10>P12>P14>P5>P7>P9>P11>P13.
Opt2: Branch Pruning. The purpose of performing dynamic ordering of candidate predicates is to get covers as early as possible so that those covers can be used to prune unnecessary branches of the search tree. Three pruning strategies are described below.
5.5 Dividing the Space of DCs
Instead of searching for all minimal DCs at once, the space of all DCs is divided into subspaces based on whether a DC contains a specific predicate P1, which can be further divided according to whether a DC contains another specific predicate P2.
This section describes how to discover minimal DCs in each subspace. A detailed strategy is described for dividing the DCs space, and the pruning opportunities identified by this operation.
In order to discover DCs that contain a predicate P, an evidence set module predicate P is defined, i.e., EviIp and a theorem is described that reduces searching DCs containing a predicate P into the problem of finding all minimal covers for Eviip
Given a P∈P, the evidence set of I module P is, EviIp={E−{P}|E∈Evii, P∈E}
THEOREM 4. ┐(
Proof: Follow the same line of the proof for Theorem 3. Theorem 4 reduces the problem of discovering all minimal DCs Σ to the problem of finding all minimal covers of EviIp for each predicate P in the predicate space P.
Consider EviI IEviIp
However, care must be taken before starting to search for minimal covers for EviIp due to the following two problems.
First, a minimal DC containing a certain predicate P is not necessarily a global minimal DC. For instance, assume that ┐(P, Q) is a minimal DC containing P because {
Second, assume that ┐(P, Q) is a global minimal DC. It would appear as an output in Σ(P), as well in Σ(Q). A minimal DC φ would then appear in |φ·Pres| searches for minimal set covers, causing a large amount of repeated work.
The second problem is solved first, then, the solution for the first problem comes naturally. The DCs space is divided and all searches are ordered in a way, such to ensure that the output of a locally minimal DC is indeed global minimal, and a previously generated minimal DC will never appear again in latter searches. Consider a predicate space P that has only 4 predicates R1 to R4 as shown in
The first problem is solved by performing depth first searches according to the taxonomy tree in a bottom-up fashion. The method starts by searching for DCs containing R4 and not containing R1, R2, R3. Then the method searches for DCs, containing R3, not containing R1, R2, and the method checks if the resulting DC is global minimal by checking if the reverse of the minimal cover is a super set of DCs already discovered from EviIR
1. Reduction of Number of Searches. If ∃P∈P, such that EviIp=ø, the method identifies two scenarios for Q, where DFS for EviIQ can be eliminated.
(i) ∀Q∈Imp(
Consider EviIp since EviIp
2. Additional Branch Pruning. Since the method performs depth-first searches according to the taxonomy tree in a bottom-up fashion, DCs discovered from previous searches are used to prune branches in current DFS. Lines 9-10 of Algorithm 6 describe the additional branching pruning strategy: if φ is a valid DC discovered from previous searches, any branch containing X, such that
Since Algorithm 6 is an exhaustive search for all minimal covers for EviI. Algorithm 3 will produce all minimal DCs that form a canonical cover.
THEOREM 5. Algorithm 3 produces a canonical cover of all non-trivial minimal DCs holding on input database I.
Complexity Analysis of FASTDC. The initialization of evidence sets takes O(|P|*n2). The time for each DFS search to find all covers for EviIp, is O((1+wP)*KP) with wP being the extra effort due to imperfect search of EviIp and KP being the number of minimal DCs containing predicate P. Altogether, the FASTDC algorithm has a worst time complexity of O(|P|*n2+|P|*(1+wP)*KP).
5.6 Approximate FASTDC: A-FASTDC
Algorithm FASTDC consumes the whole input data set and requires no violations for a discovered DC to be declared valid. In real scenarios, there are multiple reasons why this request may need to be relaxed:
To handle this requirement, we modify the discovery statement as follows: given a relational schema R and instance I, the approximate DCs discovery problem for DCs is to find a minimal cover Σ of valid DCs, where a DC φ is valid if the percentage of violations of φ on I, i.e., number of violations of φ on I divided by total number of tuple pairs |I| (|I|−1), is within threshold ∈. In this section, we describe, A-FASTDC, a variant of FASTDC for approximate DCs discovery.
Different tuple pairs might have the same satisfied predicate set. For every element E in EviI, we denote by count(E) the number of tuple pairs tx,ty such that E=SAT(tx,ty). For example, count({P2; P3; P6; P8; P9; P12; P14})=2 for the table in Example 7 since SAT(t10,t9)=SAT(t11,t9)={P2; P3; P6; P8; P9; P12; P14}.
A set of predicates X⊂P is an ∈-minimal cover for EviI if Sum(count(E))≦∈|I|(|I|−1), where E∈EviI, X∩E=0, and no subset of X has such property.
Theorem 6 transforms approximate DCs discovery problem into the problem of searching for ∈-minimal covers for EviI.
THEOREM 6. ┐(
There are two modifications for Algorithm 6 to search for ∈-minimal covers for EviI: 1) the dynamic ordering of predicates is based on Cov(P,Evi)=ΣE∈{E∈Evi, P∈E}count(E); and 2) the base cases (Lines 12-17) are either when the number of violations of the corresponding DC drops below ∈|I|(|I|−1), or the number of violations is still above ∈|I| (|I|−1) but there are no more candidate predicates to include. The detailed modifications for Algorithm 6 to search for c-minimal covers for EviI are shown in Algorithm 7 which is shown in
6. Ranking DCS
Though our FASTDC is able to prune trivial, non-minimal, and implied DCs, the number of DCs returned can still be too large. To tackle this problem, we propose a scoring function to rank the returned DCs based on their size and their support from the data. Given a DC φ, its interestingness score is denoted by the Inter function as Inter (φ). The Inter score [Inter (φ)] is similar to a schema-conformance score. A DC is schema-conforming if it is verified on every valid instances of R.
We recognize two different dimensions that influence Inter(φ): succinctness and coverage of φ, which are both defined on a scale between 0 and 1. Each of the two scores represents a different yet important intuitive dimension that should be taken into account when ranking discovered DCs.
Succinctness is motivated by the Occam's razor principle. This principle suggests that among competing hypotheses, the one that makes fewer assumptions is preferred. It is also recognized that overfitting occurs when a model is excessively complex.
Coverage is a general principle in data mining to rank results and avoid overfitting. Scoring functions measure the statistical significance of the mining targets in the input data. The more evidence in the input data that supports a DC, the more likely this DC applies on unseen data.
Given a DC φ, the interestingness score is a linear weighted combination of the two dimensions:
Inter(φ)=a1×Succ(φ)+a2×Coverage(φ),a1+a2=1
Experiments in Section 7 show that by combining both dimensions (succinctness and coverage of φ) the best results are achieved in terms of ranking discovered DCs. Succinctness and coverage are described in more detail below.
6.1 Succinctness
Minimum description length (MDL), which measures the code length needed to compress the data, is a formalism to realize the Occam's razor principle. Inspired by MDL, the length of a DC Len(φ) is measured, and the succinctness of a DC φ, i.e., Succ(φ), is defined as the minimal possible length of a DC divided by Len(φ) thus ensuring the scale of Succ(φ) is between 0 and 1.
One simple heuristic for Len(φ) is to use the number of predicates in φ, i.e., |φ·Pres|. The function computes the length of a DC with a finer granularity than a simple counting of the predicates. To compute it, we identify the alphabet from which DCs are formed as A={tα, tβ, ∪, B}, where ∪ is the set of all attributes, and B is the set of all operators. The length of a DC φ is defined as the number of symbols in A that appear in φ: Len(φ)=|{a|a∈A, a∈φ}|. The minimal DC possible is of length 4, such as c5 and c17.
Consider a database schema R with two columns A, B, with 3 DCs as follows:
┐(tα·A=tβ·A) c14:
┐(tα·A=tβ·B) c15:
┐(tα·A=tβ·Atα·B≠tβ·B) c16:
Len(c14)=4<Len(c15)=5<Len(c16)=6.
Succ(c14)=1,Succ15=0.8, and Succ16=0.67.
However, if |φ·Pres| is used as Len(φ), Len(c14)=1<Len(c15)=1<Len(c16)=2, and Succ(c14)=1, Succ(c15)=1, and Succ(c16)=0.5.
6.2 Coverage
Frequent itemset mining recognizes the importance of measuring statistical significance of the mining targets. In this case, the support of an itemset is defined as the proportion of transactions in the data that contain the itemset. Only if the support of an itemset is above a threshold, it is considered to be frequent. CFDs discovery also adopts such principle. A CFD is considered to be interesting only if their support in the data is above a certain threshold, where support is in general defined as the percentage of single tuples that match the constants in the pattern tableaux of the CFDs.
However, the above statistical significance measure requires the presence of constants in the mining targets. For example, the frequent itemsets are a set of items, which are constants. In CFDs discovery, a tuple is considered to support a CFD if that tuple matches the constants in the CFD. Our target VDCs lack constants, and so do FDs. Therefore, a different measure is needed for statistical significance of discovered DCs on I.
Consider c2, which is a FD, in Example 1. Looking at single tuple, just as the statistical measure for CFDs, every tuple matches c2 since it does not have constants. However, the tuple pair t4,t7 gives more support than the tuple pair t2,t6 because t4,t7 matches the left hand side of c2.
Being a more general form than FDs, DCs have further evidence that can be exploited to give an accurate measure of the statistical significance of a DC on I.
An evidence of a DC φ is a pair of tuples that does not violate φ; there exists a predicate in φ that is not satisfied by the tuple pair. However, depending on the number of satisfied predicates, different evidences give different support to the statistical significance score of a DC. The larger the number of satisfied predicates is in a piece of evidence, the more support it should give to the schema-conformance score of φ. kE is defined as follows: where k is the number of satisfied predicates is k, and weight w(k) is given to kE, which is from 0 to 1, and increases with k.
Consider c8 in Example 3, which has 2 predicates. There are two types of evidences, i.e., 0E and 1E.
t1,t2 is a 0E since t1·FN≠t2·FN and t1·GD=t2·GD.
t1,t3 is a 1E since t1·FN≠t3·FN and t1·GD≠t3·GD.
t1,t6 is a 1E since t1·FN=t6·FN and t1·GD=t6·GD.
Clearly, t1,t3 and t1,t6 give more support about the schema-conformance score of c8 than t1,t2.
Given such evidence, the coverage of a DC φ, Coverage(φ) is defined as follows:
The enumerator of Coverage(φ) counts the number of different evidences weighted by their respective weights, which is divided by the total number of evidences. Coverage(φ) gives a score between 0 and 1, with higher score indicating higher statistical significance.
Given 8 tuples in Table 1, there are 8*7=56 evidences. Coverage (c8)=0.80357, Coverage(c2)=0.9821. It can be seen that coverage score is more confident about c2, thus reflecting our intuitive comparison between c2 and c8 in Section 1.
7.1 Datasets
Synthetic:
A Tax data generator is used in which each record represents an individual's address and tax information. The schema consists of 13 attributes: FName, LName, AreaCode, Mobile Phone, City, State, Zip, MaritalStatus, HasChild, Salary, TaxRate, SingleTaxExemp, ChildTaxExemp. The first nine attributes are of type string, the last four attributes are of numerical types (Integer or Double). The FName, LName are populated using a name database. The address information is populated using real semantic relationship. Furthermore, salary is synthetic, while tax rates and tax exemptions (based on salary, state, marital status and number of children) correspond to real life scenarios.
Real-World:
Two datasets are used from different Web sources:
7.2 Scalability Evaluation
The Tax dataset is used to evaluate the running time of FASTDC by varying the number of tuples III, and the number of predicates IPI. As the building evidence set operation is expensive with large instances, it is shown that parallelizing this operation on a cluster leads to improvement depending on the number of machines in the cluster.
Algorithms: FASTDC was implemented in Java, and various optimization techniques were tested. FASTDC+M is used to represent running FASTDC on a cluster consisting of M machines. FASTDC-DS denotes running FASTDC without dividing the space of DCs as in Section 5.5. FASTDC-DO denotes running FASTDC without dynamic ordering of predicates in the search tree as in Section 5.4.
Exp-1: Scalability in |I|.
The running time on all 13 attributes is measured, by varying the number of tuples (up to a million tuples), as illustrated in
Exp-2: Scalability in |P|.
The running time is measured in seconds using 10 k tuples, by varying the number of predicates picked from the attributes in Tax data, as in
The amount of wasted work is measured by the number of times Line 13 of Algorithm 6 is hit. The number of minimal DCs discovered is the same for FASTDC, FASTDC-DS, and FASTDC-DO as optimizations do not alter the discovered DCs. FASTDC is always more efficient than FASTDC-DS and FASTDC-DO.
For the Hospital dataset, the number of predicates is 34; and it took 118 minutes to run on a single machine using all tuples. For the SP Stock dataset, the number of predicates is 82; and it took 593 minutes to run on a single machine using all tuples.
Parallelization. The parallelization of the tuple pair-wise comparison of Algorithm 5 can lead to better execution times. The running time of FASTDC is compared on a single machine versus the running time on a cluster consisting of 4 machines. Distributing a tuple pair-wise comparison is a viable solution if a dataset is too large to run on a single machine. Smaller size (10 k-50 k), parallel execution does not achieve a “four times” improvement since the searching time for minimal covers takes up a large overhead. For larger datasets with sizes up to 90 k, a parallel version can achieve almost four times improvement because the dominant factor is the tuple pair-wise comparison.
Exp-3: Implication Reduction.
The number of DCs returned by FASTDC can be very large, and many of them are implied by others.
Table 4 shows the number of DCs before and after performing reduction through implication testing for all datasets. It can be seen that the implication testing algorithm, is able to prune a large amount of implied DCs.
7.3 Qualitative Analysis
Given an input instance I of a fixed schema R, it is desirable to discover schema-conforming DCs. First DCs discovered for different datasets are described. A scoring function is then described which is able to improve the precision and recall of returned DCs without user involvement. The scoring function (the Inter function) identifies interesting DCs. FASTDC can be run with 10 k tuples for each dataset using all available attributes.
Discovered DCs.
Table 5 shown in
Scoring Function—the Inter function.
The number of computed DCs, even after implication reduction, is still too large for an exhaustive manual validation. Moreover, human evaluation may be impossible if domain experts are not available. To alleviate these problems, the Inter function can be used in two applications: to limit the manual verification to the k DCs with higher scores, or to prune the DCs whose score is lower than a threshold th.
Several metrics are introduced for qualitative assessments of the discovered DCs used in this section. We evaluate the two dimensions of the Inter function in Exp-4 and Exp-5 according to two different metrics. We report several discovered DCs by FASTDC that are non-trivial for users to design in Exp-6. We evaluate AFASTDC for noisy data in Exp-7. All experiments in this section are done on 100 k tuples for all datasets.
Parameters k and th. depend on the actual domain and can be fixed by the users. Users only need to verify Top-k DCs that are expected to be schema-conforming DCs with high precision, or they can set a threshold if domain experts for DCs verification are unavailable.
Metrics. We denote by Σg the gold standard DCs that are designed by
domain experts and are valid on the datasets. Specifically, Σg for the Tax dataset is designed by the present applicant; Σg for the Hospital dataset is retrieved from X. Chu, I. F. Ilyas, and P. Papotti. “Holistic data cleaning: Putting violations into context”. In ICDE, 2013.; and Σg for the SP Stock dataset have been designed by experts. Note that any DCs implied by Σg should also be considered as gold standard. The discovered DCs are denoted by Σs, i.e. the DCs returned by FASTDC.
We define G-Precision, G-Recall, and G-F-Measure of Σs as the following:
Ranking-based Σs.
By only returning Top-k DCs, many meaningful DCs are not missed. Third, results for the succinctness and coverage functions in isolation show that only by combining their scores best results are achieved in estimating the schema-conformance of DCs.
Notice that in
The discovery output is measured with the U-Precision, which captures exactly if the DCs are schema-conforming. The U-Precision is defined as the percentage of DCs in Σs that are verified to be schema-conforming by domain experts. Domain experts might not be exhaustive in designing all gold DCs. DCs that are in Σs and are not implied by Σg might also be gold. We denote by Σu the DCs in Σs that are verified by domain experts to be gold. We define U-Precision as following:
Exp-4: Evaluation of Inter score. We report in
This experiment shows that both succinctness and coverage are useful in identifying interesting DCs. Combining both dimensions into Inter score achieves the best result in all cases.
Exp-5: U-Precision:
Table 6 shows the U-Precision for all datasets using the Top-k DCs as Σs. For k=5 and k=10, they have U-Precision of 1.0. While in
(tα.ST = tβ.ST tα.SAL <
(tα.CH ≠ tβ.CH tα.STX <
(tα.MS ≠ tβ.MS tα.STX =
(tα.MC = tβ.MC tα.MN ≠
(tα.PN = tβ.PN tα.PHO ≠
(tα.Open > tα.High)
(tα.Date = tβ.Date
Exp-6: Discovered DCs:
Table 7 reports some DCs discovered in different datasets, with their semantics explained in English. It can be seen that FASTDC is able to discover meaningful DCs that are otherwise difficult to spot or design.
Exp-7: A-FASTDC—Discovering Approximate Constraints in the Presence of Dirty Data:
We randomly inject 0.1% noise into the datasets and run A-FASTDC to verify that it discovers meaningful DCs in the presence of noise. Intuitively, A-FASTDC will not only discover gold DCs, but also DCs whose violation percentages happen to be within c. For example, ┐(tα·FN=tβ·FNtα·LN=tβ·LN) is discovered for the Tax data.
Threshold-based Σs: For real life datasets, an approach is to only return DCs whose U-Precision values are above a certain threshold. Table 8 reports the U-Precision values for all the DCs in Σs where their U-Precision value is above the threshold th.
For each entry is reported the number of DCs in the sample and the precision value in parentheses. The scores give an accurate measure for the schema-conformance of the returned DCs.
Denial Constraints are a useful language formalism that can be used to detect violations, conduct sanity checks through data, clean data and enforce the correct data semantics. Denial Constraints are a useful language formalism to detect violations and enforce the correct application semantics. We have presented static analysis for DCs, including three sound axioms, and a linear implication testing algorithm. We also developed a DCs discovery algorithm (FASTDC), that can also discover approximate constraints in presence of dirty data. In addition, our interestingness score is very effective in identifying meaningful DCs. Our experiments demonstrated the effectiveness of our techniques in discovering interesting DCs. We have several directions to pursue in the future. We are developing algorithms for discovering DCs with constants and we want to investigate sampling techniques to alleviate the quadratic complexity of computing the evidence set.
When used in this specification and claims, the terms “comprises” and “comprising” and variations thereof mean that the specified features, steps or integers are included in an open ended manner. The terms are not to be interpreted to exclude the presence of other features, steps or components.
While particular embodiments have been illustrated and described herein, it should be understood that various other changes and modifications may be made without departing from the spirit and scope of the claimed subject matter. Moreover, although various aspects of the claimed subject matter have been described herein, such aspects need not be utilized in combination. It is therefore intended that the appended claims cover all such changes and modifications that are within the scope of the claimed subject matter.
This application is a National stage entry under 35 U.S.C. §371 of PCT Patent Application No. PCT/EP2013/061326, filed May 31, 2013, which is incorporated entirely by reference herein.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/EP2013/061326 | 5/31/2013 | WO | 00 |