This application is based upon and claims the benefit of priority from the prior Japanese Patent Application No. 2013-147959 filed on Jul. 16, 2013, the entire contents of which are incorporated herein by reference.
Exemplary embodiments of the present disclosure relate to a data output method, a computer-readable recording medium storing a data output program and a data output system.
When a data combination satisfying a predetermined condition is retrieved from a set of data, all of a plurality of data combinations are created and the data combination satisfying the predetermined condition is found from the plurality of created data combinations and is output.
When the number of data included in the set of data is large, the total number of data combinations increases, which requires much time for processing.
A related technique is disclosed in, for example, Japanese Patent Laid-Open Publication No. 2009-208904.
According to one aspect of the embodiments, a data output method, includes: extracting, by a computer, data satisfying a first condition on one data among a plurality of conditions, from a plurality of data, as a node; creating a first graph by coupling two nodes satisfying a second condition on a relationship between two data among the plurality of conditions with a link; creating a second graph by deleting a node that does not satisfy the second condition from the first graph; determining candidates of data combination in the second graph; and outputting a data combination satisfying the plurality of conditions from the candidates of data combination.
The object and advantages of the disclosure will be realized and attained by means of the elements and combinations particularly pointed out in the claims. It is to be understood that both the foregoing general descriptions and the following detailed descriptions are exemplary and explanatory, and are not restrictive of the invention, as claimed.
As illustrated in
A client 50 illustrated in
A client 50 illustrated in
The client 50 illustrated in
The processing server 10 illustrated in
The condition reading unit 12 reads retrieval conditions of data input from the client 50, for example, the input processing unit 52, and inputs the read retrieval conditions to the condition converting unit 14. The condition converting unit 14 converts conditions, which can be converted to unary conditions, for example, conditions on one data or binary conditions, for example, conditions on a relationship between two data, among ternary or more conditions, for example, conditions on a relationship three or more data input from the condition reading unit 12, to the unary conditions or the binary conditions.
If the conditions converted by the condition converting unit 14 include redundant conditions such as transitive conditions and/or duplicate conditions, the condition deleting unit 16 deletes such redundant conditions. The condition deleting unit 16 inputs all retrieval conditions left after the deletion to the graph generating unit 20 and the output generating unit 26.
The data reading unit 18 reads a set of data to be retrieved such as a set of events or records, from the data server 80 and inputs the read set of data to the graph generating unit 20. The graph generating unit 20 uses the set of data input from the data reading unit 18 and the retrieval conditions input from the condition deleting unit 16 to generate a graph with nodes and links based on a graph theory. The graph generating unit 20 inputs the generated graph to the graph preserving unit 22.
The graph preserving unit 22 stores the graph input from the graph generating unit 20 in the graph storing unit 30. The node deleting unit 24 verifies the graph stored in the graph storing unit 30 and deletes unnecessary nodes from the graph.
The output generating unit 26 reads the graph processed by the node deleting unit 24 from the graph storing unit 30 and determines combination candidates of data satisfying the retrieval conditions from the read graph. The output generating unit 26 compares the combination candidates and the retrieval conditions, and outputs a combination of data satisfying the retrieval conditions to the client 50 (the display processing unit 54).
The data server 80 illustrated in
At Operation S10, the condition reading unit 12 of the processing server 10 reads the retrieval conditions input from the client 50 (the input processing unit 52). For example, the condition reading unit 12 may read the retrieval conditions illustrated in
At Operation S12, the condition converting unit 14 determines whether conditions, which can be converted to a plurality of binary conditions or unary conditions among the ternary or more conditions, are included in the retrieval conditions. Ternary or more conditions which can be converted to a plurality of binary conditions or unary conditions means conditions such as equivalence or magnitude relationship between three data. In the retrieval conditions of
If the determination result at Operation S12 is affirmative, the process proceeds to Operation S14. Otherwise, the process proceeds to Operation S20.
At Operation S14, the condition converting unit 14 converts ternary or more conditions, which can be converted to a plurality of binary conditions or unary conditions, to the binary conditions or the unary conditions.
At Operation S16, the condition deleting unit 16 determines whether or not redundant conditions are included in the converted conditions. For example, if two of the conditions of “Vendors of x and y are the same”, the condition of “Vendors of y and z are the same” and the condition of “Vendors of z and x are the same” are met, the remaining other condition is also met. Accordingly, one of the three conditions may be duplicate conditions (redundant conditions). For example, if the determination result at Operation S16 is affirmative, the process proceeds to Operation S18. If the determination in S16 is negative, the process proceeds to Operation S20. For example, an example of the redundant conditions may include transitive conditions in addition to the duplicate conditions.
When the process proceeds to Operation S18, the condition deleting unit 16 deletes the redundant conditions.
After Operation S18 or if the determination result at Operation S12 or S16 is negative, the process proceeds to Operation S20 where the data reading unit 18 reads data. For example, the data reading unit 18 may read data of the database of
At the step where the graph illustrated in
At Operation S26 illustrated in
For example, in
As illustrated in
In the graph in which the node (data ID=9) has been deleted, a side of an alternate long and short dash line is not coupled to nodes (data ID=3 and 8), as illustrated in
In the graph in which the nodes (data ID=3 and 8) have been deleted, a side of a dashed line is not coupled to a node (data ID=6), as illustrated in
For example, in the stage where the graph stored in the graph storing unit 30 is created as illustrated in
When the process proceeds to Operation S30, the output generating unit 26 enumerates (determines) candidates of data combination based on the graph stored in the graph storing unit 30, for example, the graph in which all the nodes to be deleted have been deleted. For example, all combinations of nodes (data) left in the graph illustrated in
At Operation S32, the output generating unit 26 outputs combinations satisfying the retrieval conditions among the enumerated combination candidates to the client 50, for example, the display processing unit 54. For example, the output generating unit 26 determines whether or not each combination satisfies all conditions (1) to (7), for example, binary and ternary conditions (5) to (7).
For example, all combinations of nodes included in the graph of
The graph generating unit 20 extracts data satisfying the unary conditions as a node and creates a graph by coupling nodes satisfying the binary conditions with sides (links) (S22 and S24). The node deleting unit 24 repeats the process (S28) of deleting nodes, which do not satisfy the binary conditions to be satisfied by the nodes, from the graph until there exist no nodes to be deleted (until the determination result at Operation S26 is negative). The output generating unit 26 enumerates (S30) candidates of data combination based on the graph in which the nodes have been deleted by the node deleting unit 24 and outputs data combinations satisfying the conditions based on the enumerated candidates and the input conditions. The process of deleting the nodes of the graph is repeated and thus, the candidates of data combination are narrowed. Since the output generating unit 26 retrieves a combination satisfying the conditions among the narrowed combinations, a data combination satisfying the conditions may be found in a short time, as compared with retrieval of a data combination satisfying the conditions among all of data combinations.
If ternary conditions are included in the retrieval conditions, the condition converting unit 14 converts the ternary conditions to unary conditions or binary conditions (S14). Accordingly, even the ternary conditions may be used to narrow candidates of data combination using a graph, which may result in an improved accuracy of narrowing the candidates of data combination.
If redundant conditions are included in the converted conditions after Operation S14, the condition deleting unit 16 deletes the redundant conditions (S18), which may result in reduction of unnecessary processes in the graph generating unit 20 or the node deleting unit 24.
At Operation S14, the condition converting unit 14 may convert the ternary conditions. For example, if quaternary conditions or quinary conditions are equivalent conditions, these conditions may be converted into unary conditions or binary conditions. For example, if redundant conditions are included in the converted conditions, the condition deleting unit 16 may delete the redundant conditions, which may result in reduction of unnecessary processes to simplify the process.
The above-described processes may be executed by a computer. A program describing the contents of functions of a processor may be provided. The program may be executed by the computer so as to implement the processor functions on the computer. The program describing the processing contents may be recorded on a computer-readable recording medium other than a carrier wave.
The program may be distributed in the form of a portable recording medium such as a Digital Versatile Disc (DVD) or Compact Disc Read Only Memory (CD-ROM), in which the program is recorded. The program may be stored in a storage device of a server computer and transmitted from the server computer to another computer via, for example, a network.
A computer executing the program stores the program recorded on the portable recording medium or the programs transmitted from the server computer in its own storage device. The computer may read the program from its own storage device and execute processes according to the programs. The computer may execute the programs directly read from the portable recording medium. The computer may execute processes according to the programs received each time the program is transmitted from the server computer.
All examples and conditional language recited herein are intended for pedagogical purposes to aid the reader in understanding the invention and the concepts contributed by the inventor to furthering the art, and are to be construed as being without limitation to such specifically recited examples and conditions, nor does the organization of such examples in the specification relate to a showing of the superiority and inferiority of the invention. Although the exemplary embodiments of the present invention have been described in detail, it should be understood that the various changes, substitutions, and alterations could be made hereto without departing from the spirit and scope of the invention.
Number | Date | Country | Kind |
---|---|---|---|
2013-147959 | Jul 2013 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5201046 | Goldberg | Apr 1993 | A |
6092064 | Aggarwal | Jul 2000 | A |
20010007987 | Igata | Jul 2001 | A1 |
20010042059 | Uehara | Nov 2001 | A1 |
20020004710 | Murao | Jan 2002 | A1 |
20080235193 | Hattori | Sep 2008 | A1 |
20090259652 | Yamane | Oct 2009 | A1 |
20100082762 | Hotta | Apr 2010 | A1 |
20110004631 | Inokuchi et al. | Jan 2011 | A1 |
20110307511 | Asai | Dec 2011 | A1 |
20120150873 | Tokai | Jun 2012 | A1 |
20120293542 | Iwama | Nov 2012 | A1 |
20140324503 | Whittaker | Oct 2014 | A1 |
20150186457 | Enomoto | Jul 2015 | A1 |
Number | Date | Country |
---|---|---|
2001-167087 | Jun 2001 | JP |
2003-345821 | Dec 2003 | JP |
2009-176072 | Aug 2009 | JP |
2009-205269 | Sep 2009 | JP |
2009-208904 | Sep 2009 | JP |
2010-152748 | Jul 2010 | JP |
2011-128748 | Jun 2011 | JP |
2012-58835 | Mar 2012 | JP |
Entry |
---|
Final Office Action mailed Dec. 30, 2016 in co-pending U.S. Appl. No. 14/308,738. |
Office Action dated Jun. 16, 2016 in related U.S. Appl. No. 14/308,738. |
U.S. Appl. No. 14/308,738, filed Jun. 19, 2014, Takashi Katoh et al., Fujitsu Limited. |
Number | Date | Country | |
---|---|---|---|
20150026555 A1 | Jan 2015 | US |