Methods for Identifying Denial Constraints

Information

  • Patent Application
  • 20160103867
  • Publication Number
    20160103867
  • Date Filed
    May 31, 2013
    11 years ago
  • Date Published
    April 14, 2016
    8 years ago
Abstract
Computer implemented methods for identifying denial constraints are provided herein. The denial constraints can be used with a database schema R. A predicate space P can be generated for an instance I in the schema R. An evidence set EviI can be generated. The evidence set EviI can include sets of satisfied predicates in the predicate space P for each instance I. A minimal set of predicates can be identified for the evidence set EviI. Valid denial constraints can be identified from the minimal set by inverting the predicates in the minimal set.
Description
BACKGROUND

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.


SUMMARY
Example 1
Consider the US tax records in Table 1 shown in


FIG. 1. Each record describes an individual address and tax information with 15 attributes: first and last name (FN, LN), gender (GD), area code (AC), mobile phone number (PH), city (CT), state (ST), zip code (ZIP), marital status (MS), has children (CH), salary (SAL), tax rate (TR), tax exemption amount if single (STX), married (MTX), and having children (CTX).


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.


(1): {AC, PH}
(2): ZIP→ST
(3): [CT=‘Los Angeles’]→[ST=‘CA’]

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β·STcustom-charactertα·SAL<tβ·SALcustom-charactertα·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β·ACcustom-charactertα·PH=tβ·PH)  c1:





tα,tβ∈r,(tα·ZIP=tβ·ZIPcustom-charactertα·ST≠tβ·ST)  c2:





tα,tβ∈r,(tα·CT=‘Los Angeles’custom-charactertα·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:

















Input: One relational instance I, schema R



Output: Predicate space P



 1: for all A ∈ R do










 2:
P ← tα.Aθtβ.A, where θ ∈ {=, ≠}



 3:
if A is numerical type then










 4:
P ← P + tα .Aθtβ .A, where θ ∈ {>, ≦, <, ≧}









 5: Profiling to find joinable column pairs EQColPairs



 6: for all custom-character  A, B custom-character  ∈ EQColPairs do










 7:
P ← P + tα.Aθtα.B, where θ ∈ {=, ≠}



 8:
P ← P + tα.Aθtβ.B, where θ ∈ {=, ≠}









 9: Profiling to find comparable column pairs OrderColPairs



10: for all custom-character  A, B custom-character  ∈ OrderColPairs do










11:
P ← P + tα.Aθtα.B, where θ ∈ {>, ≦, <, ≧}



12:
P ← P + tα.Aθtβ.B, where θ ∈ {>, ≦, <, ≧}.










According to one or more embodiments described herein, the evidence set EviI is generated using the algorithm:

















Input: One relational instance I, predicate space P



Output: EviI



 1: for Tuple tx ∈ I do










 2:
for Tuple ty ∈ I do



 3:
if tx = ty then



 4:
continue



 5:
SAT ← ø



 6:
for P ∈ P do



 7:
if custom-character  tx,tycustom-character  |= P then



 8:
SAT ← SAT + P



 9:
if SAT ∉ EviI then



10:
EviI ← EviI + SAT.










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:








U


-



Precision


(

Σ
S

)



=




Σ
u






Σ
s





,




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:







Succ


(
ϕ
)


=


Min


(

{


Len


(
φ
)


|


φ


}

)



Len


(
ϕ
)







According to one or more embodiments described herein, the coverage is defined as:







Coverage


(
ϕ
)


=





k
=
0





ϕ
·
Pres



-
1






kE


*

w


(
k
)







I


×

(



I


-
1

)







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.





BRIEF DESCRIPTION OF THE DRAWINGS

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:



FIG. 1 depicts table (Table 1) showing data representing US tax records for Example 1 according to one or more embodiments shown and described herein;



FIG. 2 depicts table (Table 3) of FDs Axioms and their corresponding DCs forms according to one or more embodiments shown and described herein;



FIG. 3 shows a soundness proof and completeness proof of the algorithms of an interference system according to one or more embodiments shown and described herein;



FIG. 4 shows a soundness proof for Algorithm 1 according to one or more embodiments shown and described herein;



FIG. 5 shows a soundness proof for Algorithm 2 and a counterexample for Algorithm 2 according to one or more embodiments shown and described herein;



FIG. 6 schematically depicts diagram of an example taxonomy tree according to one or more embodiments shown and described herein;



FIG. 7 schematically depicts algorithm (Algorithm 7) to search ∈-minimal covers according to one or more embodiments shown and described herein;



FIGS. 8a-l depict graphical representations of the results of a scalability evaluation with respective example datasets for a FASTDC embodiment according to one or more embodiments shown and described herein; and



FIG. 9 depicts table (Table 5) showing sample denial constraints identified in the example datasets according to one or more embodiments shown and described herein.





DETAILED DESCRIPTION

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.


Example 2

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β·ZIPcustom-charactertα·SAL<tβ·SALcustom-charactertα·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.


Example 3

Consider DC c7 on Table 1 shown in FIG. 1, which states that first name determines gender.





tα,tβ∈r,(tα·FN=tβ·FNcustom-charactertα·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,(P1custom-character . . . custom-characterPm)  φ:


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 P: v12 v2, where φ21. If P is true, then P is false. The set of implied predicates of P is Imp(P)={Q|Q: v1 φ2 v2}, where φ2 ∈Imp(φ1). If P is true, then ∀Q∈Imp(P), Q is true. The inverse and implication of the six operators in B is summarized below in Table 2.

















TABLE 2









φ
=

>
<






φ


=


<
>



Imp(φ)
=, ≧, ≦

>, ≧, ≠
<, ≦, ≠












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.












TABLE 7







Symbol
Meaning









P, Q, R
Single Predicate



P, Q, R, W, X, Y
Set of Predicates



φ.Pres
Set of Predicates in DC φ



Pi
A subset of predicates in P except Pi




P

Reverse each predicate in the set



c, φ, φ
Single DCs



Σ, Γ
Set of DCs










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 (P1custom-character . . . custom-characterPn) 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 custom-characterφ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.


Example 4

Consider three additional DCs for Table 1.






(tα·SAL=tβ·SALcustom-charactertα·SAL>tβ·SAL)  c10:






(tα·PH=tβ·PH))  c11:





tα,tβ∈r,(tα·STcustom-charactertα·SAL>tβ·SALcustom-charactertα·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 Pi ∈Imp (Pj), then (P1custom-characterPj) is a trivial DC


2. Augmentation: If (P1custom-character . . . custom-characterPn) is a valid DC, then (P1custom-character . . . custom-characterPncustom-characterQ) is also a valid DC


3. Transitivity: If (P1custom-character . . . custom-characterPncustom-characterQ1) and (R1custom-character . . . custom-characterRmcustom-characterQ2) are valid DCs, and Q2∈Imp( Q1), then (P1custom-character . . . custom-characterPncustom-characterR1custom-character . . . custom-characterRm) is also a valid DC


Triviality states that if there are two predicates that cannot be true at the same time in a DC ( P1∈Imp(Pj)), then the DC is trivially satisfied.


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( Q1)), then merging two DCs plus removing those two predicates will result in a valid DC.


Since FDs are a subset of DCs, and Armstrong Axioms for FDs are well understood, we list in Table 3 (FIG. 2) FDs Axioms and their corresponding DCs forms to clarify DCs inference system I.


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., Σcustom-characterφ. The completeness of I dictates that if Σcustom-character, 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, (P1custom-character . . . custom-characterPmcustom-characterQ), where P1=tα·Aiθtβ·Ai, ∀i∈[1, m] and Q=tα·B θtβ·B with Ai, B∈U.


A formal proof of Theorem 2 is set out in FIG. 3. The completeness result for the inference system I for that form of DCs generalizes the completeness result of Armstrong Axioms for FDs. In particular, FDs adhere to the form with θ being =.


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 P to W would constitute a DC implied by Σ. This is similar to the closure of a set of attributes under a set of FDs.


Definition 1

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), Σ|=(Wcustom-characterP).


Algorithm 1 calculates the partial closure of W under Σ, whose proof of correctness is set out in FIG. 4. CloΣ(W) by initialised by adding every predicate in W and their implied predicates due to Axiom Triviality (Lines 1-2). Additional predicates are added that are implied by CloΣ(W) through basic algebraic transitivity (Line 3). The closure is enlarged if there is a DC φ in Σ such that all but one predicates in φ are in the closure (Lines 15-23). Two lists are used to keep track of exactly when such condition is met (Lines 3-11).


Example 5

Consider Σ={c1, . . . , c6} and W={tα·ZIP=tβ·ZIP, tα·SAL<tβ·SAL}.












Algorithm 1 GET PARTIAL CLOSURE:















Input: Set of DCs Σ, Set of Predicates W


Output: Set of predicates called closure of W under Σ: CloΣ(W)


 1: for all P ∈ W do








 2:
CloΣ(W) ← CloΣ(W)+ Imp(P)


 3:
CloΣ(W) ← CloΣ(W)+ Imp(CloΣ(W))







 4: for each predicate P, create a list LP, which is the set of DCs


   containing P


 5: for each DC φ, create a list Lφ, which is the set of predicates not yet


   included in the closure


 6: for all φ ∈ Σ do








 7:
for all P ∈φ.Pres do


 8:
LP← LP + φ







 9: for all P ∉ CloΣ(W) do








10:
for all φ ∈ LP do








11:
Lφ ← Lφ + P







12: create a list J, which is a queue of DC, which has all but one predicate


   in the closure


13: for all φ ∈ Σ do








14:
if |Lφ | = 1 then








15:
J ← J + φ







16: while |J | > 0 do








17:
φ ← J.pop( )


18:
P—← Lφ.pop( )


19:
for all Q ∈ Imp( P ) do


20:
for all φ ∈ LQ do








21:
Lφ ← Lφ − Q


22:
if |Lφ | = 1 then








23:
J ← custom-character  + φ








24:
CloΣ(W)← CloΣ(W)+ Imp( P )


25:
CloΣ(W)← CloΣ(W) + Imp(CloΣ(W))







26: return CloΣ(W)









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 FIG. 5. FIG. 5 also shows a counterexample where φ is indeed implied by Σ, but Algorithm 2 fails to verify because Algorithm 2 computes only a partial closure.


Example 6

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β·Hcustom-charactertβ·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)












Algorithm 2 IMPLICATION TESTING

















Input: Set of DCs Σ, one DC φ



Output: A boolean value, indicating whether Σ |= φ



1: if φ is a trivial DC then










2:
return true









3: Γ ← Σ



4: for φ ∈ Σ do










5:
Γ ← Γ + symmetric DC of φ









6: CloΓ (φ.Pres) = getClosure(φ.Pres.Γ)



7: if ∃φ ∈ Γ, s.t. φ.Pres CloΓ(φ.Pres) then










8:
return true










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.












Algorithm 3 FASTDC

















Input: One relational instance I, schema R



Output: All minimal DCs Σ



1: P ← BUILD PREDICATE SPACE (I , R)



2: EviI ← BUILD EVIDENCE SET(I , P)



3: MC ← SEARCH MINIMAL COVERS(EviI , EviI , Ø, >init , Ø )



4: for all X ∈ MC do










5:
Σ ← Σ+( X)









6: for all φ ∈ Σ do










7:
if Σ − φ |= φ then










8:
remove φ from Σ










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β·Acustom-charactertα·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).












Algorithm 4 BUILDING PREDICATE SPACE

















Input: One relational instance I, schema R



Output: Predicate space P



 1: for all A ∈ R do










 2:
P ← tα.Aθtβ.A, where θ ∈ {=, ≠}



 3:
if A is numerical type then










 4:
P ← P + tα .Aθtβ .A, where θ ∈ {>, ≦, <, ≧}









 5: Profiling to find joinable column pairs EQColPairs



 6: for all custom-character  A, B custom-character  ∈ EQColPairs do










 7:
P ← P + tα.Aθtα.B, where θ ∈ {=, ≠}



 8:
P ← P + tα.Aθtβ.B, where θ ∈ {=, ≠}









 9: Profiling to find comparable column pairs OrderColPairs



10: for all custom-character  A, B custom-character  ∈ OrderColPairs do










11:
P ← P + tα.Aθtα.B, where θ ∈ {>, ≦, <, ≧}



12:
P ← P + tα.Aθtβ.B, where θ ∈ {>, ≦, <, ≧}










Example 7

Consider a small Employee Table with three attributes: Employee ID (I), Manager ID (M), and Salary(S).














I(String)
M(String)
S(Double)







A1
A1
50


A2
A1
40


A3
A1
40










The following predicate space P can be built:



















P1: tα.I = tβ.I
P5: tα.S = tβ.S
P9: tα.S < tβ.S



P2: tα.I ≠ tβ.I
P6: tα.S ≠ tβ.S
P10: tα.S ≧ tβ.S



P3: tα.M = tβ.M
P7: tα.S > tβ.S
P11: tα.I = tα.M



P4: tα.M ≠ tβ.M
P8: tα.S ≦ tβ.S
P12: tα.I ≠ tα.M



P13: tα.I = tβ.M
P14: tα.I ≠ tβ.M










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}}.


Definition 2. Evidence Set





    • Given a pair of tuple custom-charactertx,tycustom-character∈|, the satisfied predicate set for custom-charactertx,tycustom-character is SAT (custom-charactertx,tycustom-character)={P|P∈P, custom-charactertx,tycustom-character|=P}, where P is the predicate space, and custom-charactertx,tycustom-character|=P means custom-charactertx,tycustom-character satisfies P.

    • The evidence set of I is EviI={SAT (custom-charactertx,tycustom-character) |∀custom-charactertx,tycustom-character∈I}.





The minimal cover for EviI is a set of predicates, that intersect with every SAT (custom-charactertx,tycustom-character) in EviI.


Definition 3

A set of predicates XP is a minimal cover for EviI if ∀E∈EviI, x∩E≠Ø, and custom-characterY⊂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. ( X1custom-character . . . custom-characterXn) is a valid minimal DC if and only if X={X1, . . . , Xn} is a minimal cover for EviI.


Proof. Consider XP, 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 X∉E. In other words, the presence of X disqualifies E as a possible violation of any DC.


Example 8 shows an application of Theorem 3.


Example 8

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 ┐( P10custom-characterP14), i.e., (tα·S<tβ·Scustom-charactertα·I=tβ·M) is another valid DC, which states that a manager's salary cannot be less than her employee's.


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.












Algorithm 5 BUILD EVIDENCE SET

















Input: One relational instance I, predicate space P



Output: EviI



 1: for Tuple tx ∈ I do










 2:
for Tuple ty ∈ I do



 3:
if tx = ty then



 4:
continue



 5:
SAT ← 



 6:
for P ∈ P do



 7:
if custom-character  tx, tycustom-character  |= P then



 8:
SAT ← SAT + P



 9:
if SAT ∉ EviI then



10:
EviI ← EviI + SAT










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∈Ecurrcustom-characterP∉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.












Algorithm 6 Search Minimal Covers















Input: 1. Input Evidence set, EviI


 2. Evidence set not covered so far, Evicurr


 3. The current path in the search tree, X P


 4. The current partial ordering of the predicates, >curr


 5. The DCs discovered so far, Σ


Output: A set of minimal covers for Evi, denoted as MC


 1: Branch Pruning


 2: P ← X.last


 3: if ∃Q ∈ X − P, s.t. P ∈ Imp(Q) then








 4:
return //Triviality pruning







 5: if ∃Y ∈ MC, s.t. X Y then








 6:
return //Subset pruning based on MC







 7: if ∃Y = {Y1 , . . . , Yn } ∈ MC, and ∃i ∈ [1, n], and ∃Q ∈


   Imp(Yi ), s.t. Z = Y−i Q and X Z then








 8:
return //Transitive pruning based on MC







 9: if ∃φ ∈ Σ, s.t. Xφ.Pres then








10:
return //Subset pruning based on previous discovered DCs







11: Base cases


12: if >curr =  and Evicurr ≠  then








13:
return //No DCs in this branch







14: if Evicurr =  then








15:
if no subset of size |X| − 1 covers Evicurr then


16:
MC ← MC + X


17:
return //Got a cover







18: Recursive cases


19: for all Predicate P ∈>curr do








20:
X ← X + P


21:
Evinext ← remaining evidence sets in Evicurr not yet covered by









P








22:
>next ← the total ordering of {P′ |P >curr P′} according to Evinext


23:
SEARCH MINIMAL COVERS( EviI , Evinext , X, >next , Σ)


24:
X ← X − P









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.


Example 9

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.

    • (i) Lines (2-4) describe the first branch pruning strategy. This branch would eventually result in the DC of the form φ:( X−Pcustom-characterPcustom-characterW), with predicate P being the most recent predicate added to this branch and W being other predicates if this branch is traversed. If P∈Imp( X−P), then φ is a trivially satisfied DC according to Axiom Triviality.
    • (ii) Lines (5-6) describe the second branch pruning strategy, which is based on MC. If Y is in the cover, then ( Y) is a valid DC. Any branch containing X would result in a DC of the form ( Xcustom-characterW), which is implied by ( Y) based on Axiom Augmentation, since YX.
    • (iii) Lines (7-8) describe the third branching pruning strategy, which is also based on MC. If Y is in the cover, then ( Y−icustom-characterYi) is a valid DC. Any branch containing XY−iQ would result in a DC of the form ( Y−icustom-characterQcustom-characterW). Since Q∈Imp(Yi), by applying Axiom Transitive on these two DCs, it is revealed that ( Y−icustom-characterW) is also a valid DC, which would imply ( Y−1custom-characterQcustom-characterW) based on Axiom Augmentation. Thus this branch can be pruned.


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


Definition 4

Given a P∈P, the evidence set of I module P is, EviIp={E−{P}|E∈Evii, P∈E}


THEOREM 4. ( X1custom-character . . . custom-characterXncustom-characterP) is a valid minimal DC, that contains predicate P, if and only if X={X1, . . . , Xn}I is a minimal cover for EviIp.


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.


Example 10

Consider EviI IEviIp1=ØEviIp13={{P2, P3, P6, P7, P10, P11}}. Thus (P1) is a valid DC because there is nothing in the cover for EviI, and (P13custom-characterP10) is a valid DC because {P10} is a cover for EviIp13 It is evident that EviIp is much smaller than EviI.


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 { Q} is a minimal cover for EviIp. However, it might not be a minimal DC because it is possible that (Q), which is actually smaller than (P, Q), is also a valid DC. (P, Q) is a local minimal DC with respect to P, and (Q), a global minimal DC, or a minimal DC. A global minimal DC is always a local minimal DC with respect to each predicate in the DC. The goal is to generate all globally minimal DCs.


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 FIG. 6, which presents a taxonomy of all DCs. In the first level, all DCs can be divided into DCs containing R1, denoted as +R1, and DCs not containing R1, denoted as R1. Since it is known how to search for local minimal DCs containing R1, there is only a need to further process DCs not containing R1, which can be divided based on containing R2 or not, i.e., +R2 and −R2. −R2, −R3 are divided as in FIG. 6. Searching for DCs' not containing Ri can be enforced by disallowing Ri in the initial ordering of candidate predicates for minimal cover. Since this is a taxonomy of all DCs, no minimal DCs can be generated multiple times, thus solving the second problem mentioned above.


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 EviIR4. Then the method searches for DCs, containing R2, not containing R1, and checks if the resulting DC is global minimal by checking if the reverse of the minimal cover is a superset of DCs already discovered from EviIR3, EviIR4. The process goes on until it reaches the root of the taxonomy tree, thus ensuring that the results are both globally minimal and complete. Two additional optimization opportunities coming from dividing the DCs space are discussed below:


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( P). If EviIp=ø, then (P) is a valid DC. The search for EviiQ would result in a DC of the form (Qcustom-characterW), where W represents any other set of predicates. Since Q∈Imp( P), applying Axiom Transitivity, (W) is a valid DC, which implies (Qcustom-characterW) based on Axiom Augmentation. (ii) ∀ Q∈Imp( P) Since Q∈Imp( P), then Q|=P, then Qcustom-characterW|=P. Taking the contrapositive, the result is (P)|=(Qcustom-characterW).


Example 11

Consider EviIp since EviIp1=ø and EviIp4=ø, then Q={P1, P2, P3, P4}. Thus the method only needs to perform |P|−|Q|=10 searches instead of |P|=14 searches.


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 Xφ·Pres, would result in a DC of the form (φ·Prescustom-characterW), which is implied by φ based on Axiom Augmentation.


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:

    • (1) overfitting: data is dynamic and as more data becomes available, overfitting constraints on current data set can be problematic;
    • (2) data errors: while in general learning from unclean data is a challenge, the common belief that errors constitute small percentage of data, discovering constraints that hold for most of the dataset is a common workaround.


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 custom-charactertx,tycustom-character such that E=SAT(custom-charactertx,tycustom-character). For example, count({P2; P3; P6; P8; P9; P12; P14})=2 for the table in Example 7 since SAT(custom-charactert10,t9custom-character)=SAT(custom-charactert11,t9custom-character)={P2; P3; P6; P8; P9; P12; P14}.


Definition 5

A set of predicates XP 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. ( X1custom-character . . . custom-characterXn) is a valid approximate minimal DC if and only if X={X1, . . . , Xn} is an ∈-minimal cover for EviI.


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 FIG. 7.


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.







Succ


(
ϕ
)


=


Min


(

{


Len


(
φ
)


|


φ


}

)



Len


(
ϕ
)







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.


Example 12

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β·Acustom-charactertα·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.


Example 13

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 custom-charactert4,t7custom-character gives more support than the tuple pair custom-charactert2,t6custom-character because custom-charactert4,t7custom-character 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.


Definition 5. Evidences and Weights





    • A kE of a DC φ with respect to a relational instance r is a tuple pair custom-charactertx,tycustom-character, and the number of predicates satisfied by custom-charactertx,tycustom-character is k, where k≦|φ·Pres|−1.

    • The weight for kE of a DC φ is










w


(
k
)




=
.




(

k
+
1

)




ϕ
·
Pres








Example 14

Consider c8 in Example 3, which has 2 predicates. There are two types of evidences, i.e., 0E and 1E.



custom-charactert1,t2custom-character is a 0E since t1·FN≠t2·FN and t1·GD=t2·GD.

custom-charactert1,t3custom-character is a 1E since t1·FN≠t3·FN and t1·GD≠t3·GD.

custom-charactert1,t6custom-character is a 1E since t1·FN=t6·FN and t1·GD=t6·GD.


Clearly, custom-charactert1,t3custom-character and custom-charactert1,t6custom-character give more support about the schema-conformance score of c8 than custom-charactert1,t2custom-character.


Given such evidence, the coverage of a DC φ, Coverage(φ) is defined as follows:







Coverage


(
ϕ
)


=





k
=
0





ϕ
·
Pres



-
1






kE


*

w


(
k
)







I


×

(



I


-
1

)







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.


Example 15

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:

    • 1) Hospital data from the US federal government website. There are 17 attributes, including Provider number (PN), State average (SAVG), measure code (MC), measure name (MN), phone number (PHO), etc. All of 17 attributes are string values.
    • 2) SP Stock data extracted from historical S&P 500 Stocks. Each record is arranged into fields representing the Date, Ticker, Price of Open, High, Low, Close of the day, and Volume of the day.


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 FIG. 8a. The size of the predicate space |P| is 50. The Y axis of FIG. 8a is in log scale. We compare the running time of FASTDC and FASTDC+M. FIG. 8a shows a quadratic trend as the computation is dominated by the tuple pair-wise comparison for building the evidence set. In addition, FIG. 8a shows that we achieve almost linear improvement with respect to the number of machines on a cluster; for example, for 1M tuples, it took 3257 minutes on 7 machines, but 1228 minutes on 20 machines. Running FASTDC on a cluster is a viable approach if the number of tuples is too large to run on a single machine. There are two reasons for this improvement. First, the number of depth first searches is reduced. Second, inside each search, DCs discovered from previous searches are used to perform branch pruning.


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 FIG. 8b. We compare the running time of FASTDC, FASTDC-DS, and FASTDCDO. The ordering of adding more attributes is randomly chosen and we report the average running time over 20 executions. The Y axes of FIGS. 8b, 8c and 8d are in log scale. FIG. 8b shows that the running time increases exponentially with respect to the number of predicates, especially when it involves numerical values. This is not surprising because the number of minimal DCs, as well as the amount of wasted work, increases exponentially with respect to the number of predicates, as shown in FIGS. 8c and 8d. By dividing DCs space, FASTDC can substantially reduce the amount of wasted work in DFS: for 50 predicates, the algorithm took 3500 seconds without the optimization.


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







Dataset
#DCs Before
#DCs After
% Reduction





















Tax
1964
741
61%



Hospital
157
42
73%



SP Stock
829
621
25%










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 FIG. 9 shows sample 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.


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:







G


-



Precision


(

Σ
s

)



=




{


ϕ





ϕ


Σ
s


,

Σ
g





=
ϕ

}






Σ
s











G


-



Recall


(

Σ
s

)



=




{


ϕ





ϕ


Σ
s


,

Σ
g





=
ϕ

}






Σ
g











G


-


F


-



Measure


(

Σ
s

)



=


2
*
g


-



Precision


(

Σ
s

)


*
g


-



Recall


(

Σ
s

)





g


-



Precision


(

Σ
s

)



+

g


-



Recall


(

Σ
s

)









Ranking-based Σs. FIGS. 8e-h show G-Precision, G-Recall and G-F-Measure with respect to Σg for Tax and SP Stock data, with Σs being the Top-k DCs according to the Inter function. There are several possible observations from FIGS. 8e-h. First, precision is high for small values of k. Second, recall is close to one for small values of k and it increases with k, but with a descending degree. Therefore, most of the meaningful DCs is concentrated in Top-k according to the Inter function (scoring function) being the Top-k DCs according to succinctness, coverage and interestingness—hence the term “Inter” function.


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 FIG. 8e, the precision is less than 1 with k values smaller than 15 in the Tax dataset. However, this does not necessary imply that the DCs in Σs that are not implied by Σg are not schema-conforming. In fact, it turns out that they are also schema-conforming, but are not in Σg (because the expert was not aware of them) nor are implied by Σg. DCs in Σs confirmed by domain experts to be schema-conforming are denoted by Σu. For instance, the third entry in Table 5 shown in FIG. 9 is ranked fourth in Σs, which is not in Σg nor implied by Σg, but is schema-conforming.


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:







U


-



Precision


(

Σ
S

)



=




Σ
u






Σ
s








Exp-4: Evaluation of Inter score. We report in FIGS. 8e-h G-Precision, G-Recall, and G-F-Measure for the Tax and the Hospital datasets, with Σs being the Top-k DCs according to succinctness, coverage and interestingness. Consider the Tax dataset, results using Inter function as in FIG. 8e are always better than those using succinctness alone as in FIG. 8f and those using coverage alone as in FIG. 8g. Moreover, FIG. 8e shows that Inter score with Top-20 DCs achieves perfect recall; while this is not the case for succinctness and coverage. This is due to two reasons. First, succinctness score blindly promotes shorter DCs that are not true in general, such as c7 in Example 3. Second, coverage score might promote longer DCs that have higher coverage than shorter ones that have less coverage, however, those shorter DCs might be in Σg; for example, the first entry in Table 6 has higher coverage than (tα·AC=tβ·ACcustom-charactertα·PH=tβ·PH), which is actually in Σg. For the Hospital dataset, interestingness and coverage give the same results as in FIG. 8h, which are considerably better than succinctness because gold DCs for the Hospital dataset are all FDs with two predicates, therefore succinctness has no effect on the interestingness. For the SP Stock dataset, all three scoring functions give the same results because gold DCs for this dataset are simpler DCs, such as (tα·Low>tα·High).


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.















TABLE 6







Dataset
k = 5
k= 10
k = 15
k = 20






















Tax
1.0
1.0
0.93
0.75



Hospital
1.0
1.0
0.93
0.7



SP Stock
1.0
1.0
1.0
1.0










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 FIG. 8e, Top-5 and Top-15 G-precision values are less than 1.0. This is due to the fact that FASTDC is able to discover DCs that are gold standard but not easily designed by humans such as the second and third entry in Table 7.









TABLE 7







Sample DCs discovered in the datasets









Dataset
DC Discovered
Semantics





Tax

custom-character  (tα.ST = tβ.ST custom-character  tα.SAL <

There cannot exist two persons



tβ.SAL custom-character  tα.TR > tβ.TR)
who live in the same state, but




one person earns less salary and




has higher tax rate at the same




time.


Tax

custom-character  (tα.CH ≠ tβ.CH custom-character  tα.STX <

There cannot exist two persons



tα.CTX custom-character  tβ.STX < tβ.CTX)
with both having CTX higher




than STX, but different CH.




If a person has CTX, she must




have children.


Tax

custom-character  (tα.MS ≠ tβ.MS custom-character  tα.STX =

There cannot exist two persons



tβ.STX) custom-character  tα.STX > tα.CTX)
with same STX, one person has




higher STX than CTX and they




have different MS. If a person




has STX, she must be single.


Hospital

custom-character  (tα.MC = tβ.MC custom-character  tα.MN ≠

Measure code determines



tβ.MN)
Measure name.


Hospital

custom-character  (tα.PN = tβ.PN custom-character  tα.PHO ≠

Provider number determines



tβ.PHO)
Phone number.


SP

custom-character  (tα.Open > tα.High)

The open price of any stock


Stock

should not be greater than its




high of the day.


SP

custom-character  (tα.Date = tβ.Date custom-character

Ticker and Date is a composite


Stock
tα.Ticker = tβ.Ticker)
key.









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β·FNcustom-charactertα·LN=tβ·LN) is discovered for the Tax data. FIGS. 8i-l plot the G-F-Measure for the Tax, the Hospital, and the SP Stock datasets. Given different approximation levels ∈, A-FASTDC is able to achieve reasonable F-Measure for all three datasets. However the results for the Hospital and the SP Stock datasets are better than the Tax datasets because the Tax dataset is richer in semantics. FIG. 8I shows the results for Top-40 DCs given a fixed ∈=0.6% while varying the number of tuples. It can be seen that c is independent of the database size.


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.














TABLE 8







Dataset
th = 0.85
th = 0.75
th = 0.65









Tax
 1(1.0)
 3(1.0)
12(0.92)



Hospital
 0(N/A)
13(1.0)
28(0.74)



SP Stock
21(1.0)
23(1.0)
138(0.20) 










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.

Claims
  • 1. A computer implemented method of identifying denial constraints and correcting a database instance, the denial constraints being for use with a database schema R, the method comprising: generating candidate predicates using attributes of the database schema R;generating a predicate space P using the candidate predicates;determining a set of satisfied predicates using at least two tuples of the database instance, wherein the set of satisfied predicates are an evidence set;determining a minimal cover set for the satisfied predicates of the evidence set;deriving a set of valid denial constraints using the minimal cover set and inverse satisfied predicates for the minimal cover set; andcorrecting the database instance using the derived set of valid denial constraints.
  • 2. The method according to claim 1, wherein generating the predicate space P comprises: for each attribute in the schema R, adding equality predicates describing equality and inequality between two tuples of the database instance I 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 pairswherein the joinable columns are columns comprising pairs of attributes of R which are equality predicates; andwherein the comparable columns are columns comprising pairs of attributes of R which are order predicates (>, ≦, <, ≧).
  • 3. The method according to claim 1,
  • 4. The method according to claim 1, wherein the evidence set EviI, wherein EviI is the evidence set, is generated using the algorithm:
  • 5. The method according claim 1, wherein the method further comprises dividing the space of the valid denial constraints into a plurality of subspaces that each comprise a first predicate P1.
  • 6. The method according to claim 1, wherein the method further comprises dividing the space of the valid denial constraints into a plurality of subspaces that each comprise a first predicate P1; and dividing the plurality of subspaces into a plurality of further subspaces that each comprise a second predicate P2.
  • 7. The method according to claim 1, wherein the method further comprises ordering the valid denial constraints in a taxonomy tree according to the predicates in each denial constraint.
  • 8. The method according to claim 1, wherein the method further comprises ordering the valid denial constraints in a taxonomy tree according to the predicates in each denial constraint; and searching for denial constraints by searching the taxonomy tree from the bottom-up.
  • 9. The method according to claim 1, wherein the method further comprises ordering the valid denial constraints in a taxonomy tree according to the predicates in each denial constraint; searching for denial constraints by searching the taxonomy tree from the bottom-up; andpruning 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.
  • 10. The method according to claim 1, wherein the method further comprises providing a scoring function to provide a ranking of discovered denial constraints.
  • 11. The method according to claim 1, wherein the method further comprises providing a scoring function to provide a ranking of discovered denial constraints; and the scoring function comprises assigning an interestingness score Inter(φ) to each denial constraint φ, the score Inter(φ) being a weighted combination of succinctness and coverage of each denial constraint φ.
  • 12. The method according to claim 1, wherein a U-Precision metric is provided which identifies whether a denial constraint is schema-conforming:
  • 13. The method according to claim 1, wherein the method further comprises providing a scoring function to provide a ranking of discovered denial constraints; the scoring function comprises assigning an interestingness score Inter(φ) to each denial constraint φ, the score Inter(φ) being a weighted combination of succinctness and coverage of each denial constraint φ; andwherein the succinctness is defined as:
  • 14. The method according to claim 1, wherein the method further comprises providing a scoring function to provide a ranking of discovered denial constraints; the scoring function comprises assigning an interestingness score Inter(φ) to each denial constraint φ, the score Inter(φ) being a weighted combination of succinctness and coverage of each denial constraint φ; andwherein the coverage is defined as:
  • 15. The method according to claim 1, wherein, 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 ∈.
  • 16. A system operable to identify denial constraints and correct a database instance, the denial constraints being for use with a database schema R, the system comprising: a mechanism operable to generate candidate predicates using attributes of the database schema R and a predicate space P for an instance I in the schema R using the generated candidate predicates;a mechanism operable to determine a set of satisfied predicates using at least two tuples of the database instance I, wherein the satisfied predicates are an evidence set;a mechanism operable to identify a minimal set of predicates for the evidence set, and to identify valid denial constraints from the minimal set by inverting the predicates in the minimal set; anda mechanism to correct the database instance I using the identified denial constraints.
  • 17. The method according to claim 1, wherein the method further comprises providing a scoring function to provide a ranking of discovered denial constraints; the scoring function comprises assigning an interestingness score Inter(φ) to each denial constraint φ, the score Inter(φ) being a weighted combination of succinctness and coverage of each denial constraint φ;wherein the succinctness is defined as:
CROSS-REFERENCE TO RELATED APPLICATIONS

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.

PCT Information
Filing Document Filing Date Country Kind
PCT/EP2013/061326 5/31/2013 WO 00