The present disclosure relates to a peer-to-peer terminal and a contract transaction system.
Contract transaction systems each of which matches, through a network, a person who wishes to sell content with a person who wishes to purchase the content and completes a contract transaction have been proposed.
For example, in the financial asset transaction system described in Patent Document 1, a user who wishes to transact a financial asset operates a client terminal device (paragraph 0012). Furthermore, an exchange server device receives transaction information transmitted from each client terminal device through a network, and performs a process of orchestrating transactions based on the received pieces of transaction information (paragraph 0013).
The conventional contract transaction systems typified by the financial asset transaction system described in Patent Document 1 adopt the client-server model. Here, a server performs a process of completing a contract transaction. Thus, the server is a single point of failure. When the server fails, the contract transaction system cannot be maintained. Prevention of an unauthorized access to the server and malware infection requires increasing the security strength of the server. This involves a cost for increasing the security strength of the server.
In contrast, in a peer-to-peer (P2P) network using, for example, blockchains, peer terminals communicate with each other. Unlike the server, the P2P network does not have a single point of failure. However, the P2P network has no terminal that manages the entire terminals unlike the server. When each of terminals in the P2P network performs a process of completing a contract transaction, a plurality of contract results calculated by the terminals are sometimes inconsistent. Thus, one reliable contract result is not identifiable.
The present disclosure has been conceived in view of these problems. The object of the present disclosure is to provide a contract transaction system that has no single point of failure and can identify one reliable contract result from among a plurality of inconsistent contract results.
The present disclosure relates to a peer-to-peer terminal.
The peer-to-peer terminal includes a bid data obtaining unit, a bid data transmitter, a contract result calculator, a contract result transmitter, a contract result receiver, and a contract result selector.
The bid data obtaining unit obtains bid data.
The bid data transmitter transmits the bid data to another peer-to-peer terminal.
The contract result calculator calculates a contract result from a bid data set obtained by the bid data obtaining unit, the bid data set including the bid data.
The contract result transmitter transmits the contract result to the other peer-to-peer terminal.
The contract result receiver receives, from the other peer-to-peer terminal, another contract result calculated by the other peer-to-peer terminal.
The contract result selector selects one contract result from among the contract result and the other contract result.
The present disclosure is also directed to a contract transaction system including the peer-to-peer terminals.
The present disclosure enables a peer-to-peer network including a plurality of peer-to-peer terminals to complete a contract transaction. This can provide a contract transaction system having no single point of failure. This can also provide a contract transaction system that can identify one reliable contract result from a plurality of inconsistent contract results.
The object, features, aspects, and advantages of the present disclosure will become more apparent from the following detailed description and the accompanying drawings.
A contract transaction system 1 in
The contract transaction system 1 completes a contract transaction between a purchasing bid and a selling bid, and calculates a contract result 102 indicating a result of the completed contract transaction. The contract transaction system 1 completes a contract transaction so that a purchasing user who has created the purchasing bid data can purchase a product at a price lower than or equal to the bidding price indicated by the purchasing bid data and that a selling user who has created the selling bid data can sell the product at a price higher than or equal to the bidding price indicated by the selling bid data.
A closing time for the bid is set in the contract transaction system 1. The contract transaction system 1 completes a contract transaction between a purchasing bid with details indicated by the purchasing bid data obtained until the set closing time for the bid and a selling bid with details indicated by the selling bid data obtained until the set closing time for the bid. The contract transaction system 1 completes a contract transaction at the set closing time for the bid. The closing time for the bid is set, for example, at regular intervals. The regular intervals are, for example, intervals of 5 minutes. When the regular intervals are intervals of 5 minutes, for example, TT:00, TT:05, TT:10, TT:15, TT:20, TT:25, TT:30, TT:35, TT:40, TT:45, TT:50, and TT:55 are set as closing times for the bid, where TT denotes an arbitrate hour.
1.2 Elements Included in Contract Transaction System
As illustrated in
In
Each of the terminals 11x is a peer-to-peer (P2P) terminal configuring a P2P network.
Each of the terminals 11x obtains the bid data 101. The bid data 101 to be obtained is bid data 101x received by each of the terminals 11x from a terminal that is not included in the plurality of terminals 11, bid data 101y received by each of the terminals 11x from the other terminals 11y included in the plurality of terminals 11, or bid data that is generated by each of the terminals 11x and is not illustrated. Accordingly, each of the terminals 11x obtains a bid data set 103.
Each of the terminals 11x transmits the obtained bid data 101 to the other terminals 11y.
Each of the terminals 11x completes a contract transaction between a purchasing bid and a selling bid, and calculates a contract result 102x indicating a result of the completed contract transaction.
When a plurality of the bid data sets 103 obtained by the plurality of terminals 11 are consistent, a plurality of the contract results 102x calculated by the plurality of terminals 11 are also consistent. However, when the plurality of the bid data sets 103 are inconsistent because of a communication delay or an influence such as the topology of the P2P network configured by the plurality of terminals 11, the plurality of contract results 102x are sometimes inconsistent. When the plurality of contract results 102x are inconsistent, each of the terminals 11x selects one reliable contract result from among the plurality of contract results 102x.
The Certificate Authority 12 issues a digital certificate 104 of each of the terminals 11x.
1.3 P2P Network
A P2P network 21 in
As illustrated in
Each of the terminals 11x knows an address of a terminal communicatively connected to the terminal 11x, can transmit data to the terminal, and can receive data from the terminal.
Each of the terminals 11x is operated by one user who owns the terminal 11x. Thus, the terminals 11a, 11b, 11c, 11d, 11e, 11f, . . . are operated by users A, B, C, D, E, F, . . . , respectively. Each of the terminals 11x may be operated by two or more users who share the terminal 11x.
1.4 Hardware Configuration of Each Terminal
Each of the terminals 11x includes a personal computer (PC) 31 illustrated in
As illustrated in
A contract transaction program 35 is installed in the storage 34. The contract transaction program 35 may be installed by writing, into the storage 34, the contract transaction program 35 read from an external recording medium 36 or received through a network 37.
Examples of the processor 32 include a central processing unit (CPU), a graphics processing unit (GPU), and a digital signal processor (DSP). Examples of the memory 33 include a random access memory (RAM). Examples of the storage 34 include a hard disk drive, a solid state drive, and a RAM disk. Examples of the external recording medium 36 include a compact disk (CD), a Digital Versatile Disc (DVD), a Blu-ray disc (BD), and a Universal Serial Bus (USB) memory.
The memory 33, the storage 34, and the external recording medium 36 are non-transitory computer-readable recording media in which the contract transaction program 35 is recorded.
In the PC 31, the contract transaction program 35 installed in the storage 34 is loaded into the memory 33. Then, the processor 32 executes the loaded contract transaction program 35. Thereby, the PC 31 operates as each of the terminals 11x.
1.5 Elements Included in Each Terminal
As illustrated in
These elements are configured by loading, into the memory 33, the contract transaction program 35 installed in the storage 34 and executing the loaded contract transaction program 35 by the processor 32. A part of these elements may be configured by hardware that does not execute the program.
1.6 Procedure to be Performed by Each Terminal
Each of the terminals 11x executes Steps S101 to S111 in
In Step S101, the authentication information obtaining unit 41 performs a process of obtaining authentication information. Here, the authentication information obtaining unit 41 obtains the digital certificate 104 of each of the terminals 11x from the Certificate Authority 12, and stores the obtained digital certificates 104 of the terminals 11x. The digital certificate 104 to be obtained is, for example, a digital certificate that conforms to the X.509 standard that is a public key infrastructure and is defined by the International Telecommunication Union Telecommunication Standardization Sector (ITU-T).
Next in Step S102, the bid data obtaining unit 42 performs a process of obtaining bid data. Here, the bid data obtaining unit 42 obtains the bid data 101, and stores the obtained bid data 101. Accordingly, the bid data obtaining unit 42 obtains the bid data set 103, and stores the obtained bid data set 103. Examples of the bid data 101 to be obtained include the bid data 101x received by the bid data receiver 54 from a terminal that is not included in the plurality of terminals 11, the bid data 101y received by the bid data receiver 54 from each of the other terminals 11y included in the plurality of terminals 11, and bid data that is generated by each of the terminals 11x using the bid data generator 55 and is not illustrated. Each of the terminals 11x generates the bid data through operating the terminal 11x by the user of the terminal 11x. The terminal that is not included in the plurality of terminals 11 is, for example, a terminal owned by the user. The terminal owned by the user is, for example, a smart phone owned by the user.
As illustrated in
The bid data ID 111, the time stamp 112, the terminal ID 113, the user ID 114, the product 115, the bid quantity 116, the bid unit price 117, the purchase and sale classification 118, and the digital certificate 119 are described in the first to ninth columns in the table.
The bid data ID 111 identifies the bid data 101. The bid data ID 111 is determined by avoiding an overlap with bid data IDs included in other pieces of bid data. The bid data ID 111 is, for example, a hash value to be returned when information on a terminal that has generated the bid data 101 or the time at which the bid data 101 has been generated is passed to a hash function as an argument.
The time stamp 112 indicates the time at which the bid data 101 has been generated. The time stamp 112 has a format “yyyy/MM/dd/hh:mm:ss”. “yyyy” indicates a year. “MM” indicates a month. “dd” indicates a date. “hh” indicates an hour. “mm” indicates a minute. “ss” indicates a second.
The terminal ID 113 identifies the terminal that has generated the bid data 101.
The user ID 114 identifies the user that has created the bid data 101.
The product 115, the bid quantity 116, the bid unit price 117, and the purchase and sale classification 118 indicate the product, the bid quantity, the bid unit price, and the classification between purchase and sale, respectively, as the details of the bid indicated by the bid data 101. The purchase and sale classification 118 indicates whether the bid data 101 is purchasing bid data or selling bid data. “PURCHASE” in the purchase and sale classification 118 indicates that the bid data 101 is purchasing bid data. “SALE” in the purchase and sale classification 118 indicates that the bid data 101 is selling bid data.
The digital certificate 119 is a digital certificate of the terminal that has generated the bid data 101.
When the user A has created, at 00:00:30 on Jan. 1, 2019, purchasing bid data describing details of a purchasing bid for showing an intention of purchasing a product “X” at a bid unit price “12” only in a bid quantity “2.0” using the terminal A, the bid data ID 111 is, for example, 0002. The time stamp 112 is “2019/01/01/00:00:30”. Furthermore, the terminal ID 113 is a terminal ID of the terminal A. Furthermore, the user ID 114 is a user ID of the user A. The product 115 is “X”. The bid quantity 116 is “2.0”. The bid unit price 117 is “12”. The purchase and sale classification 118 is “PURCHASE”. The digital certificate 119 is “DIGITAL CERTIFICATE A” that is a digital certificate of the terminal A.
Next in Step S103, the bid data transmitter 43 performs a process of transmitting bid data. Here, the bid data transmitter 43 transmits the obtained bid data 101 to the other terminals 11y. The bid data transmitter 43 broadcasts the obtained bid data 101 to the other terminals 11y.
Next in Step S104, the contract result calculator 44 performs a process of calculating a contract result. Here, the contract result calculator 44 calculates the contract result 102x from the obtained bid data set 103, and stores the calculated contract result 102x. When a deadline for the bid is set at intervals of 5 minutes, the contract result calculator 44 calculates the contract result 102x at intervals of 5 minutes. For example, when the current time is 00:05:00 on Jan. 1, 2019, the contract result calculator 44 calculates the contract result 102x from the bid data set 103 including the bid data 101 including the time stamp 112 indicating the time before 00:05:00 on Jan. 1, 2019. The contract result calculator 44 completes a contract transaction between a purchasing bid and a selling bid for each type of the product 115. A combination of a purchasing bid and a selling bid between which a contract transaction is completed, a contract quantity, and a contract price are determined, for example, similarly to the itayose method before opening the stock market.
As illustrated in
As illustrated in
The contract result ID 141, the time stamp 142, the terminal ID 143, and the digital certificate 144 are described in the first to fourth columns in the table.
The contract result ID 141 identifies each of the contract results 121x. The contract result ID 141 is determined by avoiding an overlap with contract results ID included in other contract results. The contract result 1D 141 is, for example, a hash value to be returned when information on the terminal that has calculated each of the contract results 121x or the time at which the contract result 121x has been calculated is passed to a hash function as an argument.
The time stamp 142 indicates the time at which each of the contract results 121x has been calculated. The time stamp 142 has a format “yyyy/MM/dd/hh:mm:ss”. “yyyy” indicates a year. “MM” indicates a month. “dd” indicates a date. “hh” indicates an hour. “mm” indicates a minute. “ss” indicates a second.
The terminal ID 143 identifies a terminal that has calculated each of the contract results 121x.
The digital certificate 144 is a digital certificate of the terminal that has calculated each of the contract results 121x.
As illustrated in
The purchasing bid data ID 151, the selling bid data ID 152, the contract quantity 153, and the contract unit price 154 are described in the first to fourth columns in the table.
The purchasing bid data ID 151 and the selling bid data ID 152 identify purchasing bid data and selling bid data describing details of a purchasing bid and details of a selling bid, respectively. A contract transaction has been completed between the purchasing bid and the selling bid.
The contract quantity 153 and the contract unit price 154 indicate a contract quantity and a contract unit price, respectively, as details of the completed contract transaction.
In the body 132, the purchasing bid data ID 151 and the selling bid data ID 152 indicating details of the purchasing bid and details of the selling bid, respectively, are associated with each other. The contract transaction has been completed between the purchasing bid and the selling bid.
Not a server but each of the terminals 11x needs to calculate the contract result 102x to complete a contract transaction in the P2P network 21. However, when each of the terminals 11x calculates the contract result 102x, the plurality of the data sets 103 obtained by the plurality of terminals 11 are sometimes inconsistent because of a communication delay or an influence such as the topology of the P2P network 21. As a result, the plurality of contract results 102x calculated by the plurality of terminals 11 are sometimes inconsistent. For example, suppose a case where the bid data set 103 obtained by the terminal 11a includes pieces of the bid data 101 including the bid data IDs 111 such as “0001”, “0002”, and “0003”, the bid data set 103 obtained by the terminal 11b includes pieces of the bid data 101 including the bid data IDs 111 such as “0001” and “0002”, and the bid data set 103 obtained by the terminal 11c includes pieces of the bid data 101 including the bid data IDs 111 such as “0002” and “0003”. The contract result 121a calculated by the terminal 11a, the contract result 121b calculated by the terminal 11b, and the contract result 121c calculated by the terminal 11c are inconsistent as illustrated in
Next in Step S105, the contract result transmitter 45 performs a process of transmitting a contract result. Here, the contract result transmitter 45 transmits the calculated contract result 102x to the other terminals 11y. In the presence of other contract results 102y received by the contract result receiver 46 from the other terminals 11y, the contract result transmitter 45 transmits the received other contract results 102y to the other terminals 11y. The contract result transmitter 45 broadcasts the calculated contract result 102x and the received other contract results 102y to the other terminals 11y.
Next in Step S106, the contract result receiver 46 performs a process of receiving contract results. Here, the contract result receiver 46 receives, from the other terminals 11y, the other contract results 102y calculated by the other terminals 11y, and stores the received other contract results 102y.
Next in Step S107, the contract result examining unit 47 performs a process of examining contract results. Here, the contract result examining unit 47 examines the received other contract results 102y, and determines whether the other contract results 102y are candidates for one contract result to be selected in Step S108, based on a result of the examination. When determining the received other contract results 102y not as the candidates for one contract result to be selected, the contract result examining unit 47 deletes the other contract results 102y.
When examining the received other contract results 102y, the contract result examining unit 47 examines whether the other contract results 102y have consistency. When the received other contract results 102y have consistency, the contract result examining unit 47 determines the other contract results 102y as the candidates for one contract result to be selected. When the received other contract results 102y do not have consistency, the contract result examining unit 47 determines the other contract results 102y not as the candidates for one contract result to be selected, and deletes the other contract results 102y.
Examining whether the other contract results 102y have consistency includes, for example, the following examinations:
(1) examining whether the digital certificates 119 included in pieces of the bid data 101 identified by the purchasing bid data ID 151 and the selling bid data ID 152 included in the other contract results 102y are identical to the digital certificate 104 obtained from the Certificate Authority 12;
(2) examining whether the digital certificates 144 included in the other contract results 102y are identical to the digital certificate 104 obtained from the Certificate Authority 12;
(3) examining whether each of the times indicated by the time stamps 112 included in the pieces of bid data 101 identified by the purchasing bid data ID 151 and the selling bid data ID 152 included in the other contract results 102y is before the time indicated by the time stamp 142 included in the other contract results 102y;
(4) examining whether the bid unit price 117 included in the (purchasing) bid data 101 identified by the purchasing bid data ID 151 included in the other contract results 102y is lower than or equal to the bid unit price 117 included in the (selling) bid data 101 identified by the selling bid data ID 152 associated with the purchasing bid data ID 151;
(5) examining whether the bid unit price 117 included in the (selling) bid data 101 identified by the selling bid data ID 152 included in the other contract results 102y is higher than or equal to the bid unit price 117 included in the (purchasing) bid data 101 identified by the purchasing bid data ID 151 associated with the selling bid data ID 152;
(6) examining whether a sum of the bid quantities 116 included in pieces of the (purchasing) bid data 101 identified by pieces of the purchasing bid data ID 151 included in the other contract results 102y is lower than or equal to the bid quantity 116 included in the (selling) bid data 101 identified by the selling bid data ID 152 associated with the purchasing bid data ID 151; and
(7) examining whether a sum of the bid quantities 116 included in pieces of the (selling) bid data 101 identified by pieces of the selling bid data ID 152 included in the other contract results 102y is lower than or equal to the bid quantity 116 included in the (purchasing) bid data 101 identified by the purchasing bid data ID 151 associated with the selling bid data ID 152.
Next in Step S108, the contract result selector 48 performs a process of selecting a contract result. Here, the contract result selector 48 selects one contract result from among the calculated contract result 102x and the received other contract results 102y. When whether the other contract results 102y are the candidates for one contract result to be selected is determined, the contract result selector 48 selects one contract result from among the contract result 102x and the other contract results 102y determined as the candidates. When a deadline for the bid is set at intervals of 5 minutes, the contract result selector 48 selects one contract result at intervals of 5 minutes, and selects one contract result from among the contract result 102x calculated in the past 5 minutes and the other contract results 102y. The contract result selector 48 selects one contract result based on a selection criterion 107.
The selection criterion 107 in
Next in Step S109, the block receiver 49 performs a process of receiving blocks. Here, the block receiver 49 receives previous (past) blocks 108 including one previous contract result selected before the one contract result is selected in Step S108, from the other terminals 11y. The block receiver 49 receives the previous blocks 108 from the other terminals 11y when each of the terminals 11x does not store the previous block 108. For example, when a deadline for the bid is set at intervals of 5 minutes, the terminal 11a does not store a previous block including one contract result selected at 00:00:00 on Jan. 1, 2019 by reason of a failure in the terminal 11a, and the terminal 11a has been recovered at 00:05:00 on Jan. 1, 2019, the block receiver 49 included in the terminal 11a receives the previous blocks from the other terminals 11y.
Next in Step S110, the block selector 50 performs a process of selecting a block. Here, the block selector 50 selects the previous block 108 to be followed by a new block, from among a plurality of the previous blocks received by the block receiver 49, and stores the selected previous block 108. The previous block 108 to be selected is one of a majority of previous blocks determined, based on majority rule, from among the plurality of previous blocks received by the block receiver 49.
Next in Step S111, the contract result storage 51 performs a process of storing a contract result. Here, the contract result storage 51 stores the selected one contract result, and updates the bid data 101. The updated bid data 101 is bid data obtained by replacing the bid quantity included in the bid data 101 before the update by a new bid quantity obtained by subtracting a contract quantity from the bid quantity. When storing the selected one contract result, the contract result storage 51 stores the new block including the selected one contract result. The new block to be stored follows the selected previous block 108.
As illustrated in
The new block 161 includes one contract result 171 selected, and a hash value 172. The previous block 162 includes one contract result 173 selected five minutes ago, and a hash value 174. The hash value 174 is a hash value to be returned when a block before last that is not illustrated is passed to a hash function 175 as an argument. The hash value 172 is a hash value to be returned when the previous block 162 is passed to the hash function 175 as an argument.
1.7 Advantages of Embodiment 1
Embodiment 1 enables completion of a contract transaction not in a server adopted in the client-server model but in the P2P network 21 including the plurality of terminals 11. This can provide the contract transaction system 1 having no single point of failure. Thus, the one contract result 171 that is reliable is identifiable from a plurality of inconsistent contract results.
A contract transaction system 2 according to Embodiment 2 in
As illustrated in
In Step S112, the incentive calculator 52 performs a process of calculating an incentive. Here, the incentive calculator 52 calculates an incentive for a terminal that has calculated the selected one contract result. The user of the terminal can obtain the calculated incentive. The incentive calculator 52 calculates an incentive based on an incentive percentage 109.
The incentive percentage 109 in
The incentive 181 in
In Step S111, the contract result storage 51 performs a process of storing a contract result. Here, the contract result storage 51 stores the incentive 181 calculated together with the selected one contract result, and updates the bid data 101.
2.2 Advantages of Embodiment 2
Embodiment 2 produces the same advantages as Embodiment 1.
In addition, Embodiment 2 produces the following advantages.
When the P2P network 21 has the topology illustrated in
Embodiment 2 enables the user of a terminal that has calculated the one contract result to be selected, that is, a contract result whose sum of the contract quantities 153 is the maximum to obtain the incentive 181. Thus, there are motivations to increase the number of pieces of the bid data 101 to be received by each of the terminals 11x and to be reflected on the contract result 102x calculated by the terminal 11x so that the user obtains the incentive 181. Here, increase in the number of terminals to be communicatively connected to each of the terminals 11x is effective at increasing the number of pieces of the bid data 101 to be received by the terminal 11x. Thus, there is a motivation to increase the number of the communication lines 22 that are the plurality of communication lines 22. This consequently can prevent partitioning the P2P network 21, and prevent the contract result calculated in the terminal set 201a from differing from the contract result calculated in the terminal set 201b.
A contract transaction system 3 according to Embodiment 3 in
As illustrated in
In Step S113, the terminal evaluator 53 performs a process of evaluating terminals. Here, the terminal evaluator 53 evaluates the other terminals 11y, and selects a terminal from which the previous block 108 has been transmitted, from the other terminals 11y based on a result of the evaluation. The terminal evaluator 53 evaluates the other terminals 11y based on an evaluation criterion 110.
The evaluation criterion 110 in
Next in Step S109, the block receiver 49 performs a process of receiving blocks. Here, the block receiver 49 receives the previous block 108 from the selected terminal from which the previous block 108 has been transmitted.
3.2 Advantages of Embodiment 3
Embodiment 3 produces the same advantages as Embodiment 1.
In addition, Embodiment 3 produces the following advantages.
In Embodiment 1, the block receiver 49 receives a plurality of previous blocks from the plurality of other terminals 11y when each of the terminals 11x does not store the previous block 108. Furthermore, the block selector 50 selects the previous block 108 to be followed by a new block, from among the received plurality of previous blocks. The previous block 108 to be selected is determined from among the received plurality of previous blocks based on majority rule. However, the block receiver 49 needs to receive many previous blocks so that a result of the majority rule is reliable. Thus, each of the terminals 11x becomes burdensome in performing the process of receiving blocks.
In contrast, when each of the terminals 11x does not store the previous block, the previous block 108 is received from the selected terminal from which the previous block 108 has been transmitted in Embodiment 3. Thus, the block receiver 49 need not receive many previous blocks. Thus, each of the terminals 11x is less burdensome in performing the process of receiving blocks.
Embodiments can be freely combined, and each of Embodiments can be appropriately modified or omitted.
Although Embodiments are described in detail, the foregoing description is in all aspects illustrative, and does not restrict Embodiments. Therefore, numerous modifications and variations that have not yet been exemplified are devised.
1, 2, 3 contract transaction system, 11 plurality of terminals, 12 Certificate Authority, 21 P2P network, 41 authentication information obtaining unit, 42 bid data obtaining unit, 43 bid data transmitter, 44 contract result calculator, 45 contract result transmitter, 46 contract result receiver, 47 contract result examining unit, 48 contract result selector, 49 block receiver, 50 block selector, 51 contract result storage, 52 incentive calculator, 53 terminal evaluator.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/JP2020/003410 | 1/30/2020 | WO |