The present invention relates to a data processing method and system for knowledge management, and more particularly to a technique for determining a value of a merge of two ontologies.
An ontology is a representation of knowledge by a set of concepts and relationships between the concepts, where the knowledge is included within one or more software-based applications. Merging (i.e., associating) ontologies that address the same knowledge domain includes aligning the concepts and relationships of the schemas underlying the ontologies so as to create a mapping between the schemas. Merging ontologies that address different knowledge domains may include aligning the schemas underlying the ontologies by interacting with an end user and an upper reference ontology instead of a domain-specific ontology, or by ensuring that the schemas are built using the same method and the same reference ontology. When two schemas that are in the same domain or different domains are aligned, the schemas may be merged by connecting the concepts that are common to the two schemas. In the case of the schemas belonging to the same domain, a merge of the two schemas makes new structures (i.e., relationships) apparent, which completes the knowledge of the domain. In the case of the schemas belonging to different domains, the merge of the two schemas creates new cross-domain structures that do not exist in the individual schemas and that are potential sources of innovation.
In first embodiments, the present invention provides a method of determining a value of a bridge of a first ontology schema with a second ontology schema. The method includes the steps of:
a computer generating the bridge of the first ontology schema (S1) with the second ontology schema (S2) by identifying significant concepts included in S2, creating a sub-schema S based on the identified significant concepts, and importing the sub-schema S into S1 to complete a generation of the bridge of S1 with S2;
the computer extracting the sub-schema S from the bridge of S1 with S2;
the computer creating a schema S′ from sub-schema S by removing common concepts from S, removing from S relationships to the common concepts, and for each common concept to which first and second concepts have immediate links in S, the computer creating a new immediate link in S′ between the first and second concepts, the common concepts being concepts that S1 and S2 have in common;
the computer determining an intrinsic value of S′;
the computer determining a strength of a bridge of S1 with S; and
based on the intrinsic value of S′ and the strength of the bridge of S1 with S, the computer determining the value of the bridge of S1 with S2.
In second embodiments, the present invention provides a computer system including a central processing unit (CPU), a memory coupled to the CPU, and a computer-readable, tangible storage device coupled to the CPU. The storage device contains instructions that, when carried out by the CPU via the memory, implement a method of determining a value of a bridge of a first ontology schema with a second ontology schema. The method includes the steps of:
the computer system generating the bridge of the first ontology schema (S1) with the second ontology schema (S2) by identifying significant concepts included in S2, creating a sub-schema S based on the identified significant concepts, and importing the sub-schema S into S1 to complete a generation of the bridge of S1 with S2;
the computer system extracting the sub-schema S from the bridge of S1 with S2;
the computer system creating a schema S′ from sub-schema S by removing common concepts from S, removing from S relationships to the common concepts, and for each common concept to which first and second concepts have immediate links in S, the computer system creating a new immediate link in S′ between the first and second concepts, the common concepts being concepts that S1 and S2 have in common;
the computer system determining an intrinsic value of S′;
the computer system determining a strength of a bridge of S1 with S; and
based on the intrinsic value of S′ and the strength of the bridge of S1 with S, the computer system determining the value of the bridge of S1 with S2.
In third embodiments, the present invention provides a computer program product including a computer-readable, tangible storage device and computer-readable program instructions stored in the computer-readable, tangible storage device. The computer-readable program instructions, when carried out by a central processing unit (CPU) of a computer system, implement a method of determining a value of a bridge of a first ontology schema with a second ontology schema. The method includes the steps of:
the computer system generating the bridge of the first ontology schema (S1) with the second ontology schema (S2) by identifying significant concepts included in S2, creating a sub-schema S based on the identified significant concepts, and importing the sub-schema S into S1 to complete a generation of the bridge of S1 with S2;
the computer system extracting the sub-schema S from the bridge of S1 with S2;
the computer system creating a schema S′ from sub-schema S by removing common concepts from S, removing from S relationships to the common concepts, and for each common concept to which first and second concepts have immediate links in S, the computer system creating a new immediate link in S′ between the first and second concepts, the common concepts being concepts that S1 and S2 have in common;
the computer system determining an intrinsic value of S′;
the computer system determining a strength of a bridge of S1 with S; and
based on the intrinsic value of S′ and the strength of the bridge of S1 with S, the computer system determining the value of the bridge of S1 with S2.
In fourth embodiments, the present invention provides a process for supporting computing infrastructure. The process includes a first computer system providing at least one support service for at least one of creating, integrating, hosting, maintaining, and deploying computer-readable code in a second computer system. The computer-readable code contains instructions. The instructions, when carried out by a processor of the second computer system, implement a method of determining a value of a bridge of a first ontology schema with a second ontology schema. The method includes the steps of:
the second computer system generating the bridge of the first ontology schema (S1) with the second ontology schema (S2) by identifying significant concepts included in S2, creating a sub-schema S based on the identified significant concepts, and importing the sub-schema S into S1 to complete a generation of the bridge of S1 with S2;
the second computer system extracting the sub-schema S from the bridge of S1 with S2;
the second computer system creating a schema S′ from sub-schema S by removing common concepts from S, removing from S relationships to the common concepts, and for each common concept to which first and second concepts have immediate links in S, the second computer system creating a new immediate link in S′ between the first and second concepts, the common concepts being concepts that S1 and S2 have in common;
the second computer system determining an intrinsic value of S′;
the second computer system determining a strength of a bridge of S1 with S; and based on the intrinsic value of S′ and the strength of the bridge of S1 with S, the second computer system determining the value of the bridge of S1 with S2.
Embodiments of the present invention allow merges between ontologies to be ranked according to the richness of the associations between the schemas underlying the ontologies. By ranking the merges between ontologies, an end user or application may save time by focusing by priority on those merges that have the highest rankings. End users and applications that may become more efficient by focusing on higher ranked merges of ontologies include (1) a network of inventors who are attempting to solve a technical challenge with a solution from another discipline or another area of expertise; (2) an intelligent web navigation system that allows a user navigating on the web to be guided from one website to another website through associations between the ontologies representing the websites; and (3) a question and answer system in which an answer given by the system triggers new questions from a user.
Overview
When two ontologies are merged (i.e., the ontology schemas underlying the ontologies are merged), new relationships (i.e., new semantics) are formed, which can be sources of innovations when the merged ontology schemas are from different knowledge domains. Embodiments of the present invention determine a value of an association or merge between two ontology schemas. Two ontology schemas may be associated (i.e., merged) whenever the two ontology schemas have some common concepts (i.e., some concepts that are identical or similar between the two ontology schemas; also known as (a.k.a.) shared concepts). A merge of ontology schema S1 with ontology schema S2 includes an import into S1 of the chains of S2 concepts that are connected to the common concepts. These imported chains bring a set of new relationships and new concepts to S1. In one embodiment, the value of an association between two ontology schemas varies directly with the number of concepts imported to one of the ontology schemas and the number of new relationships created by the association.
The number of possible merges with a given ontology schema may be significant in a network or a collaboration environment involving many users (e.g., the network is the World Wide Web). Values of the merges may be determined based on a richness of associations between the given ontology schema and the other ontology schemas. The richness of an association depends on the new structures created by the merge. Using the values of the merges, the merges may be ranked; thereby allowing an end user or application to use less time to efficiently consider only higher ranked merges instead of taking a significant amount of time to consider all the merges, including the merges that have little or no value.
As used herein, an ontology schema is also referred to simply as a schema. As used herein, a value of an association between ontologies is a value of an association between the schemas underlying the ontologies. A value of an association between schemas S1 and S2 is determined by the addition of two values: (1) the value of a bridge of S1 with S2; and (2) the value of a bridge of S2 with S1. The value of the bridge of S1 with S2 is determined by performing the following steps: (1) creating a bridge of S1 with S2, which includes (a) identifying the common concepts shared between S1 and S2; (b) identifying in S2 the significant concepts that have a relationship with one or more of the identified common concepts (i.e., the concepts in S2 that have the most relevance to S1); and (c) importing the identified significant concepts into S1; (2) identifying the sub-schema that has been imported into S1; (3) computing an intrinsic value of the sub-schema based on a graph density (i.e., compactness of the sub-schema); (4) computing a strength of the bridge, based on the position and importance of the common concepts in the schemas S1 and S2; and (5) computing the value of the bridge based on the intrinsic value and strength of the bridge computed in (3) and (4), respectively. It should be noted that steps (a), (b) and (c) discussed above describe an operation “bridging S1 with S2,” which is a particular merge of S1 with a sub-schema of S2 that includes only the structures relevant to S1. The schema resulting from bridging S1 with S2 is referred to herein as the bridge of S1 with S2, or Bridge(S1,S2).
The value of the bridge of S2 with S1 is determined as described above in the steps (1)-(5), in the same way as the value of the bridge of S1 with S2 is determined, except that S1 is replaced with S2 and S2 is replaced with S1.
In one embodiment, the value of a bridge of a first ontology schema with a second ontology schema is determined so that the value depends on the strength of a bridge of the first ontology schema with an imported sub-schema. To take account of the position and importance of the common concepts in the two schemas, the strength of the bridge may be a summation, over each of the shared concepts, of the following quotient: the number of immediate links from the imported sub-schema to the shared concept divided by the distance of the shared concept to the first ontology schema. The distance of the shared concept to the first schema is the shortest distance between the shared concept and any of the concepts which have a maximum weight in the first schema. Therefore, the bridge is stronger (i.e., has more value) if the imported sub-schema is close to the central concepts of the first schema.
Although embodiments are described herein in terms of determining values and rankings of merges of ontologies or merges of ontology schemas underlying the ontologies, variations are contemplated in which values and rankings may be determined for semantic schemas. As used herein, a semantic schema is defined as a meta-schema that describes a universe of discourse of a software-based application or an end user. A semantic schema may be an ontology or a conceptual data model.
System for Determining a Value of an Association Between Ontologies
Computer systems 104-1 . . . 104-N run software-based collaboration interfaces 108-1 . . . 108-N, respectively, and include ontologies 110-1 . . . 110-N respectively. In one embodiment, computer network 106 provides a collaboration network among users, where each ontology of ontologies 110-1 . . . 110-N describes a universe of discourse of a corresponding user of the collaboration network, and where the users may utilize collaboration interfaces 108-1 . . . 108-N to share the ontologies 110-1 . . . 110-N via network 106.
In one embodiment, ontology schemas (not shown) underlying respective ontologies 110-1 . . . 110-N are aligned and each user who wants to benefit from the semantic capabilities of network 106 uses the same schema builder (not shown) to build the ontology schemas (e.g., using the same method and reference ontology as described in U.S. patent application Ser. No. 13/432,120 entitled “BUILDING AN ONTOLOGY BY TRANSFORMING COMPLEX TRIPLES.”
Ontologies 110-1 . . . 110-N may be specified respectively by N different ontology schemas, or two or more ontologies in ontologies 110-1 . . . 110-N may by specified by the same ontology schemas.
A collaboration network provided by network 106 may be specialized or non-specialized. For example, a specialized collaboration network may be a network of inventors who want to share their knowledge and questions in order to find innovative solutions to challenges, as described in U.S. patent application Ser. No. 12/916,456 (Attorney Docket No. GB920090029US1) entitled “IDENTIFYING COMMON DATA OBJECTS REPRESENTING SOLUTIONS TO A PROBLEM IN DIFFERENT DISCIPLINES.” As another example, the collaboration network may be a network of people collaborating in a project, a game, a social network, etc., where the people in the network want to discover possible associations between their universes of discourse or centers of interest. As an example of a non-specialized network, the network may be the World Wide Web itself, specifically the Semantic Web.
Computer system 102 runs a software-based association creation engine 112, which merges (i.e., associates) ontologies included in ontologies 110-1 . . . 110-N. In one embodiment, ontologies merged by association creation engine 112 enrich a collaboration provided by network 106. Computer system 102 also runs a value determination engine 114 for determining values of associations between ontologies, where the associations are created by association creation engine 112. The values determined by value determination engine 114 allow the collaboration networks provided by network 106 to save time by not considering a merge between ontologies where the merge has no value. In one embodiment, computer system 102 ranks associations between ontologies based on the values determined by value determination engine 114. The ranked associations may allow end users in a collaboration network to efficiently utilize their time by focusing only on the merges that have the highest ranks
The functionality of the components shown in
Process for Determining a Value of an Association Between Ontologies
The creation of Bridge(S1,S2) in step 202 includes identifying concepts that S1 and S2 have in common, identifying significant concepts in S2, creating a sub-schema S of S2 based on the significant concepts, and importing S into S1. Creating Bridge(S1,S2) is described in more detail below in the discussion of
In step 204, value determination engine 114 (see
In step 206, value determination engine 114 (see
In another embodiment, a user using collaboration interface 108-1 (see
In step 208, value determination engine 114 (see
In one embodiment, a user utilizes collaboration interface 108-1 (see
In one embodiment, by default, value determination engine 114 (see
In step 210, value determination engine 114 (see
In one embodiment, a user utilizes collaboration interface 108-1 (see
In one embodiment, by default, value determination engine 114 (see
In step 212, value determination engine 114 (see
In one embodiment, a user utilizes collaboration interface 108-1 (see
In one embodiment, by default, value determination engine 114 (see
In one embodiment, by default, value determination engine 114 (see
In step 214, value determination engine 114 (see
The process of
In one embodiment, the process of
Embodiments of the present invention do not import all concepts of ontology schema S2 into ontology schema S1; instead value determination engine 114 (see
In one embodiment, an end user defines what concepts in S2 are significant and the value determination engine 114 (see
In one embodiment, by default, value determination engine 114 (see
In step 306, value determination engine 114 (see
In step 308, value determination engine 114 (see
After performing step 308, the function Bridge(S1,S2) has been built if there exists any non-common concept in ontology schema S2 that is more significant that the significance threshold; otherwise, the function Bridge(S1,S2) has not been built. In the case in which the function Bridge(S1,S2) has not been built after performing step 308, the bridge of S1 with S2 is considered to be not valuable.
The process of
In an alternate embodiment, an end user provides the significance(C1) function by utilizing collaboration interface 108-1 (see
In one embodiment, by default, value determination engine 114 (see
The value determination engine 114 (see
In one embodiment, value determination engine 114 (see
In one embodiment, by default, value determination engine 114 (see
In one embodiment, by default, value determination engine 114 (see
In one embodiment, by default, value determination engine 114 (see
In step 404, value determination engine 114 (see
In step 406, for every concept Ci that is in ontology schema S2 and that is in the common concepts identified in step 302 (see
In step 408, for every concept Ci that is in ontology schema S2 and that is not in the common concepts identified in step 302 (see
The process of
By using the significance function and the significance threshold in the steps of
In step 504, value determination engine 114 (see
In step 506, for every concept Ci in {Cc}, value determination engine 114 (see
The process of
In step 602, value determination engine 114 (see
In step 604, value determination engine 114 (see
Compactness(S′)=Num_of_links(S)/(n*(n−1)/2), where Num_of_links(S′) represents the number of immediate links found in S′, where (n*(n−1)/2) is the total number of possible immediate links between the n concepts in S′, and where an immediate link is a link between two concepts through a chain of exactly one relationship.
In another embodiment, value determination engine 114 (see
In step 606, value determination engine 114 (see
In step 608, value determination engine 114 (see
In one embodiment, an end user has an option in step 608 to utilize collaboration interface 108-1 (see
In step 610, value determination engine 114 (see
The process of
The strength of a bridge of ontology schema S1 with sub-schema S depends at least on (1) the distance that every shared concept has with the ontology schema S1; and (2) the number of immediate links that the shared concepts have with the non-shared concepts of the imported sub-schema (i.e., sub-schema S). The strength of the bridge of S1 with S is high when the bridge links many immediate concepts from the imported and valuable sub-schema S and when the common concepts joining S1 and S are close to the central concepts of S1, where the central concepts are the concepts in S1 having the highest weight. Therefore, determining the strength of the bridge requires a function that provides a measure of the distance that a concept has with its own schema, as described below. It should be noted that the determination of the strength of the bridge by the process of
The process of
Distance(C,S)=1+MIN [distance (C,Ci) |weight(Ci)=MAX(weight(Cn))], where Ci and Cn belong to sub-schema S extracted in step 204 (see
In one embodiment, value determination engine 114 (see
In one embodiment, by default, value determination engine 114 (see
weight(Ci)=Number_of_immediate_links(Ci)*Number_of_direct_concepts(Ci), where Number_of_immediate_links(Ci)=number of relationships Ci has with the other concepts, where the relationships are in chains of exactly one link, and where Number_of_direct_concepts(Ci)=number of concepts Cx in relation with Ci, through a chain of links that associates Ci and Cx, such that Distance(Ci,Cx,chain) is either zero or has the lowest possible non-zero value.
In one embodiment, value determination engine 114 (see
In one embodiment, by default, value determination engine 114 (see
distance(Ci,Cj)=MIN(Distance(Ci,Cj,chain)) on all possible chains between Ci and Cj, where Distance(Ci,Cj,chain)=number of links that are in chain and that are between the concepts Ci and Cj, where chain is a chain having Ci and Cj as its terminal concepts.
In one embodiment, Distance(Ci,Cj,chain) is the sum of weighted links along chain, where each weight of a link in chain measures a respective distance between the concepts linked by the link.
In one embodiment, value determination engine 114 (see
In step 704, for every concept Ci in the concepts common to ontology schema S1 and sub-schema S, value determination engine 114 (see
In step 706, value determination engine 114 (see
In step 708, value determination engine 114 (see
The process of
The process of
In step 804, value determination engine 114 (see
In step 806, association creation engine 112 (see
In step 808, value determination engine 114 (see
In step 810, value determination engine 114 (see
Value_of_Association(S1,S2)=Value_of_Bridge(S1,S2)+Value_of_Bridge(S2,S1)
The value determination engine 114 (see
In step 812, using the Value_of_Association function determined in step 810, value determination engine 114 (see
The process of
In one embodiment, the process of
Example
The example in this section depicts the steps of creating a bridge and computing the value of a bridge.
Creation of a Bridge:
Using step 202 (see
Tables 1-10 presented below include the calculations used in step 408 (see
Table 1 presented below includes the calculations that determine the significance of concepts Ci in Schema 1 with respect to the common concept Form 902 (see
Table 2 presented below includes the calculations that determine the significance of concepts Ci in Schema 1 with respect to the common concept Motion 904 (see
Table 3 presented below includes the calculations that determine the significance of concepts Ci in Schema 1 with respect to the common concept Time 906 (see
Table 4 presented below includes the calculations that determine the significance of concepts Ci in Schema 1 with respect to the common concept Effort 908 (see
Table 5 presented below summarizes the significance calculations in Tables 1-4, and includes a computation of significance(Ci) included in step 408 (see
Table 6 presented below includes the calculations that determine the significance of concepts Ci in Schema 2 with respect to the common concept Form 902 (see
Table 7 presented below includes the calculations that determine the significance of concepts Ci in Schema 2 with respect to the common concept Motion 904 (see
Table 8 presented below includes the calculations that determine the significance of concepts Ci in Schema 2 with respect to the common concept Time 906 (see
Table 9 presented below includes the calculations that determine the significance of concepts Ci in Schema 2 with respect to the common concept Effort 908 (see
Table 10 presented below summarizes the significance calculations in Tables 6-9, and includes a computation of significance(Ci), which is included in step 408 (see
In this example, the significance threshold is set to 3. Based on the calculations in Tables 1-10 presented above, step 202 (see
Bridge(Schema1,Schema2) is depicted as a bridge 1000 in
Bridge(Schema2,Schema1) is depicted as a bridge 1100 in
Computation of the Value of a Bridge: Using the steps 204-214 in
Schema 1300 in
Schema 1300 in
Step 208 and the steps of
Step 210 and the steps of
Step 704 (see
Step 704 (see
Step 708 (see
Step 214 (see
Using the steps 204-214 in
Schema 1400 in
Schema 1400 in
Step 208 and the steps of
Step 210 and the steps of
Step 704 (see
Step 704 (see
Step 708 (see
Step 214 (see
Since Value_of_Bridge (Schema1,Schema2)>Value_of_Bridge (Schema2,Schema1) (i.e., 6.43>5.81), this example indicates that Schema 2 (i.e., the fish schema) has more value to Schema 1 (i.e., the car schema) than Schema 1 has to Schema 2.
Computer System
Memory 1504 may comprise any known computer-readable storage medium, which is described below. In one embodiment, cache memory elements of memory 1504 provide temporary storage of at least some program code (e.g., program code 1514 and/or program code 1516) in order to reduce the number of times code must be retrieved from bulk storage while instructions of the program code are carried out. Moreover, similar to CPU 1502, memory 1504 may reside at a single physical location, comprising one or more types of data storage, or be distributed across a plurality of physical systems in various forms. Further, memory 1504 can include data distributed across, for example, a local area network (LAN) or a wide area network (WAN).
I/O interface 1506 comprises any system for exchanging information to or from an external source. I/O devices 1510 comprise any known type of external device, including a display device (e.g., monitor), keyboard, mouse, printer, speakers, handheld device, facsimile, etc. Bus 1508 provides a communication link between each of the components in computer system 102, and may comprise any type of transmission link, including electrical, optical, wireless, etc.
I/O interface 1506 also allows computer system 102 to store information (e.g., data or program instructions such as program code 1514 and program code 1516) on and retrieve the information from computer data storage unit 1512 or another computer data storage unit (not shown). Computer data storage unit 1512 may comprise any known computer-readable storage medium, which is described below. For example, computer data storage unit 1512 may be a non-volatile data storage device, such as a magnetic disk drive (i.e., hard disk drive) or an optical disc drive (e.g., a CD-ROM drive which receives a CD-ROM disk).
Memory 1504 and/or storage unit 1512 may store computer program code 1514 and program code 1516 that includes instructions that are carried out by CPU 1502 via memory 1504 to determine a value of an association between ontologies. Although
Further, memory 1504 may include other systems not shown in
Storage unit 1512 and/or one or more other computer data storage units (not shown) that are coupled to computer system 102 may store ontologies 110-1 . . . 110-N (see
As will be appreciated by one skilled in the art, in a first embodiment, the present invention may be a system; in a second embodiment, the present invention may be a method; and in a third embodiment, the present invention may be a computer program product. A component of an embodiment of the present invention may take the form of an entirely hardware-based component, an entirely software component (including firmware, resident software, micro-code, etc.) or a component combining software and hardware sub-components that may all generally be referred to herein as a “module”.
An embodiment of the present invention may take the form of a computer program product embodied in one or more computer-readable storage medium(s) (e.g., memory 1504 and/or computer data storage unit 1512) having computer-readable program code (e.g., program code 1514 and program code 1516) embodied or stored thereon.
Any combination of one or more computer-readable mediums (e.g., memory 1504 and computer data storage unit 1512) may be utilized. The computer readable medium may be a computer-readable signal medium or a computer-readable storage medium. In one embodiment, the computer-readable storage medium is a computer-readable storage device or computer-readable storage apparatus. Each of the terms computer-readable storage device and computer-readable storage apparatus does not encompass signal propagation media such as copper cables, optical fibers and wireless transmission media. A computer-readable storage medium may be, for example, but not limited to, an electronic, magnetic, electromagnetic, or semiconductor system, apparatus, device or any suitable combination of the foregoing. A non-exhaustive list of more specific examples of the computer-readable storage medium includes: a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer-readable storage medium is a tangible storage device that is not a transitory signal transmission medium and that can contain or store a program (e.g., program code 1514 or program code 1516) for use by or in connection with a system, apparatus, or device for carrying out instructions.
A computer-readable signal medium may include a propagated data signal with computer-readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electromagnetic, optical, or any suitable combination thereof. A computer-readable signal medium may be any computer-readable medium that is not a computer-readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with a system, apparatus, or device for carrying out instructions.
Program code (e.g., program code 1514 and 1516) embodied on a computer-readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, radio frequency (RF), etc., or any suitable combination of the foregoing.
Computer program code (e.g., program code 1514 and 1516) for carrying out operations for aspects of the present invention may be written in any combination of one or more programming languages, including an object-oriented programming language such as Java®, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. Java is a registered trademark of Oracle and/or its affiliates. Instructions of the program code may be carried out entirely on a user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server, where the aforementioned user's computer, remote computer and server may be, for example, computer system 102 or another computer system (not shown) having components analogous to the components of computer system 102 included in
Aspects of the present invention are described herein with reference to flowchart illustrations (e.g.,
These computer program instructions may also be stored in a computer-readable medium (e.g., memory 1504 or computer data storage unit 1512) that can direct a computer (e.g., computer system 102), other programmable data processing apparatus, or other devices to function in a particular manner, such that the instructions (e.g., program 1514 and program 1516) stored in the computer-readable medium produce an article of manufacture including instructions which implement the function/act specified in the flowcharts and/or block diagram block or blocks.
The computer program instructions may also be loaded onto a computer (e.g., computer system 102), other programmable data processing apparatus, or other devices to cause a series of operational steps to be performed on the computer, other programmable apparatus, or other devices to produce a computer implemented process such that the instructions (e.g., program 1514 and program 1516) which are carried out on the computer, other programmable apparatus, or other devices provide processes for implementing the functions/acts specified in the flowcharts and/or block diagram block or blocks.
Any of the components of an embodiment of the present invention can be deployed, managed, serviced, etc. by a service provider that offers to deploy or integrate computing infrastructure with respect to determining a value of an association between ontologies. Thus, an embodiment of the present invention discloses a process for supporting computer infrastructure, wherein the process comprises a first computer system providing at least one support service for at least one of integrating, hosting, maintaining and deploying computer-readable code (e.g., program code 1514 and program code 1516) in a second computer system (e.g., computer system 102) comprising one or more processors (e.g., CPU 1502), wherein the processor(s) carry out instructions contained in the code causing the second computer system to determine a value of an association between ontologies.
In another embodiment, the invention provides a method that performs the process steps of the invention on a subscription, advertising and/or fee basis. That is, a service provider, such as a Solution Integrator, can offer to create, maintain, support, etc. a process of determining a value of an association between ontologies. In this case, the service provider can create, maintain, support, etc. a computer infrastructure that performs the process steps of the invention for one or more customers. In return, the service provider can receive payment from the customer(s) under a subscription and/or fee agreement, and/or the service provider can receive payment from the sale of advertising content to one or more third parties.
The flowcharts in
While embodiments of the present invention have been described herein for purposes of illustration, many modifications and changes will become apparent to those skilled in the art. Accordingly, the appended claims are intended to encompass all such modifications and changes as fall within the true spirit and scope of this invention.
This application is a continuation application claiming priority to Ser. No. 13/589,614 filed Aug. 20, 2012. This application is related to U.S. patent application Ser. No. 12/916,456; U.S. Patent Application Publication No. 2011/0153539) entitled “IDENTIFYING COMMON DATA OBJECTS REPRESENTING SOLUTIONS TO A PROBLEM IN DIFFERENT DISCIPLINES,” filed on Oct. 29, 2010, and U.S. patent application Ser. No. 13/432,120 entitled “BUILDING AN ONTOLOGY BY TRANSFORMING COMPLEX TRIPLES,” filed Mar. 28, 2012, both of which are hereby incorporated by reference in their entirety.
Number | Name | Date | Kind |
---|---|---|---|
6092099 | Irie et al. | Jul 2000 | A |
6167370 | Tsourikov et al. | Dec 2000 | A |
6487545 | Wical | Nov 2002 | B1 |
7027974 | Busch et al. | Apr 2006 | B1 |
7228302 | Kuchinsky et al. | Jun 2007 | B2 |
7284196 | Skeen et al. | Oct 2007 | B2 |
7308458 | Vincent, III | Dec 2007 | B2 |
7401087 | Copperman | Jul 2008 | B2 |
7433876 | Spivack et al. | Oct 2008 | B2 |
7493333 | Hill et al. | Feb 2009 | B2 |
7496593 | Gardner et al. | Feb 2009 | B2 |
7558791 | Wahl | Jul 2009 | B2 |
7743078 | Azvine et al. | Jun 2010 | B2 |
7890518 | Aasman | Feb 2011 | B2 |
7912701 | Gray et al. | Mar 2011 | B1 |
7966305 | Olsen | Jun 2011 | B2 |
8041746 | Stubec | Oct 2011 | B2 |
8060519 | Hosokawa | Nov 2011 | B2 |
8078647 | Liang et al. | Dec 2011 | B2 |
8219540 | Carter et al. | Jul 2012 | B2 |
8352403 | Lee et al. | Jan 2013 | B2 |
8478766 | Tsypliaev et al. | Jul 2013 | B1 |
8528018 | Patil et al. | Sep 2013 | B2 |
8539001 | Haim et al. | Sep 2013 | B1 |
8747115 | Lorge et al. | Jun 2014 | B2 |
20030018616 | Wilbanks et al. | Jan 2003 | A1 |
20030074516 | Cho et al. | Apr 2003 | A1 |
20040010491 | Riedinger | Jan 2004 | A1 |
20040093331 | Garner et al. | May 2004 | A1 |
20050027681 | Bernstein et al. | Feb 2005 | A1 |
20050131920 | Rust et al. | Jun 2005 | A1 |
20050154723 | Liang | Jul 2005 | A1 |
20050228981 | Gavrilov et al. | Oct 2005 | A1 |
20060031757 | Vincent, III | Feb 2006 | A9 |
20060053098 | Gardner et al. | Mar 2006 | A1 |
20060053099 | Gardner et al. | Mar 2006 | A1 |
20060053151 | Gardner et al. | Mar 2006 | A1 |
20060053171 | Eldridge et al. | Mar 2006 | A1 |
20060053172 | Gardner et al. | Mar 2006 | A1 |
20060053174 | Gardner et al. | Mar 2006 | A1 |
20060053175 | Gardner et al. | Mar 2006 | A1 |
20060074832 | Gardner et al. | Apr 2006 | A1 |
20060074980 | Sarkar | Apr 2006 | A1 |
20070016563 | Omoigui | Jan 2007 | A1 |
20070179971 | Benson | Aug 2007 | A1 |
20070226203 | Adya et al. | Sep 2007 | A1 |
20080016036 | Omoigui | Jan 2008 | A1 |
20080021912 | Seligman et al. | Jan 2008 | A1 |
20080040308 | Ranganathan et al. | Feb 2008 | A1 |
20080091634 | Seeman | Apr 2008 | A1 |
20080091727 | Wynett et al. | Apr 2008 | A1 |
20080162498 | Omoigui | Jul 2008 | A1 |
20080189269 | Olsen | Aug 2008 | A1 |
20080195570 | Alsafadi et al. | Aug 2008 | A1 |
20080288456 | Omoigui | Nov 2008 | A1 |
20080294644 | Liu et al. | Nov 2008 | A1 |
20080313229 | Taswell | Dec 2008 | A1 |
20090048907 | Lieberman | Feb 2009 | A1 |
20090077094 | Bodain | Mar 2009 | A1 |
20090112903 | Liang et al. | Apr 2009 | A1 |
20090254572 | Redlich et al. | Oct 2009 | A1 |
20100036788 | Wu et al. | Feb 2010 | A1 |
20100115436 | Embley et al. | May 2010 | A1 |
20100121885 | Hosomi et al. | May 2010 | A1 |
20100131516 | Jean-Mary | May 2010 | A1 |
20100217784 | Carter et al. | Aug 2010 | A1 |
20110040717 | Rho et al. | Feb 2011 | A1 |
20110093467 | Sharp et al. | Apr 2011 | A1 |
20110113095 | Hatami-Hanza | May 2011 | A1 |
20110153539 | Rojahn et al. | Jun 2011 | A1 |
20110238610 | Lee et al. | Sep 2011 | A1 |
20120173493 | Sabbouh | Jul 2012 | A1 |
20120239677 | Neale | Sep 2012 | A1 |
20130091119 | Huang et al. | Apr 2013 | A1 |
20130166303 | Chang et al. | Jun 2013 | A1 |
20130260358 | Lorge et al. | Oct 2013 | A1 |
Number | Date | Country |
---|---|---|
1596313 | Dec 2011 | EP |
0115042 | Mar 2001 | WO |
0221259 | Mar 2002 | WO |
0235376 | May 2002 | WO |
03042872 | May 2003 | WO |
Entry |
---|
Shvaiko et al.; A Survey of Schema-based Matching Approaches; Journal on Data Semantics IV; vol. 3730; 2005; 26 pages. |
Euzenat et al.; An integrative proximity measure for ontology alignment; Proceedings of the Semantic Integration workshop at the International Semantic Web Conference (ISWC); 2003; 6 pages. |
Hu et al.; Discovering Simple Mappings Between Relational Database Schemas and Ontologies; In Proceedings of ISWC/ASWC2007; 2007; 14 pages. |
Raghavan et al.; Schema Mapper: A Visualization Tool for DL Integration; JCDL '05; Jun. 7-11, 2005; p. 414. |
Mir et al.; An Unsupervised Approach for Acquiring Ontologies and RDF Data from Online Life Science Databases; Lecture Notes in Computer Science; vol. 6089; Springer-Verlag Berlin Heidelberg 2010; The Semantic Web: Research and Applications, 7th Extended Semantic Web Conference; ESWC 2010; Heraklion, Crete, Greece, May 30-Jun. 3, 2010; Proceedings, Part II; 15 pages. |
Hayes et al.; A Collaborative Development Environment for Ontologies (CODE); Semantic Integration Workshop (ISWC); Oct. 2003; 5 pages. |
Balakrishna et al.; Automatic Ontology Creation from Text for National Intelligence Priorities Framework (NIPF); Proceedings of 3rd International Ontology for the Intelligence Community (OIC) Conference, 5 pages; Dec. 3-4, 2008. |
Petersen, Ulrik; Automatic Lexicon-based Ontology-creation, A methodological study; Master's Thesis research paper; Aalborg University; Jan. 6, 2003; 47 pages. |
Volkel et al., Semversion: An RDF-Based Ontology Versioning System, IADIS International Conference WWW/Internet 2006, pp. 195-202. |
Ostrovsky et al., Efficiently Merging Graph Nodes With Application to Cluster Analysis, Apr. 20, 2007, 13 pages. |
International Search Report and Written Opinion (Mail Date Jun. 11, 2013); International Application No. PCT/IB2013/051823; Filing Date Mar. 7, 2013; 8 pages. |
Morita et al.; Information Integration with Linked Data; Jounral of the Japanese Society for Artificial Intelligence; vol. 27, No. 2; Mar. 1, 2012; pp. 189-199. |
Nakayama et al.; A Method based on NLP with Link Structure Mining to Construct a Web Ontology for Wikipedia; The Institute of Electronics, Information nad Communication Engineers; the Journal of 19th Data Engineering Workshop; Apr. 7, 2008; pp. 1-6. |
Tamagawa et al.; Learning a Large Scale of Ontology from Japanese Wikipedia, Transaction of the Japanese Society for Artificial Intelligence; vol. 25 (2010), No. 5; The Japanese Society for Artificial Intelligence; Aug. 17, 2010; pp. 623-636 [retrieved from the Internet Jun. 3, 2013] ,URL httosL//www.jstage.jst.go.jp/article/tjs ai/25/5/25—5—623/—article/-char/ja/>. |
U.S. Appl. No. 12/916,456, filed Oct. 29, 2010. |
U.S. Appl. No. 13/589,614, filed Aug. 20, 2012. |
Notice of Allowance (Mail Date May 8, 2013) for U.S. Appl. No. 13/589,614, filed Aug. 20, 2012. |
U.S. Appl. No. 13/432,120, filed Mar. 28, 2012. |
Halpin; Ontological Modeling; May 17, 2011; www.orm.net (From Internet Wayback Machine); retrieved from the Internet Sep. 20, 2013; 51 pages in PTO892 in connection with Non-Final Office Action dated Sep. 26, 2013—U.S. Appl. No. 13/432,120). |
Peroni, et al.; Identifying key concepts in an ontology through the integration of cognitive principles with statistical and topological measures; 2009 (From Internet Wayback Machine URL: web. archive. org/web/20090615000000*/ http :1/ people.k mi.open. a c.u k/motta/ ... /key—c oncepts—aswc.pdf); Retrieved from the Internet Sep. 21, 2013; 16 pages (in PTO892 in connection with Non-Final Office Action dated Sep. 26, 2013—U.S. Appl. No. 13/432,120). |
Amendment filed Dec. 24, 2013 in response to Office Action (Mail Date Sep. 26, 2013) for U.S. Appl. No. 13/432,120, filed Mar. 28, 2012. |
Office Action (Mail Date Sep. 26, 2013) for U.S. Appl. No. 13/432,120, filed Mar. 28, 2012. |
Office Action (Mail Date Oct. 25, 2013) for U.S. Appl. No. 12/916,456, filed Oct. 29, 2010. |
Notice of Allowance (Mail Date Jan. 27, 2014) for U.S. Appl. No. 13/432,120, filed Mar. 28, 2012. |
Notice of Allowance (Mail Date Mar. 7, 2014) for U.S. Appl. No. 12/916,456, filed Oct. 29, 2010. |
Amendment filed Feb. 3, 2014 in response to Office Action (Mail Date Oct. 25, 2013) for U.S. Appl. No. 12/916,456, filed Oct. 29, 2010. |
List of IBM Patents or Patent Applications Treated as Related; attached Jun. 11, 2014; 1 page. |
Number | Date | Country | |
---|---|---|---|
20140052759 A1 | Feb 2014 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13589614 | Aug 2012 | US |
Child | 13957550 | US |