This application claims foreign priority under 35 U.S.C. §119(a)-(d) to Application No. EP 10176677 filed on 14 Sep. 2010, entitled “Method and Arrangement for Handling Data Sets, Data Processing Program and Computer Program Product,” the entire contents of which are hereby incorporated by reference.
The present invention relates in general to the field of data management, and in particular to a method and an arrangement or system for handling data sets. Still more particularly, the present invention relates to a data processing program and a computer program product for handling data sets.
A challenge in data integration projects is always the quantity of data sources that need to be understood. Enterprise information technology (IT) applications usually involve the use of several thousands of tables, each of these tables containing up to several hundreds of columns. The meaning and semantic of each of these columns is often not documented and it is a tedious but indispensable task to understand the data before the integration work can begin.
To facilitate this task, data understanding tools, such as IBM® InfoSphere® Information Analyzer have been invented to help the user understand and document the data sources by looking directly at the data contained in these sources. (IBM and InfoSphere are trademarks of International Business Machines Corporation, registered in many jurisdictions worldwide.)
Common features of such tools are to compute general statistics for each analyzed column, such as cardinality of the column, minimum/maximum values, most frequent value, etc., value distributions showing the user what different values are contained in a single column and how frequent the different values are, format analysis showing the user what different formats are used by the values of the columns, for instance a ZIP code being represented in 60% of the cases as a five digits value and in 40% of the cases as a five digits value followed by a four digits value, inferred types showing the user what type is really used by the values of the columns, independently from the data type of the column as defined in the metadata of the database, for instance a character based column may contain only numeric values coded as strings, and basic data classification, like for example the column contains free text, numbers or codes.
Advanced data profiling tools, such as the above mentioned Information Analyzer product additionally allow the use of specialized algorithms to detect specific domains from the data of a column. For instance, by using regular expressions or a dictionary of values, such algorithms may be able to detect that a column contains a ZIP code, a US address, a person name, an email address, a phone number, etc.
This ability to classify columns based on the values they contain is important since it documents a cryptic physical source with semantic information and facilitates its mapping to a business term or a logical model, which is well understood by the user. However in the state of the art, the algorithms used to classify the data are specific to the domain. For classical domains, such as US addresses, person names, etc. specialized algorithms are delivered out of the box. However for domains which are specific to a company like product references, enterprise codes, ticket reports, etc. or are not common like a postal code in Belgium, for example, new algorithms have to be written for the particular domain and plugged in the tool. Since the development of such algorithms requires special knowledge, the users usually have to classify a large part of their data manually, by looking at the data and using expert knowledge to recognize the domain. This is a time consuming operation, since the data of each individual column must be evaluated manually, even if the semantic of the column is used by different columns.
Accordingly, in embodiments of the present invention a method, system and computer program product are provided for handling data sets, which comprise Providing a first characteristic associated with a first data set and at least one of the following: A single data value and a second characteristic associated with a second data set; the provided characteristics allowing feasible comparison of the first data set, the second data set and the single data value, and calculating at least one of the following: Similarity of the first data set with the second data set based on the first and second characteristics, similarity of the first data set with the single data value based on the first characteristic and the single data value, confidence indicating how well the first characteristic reflects properties of the first data set based on the first characteristic, and confidence indicating how well the similarity of the first data set with the single data value reflects properties of the single data value based on the first characteristic and the single data value.
A preferred embodiment of the present invention, as described in detail below, is shown in the drawings, in which
Embodiments of the present invention provide methods, systems, and computer program products which facilitate the classification of data in any domain without requiring the use of specialized algorithms. Further, embodiments of the present invention facilitate the automatic detection of values which are incompatible to the domain of the corresponding data set in a way which is domain independent.
Therefore embodiments of the present invention evaluate the quality of the data to integrate in a data integration project. When data have been entered by a human, for example from an input mask filled by an operator in a call center, it quite often happens, that data values entered in a specific column don't correspond to the domain of the column. A common example is when an email address is entered by the operator in a field that should contain a phone number, because the phone number is not available but the application requires a value for this field. Another example is when people enter a random combination of characters or simply a “-” in a mandatory field because they don't know what to fill or don't have the correct value, etc. To evaluate the quality of the data and correct those data values before they get loaded into a new target system, it is important to understand what common types of invalid values each column may contain and detect those invalid values.
In the state of the art this problem is used by using data profiling tools such as the above mentioned Information Analyzer, which computes for each column value distributions and format distributions and allow the user to define what a valid/invalid value/format is. The tool only supports the user by displaying and describing the data. The user has to decide manually which values are valid and which values are invalid for the given column. After that, the tool is able to find all rows where the value of the specified column doesn't fulfill the criteria defined by the user. This approach is very time consuming as it requires the user to review each column and define one or multiple validity criteria for the column's values. Besides that, it is very difficult for this mechanism to handle certain types of columns. It is for instance easy but time consuming to define for a column containing a limited set of categorical values, for example a column gender may only have two different values: “M”, and “F”, by specifying explicitly what the valid values are or not. It is also feasible but time consuming to define for a column containing values following a specific format, such as ZIP codes, SSN numbers, phone numbers, email addresses, a regular expression that will validate whether each value belongs to the domain of the column or not. It is on the other side difficult and rather impossible to define such rules for a column containing non structured or non standardized data, such as person names, company names, or any type of data containing unique values and non repeatable formats.
A core idea of the present invention is to compute automatically for each data set characteristics so called “fingerprints” characterizing the class of data contained in the corresponding data set, e.g. a column. Such a fingerprint is made up of several metrics capturing different aspects of the data. Each metric composing the fingerprint is computed using a corresponding metric algorithm. Details on suggested metrics are explained later in this disclosure, but examples of metrics can be a metric measuring the frequency of each character or combination of characters in all the data values of the data set, a metric measuring the most frequent terms or formats in the data values of the data set, a metric measuring diverse statistics like average length, percentage of letters or digits, etc. for the data values of the data set etc. Also new metric algorithms can be added to the system because the “fingerprint concept” is not dependent on specific metric algorithms. Each metric algorithm used should provide methods allowing the quick computation of a similarity score between a data set and a metric algorithm of same type belonging to another data set to decide, if these two data sets contain similar data values, and a similarity score between a data set and a single data value to decide, if this data value could belong to this data set.
Some of the metric algorithms may be more or less relevant depending on the type of data in the data set. For example, a metric algorithm capturing the most frequent formats is not very representative for a data set containing data with a very high number of formats, for example an address field, but is on the other side very relevant for a data set containing values having a constant format, for instance a ZIP code. For this reason, each metric algorithm should provide methods to compute the confidence of the metric algorithm for the data set it belongs to. So metric algorithms used by embodiments of the present invention allow quick computation of a similarity score between two fingerprints belonging to two different data sets or between a fingerprint and one single data value.
When comparing two fingerprints of two data sets, a low score indicates no domain matching between the two data sets. So the two data sets contain data that look different. A score close to 100% indicates a domain matching between the two data sets. So the two data sets are likely to contain data of same type, because the data presents similar characteristics.
When comparing a fingerprint with a single data value, a low score indicates that the value doesn't match well in the domain of the data set. A value close to 100% indicates that the value is consistent with the domain of the values of the data set owning the fingerprint. To compare a single data value with the fingerprint of a data set the metric algorithms used to determine the fingerprint of the data set are also used to determine a corresponding fingerprint of the single data value.
When analyzing the data sets, there is a time expensive effort to compute the fingerprint of each data set. Once computed, this fingerprint can be serialized and attached to the metadata of the analyzed data set and easily retrieved. The operation to compare two fingerprints with each other or one fingerprint with a data value are in comparison cheap, so that a large number of pairs of columns can be compared with each others in a short time.
Once fingerprints have been computed for each data set, what is done during the data analysis operation, and stored in a metadata repository, a data profiling tool like the above mentioned Information Analyzer can use these fingerprints to provide a semi automatic way of classifying data.
Like in the prior art, the user would have first to look at a few data values of the data set and set the data class for this data set manually, but each time the data class of a data set is defined, embodiments of the present invention can use the precomputed fingerprints to find all the other data sets that have similar fingerprints like the reviewed data set. Based on that, embodiments of the present invention can set automatically the data class of all non reviewed data sets whose similarity exceeds a defined threshold, or it can use this information to suggest a data class to the user, when the user wants to define the domain of a new data set, based on the similarity with a data set whose domain is already known.
This semi automatic process accelerates a lot the reviewing work of the user. Even if the user starts with a system where no data set has a defined domain, the user doesn't have to deeply inspect the values of each individual data set. Instead the user only needs to do that for a few data values of a few data sets. Embodiments of the present invention find then the similarities with the non reviewed data sets. In a data migration process, for example in the context of a consolidation of several legacy systems into a new system, where the data of an unknown system have to be moved to a known system, the data class of the data sets of the target systems are all known. In that case the process of guessing the domain of each source data set wouldn't require the user to analyze manually a small core of data values first, because the target system contains enough examples.
The fingerprints also allow automatic detection of data values which do not fit in the domain of a corresponding data set. All single data values of a data set can be compared to the data set's fingerprint. The fingerprint produces then for each single data value a score which can be used to sort the data values. The data values with the lowest scores are data values which might not fit in the domain of the data set and require a manual review.
Such fingerprints can also be used to solve other problems, such as detect mapping candidates in a data transformation.
The above, as well as additional purposes, features, and advantages of the present invention will become apparent in the following detailed written description.
Referring to
Still referring to
If the first data set 12 is to be compared with the single data value 12′ in Block 20 instead of metric values 1422, 1424, 1426, 1428 of the second data set 14 corresponding metric values 12′22, 12′24, 12′26, 12′28 of the single data value 12′ will be calculated by the metric algorithms 22, 24, 26, 28 used to calculate the first characteristic 20.1 of the first data set 12. This is generally done in connection with comparison and not during preprocessing. The metric algorithms 22, 24, 26, 28 provide in addition to corresponding metric values 1222, 1224, 1226, 1228, 12′22, 12′24, 12′26, 12′28, 1422, 1424, 1426, 1428 at least one similarity value 42, 44 and at least one confidence value 44, 48 based on the metric values 1222, 1224, 1226, 1228, 12′22, 12′24, 12′26, 12′28, 1422, 1424, 1426, 1428. Each metric algorithm 22, 24, 26, 28 uses a first similarity function 32 of a comparison unit 30 to calculate a first similarity value 42 based on the metric values 1222, 1224, 1226, 1228 of the first data set 12 and the metric values 1422, 1424, 1426, 1428 of a same metric algorithm 22, 24, 26, 28 applied to the second data set 14, and a first confidence function 34 of the comparison unit 30 to calculate a first confidence value 44 indicating how well the corresponding metric algorithm 22, 24, 26, 28 reflects properties of the first data set 12 based on the metric values 1222, 1224, 1226, 1228 of the first data set 12.
Further, each metric algorithm uses a second similarity function 36, shown in dashed lines, of the comparison unit 30 to calculate a second similarity value 46 based on the metric values 1222, 1224, 1226, 1228 of the first data set 12 and the metric values 12′22, 12′24, 12′26, 12′28 of the same metric algorithms 22, 24, 26, 28 applied to the single data value 12′, and a second confidence function 38, also shown in dashed lines, of the comparison unit 30 to calculate a second confidence value 48 indicating how well the metric algorithms 22, 24, 26, 28 of the first data set 12, 14, 16, 18 reflects properties of the single data value 12′ based on the metric values 1222, 1224, 1226, 1228, 12′22, 12′24, 12′26, 12′28 of the first data set 12 and the single data value 12′. The first and second similarity value 42, 46 and the first and second confidence value 44, 48 are part of a comparison result 40 generated by the comparison unit 30. In other words, the similarity is a function of two data sets 12, 14 or one data set 12 and a single data value 12′. Specifically, the similarity is one of a function of two sets of metric values each determined for one corresponding data set or a function of two sets of metric values, one set determined for a data set and one set determined for a single data value. The whole data set is typically not available anymore at the time the similarity is computed, but only the metric values are. The confidence is a function of the metric algorithm itself to indicate how significant the metric algorithm is for the data set on which it was computed. When comparing two data sets, the confidence is only a function of the metric values of the first data set and is therefore “precomputed”. So once the metric values are precomputed, the confidence is known. In the case of the comparison of a single data value with a data set, the confidence is a function of the metric values of the data set and the metric values of the single data value. Then the confidence is not precomputed anymore, but may differ for each tested single data value.
The characteristics 20.1, 20.2 or fingerprints are logical containers for one or multiple metric values. Technically, fingerprints are computed by passing all the data values of the data sets 12, 14 successively through all metric algorithms composing the corresponding fingerprint. Each characteristic 20.1, 20.2 uses its own metric algorithms 22, 24, 26, 28 to compute the metric results. Once all data values have been analyzed by all metric algorithms 22, 24, 26, 28, all metric results are serialized in one entity which represents the serialized form of the fingerprint and can be stored in a metadata repository or attached to the metadata of the analyzed data sets 12, 14. Any serialization format can be used. In a preferred embodiment an XML format may be used, but the format itself is not important for the present invention.
Referring to
Still referring to
A fingerprint 20.1, 20.2, 20.3, 20.4 contains one or multiple metrics, represented by an abstract metric class. Each metric specialized by a subclass of the abstract metric class provides four functions. The first similarity function 32 is returning a similarity score 42 between a metric value 1222, 1224, 1226, 1228, 1422, 1424, 1426, 1428, 1622, 1624, 1626, 1822, 1824, 1826 and another metric value 1222, 1224, 1226, 1228, 1422, 1424, 1426, 1428, 1622, 1624, 1626, 1822, 1824, 1826 of same type from another fingerprint 20.1, 20.2, 20.3, 20.4. The first confidence function 34 is returning a confidence value 44 of the metric for the data set 12, 14, 16, 18 it has been computed for. The confidence value 44 is a value between 0.0 and 1.0 indicating how good the similarity score 42 returned by this metric can be trusted for the type of data contained in the data set 12, 14, 16, 18 owning the fingerprint 20.1, 20.2, 20.3, 20.4. The second similarity function 36 is returning a similarity score 46 indicating how good a single value fits in the metric computed for the whole data set 12, 14, 16, 18. The second confidence function 38 is returning the confidence value 48 of the result returned by the second similarity function 36.
The similarity and confidence functions 32, 34, 36, 38 are generally not symmetrical. That means that computing similarity between two data sets 12, 14 by using the metric values of the first data set 12 as reference will return a slightly different value as computing similarity between the two data sets 12, 14 by using the metric values of the second data set 14 as reference. The same is true for the confidence functions 34, 38. Normally, even if the results differ when switching the reference and compared metric, this difference is small enough that it doesn't matter which one is used as a reference. As an alternative, it could be safer but longer to compute the similarity between two data sets 12, 14 with reference to the first data set 12 and then the similarity between the two data sets 12, 14 with reference to the second data set 14 and then determine and return an average value of the two results. In the described embodiments the first confidence value 44 relates to the first data set 12 as reference data set only, since the confidence used when comparing two data sets is only a function of the reference data set. Alternatively a more complex algorithm for computing the confidence dynamically based on the metric values of both data sets 12, 14 may be used. But during tests, it appeared that considering only the reference data set to compute the confidence gave results that were good enough, so that a more complex algorithm was not justified.
Furthermore, when two data sets 12, 14 are compared just one data set may be arbitrarily chosen as being the reference data set, here called first data set/metric, and the other one as being the compared data set, here called a second data set/metric. The weights are the confidence values of the reference data set. A more precise computation would be to compute the result first with the first data set being the reference and compute the same again with the second data set being the reference and return the final result as being an average of both.
Equations (1) and (2) show exemplary formulas used to compute the similarity scores between two fingerprints 20.1, 20.2, 20.3, 20.4 or between a fingerprint 20.1, 20.2, 20.3, 20.4 and a single data value, based on the results of the metric algorithms 22, 24, 26, 28.
The similarity between two fingerprints 20.1, 20.2, 20.3, 20.4 is computed as being a weighted average of the results of the first similarity function 32 or the second similarity function 36 of the metrics they have in common. The weight used for each metric is its confidence value calculated by the corresponding confidence functions 34, 38. In Equation (1) Similarity1 represents the similarity of the fingerprint of a second data set when compared to the fingerprint of a first or reference data set, Confidence (Metrici,dataset1) the computed is confidence of the metric i for a data set 1.
Similarity (Metrici,col1, Metrici,col2) represents the similarity between the metric i for the data set 1 and the same metric i for a data set 2. The iteration in Equation (1) is done for all pairs of metrics which exist in both fingerprints.
The similarity between the fingerprint of one data set and a data value is computed in a similar way, but by applying the second similarity function 36 and the second confidence function 38 of the metrics.
In the following four different metrics algorithms 22, 24, 26, 28 will be explained used in the preferred embodiment of the present invention.
The idea of the bigram metric algorithm 28 is based on the fact that in data containing human readable values the frequency of the combinations of letters are not equally distributed, wherein values are composed of words, names, or anything based on a human language. For example, in the English language the letter E is much more frequently used in texts as the letter Z. By looking at bigrams, which represent a combination of two letters, some combinations are quite frequent, for example, a letter “Q” is in English most of the time followed by a letter “U”, some others are improbable, for example a letter “Q” followed by another letter “Q”. This table of frequencies for all possible bigrams is representative for the domain represented by the corresponding data set 12, 14. A data set 12, 14 containing free text values based on the English language, for instance addresses, person names, company names, etc. will have a bigrams table which is characteristic for the English language. A data set containing values in the German language will have a slightly different bigrams table. A data set containing codes which are not based on a natural language will have a completely different table. To calculate such a bigram table all characters of a corresponding text value are converted in upper case. Special characters like “@, -, *” and numbers are removed, wherein blanks are not ignored. Then a sliding window of two character lengths is moved over the remaining string, a matrix of all possible bigrams is generated and the frequency for each appearing bigram is counted. When all content is processed the probability of occurrence for each bigram is calculated.
In
Equation (3) shows an exemplary formula used to compute the similarity score between data sets 12, 14 based on the results of the bigram metric algorithm 28.
To compute the similarity between two bigram metrics of two different data sets 12, 14 the bigram tables 1228, 1428 for the two data sets 12, 14 are loaded. Then all values of the matrices are taken as a long sequence of numbers, one sequence of frequencies for each matrix. Next the correlation between those two series of frequencies is calculated. If the correlation is positive, it is returned as being the similarity score. If it is negative, the similarity score is considered to be 0. The more similar the matrices are the closer to 100% the correlation and therefore the similarity score will be.
Equation (4) shows an exemplary formula used to compute the confidence of the bigram metric algorithm 28. The bigram metric algorithm 28 is representative for values containing free text and less representative for bigrams patterns, and useless for values that would be randomly distributed. In the preferred embodiment the percentage of cells in the matrix having a frequency above 0 is calculated as a confidence. That way the bigram metric algorithm 28 has a strong confidence for free text columns where all bigrams are represented and a lower confidence for columns where the number and diversity of values was not high enough to populate the whole matrix.
Where f(Metriccol1(row, col))=0, if Metriccol1(row, col)=0 or f(Metriccol1(row, col))=1, if Metriccol1(row, col)>0.
To compute the similarity between a bigram metric and one single data value the bigram matrix must be normalized so that the maximum frequency in each column is normalized to 100%. Equation (5) shows the formula for the normalization. Each cell in the matrix is divided by the maximum frequency found in the same column.
Then all bigrams from the single data value to compare are extracted and the value for each of these bigrams is looked up in the normalized matrix. According to equation (6) an average is computed for all bigrams found in the single data value.
Finally the score obtained by using equation (6) has to be transformed so that scores above 0.4 give a similarity close to 1. The transformation function used in the preferred embodiment is shown in equation (7).
Alternatively the same method could be used with monograms or trigrams or n-grams in general.
The most frequent words metric algorithm 26 computes the list of the most frequently recurring words found in all data values of the analyzed data set 12, 14, 16, 18. It is a quite effective metric to detect similarities in data sets 12, 14, 16, 18 using recurring words. For example data sets 12, 14, 16, 18 containing post addresses are likely to have recurring words like “Street”, “Avenue”, “city names”, etc. Data sets 12, 14, 16, 18 containing person name are likely to have recurring first and last names.
Equations (8) and (9) show the formulas used to compute the similarity and confidence for this most frequent words metric algorithm 26 in the preferred embodiment.
Where c is a constant, for instance
To compute the similarity between the results of two most frequent words metrics 26, a Euclidean distance between the frequencies of the top N words in the first metric with the frequencies of the same words in the second metric is calculated. Additionally, the frequencies of all other words, i.e., words not belonging to the top N list, are taken as a further dimension. The formula to compute the distance dist is represented by equation (8), for example. Then the distance dist is transferred into a score between 0.0 and 1.0 by using a transformation function as represented by equation (9), for example. The confidence of the metric is the percentage of values in the data set 12, 14, 16, 18 owning the metric, for which at least one word is part of the top N words captured by the metric. Equation (10) shows the formula to compute the confidence for the most frequent words metric 26.
Where f(value(i))=0, if value (i) is not in the list of the top N most frequent words of the metric, or f(value(i)=1, if value (i) is in the list of the top N most frequent words of the metric.
The similarity between a single data value and most frequent words metric is computed a bit differently. In the preferred embodiment, a binary similarity is either 0.0 if no word of the single data value is in the top N most frequent words of the metric, and 1.0 if at least one word is in the list. The confidence is computed by summing the frequencies in the top N words metric of all the words composing the single data value.
Once the values are transformed into their format mask, a similar technique as for the most frequent words metric 26 is used to compute the top N most frequent formats. Like for the most frequent words metric 26, the similarity between two most frequent formats metrics 24 is computed by using a Euclidean distance represented by equation (11) and using a transformation function represented by equation (12).
Where c is a constant, for instance
The confidence of the metric is the sum of the frequencies of all formats captured by the most frequent formats metric 24. Equation (13) shows the formula to compute the confidence for the most frequent formats metric 24.
The similarity of a single data value with the most frequent formats metric 24 is here again binary. So the binary similarity is either 0.0 if the format of the single data value is in the top N most frequent formats of the metric 24, and 1.0 if the format is in the list. The confidence is simply the frequency of the format of the single data value in the metric.
The general statistics metric algorithm 22 is about collecting statistics about the data values contained in the analyzed data set 12, 14, 16, 18. The statistics which are collected in the preferred embodiment are an average length of the data values and its standard deviation, an average number of words in each data value and its standard deviation, an average percentage of letters in the data value and its standard deviation, and an average percentage of digits in the data value and its standard deviation. The similarity between two general statistics metrics is then the same as comparing two normal distributions for each four statistics listed previously.
Computing the similarity between a single data value and the general statistics metric 22 is done the same way. But instead of comparing two normal distributions with each other, a normal distribution is compared with a single data value, as shown in
The inventive method for handling data sets can be implemented as an entirely software embodiment, or an embodiment containing both hardware and software elements. In a preferred embodiment, the present invention is implemented in software, which includes but is not limited to firmware, resident software, microcode, etc.
Furthermore, the present invention can take the form of a computer program product accessible from a computer-usable or computer-readable medium providing program code for use by or in connection with a computer or any instruction execution system. For the purposes of this description, a computer-usable or computer-readable medium can be any apparatus that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device.
The medium can be an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system (or apparatus or device) or a propagation medium. Examples of a computer-readable medium include a semiconductor or solid state memory, magnetic tape, a removable computer diskette, a random access memory (RAM), a read-only memory (ROM), a rigid magnetic disk, and an optical disk. Current examples of optical disks include compact disk-read only memory (CD-ROM), compact disk-read/write (CD-R/W), and DVD. A data processing system suitable for storing and/or executing program code will include at least one processor coupled directly or indirectly to memory elements through a system bus. The memory elements can include local memory employed during actual execution of the program code, bulk storage, and cache memories which provide temporary storage of at least some program code in order to reduce the number of times code must be retrieved from bulk storage during execution. Input/output or I/O devices (including but not limited to keyboards, displays, pointing devices, etc.) can be coupled to the system either directly or through intervening I/O controllers.
Network adapters may also be coupled to the system to enable the data processing system to become coupled to other data processing systems or remote printers or storage devices through intervening private or public networks. Modems, cable modems, and Ethernet cards are just a few of the currently available types of network adapters.
Number | Date | Country | Kind |
---|---|---|---|
10176677 | Sep 2010 | EP | regional |
Number | Name | Date | Kind |
---|---|---|---|
5315709 | Alston et al. | May 1994 | A |
5392390 | Crozier | Feb 1995 | A |
5555346 | Gross | Sep 1996 | A |
5561793 | Bennett et al. | Oct 1996 | A |
5586025 | Tsuji | Dec 1996 | A |
5684990 | Boothby | Nov 1997 | A |
5729665 | Gauthier | Mar 1998 | A |
5761671 | Blackman et al. | Jun 1998 | A |
5802253 | Gross | Sep 1998 | A |
5943676 | Boothby | Aug 1999 | A |
5966717 | Sass | Oct 1999 | A |
6029160 | Cabrera et al. | Feb 2000 | A |
6044381 | Boothby et al. | Mar 2000 | A |
6076090 | Burroughs et al. | Jun 2000 | A |
6154748 | Gupta et al. | Nov 2000 | A |
6230157 | Malcolm et al. | May 2001 | B1 |
6279008 | Ng et al. | Aug 2001 | B1 |
6301584 | Ranger | Oct 2001 | B1 |
6408302 | Lee et al. | Jun 2002 | B1 |
6460048 | Teng et al. | Oct 2002 | B1 |
6496835 | Liu et al. | Dec 2002 | B2 |
6609133 | Ng et al. | Aug 2003 | B2 |
7039898 | Shah | May 2006 | B2 |
7043492 | Neal | May 2006 | B1 |
7069269 | Morris | Jun 2006 | B2 |
7080088 | Lau | Jul 2006 | B1 |
7136852 | Sterling et al. | Nov 2006 | B1 |
7437471 | Hohmann | Oct 2008 | B2 |
7472346 | Baelen | Dec 2008 | B2 |
7536409 | Barcia | May 2009 | B2 |
7657506 | Levin | Feb 2010 | B2 |
7797289 | Chan et al. | Sep 2010 | B2 |
7814045 | Hermann et al. | Oct 2010 | B2 |
7921110 | Ting et al. | Apr 2011 | B1 |
7958162 | Basile | Jun 2011 | B2 |
8266168 | Bayliss | Sep 2012 | B2 |
20010014890 | Liu et al. | Aug 2001 | A1 |
20020007482 | Cime | Jan 2002 | A1 |
20020089681 | Gauthier | Jul 2002 | A1 |
20020143761 | Shimano | Oct 2002 | A1 |
20020143818 | Roberts | Oct 2002 | A1 |
20030225742 | Tenner et al. | Dec 2003 | A1 |
20040083199 | Govindugari et al. | Apr 2004 | A1 |
20050050068 | Vaschillo et al. | Mar 2005 | A1 |
20050091640 | McCollum | Apr 2005 | A1 |
20050131771 | Tischer | Jun 2005 | A1 |
20050182777 | Block et al. | Aug 2005 | A1 |
20050197931 | Gupta | Sep 2005 | A1 |
20050262113 | Arora et al. | Nov 2005 | A1 |
20050283486 | Lauterbach et al. | Dec 2005 | A1 |
20060026127 | Bodlaender | Feb 2006 | A1 |
20060101423 | Aharoni et al. | May 2006 | A1 |
20060230025 | Baelen | Oct 2006 | A1 |
20060242181 | Mueller-Klingspor | Oct 2006 | A1 |
20070112827 | Dettinger | May 2007 | A1 |
20070198910 | Jensen | Aug 2007 | A1 |
20080140602 | Roth et al. | Jun 2008 | A1 |
20080177731 | Matsuzaki | Jul 2008 | A1 |
20080201172 | McNamar | Aug 2008 | A1 |
20080208855 | Lingenfelder et al. | Aug 2008 | A1 |
20080275829 | Stull et al. | Nov 2008 | A1 |
20080319983 | Meadows | Dec 2008 | A1 |
20090006282 | Roth et al. | Jan 2009 | A1 |
20090006283 | Labrie et al. | Jan 2009 | A1 |
20090006472 | Bush et al. | Jan 2009 | A1 |
20090019358 | Blake | Jan 2009 | A1 |
20090024551 | Agrawal et al. | Jan 2009 | A1 |
20090030754 | McNamar | Jan 2009 | A1 |
20090037488 | Abrams | Feb 2009 | A1 |
20090138789 | Tangen et al. | May 2009 | A1 |
20090287923 | Topalov et al. | Nov 2009 | A1 |
20100131526 | Sun et al. | May 2010 | A1 |
20110178971 | Meeks et al. | Jul 2011 | A1 |
20110196621 | Huyse et al. | Aug 2011 | A1 |
20110225173 | Gulhane et al. | Sep 2011 | A1 |
20120095970 | Shyam et al. | Apr 2012 | A1 |
20120096434 | Rama | Apr 2012 | A1 |
20120158625 | Nelke et al. | Jun 2012 | A1 |
20120158678 | McGraw et al. | Jun 2012 | A1 |
20120197836 | Meeks et al. | Aug 2012 | A1 |
20120216274 | Chauhan et al. | Aug 2012 | A1 |
20120254739 | Dehmann et al. | Oct 2012 | A1 |
20120330911 | Gruenheid et al. | Dec 2012 | A1 |
20130031117 | Mandelstein et al. | Jan 2013 | A1 |
Number | Date | Country |
---|---|---|
0513653 | Nov 1992 | EP |
1798684 | Jun 2007 | EP |
2007279852 | Oct 2007 | JP |
0062191 | Oct 2000 | WO |
Entry |
---|
Koch et al., “Policy Definition Language for Automated Management of Distributed Systems”, (1996) IEEE 2nd Int'l of Distrib. Sys., pp. 55-64. |
Computer Associates International et al., Chapters 7-9 “Truth Maintenance”, Computer Associates International, Inc., 70 pages, Jan. 1, 2004. |
PCT International Search Report and Written Opinion, PCT/EP2011/069332, Jan. 5, 2012, 12 pages. |
Wolfgang May, “A Database-Based Service for Handling Logical Variable Bindings”, Institut fur Informatik, Universitat Gottingen, Germany, 14 pages, Jan. 1, 2009. |
Computer Associates International et al., CleverPath Avion Business Rules Expert, Computer Associates International, Inc., 64 pages, Jan. 1, 2004. |
Computer Associates International et al., Chapter 5 “Pattern Matching, Pattern Matching Rules”, Computer Associates International, Inc., 36 pages, Jan. 1, 2004. |
Computer Associates International et al., Chapter 7 “Truth Maintenance, Truth Maintenance Operations and Terminology”, and Chapter 8 Maintaining the Dynamic Rulebase, Computer Associates International, Inc., 12 pages, Jan. 1, 2004. |
http://www.xbrl.org/TaxonomyRecognition/US%20GAAP%202009/XBRLUS-USGAAP, “XBRL US Country Taxonomy 2009”, pp. 1-2. |
http://www.xbrl.org/TaxonomyRecognition/US%20GAAP%202009/XBRLUS-USGAAP, “XBRL US Accountants' Report Taxonomy 2009”, pp. 1-2. |
http://www.xbrl.org/TaxonomyRecognition/US%20GAAP%202009/XBRLUS-USGAAP, “XBRL US GAAP Taxonomy 2009”, pp. 1-2. |
http://www.w3.org/TR/owl-parsing/ “OWL Web Ontology Language Parsing OWL in RDF/XML”, W3C Working Group Note Jan. 21, 2004, pp. 1-20. |
Pauvel Shvaiko et al., “Ontology Matching OM-2009”, Papers from the ISWC Workshop, pp. 1-271. |
International Search Report and Written Opinion, PCT/EP2011/062074, Sep. 21, 2012, 16 pages. |
Mason B. McDaniel, “An Algorithm for Content-Based Automated File Type Recognition, Master Thesis”, James Madison University, www.forensicswiki.org/w/images/f/f9/Mcdaniel01.pdf Dec. 1, 2001, 105pages. |
International Search Report and Written Opinion, PCT/IB2012/053380, Nov. 15, 2012, 10 pages. |
“Legacy Data Encapsulator”, ip.com, Jun. 14, 2001, 3 pages. |
Number | Date | Country | |
---|---|---|---|
20120066214 A1 | Mar 2012 | US |