JP5871347B1 - Virtual currency management program and virtual currency management method - Google Patents

Virtual currency management program and virtual currency management method Download PDF

Info

Publication number
JP5871347B1
JP5871347B1 JP2015048690A JP2015048690A JP5871347B1 JP 5871347 B1 JP5871347 B1 JP 5871347B1 JP 2015048690 A JP2015048690 A JP 2015048690A JP 2015048690 A JP2015048690 A JP 2015048690A JP 5871347 B1 JP5871347 B1 JP 5871347B1
Authority
JP
Japan
Prior art keywords
remittance
transaction
amount
virtual currency
unit
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
JP2015048690A
Other languages
Japanese (ja)
Other versions
JP2016170530A (en
Inventor
賢爾 斉藤
賢爾 斉藤
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
ORB Inc
Original Assignee
ORB Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by ORB Inc filed Critical ORB Inc
Priority to JP2015048690A priority Critical patent/JP5871347B1/en
Application granted granted Critical
Publication of JP5871347B1 publication Critical patent/JP5871347B1/en
Publication of JP2016170530A publication Critical patent/JP2016170530A/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Landscapes

  • Financial Or Insurance-Related Operations Such As Payment And Settlement (AREA)

Abstract

【課題】マイナーに対して報酬を無限に支払い続けることが可能であり、価値の変動の少ない仮想通貨を提供する、仮想通貨管理プログラム、及び仮想通貨管理方法を提供する。【解決手段】コンピュータを、仮想通貨を送金する第1の取引における第1の送金金額及び第1の送金日時を含む第1の取引情報と、第1の送金金額の少なくとも一部を送金する第2の取引における第2の送金金額及び第2の送金日時を含む第2の取引情報と、を記憶する記憶手段、第2の取引情報の正当性を検証する手段、第1の送金日時と第2の送金日時との差分と、第1の送金金額とに基づいて、第1の送金金額の前記第2の送金日時における減価額を計算する手段、及び減価額に基づいて、第2の取引情報の検証者への報酬額を決定する手段として機能させる。【選択図】図1The present invention provides a virtual currency management program and a virtual currency management method, which can continue to pay an infinite remuneration to a minor and provide a virtual currency with little fluctuation in value. A first remittance information including a first remittance amount and a first remittance date and time in a first transaction for remittance of virtual currency, and at least a part of the first remittance amount. Storage means for storing the second remittance amount and second remittance date and time in the second transaction, means for verifying the validity of the second transaction information, first remittance date and 2 based on the difference between the remittance date and time of the second remittance and the first remittance amount, the second remittance based on the means for calculating the reduced amount of the first remittance amount at the second remittance date and time It functions as a means for determining the amount of reward for the verifier of information. [Selection] Figure 1

Description

本発明は、仮想通貨管理プログラム、及び仮想通貨管理方法等に関する。   The present invention relates to a virtual currency management program, a virtual currency management method, and the like.

近年、円やドルといった現実の貨幣による物品の取引だけでなく、電子マネー等の仮想通貨を用いた商取引が行われている。非特許文献1には、ビットコインと呼ばれる仮想通貨を用いて取引を行う技術について開示されている。
ビットコインによる取引では、ハッシュ関数と公開鍵暗号方式とを用いて、取引データの完全性が担保されている。暗号化を用いて行われた取引(以下、ビットコインの取引を「トランザクション」とも呼ぶ)は、ビットコインを利用する全端末に対してブロードキャストで配信される。配信されたトランザクションは、マイナー(発掘者)と呼ばれる端末ソフトウェアによって正当性が検証され、承認されると発掘されたブロックにまとめられ、ブロックチェーンと呼ばれる台帳に記録される。
In recent years, not only transactions of goods using real money such as yen and dollars but also business transactions using virtual currency such as electronic money have been carried out. Non-Patent Document 1 discloses a technique for performing a transaction using a virtual currency called bitcoin.
In the transaction using Bitcoin, the integrity of the transaction data is secured using a hash function and a public key cryptosystem. Transactions performed using encryption (hereinafter, bitcoin transactions are also referred to as “transactions”) are distributed by broadcast to all terminals using bitcoins. The delivered transactions are verified for validity by terminal software called a miner (digger), and when approved, they are collected into excavated blocks and recorded in a ledger called a block chain.

非特許文献1には、マイナーがブロックを発掘した際に、当該マイナーに対して報酬を支払う方法について開示されている。非特許文献1に記載の方法によれば、ブロックを発掘したマイナーは、報酬として新たなビットコインを獲得できる。具体的には、ブロックに格納する先頭のトランザクションを、「無」から自分に宛てられたトランザクションとして格納することで、報酬とすることができる。   Non-Patent Document 1 discloses a method of paying a reward to a miner when the miner finds a block. According to the method described in Non-Patent Document 1, a minor who has found a block can acquire a new bit coin as a reward. Specifically, the first transaction stored in the block can be rewarded by storing it as a transaction addressed to itself from “No”.

斉藤賢爾著、「これでわかった ビットコイン [生き残る通貨の条件]」、初版、太郎次郎社エディタス、2014年5月5日、p.87−89By Kengo Saito, “Bitcoin I understand now [Conditions for Surviving Currency]”, first edition, Taro Jiro Editors, May 5, 2014, p. 87-89

ビットコインの総量はあらかじめ定められている。そのため、非特許文献1に記載の方法の場合、マイナーが受け取る報酬は、4年ごとに半分となり、すべてのブロックが発掘されると、マイナーが受け取れる報酬は取引手数料のみとなってしまう。報酬が取引手数料だけでは、マイニングのコストに見合わず、マイニングを行うマイナーがいなくなってしまうおそれがある。
また、ビットコインは現実の貨幣と相互に交換可能であるため、投資の対象となり、その価値が安定しない。
The total amount of bit coins is predetermined. Therefore, in the case of the method described in Non-Patent Document 1, the reward received by the miner is halved every four years, and when all the blocks are excavated, the reward that the miner can receive is only the transaction fee. If the transaction fee is only the reward, it does not match the mining cost, and there is a risk that the mining miner will disappear.
In addition, since bit coins can be exchanged with real money, they are the target of investment and their value is not stable.

そこで、本発明は、上記事情に鑑み、マイナーに対して報酬を支払い続けることが可能であり、価値の変動の少ない仮想通貨を提供する、仮想通貨管理プログラム、及び仮想通貨管理方法を提供することを目的とするものである。   Therefore, in view of the above circumstances, the present invention provides a virtual currency management program and a virtual currency management method that can provide a virtual currency that can continue to pay a minor to a minor and has little fluctuation in value. It is intended.

本発明による仮想通貨管理プログラムは、コンピュータを、仮想通貨を送金する第1の取引における第1の送金金額及び第1の送金日時を含む第1の取引情報と、第1の送金金額の少なくとも一部を送金する第2の取引における第2の送金金額及び第2の送金日時を含む第2の取引情報と、を記憶する記憶手段、第2の取引情報の正当性を検証する手段、第1の送金日時と第2の送金日時との差分と、第1の送金金額とに基づいて、第1の送金金額の前記第2の送金日時における減価額を計算する手段、及び減価額に基づいて、第2の取引情報の検証者への報酬額を決定する手段として機能させるものを含む。   The virtual currency management program according to the present invention causes the computer to execute at least one of the first transaction information including the first remittance amount and the first remittance date and time in the first transaction for remittance of the virtual currency, and the first remittance amount. Storage means for storing the second remittance amount and the second remittance information including the second remittance date and time in the second transaction for remittance of the part, means for verifying the validity of the second transaction information, A means for calculating a depreciation value of the first remittance amount at the second remittance date and time based on the difference between the remittance date and time and the second remittance date and the first remittance amount, and , Including a function that functions as a means for determining a reward amount to the verifier of the second transaction information.

また、本発明による仮想通貨管理方法は、コンピュータが、仮想通貨を送金する第1の取引における第1の送金金額及び第1の送金日時を含む第1の取引情報と、第1の送金金額の少なくとも一部を送金する第2の取引における第2の送金金額及び第2の送金日時を含む第2の取引情報と、を記憶するステップと、第2の取引情報の正当性を検証するステップと、第1の送金日時と第2の送金日時との差分と、第1の送金金額とに基づいて、第1の送金金額の第2の送金日時における減価額を計算するステップと、減価額に基づいて、第2の取引情報の検証者への報酬額を決定するステップとを実行する方法を含む。   Further, the virtual currency management method according to the present invention includes a first transaction information including a first remittance amount and a first remittance date and time in a first transaction in which the computer remits the virtual currency, and the first remittance amount. Storing a second remittance amount and a second remittance information including a second remittance date and time in a second remittance for remittance at least in part, and verifying validity of the second transaction information; Calculating a depreciation amount of the first remittance amount at the second remittance date and time based on the difference between the first remittance date and the second remittance date and the first remittance amount; And determining a reward amount for the verifier of the second transaction information based on the method.

本発明のプログラムは、CD−ROM等の光学ディスク、磁気ディスク、半導体メモリなどの各種の記録媒体を通じて、又は通信ネットワークなどを介してダウンロードすることにより、コンピュータにインストール又はロードすることができる。   The program of the present invention can be installed or loaded on a computer through various recording media such as an optical disk such as a CD-ROM, a magnetic disk, or a semiconductor memory, or via a communication network.

また、本明細書等において、「部」とは、単に物理的構成を意味するものではなく、その構成が有する機能をソフトウェアによって実現する場合も含む。また、1つの構成が有する機能が2つ以上の物理的構成により実現されても、2つ以上の構成の機能が1つの物理的構成により実現されてもよい。   Further, in this specification and the like, the “unit” does not simply mean a physical configuration, but also includes a case where the functions of the configuration are realized by software. In addition, functions of one configuration may be realized by two or more physical configurations, or functions of two or more configurations may be realized by one physical configuration.

本発明によれば、マイナーに対して報酬を支払い続けることが可能であり、価値の変動の少ない仮想通貨を提供する、仮想通貨管理プログラム、及び仮想通貨管理方法を提供することができる。   According to the present invention, it is possible to provide a virtual currency management program and a virtual currency management method that can continue to pay a minor to a minor and provide a virtual currency with little fluctuation in value.

本発明の実施形態における仮想通貨システムの構成図である。It is a block diagram of the virtual currency system in embodiment of this invention. 本発明の実施形態における端末の機能ブロックの一例を示す図である。It is a figure which shows an example of the functional block of the terminal in embodiment of this invention. 本発明の実施形態における仮想通貨の、経過時間と減価額との対応関係の一例を示す図である。It is a figure which shows an example of the correspondence of the elapsed time and the depreciation of the virtual currency in the embodiment of the present invention. 本発明の実施形態におけるトランザクションの一例を示す図である。It is a figure which shows an example of the transaction in embodiment of this invention. 本発明の実施形態におけるマイニング処理の流れの一例を示す図である。It is a figure which shows an example of the flow of the mining process in embodiment of this invention. 本発明の実施形態における端末のハードウェア構成の一例を示す図である。It is a figure which shows an example of the hardware constitutions of the terminal in embodiment of this invention.

[第1の実施形態]
以下、本発明の実施の形態の1つについて詳細に説明する。なお、以下の実施の形態は、本発明を説明するための例示であり、本発明をその実施の形態のみに限定する趣旨ではない。また、本発明は、その要旨を逸脱しない限り、さまざまな変形が可能である。さらに、当業者であれば、以下に述べる各要素を均等なものに置換した実施の形態を採用することが可能であり、かかる実施の形態も本発明の範囲に含まれる。またさらに、必要に応じて示す上下左右等の位置関係は、特に断らない限り、図示の表示に基づくものとする。さらにまた、図面における各種の寸法比率は、その図示の比率に限定されるものではない。
[First Embodiment]
Hereinafter, one embodiment of the present invention will be described in detail. The following embodiments are examples for explaining the present invention, and are not intended to limit the present invention only to the embodiments. The present invention can be variously modified without departing from the gist thereof. Furthermore, those skilled in the art can employ embodiments in which the elements described below are replaced with equivalent ones, and such embodiments are also included in the scope of the present invention. Furthermore, positional relationships such as up, down, left, and right shown as needed are based on the display shown unless otherwise specified. Furthermore, various dimensional ratios in the drawings are not limited to the illustrated ratios.

<1.システム構成の概要>
図1は、仮想通貨システム10の構成の一例を示している。図1に示すように、仮想通貨システム10は、本発明に係る仮想通貨管理プログラムをインストールした、複数のクライアント装置同士が互いに通信を行う、P2Pの構成となっている。図1の例では、仮想通貨を用いて取引を行うユーザのクライアント端末を端末100A〜C(以下、端末100A〜Cをまとめて「端末100」とも呼ぶ。)、トランザクションの検証や承認を行うユーザのクライアント端末を端末200A〜C(以下、端末200A〜Cをまとめて「端末200」とも呼ぶ。)として説明する。
<1. Overview of system configuration>
FIG. 1 shows an example of the configuration of the virtual currency system 10. As shown in FIG. 1, the virtual currency system 10 has a P2P configuration in which a plurality of client devices that have installed the virtual currency management program according to the present invention communicate with each other. In the example of FIG. 1, client terminals of users who perform transactions using virtual currency are terminals 100A to 100C (hereinafter, terminals 100A to 100C are collectively referred to as “terminal 100”), and users who verify and approve transactions. Are described as terminals 200A to 200C (hereinafter, terminals 200A to 200C are collectively referred to as “terminal 200”).

端末100及び端末200は、インターネットや専用線等のネットワーク400に接続されたコンピュータである。具体的には、携帯電話やスマートフォン、PC(Personal Computer)、PDA(Personal Digital Assistants)、タブレット、ウェアラブル(Wearable)端末等が挙げられるが、これに限られない。ネットワーク400に有線又は無線で接続された装置100及び200が、互いに通信可能に設定されることにより、仮想通貨システム10を構成する。なお、本実施形態において、仮想通貨システム10は、P2P型のシステムであるとして説明するが、これに限定されるものではない。例えば、仮想通貨システム10は、クラウドコンピューティング形式のシステムとして構成されてもよい。この場合、ユーザは、仮想通貨システム10のコンピュータ処理をネットワーク経由でサービスとして利用する。また、仮想通貨システム10は、ASP(Application Service Provider)のサーバを含むシステムとして構成されてもよい。   The terminal 100 and the terminal 200 are computers connected to a network 400 such as the Internet or a dedicated line. Specific examples include a mobile phone, a smartphone, a PC (Personal Computer), a PDA (Personal Digital Assistant), a tablet, and a wearable terminal. The devices 100 and 200 connected to the network 400 by wire or wirelessly are set to be communicable with each other, so that the virtual currency system 10 is configured. In the present embodiment, the virtual currency system 10 is described as being a P2P type system, but is not limited thereto. For example, the virtual currency system 10 may be configured as a cloud computing system. In this case, the user uses the computer processing of the virtual currency system 10 as a service via the network. Moreover, the virtual currency system 10 may be configured as a system including an ASP (Application Service Provider) server.

<2.仮想通貨の概要>
まず、仮想通貨システム10によって提供される仮想通貨(以下、仮想通貨システム10によって提供される仮想通貨を「オーブ」とも呼ぶ。)の概要について説明する。オーブは既存のビットコインと同様に、インターネットを用いたP2Pデジタル通貨であり、公開鍵暗号方式とハッシュ関数を用いたデジタル署名によって取引情報の完全性が担保されている。また、オーブの取引に関する情報や履歴は、仮想通貨システム10全体で分散して管理される。なお、本実施形態においてオーブは最小単位が「1Orb」である通貨として説明する。
<2. Overview of virtual currency>
First, the outline of the virtual currency provided by the virtual currency system 10 (hereinafter, the virtual currency provided by the virtual currency system 10 is also referred to as “orb”) will be described. Orb is a P2P digital currency using the Internet, like the existing Bitcoin, and the integrity of transaction information is secured by a digital signature using a public key cryptosystem and a hash function. In addition, information and history regarding orb transactions are distributed and managed in the entire virtual currency system 10. In the present embodiment, the orb will be described as a currency whose minimum unit is “1Orb”.

オーブを利用するユーザは、まず仮想通貨管理プログラムをインストールする必要がある。仮想通貨管理プログラムには、ウォレットツールとマイニングツールとが含まれていることが望ましい。ウォレットツールは、オーブの購入やオーブを用いた取引を行うために必要なツールをいう。一方で、マイニングツールは、オーブを用いた取引の完全性や整合性を検証し、取引を承認するために必要なツールをいう。   A user who uses an orb must first install a virtual currency management program. The virtual currency management program preferably includes a wallet tool and a mining tool. The wallet tool is a tool necessary to purchase orbs and conduct transactions using the orbs. On the other hand, the mining tool refers to a tool necessary for verifying the integrity and consistency of a transaction using an orb and approving the transaction.

ウォレットツールをクライアント端末にインストールしたユーザには、ネットワーク400に一意なアドレスが割り当てられる(以下、「口座アドレス」とも呼ぶ。)。口座アドレスを取得したユーザは、オーブを購入することができるようになる。「オーブを購入する」とは、仮想通貨システム10に新たなオーブを発生させることをいう。具体的には、ユーザによって、任意の金額の現実の通貨からオーブへと換金されることを指す。   A user who installs the wallet tool on the client terminal is assigned a unique address in the network 400 (hereinafter also referred to as “account address”). The user who has acquired the account address can purchase the orb. “Purchase an orb” means that a new orb is generated in the virtual currency system 10. Specifically, it means that an arbitrary amount of real currency is converted into an orb by the user.

さらにユーザは、購入したオーブを他のユーザに送金することができる。「オーブを送金する」とは、元の所有者から新たな所有者へとオーブの受け渡しが行われることをいう。   Further, the user can remit the purchased orb to another user. “Transmit the orb” means that the orb is transferred from the original owner to the new owner.

オーブの購入や送金に関するデータ(以下、オーブの購入や送金に関するデータを「トランザクション」とも呼ぶ。特に、オーブの購入に関するデータを「通貨発生トランザクション」とも呼ぶ。)は、後述するブロックチェーンと呼ばれる構造体によって管理される。ブロックチェーンは、ブロックと呼ばれるデータが時系列に並べられたものであり、オーブの送金を記した台帳としての役割を有している。マイニングツールをウォレットツールに加えてクライアント端末にインストールしたユーザ(以下、ウォレットツールのみをインストールしたユーザを単に「ユーザ」と呼び、ウォレットツールとマイニングツールとをインストールしたユーザを「マイナー」と呼ぶ。)は、トランザクションの正当性を検証し、正当なトランザクションを承認することができる。さらにマイナーは、承認済みのトランザクションから構成されるブロックを生成(以下、ブロックを生成することを「ブロックを発掘する」とも呼ぶ。)して、ブロックチェーンにつなぐことができる。   Data related to orb purchase and remittance (hereinafter, data related to orb purchase and remittance is also referred to as “transaction”. In particular, data related to orb purchase is also referred to as “currency-generating transaction”) Managed by the body. The block chain is a series of data called blocks, and serves as a ledger that records the remittance of orbs. A user who has installed the mining tool on the client terminal in addition to the wallet tool (hereinafter, a user who has installed only the wallet tool is simply referred to as “user”, and a user who has installed the wallet tool and mining tool is referred to as “minor”) Can verify the legitimacy of a transaction and approve a legitimate transaction. Further, a minor can generate a block composed of approved transactions (hereinafter, generating a block is also referred to as “excavating a block”) and connecting it to a block chain.

なお、オーブは、購入時から時間の経過とともに、減価するように構成されている。そのため、オーブを購入したユーザは、オーブが減価によって消滅してしまう前に消費する必要がある。オーブが減価するように構成されることで、ユーザは投資の対象とせず、結果として、オーブの価値を安定させることが可能になる。   The orb is configured to depreciate as time passes from the time of purchase. Therefore, the user who purchased the orb needs to consume it before the orb disappears due to depreciation. By configuring the orb to depreciate, the user is not the target of the investment, and as a result, the value of the orb can be stabilized.

<3.機能構成>
次に、図2を用いて、本実施形態に係る仮想通貨管理プログラムをインストールした端末100及び200の機能構成について説明する。
<3−1.ウォレットツールの機能>
図2(A)は、ウォレットツールをインストールした、端末100の機能ブロック図の一例を示す図である。ウォレットツールをインストールした端末100には、トランザクションDB131と、ブロック情報DB132と、公開鍵情報DB133と、口座情報DB134と、送金受付部101と、インプットデータ作成部102と、アウトプットデータ作成部103と、トランザクション配信部104とが構築されることが望ましい。
<3. Functional configuration>
Next, the functional configuration of the terminals 100 and 200 installed with the virtual currency management program according to the present embodiment will be described with reference to FIG.
<3-1. Wallet Tool Functions>
FIG. 2A is a diagram illustrating an example of a functional block diagram of the terminal 100 in which the wallet tool is installed. In the terminal 100 in which the wallet tool is installed, a transaction DB 131, a block information DB 132, a public key information DB 133, an account information DB 134, a remittance accepting unit 101, an input data creating unit 102, an output data creating unit 103, The transaction delivery unit 104 is preferably constructed.

トランザクション情報DB131には、端末100又は200がネットワーク400にブロードキャストで配信したトランザクションの履歴が保存されている。1つのトランザクションには、通常、インプットデータ、アウトプットデータ、トランザクションが発生した時刻、トランザクションが後述するブロックチェーンに追加された時刻が含まれることが望ましい。なお、オーブの購入時に配信される通貨発生トランザクションには、インプットデータは含まれないとしてもよい。   The transaction information DB 131 stores a history of transactions distributed by the terminal 100 or 200 to the network 400 by broadcast. In general, it is desirable that one transaction includes input data, output data, time when the transaction occurs, and time when the transaction is added to a block chain described later. Note that the currency generation transaction distributed at the time of purchasing the orb may not include input data.

アウトプットデータには、送金されるオーブの金額と、送金先の口座アドレスとが含まれていることが望ましい。なお、アウトプットデータは、送金先の口座アドレスの代わりに、送金先のユーザを特定できる情報を含めばよく、たとえば、送金先ユーザの公開鍵を含んでも良い。   The output data preferably includes the amount of the orb to be transferred and the account address of the transfer destination. Note that the output data may include information that can identify the user of the remittance destination instead of the account address of the remittance destination, and may include, for example, the public key of the remittance destination user.

インプットデータには、今回送金するオーブを送金元ユーザが受け取ったトランザクションのアウトプットデータへのポインタと、後述する電子署名作成処理によって作成される送金元ユーザの電子署名とが含まれていることが望ましい。   The input data includes a pointer to the output data of the transaction in which the remittance user has received the orb to be remitted this time, and the remittance user's electronic signature created by the electronic signature creation process described later. desirable.

オーブを用いた取引では、過去に受け取った、又は購入したオーブを送金対象として指定し、別のユーザへと送金する。そのため、送金を行う際には、過去のトランザクションから、送金元ユーザが送金先ユーザとなったアウトプットデータを今回の送金対象として指定する必要がある。このように、オーブのトランザクションは、インプットデータが1つ前のアウトプットデータへのポインタを有する構造をしている。その結果、すべてのトランザクションは、通貨発生トランザクションまでポインタを介して数珠つなぎとなるデータ構造となっている。   In a transaction using an orb, an orb received or purchased in the past is designated as a remittance target and remittance to another user. For this reason, when performing remittance, it is necessary to designate output data in which the remittance source user has become the remittance destination user from the past transaction as the current remittance target. Thus, the orb transaction has a structure in which input data has a pointer to the previous output data. As a result, all transactions have a data structure that is linked in a daisy chain through pointers to currency generation transactions.

ブロック情報DB132には、生成されたブロックに関する情報が保存されている。ブロックには、マイナーが正当性を検証して承認した複数のトランザクションが格納されている。オーブの購入や送金は、ブロックチェーンと呼ばれる構造体によって管理されている。ブロックチェーンは、ブロックと呼ばれるデータが時系列に並べられたものをいう。ブロックチェーンは仮想通貨システム10の全端末が共有するが、ユーザはブロックチェーンのうち自己が関心をもつ部分のみを所持していればよい。マイナーはブロックチェーンの全体を所持していることが望ましい。
ブロックには、1つ前のブロックのハッシュ、及び複数のトランザクションが含まれている。
The block information DB 132 stores information about the generated block. The block stores a plurality of transactions that the minor has verified and approved. Orb purchases and remittances are managed by a structure called a blockchain. A block chain refers to data called blocks arranged in time series. The block chain is shared by all terminals of the virtual currency system 10, but the user only needs to have a portion of the block chain that he is interested in. It is desirable that the minor possesses the entire block chain.
The block includes a hash of the previous block and a plurality of transactions.

公開鍵情報DB133には、仮想通貨システム10に含まれる全ユーザの口座アドレスと、公開鍵とが対応付けられて保存されている。   In the public key information DB 133, account addresses of all users included in the virtual currency system 10 and public keys are stored in association with each other.

口座情報DB134には、上述した口座アドレスが割り当てられていて、端末100を利用するユーザの秘密鍵が保存されている。   The account information DB 134 is assigned with the account address described above, and stores the secret key of the user who uses the terminal 100.

送金受付部101は、ユーザから送金先のユーザと送金する金額との指定を受け付ける。送金受付部101は、送金受付画面を端末100のディスプレイに提示することが望ましい。また、送金受付部101は通貨購入画面をディスプレイに提示して、ユーザからオーブの購入を受け付けてもよい。   The remittance accepting unit 101 accepts designation of the remittance destination user and the amount of money to be remittance from the user. It is desirable that the remittance acceptance unit 101 presents a remittance acceptance screen on the display of the terminal 100. Further, the remittance accepting unit 101 may present the currency purchase screen on the display and accept the purchase of the orb from the user.

インプットデータ作成部102は、送金受付部101が受け付けた送金金額に応じてインプットデータを作成する。インプットデータ作成部102は、インプットデータを作成するために、以下の4つの処理を行う。
・送金対象検索処理
・減価額計算処理
・ポインタ指定処理
・電子署名作成処理
The input data creation unit 102 creates input data according to the remittance amount received by the remittance accepting unit 101. The input data creation unit 102 performs the following four processes in order to create input data.
・ Remittance object search processing ・ Price reduction calculation processing ・ Pointer designation processing ・ Digital signature creation processing

(送金対象検索処理)
インプットデータ作成部102は、送金対象検索処理として、まず、送金対象として用いることができるアウトプットデータを有するトランザクションをトランザクション情報DB131から検索することができる。たとえば、インプットデータ作成部102は、トランザクション情報DB131から、送金元ユーザの口座アドレスが、送金先アドレスとして指定されているアウトプットを有するトランザクションであって、他のトランザクションのインプットデータのポインタとして指定されていないアウトプットデータを有するトランザクションを抽出することが望ましい。
(Remittance target search process)
As the remittance target search process, the input data creation unit 102 can first search the transaction information DB 131 for a transaction having output data that can be used as a remittance target. For example, the input data creation unit 102 is a transaction having an output in which the account address of the remittance source user is designated as the remittance destination address from the transaction information DB 131, and is designated as a pointer to input data of another transaction. It is desirable to extract transactions that have output data that is not.

(減価額計算処理)
次に、インプットデータ作成部102は、抽出したトランザクションのアウトプットデータに含まれる送金金額を参照し、現在までに減額した金額(減価額)を計算する。まず、インプットデータ作成部102は、抽出したトランザクションのインプットデータに含まれるポインタを順次参照していき、通貨発生トランザクションを抽出する。そして、インプットデータ作成部102は、通貨発生トランザクションのトランザクション発生時刻を参照し、現在時刻との差分に基づいて減価率を計算する。
(Depreciation calculation processing)
Next, the input data creation unit 102 refers to the remittance amount included in the output data of the extracted transaction, and calculates the amount (reduced price) that has been reduced to date. First, the input data creation unit 102 sequentially refers to the pointers included in the input data of the extracted transaction, and extracts a currency generating transaction. Then, the input data creation unit 102 refers to the transaction occurrence time of the currency generation transaction, and calculates the depreciation rate based on the difference from the current time.

図3は、時間の経過とオーブの残高率との対応関係の一例を示す図である。図3の例では、オーブが購入されてから10日経過するごとに現在の金額から10%減価する様子を示している。オーブの減価率が図3の表のように定義されている場合には、インプットデータ作成部102は、たとえば購入から22日経過したオーブに対しては、現在の残高は購入時の残高の81%であり、減価率は19%であると算出する。なお、オーブの減価の態様は図3の例に限定されず、たとえば、時間の経過ごとに一定金額が減額されるとしてもよいし、時間の経過につれて減価率が変化してもよい。
インプットデータ作成部102は、抽出したトランザクションのアウトプットデータの金額と計算した現在の減価率を用いて、当該金額の減価額を計算することができる。
FIG. 3 is a diagram illustrating an example of a correspondence relationship between the passage of time and the balance rate of the orb. In the example of FIG. 3, a state in which the current amount is deducted by 10% every 10 days after the orb is purchased is shown. When the depreciation rate of the orb is defined as shown in the table of FIG. 3, the input data creation unit 102, for example, for an orb that has passed 22 days from the purchase, the current balance is 81 of the balance at the time of purchase. % And the depreciation rate is calculated to be 19%. The manner in which the orb is depreciated is not limited to the example in FIG. 3. For example, a certain amount of money may be reduced as time elapses, or the depreciation rate may change as time elapses.
The input data creation unit 102 can calculate the depreciation of the amount using the amount of the output data of the extracted transaction and the calculated current depreciation rate.

(ポインタ指定処理)
次に、インプットデータ作成部102は、送金受付部101が受け付けた送金金額に基づいて、抽出したトランザクションの中から、ポインタを指定するのに適したアウトプットデータを選択する。具体的には、インプットデータ作成部102は、抽出したアウトプットデータの金額と、計算した減価率とに基づいて、各アウトプットデータの残高を計算する。そして、計算した残高が、送金受付部101が受け付けた送金金額を上回っているアウトプットデータへのポインタを、今回のインプットデータとして指定することができる。
なお、計算した残高が、送金受付部101が受け付けた送金金額を上回っているアウトプットデータが存在しない場合には、本実施形態では、インプットデータ作成部102は、送金金額をいくつかの金額へ分割したうえで、再度、計算した残高が分割した金額を上回っているアウトプットデータを検索することが望ましい。なお、これに限定されず、今回の送金金額よりも大きな金額のアウトプットデータを有するトランザクションが存在しない場合には、インプットデータ作成部102は、複数のアウトプットデータのポインタを指定するために複数のインプットデータを作成するとしてもよい。
(Pointer specification processing)
Next, the input data creation unit 102 selects output data suitable for designating a pointer from the extracted transactions based on the remittance amount received by the remittance reception unit 101. Specifically, the input data creation unit 102 calculates the balance of each output data based on the amount of the extracted output data and the calculated depreciation rate. Then, a pointer to output data in which the calculated balance exceeds the remittance amount accepted by the remittance accepting unit 101 can be designated as current input data.
When there is no output data in which the calculated balance exceeds the remittance amount accepted by the remittance acceptance unit 101, in this embodiment, the input data creation unit 102 changes the remittance amount to some amount. After dividing, it is desirable to search again for output data in which the calculated balance exceeds the divided amount. Note that the present invention is not limited to this, and when there is no transaction having output data with an amount larger than the current remittance amount, the input data creation unit 102 specifies a plurality of output data pointers. The input data may be created.

インプットデータ作成部102は、送金受付部101が複数のユーザへの送金を受け付けた場合には、受け付けた送金金額の合計金額に基づいてポインタを選択することが望ましい。   When the remittance accepting unit 101 accepts remittance to a plurality of users, the input data creating unit 102 desirably selects a pointer based on the total amount of accepted remittance amounts.

(電子署名作成処理)
さらに、インプットデータ作成部102は、送金元ユーザの電子署名を作成する。たとえば、インプットデータ作成部102は、電子署名を格納する部分を除く、作成中のトランザクションのデータ全体から、ハッシュ関数を使ってダイジェストを生成する。そして、インプットデータ作成部102は、生成したダイジェストを送金元ユーザの秘密鍵で暗号化することで電子署名を作成することができる。
(Digital signature creation process)
Further, the input data creation unit 102 creates an electronic signature of the remittance source user. For example, the input data creation unit 102 generates a digest using a hash function from the entire data of the transaction being created, excluding the part that stores the electronic signature. The input data creation unit 102 can create an electronic signature by encrypting the generated digest with the private key of the remittance source user.

図2(A)に戻り、各機能ブロックの機能の続きについて説明する。
アウトプットデータ作成部103は、送金受付部101が受け付けた、送金先のユーザと送金する金額とに基づいて、アウトプットデータを作成する。たとえば、アウトプットデータ作成部103は、公開鍵情報DB133を参照して、送信先ユーザに対応する口座アドレスをアウトプットデータに指定することができる。
また、アウトプットデータ作成部103は、インプットデータ作成部102がポインタを指定したアウトプットデータの残高から、今回の送金金額の合計金額を減算し、差額を、送金元ユーザ宛の送金としてアウトプットデータを作成することが望ましい。
Returning to FIG. 2A, the continuation of the function of each functional block will be described.
The output data creation unit 103 creates output data based on the remittance destination user and the amount to be remittance received by the remittance accepting unit 101. For example, the output data creation unit 103 can refer to the public key information DB 133 and designate an account address corresponding to the transmission destination user as output data.
Further, the output data creation unit 103 subtracts the total amount of the current remittance amount from the balance of the output data designated by the input data creation unit 102, and outputs the difference as a remittance to the remittance source user. It is desirable to create data.

なお、アウトプットデータ作成部103は、送金受付部101が、ユーザからオーブの購入を受け付けた場合には、オーブの購入を入力したユーザを送金先ユーザとして、アウトプットデータを作成することが望ましい。   In addition, when the remittance accepting unit 101 accepts the purchase of the orb from the user, the output data creating unit 103 desirably creates the output data with the user who inputs the orb purchase as the remittance destination user. .

トランザクション配信部104は、今回の送金に関するトランザクションを作成し、ネットワーク400へと配信する。トランザクション配信部104は、以下の2種類のトランザクションを作成する処理を行う。
・通常トランザクション(以下、通常トランザクションのことを単に「トランザクション」とも呼ぶ。)
・通貨発生トランザクション
The transaction distribution unit 104 creates a transaction related to the current remittance and distributes it to the network 400. The transaction delivery unit 104 performs processing for creating the following two types of transactions.
Normal transaction (hereinafter, the normal transaction is also simply referred to as “transaction”)
-Currency generation transaction

(通常トランザクション)
通常トランザクションは、オーブの送金が行われた場合に、トランザクション配信部104が配信するトランザクションをいう。通常トランザクションには、インプットデータと、アウトプットデータと、トランザクションが発生した時刻と、トランザクションがブロックチェーンに追加された時刻とが含まれる。
トランザクション配信部104は、インプットデータ作成部102が作成したインプットデータと、アウトプットデータ作成部103が作成したアウトプットデータと、を通常トランザクションに格納し、さらに現在時刻をトランザクション発生時刻に指定して、通常トランザクションをネットワーク400へブロードキャストで配信することができる。
(Normal transaction)
The normal transaction refers to a transaction distributed by the transaction distribution unit 104 when orb remittance is performed. A normal transaction includes input data, output data, the time when the transaction occurred, and the time when the transaction was added to the block chain.
The transaction distribution unit 104 stores the input data created by the input data creation unit 102 and the output data created by the output data creation unit 103 in a normal transaction, and further specifies the current time as the transaction occurrence time. The normal transaction can be broadcast to the network 400.

(通貨発生トランザクション)
通貨発生トランザクションは、オーブが購入された場合にトランザクション配信部104が配信するトランザクションをいう。すべてのトランザクションは、インプットデータのポインタを参照していくと通貨発生トランザクションに収束する。
通貨発生トランザクションには、インプットデータは含まれないことが望ましい。トランザクション配信部104は、アウトプットデータ作成部103が作成した、オーブの購入を入力したユーザを送金先ユーザとするアウトプットデータを通貨発生トランザクションに格納し、さらに現在時刻をトランザクション発生時刻に指定して、通貨発生トランザクションをネットワーク400にブロードキャストで配信することができる。
(Currency transaction)
A currency generation transaction refers to a transaction distributed by the transaction distribution unit 104 when an orb is purchased. All transactions converge to a currency generation transaction by referring to the input data pointer.
The currency generation transaction should not include input data. The transaction distribution unit 104 stores the output data created by the output data creation unit 103 and used as the remittance user as the remittance user, and designates the current time as the transaction occurrence time. Thus, the currency generation transaction can be broadcast to the network 400.

<3−2.オーブ送金処理フロー>
次に図4を用いて、ユーザAがユーザBへオーブを送金する際の処理フローについて説明する。図4は、ユーザAが端末100Aを用いて、購入したオーブをユーザBへ送金する場合のトランザクションを模式的に示した図である。
この例では、オーブの送金元ユーザであるユーザAが利用する端末を端末100A、オーブの送金先ユーザであるユーザBが利用する端末をそれぞれ端末100Bとして説明する。また、図4の例においても、経過時間とオーブの減価率とは図3に示した対応関係にあるとして説明する。
<3-2. Orb remittance processing flow>
Next, a processing flow when the user A remits the orb to the user B will be described with reference to FIG. FIG. 4 is a diagram schematically showing a transaction when the user A remits the purchased orb to the user B using the terminal 100A.
In this example, the terminal used by the user A who is the orb remittance source user is described as the terminal 100A, and the terminal used by the user B who is the orb remittance destination user is described as the terminal 100B. Also, in the example of FIG. 4, the description will be made assuming that the elapsed time and the orb depreciation rate have the correspondence shown in FIG.

図4において、ブロックB02は、ブロックチェーンの末尾のブロックであり、ブロックB01はブロックB02の1つ前のブロックであるとする。また、トランザクションT11は通貨発生トランザクションであり、トランザクションT12は、ユーザAからユーザBへのオーブの送金に関する通常トランザクションである。さらに、O11〜O13はそれぞれアウトプットデータを表し、I11はインプットデータを表している。   In FIG. 4, block B02 is the last block in the block chain, and block B01 is the block immediately preceding block B02. Transaction T11 is a currency generation transaction, and transaction T12 is a normal transaction related to remittance of orbs from user A to user B. Further, O11 to O13 each represent output data, and I11 represents input data.

まず、ユーザAがオーブを10000Orb購入するとする。この場合、送金受付部101によって、通貨購入画面が端末100Aのディスプレイに提示される。ユーザAは提示された通貨購入画面から、購入するオーブの金額を10000Orbとして指定する。このとき、アウトプットデータ作成部103は、送金金額を10000Orb、送金先をユーザAの口座アドレスとするアウトプットデータO11を作成する。   First, it is assumed that user A purchases 10,000 orbs. In this case, the remittance accepting unit 101 presents a currency purchase screen on the display of the terminal 100A. User A designates the amount of the orb to be purchased as 10,000 Orb from the presented currency purchase screen. At this time, the output data creation unit 103 creates output data O11 in which the remittance amount is 10,000 Orb and the remittance destination is the account address of the user A.

次に、トランザクション配信部104が、アウトプットデータO11をトランザクションT11に格納し、現在時刻をトランザクション発生時刻に指定して、通貨発生トランザクションを作成し、ネットワーク400に配信する。配信した通貨発生トランザクションが、後述するマイナーの発掘処理によって、承認され、ブロックチェーンにつながれると、ユーザAは購入したオーブを取引に使えるようになる。   Next, the transaction distribution unit 104 stores the output data O11 in the transaction T11, specifies the current time as the transaction generation time, creates a currency generation transaction, and distributes it to the network 400. When the distributed currency generation transaction is approved by the mining excavation process described later and connected to the block chain, the user A can use the purchased orb for the transaction.

ユーザAは、たとえばオーブの購入から11日後に、購入したオーブの一部(7000Orb)をユーザBに対して送金するとする。この場合、インプットデータ作成部102が、まず送金対象検索処理を実行し、これまでにユーザAが送金先ユーザとして指定されているアウトプットデータを有するトランザクションを検索する。図4の例では、該当するトランザクションがトランザクションT11だけであるため、インプットデータ作成部102はトランザクションT11を抽出する。   For example, assume that the user A remits a part of the purchased orb (7000 Orb) to the user B 11 days after the purchase of the orb. In this case, the input data creation unit 102 first executes a remittance target search process, and searches for a transaction having output data for which user A has been designated as a remittance destination user. In the example of FIG. 4, since the corresponding transaction is only the transaction T11, the input data creation unit 102 extracts the transaction T11.

次に、インプットデータ作成部102は、減価額計算処理を実行し、アウトプットデータO11の減価額を計算する。今回の送金は、オーブの購入から11日後に行われているため、減価率は10%である。そのため、インプットデータ作成部102は、アウトプットデータO11の減価額は、1000Orbであると算出する。インプットデータ作成部102は、算出した減価額(1000Orb)をアウトプットデータO11の送金金額(10000Orb)から減算し、アウトプットデータO11の残高を9000Orbであると算出する。これは、今回の送金金額である7000Orbを上回っているため、インプットデータ作成部102は、アウトプットデータO11のポインタを、今回のインプットデータI11に指定する。さらにインプットデータ作成部102は、電子署名作成処理を実行する。具体的には、電子署名を格納する部分を除く、作成中のトランザクションのデータ全体にハッシュ関数を用いてダイジェストを作成する。そして、口座情報DB134に保存されたユーザAの秘密鍵を用いてインプットデータ作成部102は、生成したダイジェストを暗号化して電子署名を作成する。   Next, the input data creation unit 102 executes a depreciation calculation process, and calculates a depreciation of the output data O11. Since this remittance is made 11 days after the purchase of the orb, the depreciation rate is 10%. Therefore, the input data creation unit 102 calculates that the reduced price of the output data O11 is 1000 Orb. The input data creation unit 102 subtracts the calculated price reduction (1000 Orb) from the remittance amount (10000 Orb) of the output data O11, and calculates the balance of the output data O11 to be 9000 Orb. This exceeds the current remittance amount of 7000 Orb, so the input data creation unit 102 designates the pointer of the output data O11 as the current input data I11. Further, the input data creation unit 102 executes digital signature creation processing. Specifically, a digest is created using a hash function for the entire data of the transaction being created, excluding the part that stores the electronic signature. Then, using the user A's private key stored in the account information DB 134, the input data creation unit 102 encrypts the generated digest and creates an electronic signature.

次に、アウトプットデータ作成部103は、送金金額を7000Orb、送金先をユーザBの口座アドレスとして、アウトプットデータO12を作成する。さらに、アウトプットデータ作成部103は、アウトプットデータO11の残高9000Orbから今回のアウトプットデータO12の送金金額である7000Orbを減算し、差分である2000Orbを、ユーザAの口座アドレスを送金先とするアウトプットデータO13を作成する。   Next, the output data creation unit 103 creates output data O12 with a remittance amount of 7000 Orb and a remittance destination as the account address of the user B. Further, the output data creation unit 103 subtracts 7000 Orb, which is the remittance amount of the current output data O12, from the balance 9000 Orb of the output data O11, and uses 2000 Orb, which is the difference, as the remittance destination of the user A's account address. Output data O13 is created.

トランザクション配信部104は、インプットデータI11と、アウトプットデータO12と、アウトプットデータO13とをトランザクションT12に格納し、現在時刻をトランザクション発生時刻に指定して、トランザクションT12を配信する。   The transaction distribution unit 104 stores the input data I11, the output data O12, and the output data O13 in the transaction T12, and specifies the current time as the transaction occurrence time, and distributes the transaction T12.

なお、上述の例で、送金金額がたとえば9500Orbである場合、送金金額がアウトプットデータO11の残高である9000Orbを上回っているため、インプットデータ作成部102は、アウトプットデータO11のポインタを指定することができない。この場合、インプットデータ作成部102は、送金金額をたとえば9000Orbと500Orbとの2つの金額に分割することができる。このとき、インプットデータ作成部102は、それぞれの送金金額に対応するインプットデータを作成し、ポインタで参照するアウトプットデータを検索することが望ましい。さらにこの場合、アウトプットデータ作成部103は、送金金額が9000Orbのアウトプットデータと、500Orbのアウトプットデータとをそれぞれ作成するとしてもよい。   In the above example, when the remittance amount is 9500 Orb, for example, the remittance amount exceeds 9000 Orb, which is the balance of the output data O11, and therefore the input data creation unit 102 designates the pointer of the output data O11. I can't. In this case, the input data creation unit 102 can divide the remittance amount into two amounts, for example, 9000 Orb and 500 Orb. At this time, it is desirable that the input data creation unit 102 creates input data corresponding to each remittance amount and retrieves output data referred to by a pointer. Further, in this case, the output data creation unit 103 may create output data with a remittance amount of 9000 Orb and output data with 500 Orb, respectively.

このように本実施形態に係るウォレットツールが、オーブが時間の経過とともに減額するように、端末100を機能させることで、オーブは投資の対象とされにくくなり、通貨価値の変動を抑えることが可能となる。   As described above, the wallet tool according to the present embodiment makes the orb less likely to be an investment target by causing the terminal 100 to function so that the orb is reduced over time, and it is possible to suppress fluctuations in currency value. It becomes.

図2に戻り、端末200の機能について説明する。
<3−3.マイニングツールの機能>
図2(B)は、ウォレットツールに加えて、マイニングツールをインストールした、端末200の機能ブロック図の一例を示す図である。マイニングツールをインストールした端末200には、上述したウォレットツールによって作成される機能ブロックに加えて、検証部201と、発掘部202と、報酬計算部203とが構築されることが望ましい。
Returning to FIG. 2, the function of the terminal 200 will be described.
<3-3. Mining Tool Functions>
FIG. 2B is a diagram illustrating an example of a functional block diagram of the terminal 200 in which a mining tool is installed in addition to the wallet tool. In the terminal 200 in which the mining tool is installed, in addition to the functional blocks created by the above-described wallet tool, a verification unit 201, an excavation unit 202, and a reward calculation unit 203 are preferably constructed.

検証部201は、受信したトランザクションの正当性を検証するために、以下の2つの処理を実行する。
・完全性検証処理
・整合性検証処理
検証部201は上記2つの検証処理の結果、完全性と整合性とが認められたトランザクションを正当なトランザクションであると承認することができるとしてもよい。
The verification unit 201 executes the following two processes in order to verify the validity of the received transaction.
Integrity Verification Processing / Consistency Verification Processing The verification unit 201 may be able to approve a transaction for which integrity and consistency are recognized as a result of the above two verification processings as a legitimate transaction.

(完全性検証処理)
検証部201は、完全性検証処理として、受信したトランザクションに対して改ざんが行われていないかを検証する。具体的には、検証部201は、まず公開鍵情報DB133を参照して、受信したトランザクションのインプットデータに含まれる電子署名を、もとの所有者の公開鍵で復号して、インプットデータ作成部102が作成したダイジェストを取り出す。さらに検証部201は受信したトランザクションのデータ全体のうち電子署名を格納する部分を除いたデータから、ハッシュ関数を用いてダイジェストを生成する。検証部201は、復号したダイジェストと生成したダイジェストとが一致するか否かを検証し、一致する場合にはトランザクションデータの完全性を承認することができる。検証部201は、トランザクションに含まれるすべてのインプットデータの電子署名を検証できた場合に、当該トランザクションの完全性を承認することができるとしてもよい。
(Integrity verification process)
The verification unit 201 verifies whether the received transaction has been tampered with as the integrity verification process. Specifically, the verification unit 201 first refers to the public key information DB 133, decrypts the electronic signature included in the input data of the received transaction with the original owner's public key, and generates an input data creation unit. The digest created by 102 is taken out. Further, the verification unit 201 generates a digest using a hash function from the data excluding the part that stores the electronic signature in the entire data of the received transaction. The verification unit 201 verifies whether or not the decrypted digest and the generated digest match, and if they match, can confirm the integrity of the transaction data. The verification unit 201 may be able to approve the integrity of the transaction when the digital signatures of all input data included in the transaction can be verified.

(整合性検証処理)
検証部201は、整合性検証処理として、受信したトランザクションがブロックチェーン全体として整合性がとれた取引であるか否かを検証する。具体的には、検証部201は、上述した減価額計算処理と同様の処理を実行して、インプットデータの残高を計算して、計算した残高がアウトプットデータの金額より上回っているか検証する。
また、検証部201は、整合性検証処理として、検証対象のトランザクションのインプットデータと同じアウトプットデータを参照しているトランザクションがすでに承認されていないかを確認して二重取引の検証を行うとしてもよい。具体的には、検証部201は、ブロック情報DB132を参照して、ブロックチェーンにつながれたブロックに含まれるトランザクションのインプットデータのポインタが参照するアウトプットデータを抽出する。さらに検証部201は、今回の検証対象のトランザクションのインプットデータとして指定されたポインタが参照するアウトプットデータが、すでに参照されているものか否かを検証する。今回の検証対象のトランザクションのインプットデータとして指定されたポインタが参照するアウトプットデータが、過去のトランザクションのインプットデータからポインタを指定されていない場合、検証部201は、今回の検証対象のトランザクションのインプットデータの整合性を承認することができる。
検証部201は、トランザクションに含まれるすべてのインプットデータの整合性が承認できた場合に、当該トランザクションの整合性を承認することができるとしてもよい。
(Consistency verification process)
As the consistency verification process, the verification unit 201 verifies whether or not the received transaction is a transaction that is consistent with the entire block chain. Specifically, the verification unit 201 executes a process similar to the above-described price reduction calculation process, calculates the balance of input data, and verifies whether the calculated balance exceeds the amount of output data.
Further, the verification unit 201 confirms that the transaction referring to the same output data as the input data of the transaction to be verified has already been approved as the consistency verification processing and verifies the double transaction. Also good. Specifically, the verification unit 201 refers to the block information DB 132 and extracts the output data referred to by the input data pointer of the transaction included in the block connected to the block chain. Further, the verification unit 201 verifies whether or not the output data referred to by the pointer designated as the input data of the transaction to be verified this time has already been referenced. When the output data referred to by the pointer specified as the input data of the current verification target transaction does not specify the pointer from the past transaction input data, the verification unit 201 inputs the input of the current verification target transaction. Data integrity can be approved.
The verification unit 201 may approve the consistency of the transaction when the consistency of all input data included in the transaction is approved.

発掘部202は、検証部201の処理によって完全性と整合性が認められた正当なトランザクションを格納するブロックを生成するために、マイニングの処理を行う。具体的には、発掘部202は、現在のブロックチェーンの末尾のハッシュ値を、ハッシュ関数を用いて計算する。計算したハッシュ値と、生成するブロックに所定の値とを合わせたデータに対して、発掘部202は、ハッシュ関数を用いてハッシュ値を計算する。このデータには、ブロックの生成時刻を含めてもよい。このハッシュ値が所定の値以下になる場合、本実施形態では「ブロックが発掘された」という。ブロックを発掘すると、発掘部202は、当該ブロックを、ブロックチェーンの末尾につなぐことができる。
発掘部202は、ブロックをブロックチェーンにつなぐ際に、現在時刻を、当該ブロックに格納されているトランザクションのブロックチェーン追加時刻として指定することが望ましい。
The excavation unit 202 performs a mining process in order to generate a block that stores a legitimate transaction whose integrity and consistency are recognized by the process of the verification unit 201. Specifically, the excavation unit 202 calculates a hash value at the end of the current block chain using a hash function. For the data obtained by combining the calculated hash value and a predetermined value with the block to be generated, the excavation unit 202 calculates a hash value using a hash function. This data may include the generation time of the block. When the hash value is equal to or less than a predetermined value, it is said that “the block has been excavated” in the present embodiment. When the block is excavated, the excavation unit 202 can connect the block to the end of the block chain.
When the excavation unit 202 connects a block to a block chain, it is desirable to specify the current time as the block chain addition time of the transaction stored in the block.

報酬計算部203は、ブロックに格納した正当なトランザクションの減価額に基づいて、マイナーの報酬を計算する。たとえば、報酬計算部203は、インプットデータのポインタとして指定されたアウトプットデータの金額の、減価額の合計をマイナーの報酬として計算してもよい。具体的には、報酬計算部203は、インプットデータに含まれるポインタを順次参照していき、通貨発生トランザクションを抽出する。そして、報酬計算部203は、通貨発生トランザクションのトランザクション発生時刻を参照し、現在時刻との差分に基づいて減価率を計算する。この処理は、インプットデータ作成部102の減価額計算処理と同様の処理であってもよい。報酬計算部203は、発掘部202が生成したブロックに格納される各トランザクションの減価額の合計をマイナーの報酬として計算することができる。
さらに報酬計算部203は、送金金額を計算した報酬の金額、送信先を端末200を利用するマイナーに指定して、アウトプットデータを作成して、当該アウトプットデータに基づいて通貨発生トランザクションを作成することが望ましい。報酬計算部203は作成した通貨発生トランザクションを、ネットワーク400にブロードキャストで配信する。この通貨発生トランザクションは生成するブロックに含めることでブロードキャストすることが望ましい。この通貨発生トランザクションがネットワーク400に接続しているいずれかのマイナーの端末によって承認されることで、端末200を利用するマイナーは、報酬を受け取ることができる。
The reward calculation unit 203 calculates a minor reward based on the reduced price of the legitimate transaction stored in the block. For example, the remuneration calculation unit 203 may calculate the total reduction amount of the amount of the output data specified as the input data pointer as the minor remuneration. Specifically, the reward calculation unit 203 sequentially refers to the pointers included in the input data, and extracts a currency generation transaction. And the reward calculation part 203 calculates the depreciation rate based on the difference with the present time with reference to the transaction generation time of a currency generation transaction. This process may be the same process as the depreciation calculation process of the input data creation unit 102. The reward calculation unit 203 can calculate the total reduction amount of each transaction stored in the block generated by the excavation unit 202 as a minor reward.
Further, the remuneration calculation unit 203 designates the amount of remuneration for which the remittance amount has been calculated, designates the transmission destination as a minor using the terminal 200, creates output data, and creates a currency generation transaction based on the output data It is desirable to do. The reward calculation unit 203 distributes the created currency generation transaction to the network 400 by broadcast. It is desirable to broadcast this currency generation transaction by including it in a block to be generated. When the currency generation transaction is approved by any of the minor terminals connected to the network 400, the minor using the terminal 200 can receive a reward.

<3−4.マイニング処理フロー>
図5を用いて、マイニングツールをインストールした端末200のマイニング処理の処理フローについて説明する。
まず、検証部201は、トランザクションDB131を参照して、受信したトランザクションのうち、検証が行われていない未検証トランザクションが残っているか否か確認する(S101)。未検証トランザクションが残っている場合(S101:YES)には、検証部201は、当該未検証トランザクションを、検証を行うために取得する(S102)。
<3-4. Mining process flow>
A processing flow of the mining process of the terminal 200 in which the mining tool is installed will be described with reference to FIG.
First, the verification unit 201 refers to the transaction DB 131 and confirms whether there are unverified transactions that have not been verified among the received transactions (S101). When an unverified transaction remains (S101: YES), the verification unit 201 acquires the unverified transaction for verification (S102).

次に検証部201は、取得した検証対象のトランザクションに含まれるインプットデータのうち、未検証のインプットデータがある場合(S103:YES)、当該未検証のインプットを取得して(S104)、インプットデータの検証を行う。まず、検証部201は、取得したインプットデータのポインタから、当該インプットデータに用いられているオーブの通貨発生トランザクションを抽出する(S105)。さらに、検証部201は通貨発生トランザクションのトランザクション発生時刻と現在時刻との差分から、減価額とインプットデータの残高とを計算する(S106)。   Next, when there is unverified input data among the input data included in the acquired transaction to be verified (S103: YES), the verification unit 201 acquires the unverified input (S104), and the input data Perform verification. First, the verification unit 201 extracts an orb currency generating transaction used for the input data from the pointer of the acquired input data (S105). Further, the verification unit 201 calculates a price reduction and a balance of input data from the difference between the transaction occurrence time and the current time of the currency generation transaction (S106).

次に、検証部201は、検証対象トランザクションに含まれるアウトプットデータの送金金額の合計金額が、計算した残高を上回っていないか確認して、当該インプットデータの正当性を検証する(S107)。送金金額の合計金額が、計算した残高を上回っている場合(S107:NO)には、検証部201は、検証対象のトランザクションは不正なトランザクションであるとして、ブロックには格納しない(S151)。一方で、検証対象トランザクションに含まれるアウトプットデータの送金金額の合計金額が、計算した残高を上回っていない場合(S107:YES)には、検証対象トランザクションは、正当なインプットデータであるとして、当該インプットデータを承認する。検証部201は、このS103〜107までの処理をトランザクションに含まれるすべてのインプットデータの検証が完了するまで繰り返し実行する。トランザクションに含まれるすべてのインプットデータが正当であると承認した場合には、検証は当該トランザクションを正当なトランザクションとしてブロックに格納する。   Next, the verification unit 201 verifies whether the total amount of remittance of output data included in the verification target transaction exceeds the calculated balance, and verifies the validity of the input data (S107). If the total amount of remittance exceeds the calculated balance (S107: NO), the verification unit 201 assumes that the transaction to be verified is an illegal transaction and does not store it in the block (S151). On the other hand, when the total amount of the remittance amount of the output data included in the verification target transaction does not exceed the calculated balance (S107: YES), the verification target transaction is assumed to be valid input data. Approve input data. The verification unit 201 repeatedly executes the processes from S103 to S107 until verification of all input data included in the transaction is completed. If all input data included in the transaction is approved as valid, verification stores the transaction as a valid transaction in the block.

検証部201は、S101〜S107までの処理を未検証トランザクションがなくなるまで繰り返し実行する。端末200が受信したトランザクションに未検証トランザクションがなくなると(S101:NO)、報酬計算部203は、ブロックに格納したトランザクションの減価額の合計金額に基づいて、マイナーの報酬を計算する。さらに報酬計算部203は、送金金額を計算した合計金額とし、送金先を当該マイナーに指定して、通貨発生トランザクションを作成し、ネットワーク400にブロードキャストで配信する(S108)。配信した通貨発生トランザクションが他のマイナーに承認されると、報酬金が、通貨発生トランザクションを配信したマイナーに与えられる(S109)。   The verification unit 201 repeatedly executes the processing from S101 to S107 until there is no unverified transaction. When there is no unverified transaction in the transaction received by the terminal 200 (S101: NO), the reward calculation unit 203 calculates a minor reward based on the total amount of transaction depreciation stored in the block. Further, the remuneration calculation unit 203 sets the remittance amount as a total amount, designates the remittance destination as the minor, creates a currency generation transaction, and distributes it to the network 400 by broadcast (S108). When the distributed currency generation transaction is approved by another miner, a reward is given to the miner who distributed the currency generation transaction (S109).

このように本実施形態に係るマイニングツールが、マイナーが獲得する報酬が承認したブロックに含まれるトランザクションの減価額に基づいて決定するように端末200を機能させることで、マイナーに対する報酬を枯渇させないようにすることが可能となる。   As described above, the mining tool according to the present embodiment causes the terminal 200 to function based on the depreciation of the transaction included in the block approved by the miner so as not to deplete the miner's reward. It becomes possible to.

(4 ハードウェア構成)
以下、図6を参照しながら、上述してきた端末100及び端末200をコンピュータ800により実現する場合のハードウェア構成の一例を説明する。なお、それぞれの装置の機能は、複数台の装置に分けて実現することもできる。
(4 hardware configuration)
Hereinafter, an example of a hardware configuration when the terminal 100 and the terminal 200 described above are realized by the computer 800 will be described with reference to FIG. The function of each device can be realized by dividing it into a plurality of devices.

図6に示すように、コンピュータ800は、プロセッサ801、メモリ803、記憶装置805、入力I/F部807、データI/F部809、通信I/F部811、及び表示装置813を含む。   As illustrated in FIG. 6, the computer 800 includes a processor 801, a memory 803, a storage device 805, an input I / F unit 807, a data I / F unit 809, a communication I / F unit 811, and a display device 813.

プロセッサ801は、メモリ803に記憶されているプログラムを実行することによりコンピュータ800における様々な処理を制御する。例えば、端末100の送金受付部101やインプットデータ作成部102、アウトプットデータ作成部103、トランザクション配信部104、端末200の検証部201や発掘部202、報酬計算などは、メモリ803に一時記憶された上で、主にプロセッサ801上で動作するプログラムとして実現可能である。   The processor 801 controls various processes in the computer 800 by executing a program stored in the memory 803. For example, the remittance acceptance unit 101, the input data creation unit 102, the output data creation unit 103, the transaction delivery unit 104, the verification unit 201, the excavation unit 202, and the reward calculation of the terminal 200 are temporarily stored in the memory 803. In addition, it can be realized as a program that mainly operates on the processor 801.

メモリ803は、例えばRAM(Random Access Memory)等の記憶媒体である。メモリ803は、プロセッサ801によって実行されるプログラムのプログラムコードや、プログラムの実行時に必要となるデータを一時的に記憶する。   The memory 803 is a storage medium such as a RAM (Random Access Memory). The memory 803 temporarily stores a program code of a program executed by the processor 801 and data necessary for executing the program.

記憶装置805は、例えばハードディスクドライブ(HDD)やフラッシュメモリ等の不揮発性の記憶媒体である。記憶装置805は、オペレーティングシステムや、上記各構成を実現するための各種プログラムを記憶する。この他、記憶装置805は、トランザクション情報DB131や、ブロック情報DB132、公開鍵情報DB133、口座情報DB134を記憶することも可能である。このようなプログラムやデータは、必要に応じてメモリ803にロードされることにより、プロセッサ801から参照される。   The storage device 805 is a non-volatile storage medium such as a hard disk drive (HDD) or a flash memory. The storage device 805 stores an operating system and various programs for realizing the above-described configurations. In addition, the storage device 805 can store a transaction information DB 131, a block information DB 132, a public key information DB 133, and an account information DB 134. Such programs and data are referred to by the processor 801 by being loaded into the memory 803 as necessary.

入力I/F部807は、ユーザからの入力を受け付けるためのデバイスである。入力I/F部807の具体例としては、キーボードやマウス、タッチパネル、各種センサ、ウェアラブル・デバイス等が挙げられる。入力I/F部807は、例えばUSB(Universal Serial Bus)等のインタフェースを介してコンピュータ800に接続されても良い。   The input I / F unit 807 is a device for receiving input from the user. Specific examples of the input I / F unit 807 include a keyboard, a mouse, a touch panel, various sensors, and a wearable device. The input I / F unit 807 may be connected to the computer 800 via an interface such as a USB (Universal Serial Bus).

データI/F部809は、コンピュータ800の外部からデータを入力するためのデバイスである。データI/F部809の具体例としては、各種記憶媒体に記憶されているデータを読み取るためのドライブ装置等がある。データI/F部809は、コンピュータ800の外部に設けられることも考えられる。その場合、データI/F部809は、例えばUSB等のインタフェースを介してコンピュータ800へと接続される。   A data I / F unit 809 is a device for inputting data from the outside of the computer 800. Specific examples of the data I / F unit 809 include a drive device for reading data stored in various storage media. The data I / F unit 809 may be provided outside the computer 800. In this case, the data I / F unit 809 is connected to the computer 800 via an interface such as a USB.

通信I/F部811は、コンピュータ800の外部の装置と有線又は無線により、インターネットNを介したデータ通信を行うためのデバイスである。通信I/F部811は、コンピュータ800の外部に設けられることも考えられる。その場合、通信I/F部811は、例えばUSB等のインタフェースを介してコンピュータ800に接続される。   The communication I / F unit 811 is a device for performing data communication with the external device of the computer 800 via the Internet N by wire or wireless. The communication I / F unit 811 may be provided outside the computer 800. In that case, the communication I / F unit 811 is connected to the computer 800 via an interface such as a USB.

表示装置813は、各種情報を表示するためのデバイスである。表示装置813の具体例としては、例えば液晶ディスプレイや有機EL(Electro−Luminescence)ディスプレイ、ウェアラブル・デバイスのディスプレイ等が挙げられる。表示装置813は、コンピュータ800の外部に設けられても良い。その場合、表示装置813は、例えばディスプレイケーブル等を介してコンピュータ800に接続される。   The display device 813 is a device for displaying various information. Specific examples of the display device 813 include a liquid crystal display, an organic EL (Electro-Luminescence) display, and a wearable device display. The display device 813 may be provided outside the computer 800. In that case, the display device 813 is connected to the computer 800 via, for example, a display cable.

[その他の実施形態]
以上、本発明の実施形態について述べたが、本発明は既述の実施形態に限定されるものではなく、本発明の技術的思想に基づいて各種の変形及び変更が可能である。
[Other embodiments]
Although the embodiments of the present invention have been described above, the present invention is not limited to the above-described embodiments, and various modifications and changes can be made based on the technical idea of the present invention.

例えば、既述の実施形態において、マイニングツールは、ウォレットツールと合わせてインストールされる構成として説明したが、これに限定されない。たとえば、端末200はマイニングツールだけをインストールする構成としてもよい。この場合、端末200には、検証部201、発掘部202、及び報酬計算部203とあわせて、トランザクション情報DB131、ブロック情報DB132、及び公開鍵情報DB133がインストールされることが望ましい。   For example, in the above-described embodiment, the mining tool has been described as being installed together with the wallet tool, but the present invention is not limited to this. For example, the terminal 200 may be configured to install only a mining tool. In this case, it is desirable that the transaction information DB 131, the block information DB 132, and the public key information DB 133 are installed in the terminal 200 together with the verification unit 201, the excavation unit 202, and the reward calculation unit 203.

10 仮想通貨システム
100 端末
101 送金受付部
102 インプットデータ作成部
103 アウトプットデータ作成部
104 トランザクション配信部
131 トランザクション情報DB
132 ブロック情報DB
133 公開鍵情報DB
134 口座情報DB
200 端末
201 検証部
202 発掘部
203 報酬計算部
400 ネットワーク
DESCRIPTION OF SYMBOLS 10 Virtual currency system 100 Terminal 101 Remittance reception part 102 Input data creation part 103 Output data creation part 104 Transaction delivery part 131 Transaction information DB
132 Block information DB
133 Public key information DB
134 Account Information DB
200 Terminal 201 Verification Unit 202 Excavation Unit 203 Reward Calculation Unit 400 Network

Claims (5)

コンピュータを、
仮想通貨を送金する第1の取引における第1の送金金額及び第1の送金日時を含む第1の取引情報と、前記第1の送金金額の少なくとも一部を送金する第2の取引における第2の送金金額及び第2の送金日時を含む、前記第1の取引情報とは異なる第2の取引情報と、を記憶する記憶手段、
前記第2の取引情報の正当性を検証する手段、
前記第1の送金日時と前記第2の送金日時との差分と、前記第1の送金金額とに基づいて、前記第1の送金金額の前記第2の送金日時における減価額を計算する手段、及び
前記減価額に基づいて、前記第2の取引情報の検証者への報酬額を決定する手段
として機能させる仮想通貨管理プログラム。
Computer
First transaction information including a first remittance amount and a first remittance date and time in a first transaction for remittance of virtual currency, and a second in a second transaction for remittance of at least part of the first remittance amount Storage means for storing second transaction information different from the first transaction information , including the remittance amount and the second remittance date and time,
Means for verifying the validity of the second transaction information;
Means for calculating a reduction amount of the first remittance amount at the second remittance date and time based on the difference between the first remittance date and the second remittance date and time and the first remittance amount; And a virtual currency management program that functions as means for determining a remuneration amount to a verifier of the second transaction information based on the reduced price.
前記仮想通貨管理プログラムは、前記コンピュータを、さらに、
前記正当性の検証者に前記報酬額の仮想通貨を送金する第3の取引のために、前記報酬額である第3の送金金額と第3の送金日時とを含む第3の取引情報を送信する手段、
として機能させる請求項1に記載の仮想通貨管理プログラム。
The virtual currency management program further includes the computer,
Sending third transaction information including the third remittance amount and the third remittance date and time as the remuneration amount for a third transaction for remitting the virtual currency of the remuneration amount to the verifier of validity Means to
The virtual currency management program according to claim 1, which is made to function as:
前記第2の取引情報は、
前記第1の送金金額から前記第2の送金金額と前記減価額とを差し引いた第4の送金金額を含むことを特徴とする請求項1又は2記載の仮想通貨管理プログラム。
The second transaction information is:
3. The virtual currency management program according to claim 1, further comprising a fourth remittance amount obtained by subtracting the second remittance amount and the reduced value from the first remittance amount.
前記第2の取引情報は、デジタル署名が付与されており、
前記正当性を検証する手段は、
前記第2の取引情報に付与された前記デジタル署名を検証することで、当該第2の取引情報の正当性を検証することを特徴とする請求項1〜3いずれか一項に記載の仮想通貨管理プログラム。
The second transaction information is given a digital signature,
The means for verifying the validity is:
The virtual currency according to any one of claims 1 to 3, wherein the validity of the second transaction information is verified by verifying the digital signature given to the second transaction information. Management program.
コンピュータが、
仮想通貨を送金する第1の取引における第1の送金金額及び第1の送金日時を含む第1の取引情報と、前記第1の送金金額の少なくとも一部を送金する第2の取引における第2の送金金額及び第2の送金日時を含む、前記第1の取引情報とは異なる第2の取引情報と、を記憶するステップと、
前記第2の取引情報の正当性を検証するステップと、
前記第1の送金日時と前記第2の送金日時との差分と、前記第1の送金金額とに基づいて、前記第1の送金金額の前記第2の送金日時における減価額を計算するステップと、
前記減価額に基づいて、前記第2の取引情報の検証者への報酬額を決定するステップとを実行する仮想通貨管理方法。
Computer
First transaction information including a first remittance amount and a first remittance date and time in a first transaction for remittance of virtual currency, and a second in a second transaction for remittance of at least part of the first remittance amount Storing the second transaction information different from the first transaction information , including the remittance amount and the second remittance date and time,
Verifying the validity of the second transaction information;
Calculating a reduction amount of the first remittance amount at the second remittance date and time based on the difference between the first remittance date and the second remittance date and the first remittance amount; ,
A virtual currency management method that executes a step of determining a reward amount to a verifier of the second transaction information based on the price reduction.
JP2015048690A 2015-03-11 2015-03-11 Virtual currency management program and virtual currency management method Active JP5871347B1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2015048690A JP5871347B1 (en) 2015-03-11 2015-03-11 Virtual currency management program and virtual currency management method

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2015048690A JP5871347B1 (en) 2015-03-11 2015-03-11 Virtual currency management program and virtual currency management method

Publications (2)

Publication Number Publication Date
JP5871347B1 true JP5871347B1 (en) 2016-03-01
JP2016170530A JP2016170530A (en) 2016-09-23

Family

ID=55362132

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2015048690A Active JP5871347B1 (en) 2015-03-11 2015-03-11 Virtual currency management program and virtual currency management method

Country Status (1)

Country Link
JP (1) JP5871347B1 (en)

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2017204706A (en) * 2016-05-10 2017-11-16 日本電信電話株式会社 Content distribution system, content distribution method, content generation device and content generation program
WO2018047982A1 (en) * 2016-09-08 2018-03-15 齋 石田 Payment method and payment system utilizing code information
KR20190032522A (en) * 2016-07-25 2019-03-27 티비씨에이소프트, 인코포레이티드 Digital Asset Management on Distributed Transaction Consensus Networks
WO2020085125A1 (en) 2018-10-25 2020-04-30 マツダ株式会社 Virtual currency management device and virtual currency management method
JP2021189993A (en) * 2020-06-04 2021-12-13 エヌ・ティ・ティ・コミュニケーションズ株式会社 Cryptocurrency management device, method and program
JP2022097616A (en) * 2018-02-05 2022-06-30 Gve株式会社 Management apparatus
CN117422058A (en) * 2023-12-18 2024-01-19 佳瑛科技有限公司 Visual graphic report generation method

Families Citing this family (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP6533771B2 (en) 2016-11-15 2019-06-19 富士通株式会社 Communication method, apparatus and program
JP6247738B1 (en) * 2016-11-16 2017-12-13 PwCあらた有限責任監査法人 Data structure, information processing apparatus, program, information processing method, and transaction system
JP6247737B1 (en) * 2016-11-16 2017-12-13 PwCあらた有限責任監査法人 Data structure, information processing apparatus, program, information processing method, and transaction system
JP6234539B1 (en) * 2016-11-16 2017-11-22 PwCあらた有限責任監査法人 Data structure, information processing apparatus, program, information processing method, and transaction system
WO2018112948A1 (en) * 2016-12-23 2018-06-28 深圳前海达闼云端智能科技有限公司 Block generation method and device, and blockchain network
US11190360B2 (en) 2016-12-23 2021-11-30 Cloudminds (Shanghai) Robotics Co., Ltd. Method, apparatus, node, signature device and system for generating block of blockchain
JP6931999B2 (en) * 2017-02-06 2021-09-08 株式会社日立製作所 Credit management system and credit management method
JP6341491B1 (en) * 2017-02-21 2018-06-13 株式会社三菱Ufj銀行 Signal processing method and signal processing program
WO2018158960A1 (en) * 2017-03-03 2018-09-07 A・Tコミュニケーションズ株式会社 Information processing device, information processing method, and program
JP7264878B6 (en) * 2017-09-08 2024-02-15 エヌチェーン ライセンシング アーゲー Improved time-locking technology to protect resources in blockchain
JP6610814B2 (en) * 2019-02-12 2019-11-27 富士通株式会社 COMMUNICATION METHOD, DEVICE, AND PROGRAM
WO2024028918A1 (en) * 2022-07-31 2024-02-08 武山素也 Currency convertible to agricultural product and currency system

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2004086486A (en) * 2002-08-26 2004-03-18 Sony Corp Settlement method, currency data storage, and digital money
WO2004036471A1 (en) * 2002-10-18 2004-04-29 Matsushita Electric Industrial Co., Ltd. Electronic money processing device
JP2007122099A (en) * 2005-10-24 2007-05-17 Fuji Electric Retail Systems Co Ltd Transaction settlement device and transaction management system
JP2013016197A (en) * 2012-09-25 2013-01-24 Rakuten Edy Inc Electronic money system, amount change information transmitter, server, and amount change information transmission method

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2004086486A (en) * 2002-08-26 2004-03-18 Sony Corp Settlement method, currency data storage, and digital money
WO2004036471A1 (en) * 2002-10-18 2004-04-29 Matsushita Electric Industrial Co., Ltd. Electronic money processing device
JP2007122099A (en) * 2005-10-24 2007-05-17 Fuji Electric Retail Systems Co Ltd Transaction settlement device and transaction management system
JP2013016197A (en) * 2012-09-25 2013-01-24 Rakuten Edy Inc Electronic money system, amount change information transmitter, server, and amount change information transmission method

Non-Patent Citations (4)

* Cited by examiner, † Cited by third party
Title
JPN6015033971; Hisa Ando: '"ビットコインの仕組みに見る暗号技術とASICによる採掘技術"' [online] , 20140917, 株式会社マイナビ *
JPN6015033975; Satoshi Nakamoto: '"Bitcoin: A Peer-to-Peer Electronic Cash System"' [online] , 20141031, 第2-5頁, bitcoin.org *
JPN6015033977; tsuchitani: '"連載『bitcoinに迫る!』第3回 〜敵を味方に変える保護メカニズム〜"' [online] , 20131205, 株式会社寺島情報企画 *
JPN6015033980; syncn: '"Bitcoinの仕組み"' [online] , 20130416, syncn *

Cited By (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2017204706A (en) * 2016-05-10 2017-11-16 日本電信電話株式会社 Content distribution system, content distribution method, content generation device and content generation program
JP7112690B2 (en) 2016-07-25 2022-08-04 ティービーシーエーソフト,インコーポレイテッド Digital Wealth Management for Decentralized Transaction Consensus Network
KR102665646B1 (en) * 2016-07-25 2024-05-10 티비씨에이소프트, 인코포레이티드 Digital asset management on a decentralized trading consensus network
KR20190032522A (en) * 2016-07-25 2019-03-27 티비씨에이소프트, 인코포레이티드 Digital Asset Management on Distributed Transaction Consensus Networks
JP2019523495A (en) * 2016-07-25 2019-08-22 ティービーシーエーソフト,インコーポレイッテッド Digital goods management in a distributed transaction consensus network
JPWO2018047982A1 (en) * 2016-09-08 2019-08-15 齋 石田 Payment method and payment system using code information
WO2018047982A1 (en) * 2016-09-08 2018-03-15 齋 石田 Payment method and payment system utilizing code information
JP2022097616A (en) * 2018-02-05 2022-06-30 Gve株式会社 Management apparatus
JP7353670B2 (en) 2018-02-05 2023-10-02 Gve株式会社 management device
WO2020085125A1 (en) 2018-10-25 2020-04-30 マツダ株式会社 Virtual currency management device and virtual currency management method
JP2021189993A (en) * 2020-06-04 2021-12-13 エヌ・ティ・ティ・コミュニケーションズ株式会社 Cryptocurrency management device, method and program
JP7005688B2 (en) 2020-06-04 2022-01-21 エヌ・ティ・ティ・コミュニケーションズ株式会社 Cryptocurrency management equipment, methods and programs
CN117422058A (en) * 2023-12-18 2024-01-19 佳瑛科技有限公司 Visual graphic report generation method
CN117422058B (en) * 2023-12-18 2024-03-12 佳瑛科技有限公司 Visual graphic report generation method

Also Published As

Publication number Publication date
JP2016170530A (en) 2016-09-23

Similar Documents

Publication Publication Date Title
JP5871347B1 (en) Virtual currency management program and virtual currency management method
JP5858506B1 (en) Virtual currency management program and virtual currency management method
JP5858507B1 (en) Virtual currency management program and virtual currency management method
US11182781B2 (en) Block chain encryption tags
Nguyen et al. Risk allocation in US public-private partnership highway project contracts
US20210351915A1 (en) Multi-blockchain digital transaction information segregation system
Antonopoulos Mastering Bitcoin: unlocking digital cryptocurrencies
KR102610127B1 (en) Apparatus and method for providing transaction service of crypto currency using electronic wallet
US11373216B2 (en) Method, server, and computer program for mediating advertisement based on block chain
CN109559164B (en) Preferential information processing method and device, electronic equipment and computer readable medium
Xu et al. A blockchain based micro payment system for smart devices
JP2019079502A (en) Item trading system and item trading program
CN104200365A (en) Writing and paying method for electronic check
JP2018160179A (en) Virtual currency management program and method
CN110599140A (en) Digital currency verification method and system
JP6583655B1 (en) Virtual currency management system, program
US20210326942A1 (en) Method of Securing Online Merchant Reviews Using Block Chains
WO2021117515A1 (en) Electronic asset management method, and electronic asset management device
KR102327668B1 (en) Apparatus and method for providing electronic receipt using blockchain inquiry code
KR20210032168A (en) Apparatus and method for managing electronic receipt based on block chain
KR20210061676A (en) Blockchain based advertisement apparatus and method using advertisement module included in application
AU2015203621B2 (en) Dynamic electronic money
JP2020021446A (en) Method for processing information, information processor, and program
US20230039832A1 (en) Method and system for transaction of digital asset
JP6776396B2 (en) Trading system

Legal Events

Date Code Title Description
TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20151215

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20160107

R150 Certificate of patent or registration of utility model

Ref document number: 5871347

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

S531 Written request for registration of change of domicile

Free format text: JAPANESE INTERMEDIATE CODE: R313531

R350 Written notification of registration of transfer

Free format text: JAPANESE INTERMEDIATE CODE: R350

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250