IP Force 特許公報掲載プロジェクト 2022.1.31 β版

知財求人 - 知財ポータルサイト「IP Force」

▶ 富士通株式会社の特許一覧

特許7469715データ格納方法、データ格納プログラム、および情報処理装置
<>
  • 特許-データ格納方法、データ格納プログラム、および情報処理装置 図1
  • 特許-データ格納方法、データ格納プログラム、および情報処理装置 図2
  • 特許-データ格納方法、データ格納プログラム、および情報処理装置 図3
  • 特許-データ格納方法、データ格納プログラム、および情報処理装置 図4
  • 特許-データ格納方法、データ格納プログラム、および情報処理装置 図5
  • 特許-データ格納方法、データ格納プログラム、および情報処理装置 図6
  • 特許-データ格納方法、データ格納プログラム、および情報処理装置 図7
  • 特許-データ格納方法、データ格納プログラム、および情報処理装置 図8
  • 特許-データ格納方法、データ格納プログラム、および情報処理装置 図9
  • 特許-データ格納方法、データ格納プログラム、および情報処理装置 図10
  • 特許-データ格納方法、データ格納プログラム、および情報処理装置 図11
  • 特許-データ格納方法、データ格納プログラム、および情報処理装置 図12
  • 特許-データ格納方法、データ格納プログラム、および情報処理装置 図13
  • 特許-データ格納方法、データ格納プログラム、および情報処理装置 図14
< >
(19)【発行国】日本国特許庁(JP)
(12)【公報種別】特許公報(B2)
(11)【特許番号】
(24)【登録日】2024-04-09
(45)【発行日】2024-04-17
(54)【発明の名称】データ格納方法、データ格納プログラム、および情報処理装置
(51)【国際特許分類】
   G06Q 50/06 20240101AFI20240410BHJP
【FI】
G06Q50/06
【請求項の数】 9
(21)【出願番号】P 2022574893
(86)(22)【出願日】2021-01-13
(86)【国際出願番号】 JP2021000742
(87)【国際公開番号】W WO2022153375
(87)【国際公開日】2022-07-21
【審査請求日】2023-02-09
(73)【特許権者】
【識別番号】000005223
【氏名又は名称】富士通株式会社
(74)【代理人】
【識別番号】110002918
【氏名又は名称】弁理士法人扶桑国際特許事務所
(72)【発明者】
【氏名】宮前 剛
(72)【発明者】
【氏名】小櫻 文彦
【審査官】池田 聡史
(56)【参考文献】
【文献】特開2019-133630(JP,A)
【文献】特開2020-87209(JP,A)
【文献】特開2020-119143(JP,A)
【文献】特開2019-144851(JP,A)
【文献】小櫻文彦,“電力の需要家間取引をブロックチェーン上で実現”,OHM,日本,株式会社オーム社,2019年07月05日,第106巻, 第7号, ISSN0386-5576,pp.36~38
【文献】中村誠吾ほか3名,“第3章 1 記録されるデータの構造”, “第3章 4.3 UTXO型での二重取引防止”, “第6章 3 個人間電力取引”,ブロックチェーン システム設計,第1版, ISBN978-4-86594-115-9,株式会社リックテレコム,2018年08月02日,pp.36~43, 52, 114~117
【文献】佐藤哲平ほか2名,“ブロックチェーンシステムにおける匿名信頼性付与手法の実装・評価”,2020年 暗号と情報セキュリティシンポジウム予稿集, 電子情報通信学会情報セキュリティ(ISEC)研究,2020年01月21日,1D1-4,pp.1~6
【文献】岡本龍明ほか14名,“第4章 ゼロ知識証明モデルと計算量理論”,暗号・ゼロ知識証明・数論,初版1刷, ISBN4-320-02740-X,共立出版株式会社,1995年06月01日,pp.73~91
(58)【調査した分野】(Int.Cl.,DB名)
G06Q 10/00-99/00
(57)【特許請求の範囲】
【請求項1】
コンピュータが、
生産者が生産した取引資源の生産実績を示す第1のデータと、消費者が消費した前記取引資源の消費実績を示す第2のデータとを取得し、
前記消費者の前記消費実績分の前記取引資源の供給元として前記生産者の前記生産実績分の前記取引資源を割り当てることについての前記第1のデータと前記第2のデータとの整合性の条件が満たされることを証明する証明情報を生成し、
前記証明情報を含み、前記第1のデータおよび前記第2のデータの総データサイズよりもデータサイズが小さい第3のデータを生成し、
前記生産者が生産した前記取引資源の供給権の取引履歴が格納されたブロックチェーンに、前記第3のデータを含む、前記取引資源が前記消費者によって消費されたことを示すトランザクションレコードを格納する、
データ格納方法。
【請求項2】
前記トランザクションレコードの格納では、第1のコンピュータが前記トランザクションレコードを生成し、前記第1のコンピュータは生成した前記トランザクションレコードを、前記ブロックチェーンを格納している第2のコンピュータに送信し、前記第2のコンピュータは、前記証明情報に基づいて、前記第1のデータと前記第2のデータとの整合性の条件が満たされることを検証し、正しく検査できた場合に前記トランザクションレコードを前記ブロックチェーンに格納する、
請求項1記載のデータ格納方法。
【請求項3】
前記証明情報の生成では、所定の資源供給期間内の単位期間ごとに、前記第1のデータに示される前記生産実績と、前記第2のデータに示される前記消費実績とを比較し、前記単位期間それぞれについて消費量分の生産量があるという条件が満たされることを証明する前記証明情報を生成する、
請求項1または2に記載のデータ格納方法。
【請求項4】
前記証明情報の生成では、前記第2のデータに示される前記消費実績の総量についてのコミットメント関数の値を計算し、前記第1のデータと前記第2のデータとの整合性の条件が満たされることに加え、前記コミットメント関数の値が正しいことを証明する前記証明情報を生成する。
請求項1ないし3のいずれかに記載のデータ格納方法。
【請求項5】
前記ブロックチェーン上での前記取引資源を供給する権利の取引情報をUTXO(Unspent Transaction Output)方式で管理し、前記生産者の生産期間と単位時間当たりの生産量とにより、前記UTXO方式におけるインプットとアウトプットの対象となる前記取引資源を特定する、
請求項1ないし4のいずれかに記載のデータ格納方法。
【請求項6】
前記第1のデータは、前記生産実績についての前記生産者の第1の電子署名を含み、前記第2のデータは、前記消費実績についての前記消費者の第2の電子署名を含み、
前記証明情報の生成では、前記第1のデータと前記第2のデータとの整合性の条件が満たされることに加え、前記生産者の前記第1の電子署名と前記消費者の前記第2の電子署名とが正当であることを証明する前記証明情報をする、
請求項1ないし5のいずれかに記載のデータ格納方法。
【請求項7】
前記トランザクションレコードの格納では、前記ブロックチェーンにおいて前記取引資源を供給する権利を有する者の署名を含む前記トランザクションレコードを前記ブロックチェーンに格納する、
請求項1ないし6のいずれかに記載のデータ格納方法。
【請求項8】
コンピュータに、
生産者が生産した取引資源の生産実績を示す第1のデータと、消費者が消費した前記取引資源の消費実績を示す第2のデータとを取得し、
前記消費者の前記消費実績分の前記取引資源の供給元として前記生産者の前記生産実績分の前記取引資源を割り当てることについての前記第1のデータと前記第2のデータとの整合性の条件が満たされることを証明する証明情報を生成し、
前記証明情報を含み、前記第1のデータおよび前記第2のデータの総データサイズよりもデータサイズが小さい第3のデータを生成し、
前記生産者が生産した前記取引資源の供給権の取引履歴が格納されたブロックチェーンに、前記第3のデータを含む、前記取引資源が前記消費者によって消費されたことを示すトランザクションレコードを格納する、
処理を実行させるデータ格納プログラム。
【請求項9】
生産者が生産した取引資源の生産実績を示す第1のデータと、消費者が消費した前記取引資源の消費実績を示す第2のデータとを記憶する記憶部と、
前記消費者の前記消費実績分の前記取引資源の供給元として前記生産者の前記生産実績分の前記取引資源を割り当てることについての前記第1のデータと前記第2のデータとの整合性の条件が満たされることを証明する証明情報を生成し、前記証明情報を含み、前記第1のデータおよび前記第2のデータの総データサイズよりもデータサイズが小さい第3のデータを生成し、前記生産者が生産した前記取引資源の供給権の取引履歴が格納されたブロックチェーンに、前記第3のデータを含む、前記取引資源が前記消費者によって消費されたことを示すトランザクションレコードを格納する処理部と、
を有する情報処理装置。
【発明の詳細な説明】
【技術分野】
【0001】
本発明は、データ格納方法、データ格納プログラム、および情報処理装置に関する。
【背景技術】
【0002】
多数のユーザが参加する取引に関するデータは、何らかの手段によって台帳で管理される。台帳を中央集権型のプラットフォームで管理すると、そのプラットフォームの維持管理を行う第三者機関が本当に信頼できるか否かを証明し続けなければならない。特にプラットフォームが成長して管理者の責任や権限が増大した場合や、管理者を含めたプラットフォームのユーザの間の利害関係が複雑化してしまうと、その証明は非常に困難になる。
【0003】
近年では、信頼できる第三者機関を置かずに、非中央集権的な台帳管理が可能なブロックチェーンによる台帳管理が提案されている。ブロックチェーンは、ネットワークを構成する複数のノードが同一のデータベースを保持する分散型台帳技術の1つである。ブロックチェーンでは、ネットワーク上のトランザクション群がブロックとしてまとめて処理され、ハッシュ関数によって各ブロックがリンクされている。ブロックチェーンにおいて記録されたブロックのデータは、後続のすべてのブロックを変更しない限り遡及的に変更することはできず、ブロックチェーンを用いた台帳管理のプラットフォームは改変に対する安全性が高い。
【0004】
ブロックチェーンは、取引履歴がオープンであり、取引履歴の改ざんが困難なことから、暗号資産の台帳管理などの様々な分野で利用されている。ブロックチェーンを利用した技術の一例として、環境に貢献する電力を、環境に貢献する方法で消費することを促し、再生可能エネルギーの導入・普及の促進を図る電力取引システムが提案されている。
【先行技術文献】
【特許文献】
【0005】
【文献】特開2020-107202号公報
【発明の概要】
【発明が解決しようとする課題】
【0006】
ブロックチェーンでは台帳を分散管理するため、サーバで一括して管理するデータベースと比較してストレージコストが高くなる。この問題は、取り扱うデータ量が大きくなったときに顕著となる。例えば電力などの資源取引において実際に消費した資源を生産者から購入する場合、購入対象期間内の生産実績と消費実績とを照合することとなる。資源の生産実績や消費実績のデータは逐次生成されるため、これらのデータを含めてブロックチェーンで管理しようとするとブロックチェーンで管理するデータ量が肥大化し、ストレージコストの増大を招く。
【0007】
1つの側面では、本発明は、ブロックチェーンで取り扱うデータ量を削減することを目的とする。
【課題を解決するための手段】
【0008】
1つの案では、コンピュータによるデータ格納方法が提供される。
コンピュータは、生産者が生産した取引資源の生産実績を示す第1のデータと、消費者が消費した取引資源の消費実績を示す第2のデータとを取得する。次にコンピュータは、消費者の消費実績分の取引資源の供給元として生産者の生産実績分の取引資源を割り当てることについての第1のデータと第2のデータとの整合性の条件が満たされることを証明する証明情報を生成する。さらにコンピュータは、証明情報を含み、第1のデータおよび第2のデータの総データサイズよりもデータサイズが小さい第3のデータを生成する。そしてコンピュータは、生産者が生産した取引資源の供給権の取引履歴が格納されたブロックチェーンに、第3のデータを含む、取引資源が消費者によって消費されたことを示すトランザクションレコードを格納する。
【発明の効果】
【0009】
1態様によれば、ブロックチェーンで取り扱うデータ量を削減することができる。
本発明の上記および他の目的、特徴および利点は本発明の例として好ましい実施の形態を表す添付の図面と関連した以下の説明により明らかになるであろう。
【図面の簡単な説明】
【0010】
図1】第1の実施の形態に係るデータ格納方法の一例を示す図である。
図2】電力取引システムの構成の一例を示す図である。
図3】ノードのハードウェアの一例を示す図である。
図4】各ノードの機能の一例を示すブロック図である。
図5】電力供給権の取引の概要を示す図である。
図6】電力供給権の取引の一例を示す図である。
図7】電力供給権の取引の第1の例を示す図である。
図8】電力供給権の取引の第2の例を示す図である。
図9】電源供給権トランザクションレコードのデータ構造の一例を示す図である。
図10】スマートメータレコードと電力マッチングレコードとに含まれる情報の一例を示す図である。
図11】電力マッチングの一例を示す図である。
図12】取引対象の電力の総電力供給期間開始前の処理手順の一例を示すシーケンス図である。
図13】取引対象の電力の総電力供給期間開始後の処理手順の一例を示すシーケンス図である。
図14】非化石証書の発行と検証の処理手順の一例を示すシーケンス図である。
【発明を実施するための形態】
【0011】
以下、本実施の形態について図面を参照して説明する。なお各実施の形態は、矛盾のない範囲で複数の実施の形態を組み合わせて実施することができる。
〔第1の実施の形態〕
まず第1の実施の形態について説明する。第1の実施の形態は、資源の供給権の取引をブロックチェーンで管理し、資源の生産実績と消費実績とをブロックチェーン外で管理することで、ブロックチェーンで取り扱うデータ量を削減するためのデータ格納方法である。
【0012】
図1は、第1の実施の形態に係るデータ格納方法の一例を示す図である。図1にはブロックチェーンシステム4と、ブロックチェーンシステム4外の情報処理装置10とが示されている。
【0013】
ブロックチェーンシステム4は、例えば複数のコンピュータを含み、複数のコンピュータはP2P(Peer to Peer)で接続されている。ブロックチェーンシステム4に含まれるコンピュータは、ノードと呼ぶこともある。ブロックチェーンシステム4では、複数のノードにブロックチェーン5が分散格納される。
【0014】
ブロックチェーン5には、生産者1,2で生産され消費者3によって消費される取引資源についての供給権の取引台帳が格納される。取引資源は、例えば電力などのエネルギー資源である。取引資源には、例えば生物体の持つエネルギーを利用したバイオ燃料も含まれる。ブロックチェーン5には、取引資源の供給権が譲渡された場合に、その譲渡取引を示すトランザクションレコード5a,5bが登録される。
【0015】
生産者1,2は、自身が有する生産設備で生産する取引資源の供給権を有する。そして生産者1,2は、取引資源の供給権を第三者に譲渡することができる。
例えば生産者1,2が取引資源の供給権を譲渡すると、その取引内容を示すトランザクションレコード5aがブロックチェーン5に登録される。トランザクションレコード5aには、ID「A」の生産者1とID「B」の生産者2とが、取引資源をID「D」の仲介者に譲渡したことが示されている。
【0016】
情報処理装置10は、例えば記憶部11と処理部12とを有するコンピュータである。情報処理装置10は、例えば所定の処理手順が記述されたデータ格納プログラムを実行することにより、第1の実施の形態に係るデータ格納方法を実施することができる。記憶部11は、例えば情報処理装置10が有するメモリ、またはストレージ装置である。処理部12は、例えば情報処理装置10が有するプロセッサ、または演算回路である。
【0017】
情報処理装置10は、例えば生産者1,2が生産する取引資源の供給権を有する仲介者(ID[D])が有する装置である。仲介者「D」は、生産者1,2が取引資源を生産した後、消費者3(ID[C])にその取引資源の供給権に基づく供給契約を結ぶことができる。この供給契約を履行するには、生産者1,2による取引資源の生産実績が、消費者3による消費実績以上であることが前提となる。
【0018】
そこで情報処理装置10の処理部12は、生産者1,2が生産した取引資源の生産実績を示す第1のデータ6と、消費者3が消費した取引資源の消費実績を示す第2のデータ7とを取得する。例えば処理部12は、生産者1,2それぞれの生産設備に取り付けられた計測器で計測された生産量の時系列変化を示すデータを、第1のデータ6として取得する。例えば処理部12は、消費者3の消費設備に取り付けられた計測器で計測された消費量の時系列変化を示すデータを、第2のデータ7として取得する。処理部12は、取得した第1のデータ6と第2のデータ7とを記憶部11に格納する。
【0019】
処理部12は、消費者3の消費実績分の取引資源の供給元として生産者1,2の生産実績分の取引資源を割り当てることについての第1のデータ6と第2のデータ7との整合性の条件が満たされることを証明する証明情報8bを生成する。証明情報8bは、例えばゼロ知識証明の値である。ゼロ知識証明としては、例えば非対話ゼロ知識証明が用いられる。
【0020】
例えば処理部12は、所定の資源供給期間内の単位期間ごとに、第1のデータ6に示される生産実績と、第2のデータ7に示される消費実績とを比較する。処理部12は、単位期間それぞれについて消費量分の生産量があるという条件が満たされることを証明する証明情報8bを生成する。
【0021】
また処理部12は、第2のデータ7に示される消費実績の総量(総消費実績)についてのコミットメント関数の値8aを計算してもよい。この場合、処理部12は、第1のデータ6と第2のデータ7との整合性の条件が満たされることに加え、コミットメント関数の値8aが正しいことを証明する証明情報8bを生成する。
【0022】
さらに処理部12は、証明情報8bを含み、第1のデータ6および第2のデータ7の総データサイズよりもデータサイズが小さい第3のデータ8を生成する。なお、処理部12は、証明情報8bにおいてコミットメント関数の値8aが正しいことを証明した場合、第3のデータ8にコミットメント関数の値8aを含める。
【0023】
処理部12は、生産者1,2が生産した取引資源の供給権の取引履歴が格納されたブロックチェーン5に、第3のデータ8を含む、取引資源が消費者によって消費されたことを示すトランザクションレコード5bを格納する。例えば処理部12は、トランザクションレコード5bをブロックチェーンシステム4に送信する。ブロックチェーンシステム4では、トランザクションレコード5bの正当性を検証する。例えばブロックチェーンシステム4内の1つのノードが、証明情報8bに基づいて、第1のデータ6と第2のデータ7との整合性の条件が満たされることを検証する。そのノードは、正当な場合にトランザクションレコード5bを含むブロックをブロックチェーン5に追加する。
【0024】
このように生産実績と消費実績との管理がブロックチェーンシステム4外で行われ、ブロックチェーンには生産実績と消費実績を集約することで生成された第3のデータが格納されている。これにより、ブロックチェーン5のデータ量を削減することができる。なお生産実績と消費実績との整合性がとれていることは証明情報8bによって証明される。そのため、ブロックチェーンシステム4では証明情報8bを検証することで、ブロックチェーンシステム4内で第1のデータ6および第2のデータ7を管理することなく、生産実績と消費実績との整合性がとれていることを検証できる。証明情報8bがゼロ知識証明の値であれば、ブロックチェーンシステム4のノードは、適用されたゼロ知識証明の検証処理を実施することで、証明情報8bの正当性を検証できる。
【0025】
生産実績と消費実績とをブロックチェーンシステム4外で管理すれば、生産者の生産実績および消費者の消費実績を秘匿状態とすることも可能となる。すなわち、生産実績と消費実績とをブロックチェーンシステム4内に管理すると、生産実績と消費実績は公開情報とならざるを得ない。それに対し、生産実績と消費実績とをブロックチェーンシステム4外で管理していれば、生産実績と消費実績とを取り扱う情報処理装置10などにおいて生産実績と消費実績を非公開の情報として管理することができる。その結果、生産者および消費者のプライバシーが保護される。
【0026】
またブロックチェーンシステム4では、例えばブロックチェーン5上での取引資源を供給する権利の取引情報をUTXO(Unspent Transaction Output)方式で管理することができる。この場合、ブロックチェーンシステム4内のノードは、生産者1,2の生産期間と単位時間当たりの生産量とにより、UTXO方式におけるインプットとアウトプットの対象となる取引資源を特定する。このように生産期間と生産量との2次元の情報で取引対象となる取引資源を特定することで、電力のように生産期間と消費期間とが一致することが求められるような取引資源の供給権の取引にUTXO方式を適用することが可能となる。そしてUTXO方式を利用することにより、同じ取引資源が複数の相手に譲渡されること(ダブルカウント)を抑止できる。
【0027】
なお生産者1,2および消費者3の正当性は、電子署名技術を用いて証明することができる。例えば情報処理装置10の処理部12は、生産実績についての生産者1,2の第1の電子署名を含む第1のデータ6を取得すると共に、消費実績についての消費者3の第2の電子署名を含む第2のデータ7を取得する。そして処理部12は、生産実績と消費実績との整合性の条件が満たされることに加え、生産者1,2の第1の電子署名と消費者3の第2の電子署名とが正当であることを証明する証明情報8bを生成する。
【0028】
これにより第1のデータ6が、ブロックチェーン5に示される供給権についての生産者の生産実績であることが保証される。また消費者3が誰であるのかについても証明情報8bによって証明される。消費者3を証明できることは、例えば非化石エネルギーを用いて生産された取引資源を消費したことを消費者3が証明する場合に有用となる。
【0029】
なお生産者1,2が生産した取引資源を譲渡できるのは、その取引資源の供給権を有する者(例えばID「D」の仲介者)である。そこで情報処理装置10の処理部12は、例えばブロックチェーン5において取引資源を供給する権利を有する者の電子署名を含むトランザクションレコード5bをブロックチェーン5に格納する。これにより、ブロックチェーンシステム4において、取引資源を供給する権利を有する者の意思による譲渡取引のトランザクションレコード5bであることを確認できる。
【0030】
〔第2の実施の形態〕
次に第2の実施の形態について説明する。第2の実施の形態は、電力取引の台帳をブロックチェーンで管理する場合におけるデータ量の削減に関するものである。
【0031】
<システム構成>
図2は、電力取引システムの構成の一例を示す図である。ネットワーク20には、ブロックチェーンシステム30に含まれる複数のノード400,400a,・・・が接続されている。複数のノード400,400a,・・・は、互いにP2Pで通信接続されている。複数のノード400,400a,・・・が連係して動作することで、電力取引の台帳がブロックチェーンにより分散管理される。
【0032】
電力取引は発電事業者41a,41b,・・・、小売電気事業者43a,43b,・・・、および電力消費者42a,42b,・・・の間で行われる。電力取引の参加者であるユーザは、それぞれネットワーク20に接続されたノード100,100a,・・・,200,200a,・・・,300,300a,・・・,400,400a,・・・を有する。ノード100,100a,・・・,200,200a,・・・,300,300a,・・・,400,400a,・・・は、電力を供給する権利の取引に用いるコンピュータである。
【0033】
発電事業者41aは、物理発電設備51aを有する。物理発電設備51aは、石油、ガス、石炭などの化石燃料を用いた発電設備、または水力、太陽光、風力などの再生可能エネルギーを用いた発電設備である。物理発電設備51aは発電した電力を、電力供給網(変電・送電・配電のシステム)に供給する。物理発電設備51aにはスマートメータ53aが取り付けられており、発電した電力がスマートメータ53aにより計測される。スマートメータ53aは、ネットワーク20に接続されている。スマートメータ53aが計測した電力は、発電事業者41aのノード200によって読み出される。
【0034】
同様に発電事業者41bも、スマートメータ53bが取り付けられた物理発電設備51bを有する。スマートメータ53bが計測した電力は、発電事業者41bのノード200aによって読み出される。
【0035】
電力消費者42aは、電力消費設備52aを有する。電力消費設備52aは、工場、住宅、オフィスなどの電力を用いた機器を有する設備である。電力消費設備52aは、電力供給網を介して電力の供給を受ける。電力消費設備52aにはスマートメータ53cが取り付けられており、消費した電力がスマートメータ53cにより計測される。スマートメータ53cは、ネットワーク20に接続されている。スマートメータ53cが計測した電力は、電力消費者42aのノード300によって読み出される。
【0036】
同様に電力消費者42bも、スマートメータ53dが取り付けられた電力消費設備52bを有する。スマートメータ53dが計測した電力は、電力消費者42bのノード300aによって読み出される。
【0037】
小売電気事業者43a,43b,・・・は、ノード100,100a,・・・を用いて、例えば発電事業者41a,41b,・・・から電力供給権を買い取り、その電力供給権の範囲内で電力消費者42a,42b,・・・に電力を販売する。小売電気事業者43a,43b,・・・間で電力供給権を取引することもできる。
【0038】
電力供給権の取引は、ブロックチェーンによって台帳が管理される。例えば発電事業者41aが電力供給権を売却した場合、ノード200が、電力供給権の取引内容を示すトランザクションレコード(電力供給権トランザクションレコード)を生成する。ノード20aは、生成した電力供給トランザクションレコードをブロックチェーンシステム30のいずれかのノードに送信する。ブロックチェーンシステム30によって電力供給トランザクションレコードの正当性が検証されると、その電力供給トランザクションレコードがブロックチェーンに登録される。
【0039】
非化石価値検証者44は、ノード500により非化石証書の正当性を検証し、再生可能エネルギーで発電した電力を利用したことの認定を行う。非化石証書は、再生可能エネルギーで発電した電力の非化石価値を証書化したものである。非化石化証書は、再生可能エネルギーで発電された電力を供給した小売電気事業者43aのノード100で発行される。発行された非化石証書は、該当する電力の供給を受けた電力消費者42aのノード300に渡される。電力消費者42aは、非化石証書をノード300からノード500に送信する。するとノード500は、非化石証書が正当であることを検証する。
【0040】
図3は、ノードのハードウェアの一例を示す図である。図3には、代表的にノード100のハードウェア構成を示している。
ノード100は、プロセッサ101によって装置全体が制御されている。プロセッサ101には、バス109を介してメモリ102と複数の周辺機器が接続されている。プロセッサ101は、マルチプロセッサであってもよい。プロセッサ101は、例えばCPU(Central Processing Unit)、MPU(Micro Processing Unit)、またはDSP(Digital Signal Processor)である。プロセッサ101がプログラムを実行することで実現する機能の少なくとも一部を、ASIC(Application Specific Integrated Circuit)、PLD(Programmable Logic Device)などの電子回路で実現してもよい。
【0041】
メモリ102は、ノード100の主記憶装置として使用される。メモリ102には、プロセッサ101に実行させるOS(Operating System)のプログラムやアプリケーションプログラムの少なくとも一部が一時的に格納される。また、メモリ102には、プロセッサ101による処理に利用する各種データが格納される。メモリ102としては、例えばRAM(Random Access Memory)などの揮発性の半導体記憶装置が使用される。
【0042】
バス109に接続されている周辺機器としては、ストレージ装置103、GPU(Graphics Processing Unit)104、入力インタフェース105、光学ドライブ装置106、機器接続インタフェース107およびネットワークインタフェース108がある。
【0043】
ストレージ装置103は、内蔵した記録媒体に対して、電気的または磁気的にデータの書き込みおよび読み出しを行う。ストレージ装置103は、コンピュータの補助記憶装置として使用される。ストレージ装置103には、OSのプログラム、アプリケーションプログラム、および各種データが格納される。なお、ストレージ装置103としては、例えばHDD(Hard Disk Drive)やSSD(Solid State Drive)を使用することができる。
【0044】
GPU104は画像処理を行う演算装置であり、グラフィックコントローラとも呼ばれる。GPU104にはモニタ21が接続されている。GPU104は、プロセッサ101からの命令に従って、画像をモニタ21の画面に表示させる。モニタ21としては、有機EL(Electro Luminescence)を用いた表示装置や液晶表示装置などがある。
【0045】
入力インタフェース105には、キーボード22とマウス23とが接続されている。入力インタフェース105は、キーボード22やマウス23から送られてくる信号をプロセッサ101に送信する。なお、マウス23は、ポインティングデバイスの一例であり、他のポインティングデバイスを使用することもできる。他のポインティングデバイスとしては、タッチパネル、タブレット、タッチパッド、トラックボールなどがある。
【0046】
光学ドライブ装置106は、レーザ光などを利用して、光ディスク24に記録されたデータの読み取り、または光ディスク24へのデータの書き込みを行う。光ディスク24は、光の反射によって読み取り可能なようにデータが記録された可搬型の記録媒体である。光ディスク24には、DVD(Digital Versatile Disc)、DVD-RAM、CD-ROM(Compact Disc Read Only Memory)、CD-R(Recordable)/RW(ReWritable)などがある。
【0047】
機器接続インタフェース107は、ノード100に周辺機器を接続するための通信インタフェースである。例えば機器接続インタフェース107には、メモリ装置25やメモリリーダライタ26を接続することができる。メモリ装置25は、機器接続インタフェース107との通信機能を搭載した記録媒体である。メモリリーダライタ26は、メモリカード27へのデータの書き込み、またはメモリカード27からのデータの読み出しを行う装置である。メモリカード27は、カード型の記録媒体である。
【0048】
ネットワークインタフェース108は、ネットワーク20に接続されている。ネットワークインタフェース108は、ネットワーク20を介して、他のコンピュータまたは通信機器との間でデータの送受信を行う。ネットワークインタフェース108は、例えばスイッチやルータなどの有線通信装置にケーブルで接続される有線通信インタフェースである。またネットワークインタフェース108は、基地局やアクセスポイントなどの無線通信装置に電波によって通信接続される無線通信インタフェースであってもよい。
【0049】
ノード100は、以上のようなハードウェアによって、第2の実施の形態の処理機能を実現することができる。図2に示した他のノード31,32,・・・,200,300,400,500,600も、ノード100と同様のハードウェアによって実現することができる。また第1の実施の形態に示した装置も、図3に示したノード100と同様のハードウェアにより実現することができる。
【0050】
ノード100は、例えばコンピュータ読み取り可能な記録媒体に記録されたプログラムを実行することにより、第2の実施の形態の処理機能を実現する。ノード100に実行させる処理内容を記述したプログラムは、様々な記録媒体に記録しておくことができる。例えば、ノード100に実行させるプログラムをストレージ装置103に格納しておくことができる。プロセッサ101は、ストレージ装置103内のプログラムの少なくとも一部をメモリ102にロードし、プログラムを実行する。またノード100に実行させるプログラムを、光ディスク24、メモリ装置25、メモリカード27などの可搬型記録媒体に記録しておくこともできる。可搬型記録媒体に格納されたプログラムは、例えばプロセッサ101からの制御により、ストレージ装置103にインストールされた後、実行可能となる。またプロセッサ101が、可搬型記録媒体から直接プログラムを読み出して実行することもできる。
【0051】
<電力供給権の取引に求められる技術要件>
図2図3に示した構成のシステムにより、電力供給権の取引が実施される。ここで電力供給権の取引を行うシステムに求められる技術的な要件について説明する。
【0052】
[非中央集権性]
最初の要件は、非中央集権的なシステムであることである。すなわち信頼できる第三者機関を置かない前提で、トランザクションシステムを正しく運用できることが求められる。
【0053】
[トレーサビリティ]
2つ目の要件は、トレーサビリティを有することである。物理発電設備51a,51bは、例えば家庭のソーラー光発電設備のように再生可能エネルギーを用いた発電設備の場合がある。再生可能エネルギーで発電された電力に基づく電力供給権は、例えば小売電気事業者43a,43bに譲渡され、その電力供給権に基づいて電力消費者42a,42bに電力が供給される。電力消費者42a,42bである企業は、太陽光、水力、地熱などの非化石電源により発電された電力を購入して消費すると、CSR(Corporate Social Responsibility)の観点で高く評価される。従って電力消費者42a,42bは、非化石電源により発電された電力を購入した際には、それを証明する情報(非化石価書)の取得を希望する場合がある。非化石電力の消費者が非化石価値の検証者から非化石価値の獲得を認められるためには、いつどの物理発電設備によって発電された電力に基づく非化石価値であるかを証明できることが重要となる。そのために、電力供給権の取引の履歴を正しく追跡できることが要求される。
【0054】
[ダブルカウント防止]
3つ目の要件は、電力供給権のダブルカウントが防止されていることである。電力の取引におけるダブルカウントは、1つの物理発電設備においてある期間に発電される電力供給権が、異なる2つの相手に譲渡されることである。これは各物理発電設備の各時刻の発電実績が、複数の異なる発電実績として悪用されてしまうことを防止するために重要となる。
【0055】
[スケーラビリティー]
4つ目の要件は、高いスケーラビリティーを有することである。個人の家屋への小規模の太陽光発電システムの導入が一般化し、100万件規模の小規模発電事業者が存在する。これらの小規模発電事業者で発電した電力供給権を取引するには、100万件以上のリアルタイムに近い(30分単位の)非化石電力についての需給マッチングを管理できるトランザクション性能が求められる。
【0056】
[ストレージコスト]
5つ目の要件はストレージコストを低く抑えることである。電力は物理発電設備51a,51bによって生産され、電力消費設備52a,52bによって消費される。これらの設備による発電実績と電力消費実績とを正確に管理することが要求される。物理発電設備51a,51bに取り付けられているスマートメータ53a,53bは、30分ごとに、過去30分間に発電した電力量を含むスマートメータレコードを生成する。一方、電力消費設備52a,52bのスマートメータ53c,53dは、30分ごとに、過去30分間に消費した電力量を含むスマートメータレコードを生成する。その結果、スマートメータレコードが大量に生成される。そのため長期間にわたって運用可能なシステムとするには、膨大な量のスマートメータレコードを管理するためのストレージコストを低く抑えることが重要となる。
【0057】
[プライバシー]
6つ目の要件は、ユーザのプライバシーを保護できることである。プライバシー情報と位置付けられるのは、例えば電力発電実績および電力消費実績のスマートメータのデータである。スマートメータのデータを電力取引の当事者以外のユーザには開示せずにすむことが求められる。
【0058】
<要件を満たすための技術の概要>
第2の実施の形態では、以上の6つの要件を満たすために、ブロックチェーンを用いたシステムを提供する。ただし、ブロックチェーンを用いただけでは、電力供給権の取引に求められるすべての技術的要件を満たすことはできない。特に以下のような課題が存在する。
【0059】
まず、ブロックチェーンは通常のデータベースと比較してストレージコストが高く、またデータの整合性を検証するための処理が遅い。さらに、ブロックチェーンはすべてのユーザ間でデータを共有するため、電力発電実績や電力消費実績をそのままの形でブロックチェーンに格納するとプライバシーが保たれない。
【0060】
すなわちブロックチェーンは分散型で取引の台帳を管理可能な技術であり、ブロックチェーンを利用することで非中央集権型のシステムを構築できる。ただしブロックチェーンは、トランザクション数が多くなりすぎると迅速に処理できなくなるというスケーラビリティー問題が存在する。そのため、多数の物理発電設備または電力消費設備によって30分ごとに生成される膨大なスマートメータレコードすべてをトランザクションとしてブロックチェーンに格納することは困難である。
【0061】
そこで第2の実施の形態のシステムでは、膨大なスマートメータレコードをブロックチェーンに格納するのではなく、スマートメータレコードを集約することでサイズダウンした電力マッチングレコードをブロックチェーンに格納する。これにより、ブロックチェーンに格納するデータサイズを抑えることができ、スケーラビリティー問題を解決できる。
【0062】
電力マッチングレコードは、ある物理発電設備により発電された電力に対応するスマートメータレコードとその電力を消費した消費設備のスマートメータレコードとを集約することにより生成されるものである。電力マッチングレコードには、「消費設備ID」「総電力供給期間」「総電力量コミットメント」「ゼロ知識証明」「仮想発電設備による電子署名」が含まれるが、集約元の複数のスマートメータレコードのデータの総量よりもデータサイズが小さい。そのため、電力マッチングレコードであれば、ブロックチェーンに格納しても、ブロックチェーンで取り扱うデータ量の増大が抑止される。
【0063】
しかも第2の実施の形態のシステムでは、ブロックチェーンに格納された電力マッチングレコードに「総電力量コミットメント」と「ゼロ知識証明」を含めることにより、発電実績と電力消費実績との整合性がとれていることをゼロ知識証明によって証明する。これにより、例えば発電量の総量及び消費量の総量が一致しているか否かの検証を、それぞれのスマートメータレコードに含まれる発電実績および電力消費実績を秘匿したまま実行することが可能となる。
【0064】
このように、第2の実施の形態に係る電力取引システムによれば、サイズダウンした電力マッチングレコードがブロックチェーンに格納される。これにより、ブロックチェーンのスケーラビリティー問題を解決するとともに、ゼロ知識証明技術によって、発電実績および電力消費実績を秘匿したまま、電力取引の正当性の検証を可能とする電力取引ブロックチェーンシステムを提供することができる。
【0065】
なお、物理発電設備のスマートメータレコードと消費設備のスマートメータレコードとをマージしたデータを圧縮すればデータサイズを小さくすることができる。そのためデータ圧縮技術を用いればブロックチェーンの容量の削減は可能である。しかし、ブロックチェーンに登録されたデータは公開情報となる。そのため、圧縮されたデータを伸張することで、スマートメータレコードの内容も第三者に見られてしまう。従って、プライバシー保護の要件を満たしつつブロックチェーンのデータサイズを削減するには、スマートメータレコードをブロックチェーン外で管理し、電力マッチングレコードのみをブロックチェーンに登録するのが適切である。
【0066】
電力供給権の取引は、発電事業者41a,41b,・・・、電力消費者42a,42b,・・・、および小売電気事業者43a,43b,・・・の間で行われる。このうち小売電気事業者43a,43b,・・・は、電力供給権の取引においては、仮想発電設備の運用者として取り扱うことができる。また発電事業者41a,41b,・・・それぞれは、複数の物理発電設備を運用する可能性がある。同様に電力消費者42a,42b,・・・は、複数の電力消費設備を運用する可能性がある。
【0067】
このように電力供給権を取引するユーザと物理発電設備または電力消費設備とは、1対1には対応しない。そして、実際の電力の供給と消費は、仮想発電設備を介して、物理発電設備と電力消費設備との間で行われる。そのため、発電実績と電力消費実績を考慮した取引を行うには、仮想発電設備、物理発電設備、電力消費設備それぞれを識別することが求められる。そこで仮想発電設備、物理発電設備、電力消費設備それぞれには予め一意の識別子(電力設備ID)が付与され、電力設備IDを用いて電力供給権の取引、発電実績、電力消費実績が管理される。このときシステム上は、仮想発電設備、物理発電設備、電力消費設備それぞれが、電力供給権の取引主体として取り扱われる。以下、仮想発電設備、物理発電設備、および電力消費設備を総称して、電力設備と呼ぶ。
【0068】
<電力供給権の取引のためのノードの機能>
次にブロックチェーンを利用して電力供給権を取引するために各ノードが有する機能について説明する。
【0069】
図4は、各ノードの機能の一例を示すブロック図である。発電事業者41aのノード200は、スマートメータレコード提供部210とトランザクション生成部220とを有する。
【0070】
スマートメータレコード提供部210は、物理発電設備51a(図2参照)に取り付けられたスマートメータ53aから、物理発電設備51aにおける発電量の時間遷移を示すスマートメータレコードを定期的に取得する。スマートメータレコード提供部210は、物理発電設備51aで発電した電力を販売する権利を有する小売電気事業者のノードに、取得したスマートメータレコードを送信する。
【0071】
トランザクション生成部220は、発電事業者41aが電力供給権を小売電気事業者に売った場合に、取引内容を示す電力供給権トランザクションレコードを生成する。トランザクション生成部220は、生成した電力供給権トランザクションレコードを、ブロックチェーンシステム30内のいずれかのノードに送信する。またトランザクション生成部220は、生成した電力供給権トランザクションレコードを、電力供給権の譲渡先の電力設備(例えば仮想発電設備)を運用するユーザ(例えば小売電気事業者)のノードへ送信する。
【0072】
発電事業者41a以外の発電事業者41b,・・・が有するノード200a,・・・も、ノード200と同様の機能を有する。
電力消費者42aのノード300は、スマートメータレコード提供部310と非化石証書管理部320とを有する。
【0073】
スマートメータレコード提供部310は、電力消費設備52a(図2参照)に取り付けられたスマートメータ53cから、電力消費設備52aにおける消費電力の時間遷移を示すスマートメータレコードを定期的に取得する。スマートメータレコード提供部310は、電力消費設備52aで消費した電力分の電力供給権を有する小売電気事業者から電力の共有を受ける契約を結んだ場合に、その小売電気事業者のノードに取得したスマートメータレコードを送信する。
【0074】
非化石証書管理部320は、非化石エネルギーで発電された電力の販売する権利を購入した場合に、その電力の販売元から非化石証書を取得する。非化石証書管理部320は、取得した非化石証書をメモリまたはストレージ装置に格納する。そして非化石証書管理部320は、非化石エネルギーで発電された電力を消費したことを第三者(例えば非化石価値検証者44)に非化石証書を送信する。
【0075】
電力消費者42a以外の電力消費者42b,・・・が有するノード300a,・・・(図2参照)も、ノード300と同様の機能を有する。
小売電気事業者43aのノード100は、スマートメータレコード管理部110、マッチング部120、トランザクション生成部130、トランザクション記憶部140、および非化石証書発行部150を有する。
【0076】
スマートメータレコード管理部110は、小売電気事業者43aが、電力供給権に基づく電力共有契約を締結したことを示す情報の入力に応じて、その電力供給権に対応する物理発電設備と電力供給先の電力消費設備とのスマートメータレコードとを取得する。スマートメータレコード管理部110は、取得したスマートメータレコードをメモリ102またはストレージ装置103に格納する。
【0077】
マッチング部120は、電力供給契約の対象となる電力供給権に対応する物理発電設備の発電実績と電力消費設備の電力消費実績の整合性を検証する。整合性が確認できた場合、トランザクション生成部130に電力供給権トランザクションレコードの生成を指示する。
【0078】
トランザクション生成部130は、取引された総電力量を示す総電力量コミットメントと、発電実績と電力消費実績との整合性がとれていることを証明するゼロ知識証明とを含む電力供給権トランザクションレコードを生成する。そしてトランザクション生成部130は、生成した電力供給権トランザクションレコードを、ブロックチェーンシステム30内のいずれかのノードに送信する。またトランザクション生成部130は、電力供給権トランザクションレコードの生成に使用した情報をトランザクション記憶部140に格納する。さらにトランザクション生成部130は、電力供給権の譲渡先の電力設備(例えば他の仮想発電設備)を運用するユーザ(例えば他の小売電気事業者)のノードへ、生成した電力供給権トランザクションレコードを送信する。
【0079】
トランザクション生成部130は、他のノードからそのノードが生成した電力供給権トランザクションレコードを受信した場合、受信した電力供給権トランザクションレコードをトランザクション記憶部140に格納する。
【0080】
トランザクション記憶部140は、トランザクション生成部130が生成した電力供給権トランザクションレコードを記憶する。またトランザクション記憶部140は、他のノードからノード100に送信された電力供給権トランザクションレコード(ノード100に対応する仮想発電設備を電力供給権の譲渡先とする電力供給権トランザクションレコード)を記憶する。
【0081】
非化石証書発行部150は、非化石エネルギーで発電された電力の電力供給権の販売先の電力消費者からの依頼に応じて、非化石証書を発行する。例えば非化石証書発行部150は、トランザクション記憶部140に格納されている電力供給権トランザクションレコードに基づいて非化石証書を生成する。そして非化石証書発行部150は、生成した非化石証書を、発行を依頼した電力消費者のノードへ送信する。
【0082】
小売電気事業者43a以外の小売電気事業者43b,・・・が有するノード100a,・・・(図2参照)も、ノード100と同様の機能を有する。
ブロックチェーンシステム30を構成するノード400は、スマートコントラクト410とブロックチェーンプラットフォーム420とを有する。
【0083】
スマートコントラクト410は、ブロックチェーンを用いた取引契約を自動で実行する。例えばスマートコントラクト410は、電力供給権トランザクションレコードを受信すると、そのトランザクションレコードに示される取引内容に基づいて、予め設定されている取引の成約条件が満たされたか否かを検証する。そしてスマートコントラクト410は、取引の成約条件が満たされた場合、電力供給権トランザクションレコードのブロックチェーンプラットフォーム420への格納処理を行う。
【0084】
ブロックチェーンプラットフォーム420は、ブロックチェーンシステム30内の他のノード400a,・・・と連係し、ブロックチェーンの仕組みを用いて電力供給権の取引の台帳を管理する。例えばブロックチェーンプラットフォーム420は、スマートコントラクト410から受信した電力供給権トランザクションレコードを含むブロックを、ブロックチェーンの新たなブロックとして追加する。ブロックチェーンプラットフォーム420は、ブロックチェーンにブロックを追加した場合、ブロックチェーンシステム30を構成する他のノード400a,・・・にブロックチェーンを送信し、ブロックチェーンを分散管理する。
【0085】
ブロックチェーン記憶部421は、電力供給権の取引を示すブロックチェーンを記憶する。例えばブロックチェーン記憶部421には、スマートコントラクト410またはブロックチェーンシステム30を構成する他のノード400a,・・・で更新されたブロックチェーンが格納される。
【0086】
ブロックチェーンシステム30を構成するノード400以外のノード400a,・・・も、ノード400と同様の構成を有する。
なお、図4に示した各要素間を接続する線は通信経路の一部を示すものであり、図示した通信経路以外の通信経路も設定可能である。例えばブロックチェーンシステム30で管理しているブロックチェーンは公開情報であり、ブロックチェーンシステム30外のいずれのノードからも参照可能である。また、図4に示した各ノード内の各要素の機能は、例えば、その要素に対応するプログラムモジュールをコンピュータに実行させることで実現することができる。
【0087】
<電力供給権の取引の概要>
図5は、電力供給権の取引の概要を示す図である。図5に示すように、電力供給権の取引はブロックチェーン60内で管理される。他方、発電実績と電力消費実績は、ブロックチェーン60外で管理される。
【0088】
前述の電力供給権に求められる要件のうち、非中央集権性はブロックチェーン60を利用することにより達成できる。トレーサビリティおよびダブルカウント防止はブロックチェーン60においてUTXO(Unspent Transaction Output)方式を用いた電力供給権管理を行うことで達成される。
【0089】
UTXO方式は、あるユーザ(例えば小売電気事業者)の未使用トランザクションを合計することで、そのユーザの有する権利(例えば電力供給権)の総量を算出するものである。UTXO方式を採用すると、電力供給権の譲渡を表す電力供給権トランザクションレコードにおいて、譲渡元のユーザが有する電力供給権がインプットに設定される。その電力供給権トランザクションレコードのアウトプットに、譲渡する電力供給権が設定される。あるユーザがアウトプットで指定された電力供給権のうち、他の電力供給権トランザクションレコードのインプットとして使用されていない電力供給権が、そのユーザから他のユーザに移譲されていない(自身が保有している)電力供給権を表す。
【0090】
UTXO方式においては、同じリソースを異なる複数の他者に譲渡することはできない。そのためUTXO方式で電力供給権を取引することで、電力供給権の取引のダブルカウントの防止が可能となる。またUTXO方式では、インプットとアウトプットの形式で電力供給権の譲渡人と譲受人とが電力供給権トランザクションレコードに示される。その結果、電力供給権の取引の履歴を正しく追跡できる(トレーサビリティの要件が満たされる)。
【0091】
ストレージコストの要件は、スマートメータレコード75a,75b,・・・,76a,76b,・・・,77a,77b,・・・を集約した電力マッチングレコード78をブロックチェーン60に登録することで達成される。スケーラビリティーの要件は、取引対象の電力供給権に対応する物理発電設備の発電実績と譲受人の電力消費設備の電力消費実績とのマッチングをブロックチェーン60外で行うことで達成できる。
【0092】
さらにブロックチェーンシステム30外の各ノードがスマートメータレコードを秘密に管理する。そしてブロックチェーンシステム30外の各ノードは、コミットメントスキームを用いて総電力供給量を隠蔽するとともに、マッチング結果の正当性をゼロ知識証明78bによって証明する。これによりプライバシーの保護が達成される。
【0093】
図5には、物理発電設備Aと物理発電設備Bの電力供給権を小売電気事業者が取得し、その小売電気事業者が電力消費設備Gを有する電力消費者へ、電力供給権を譲渡する場合の例が示されている。なおシステム上は、小売電気事業者が仮想発電設備Dを運用しているものとして扱われる。このような取引の概略を以下に示す。
【0094】
ブロックチェーンシステム30において、電力供給権を管理する台帳がブロックチェーン60で生成される。電力供給管理は、多くの場合、一ヶ月といったまとまった期間で行われるためデータ量は膨大にはならない。従って、電力供給権の取引に関するすべての電力供給権トランザクションレコードをブロックチェーン60上で管理する。
【0095】
例えばブロック61には、物理発電設備Aを有する発電事業者が電力供給権71を有し、物理発電設備Bを有する発電事業者が電力供給権72を有することが記録されているものとする。電力供給権71,72には、物理発電設備で発電予定の電力と発電期間が設定されている。
【0096】
仮想発電設備Dを有する小売電気事業者は、各発電事業者との間で電力供給権71,72の譲渡契約を結ぶ。この譲渡契約は、例えば電力供給権71,72に設定された発電期間の開始前に行われる。譲渡契約が結ばれると、発電事業者は自身の有するノードを用いて電力供給権71,72の譲渡内容を示す電力供給権トランザクションレコード70a,70bを生成する。そして各発電事業者のノードは、電力供給権トランザクションレコード70a,70bをブロックチェーンシステム30内のノードに送信する。
【0097】
ブロックチェーンシステム30では、電力供給権トランザクションレコード70a,70bの内容が正当であることを確認後、電力供給権トランザクションレコード70a,70bを含む新たなブロック62をブロックチェーン60に登録する。ブロック62には、2つの電力供給権71,72を包含する電力供給権73を、仮想発電設備Dを運用する小売電気事業者が有していることが示される。またブロック62には、前のブロック61のハッシュ値が含まれる。これにより取引履歴の改ざんが抑止される。
【0098】
なお、ブロックチェーンシステム30では、発電実績のダブルカウントを防止するために、各物理発電設備の各時刻の電力供給権が複数の異なる電力消費設備に割り当てられることがないように、UTXO方式で電力供給権の取引を管理する。
【0099】
次に仮想発電設備Dを運用する小売電気事業者は、電力消費設備Gを有する電力消費者との間で電力供給権73に基づく電力の供給を結ぶ。電力供給権71,72に設定されていた発電期間が終了すると、仮想発電設備Dを運用する小売電気事業者は、自身の有するノードによりスマートメータレコード75a,75b,・・・,76a,76b,・・・,77a,77b,・・・を収集する。以下仮想発電設備Dを運用するのは小売電気事業者43a(図2参照)であり、その小売電気事業者43aはノード100を用いて電力供給権の取引を行うものとする。
【0100】
スマートメータレコード75a,75b,・・・,76a,76b,・・・,77a,77b,・・・には、譲渡する電力供給権73に示される発電期間分の一定時間(例えば30分)間隔の発電および電力消費実績が示される。小売電気事業者43aのノード100は、物理発電設備Aと物理発電設備Bとのスマートメータレコード75a,75b,・・・,76a,76b,・・・に基づいて、取引の対象となる発電期間における一定時間間隔の発電量(発電実績)を算出する。またノード100は、電力消費設備Gのスマートメータレコード77a,77b,・・・に基づいて、取引の対象となる発電期間における一定時間間隔の電力消費量(電力消費実績)を算出する。
【0101】
次にノード100は、電力発電実績と電力消費実績のマッチングが正しいことを示す電力マッチングレコード78を生成し、ブロックチェーンシステム30に送信する。電力マッチングレコード78には、総電力供給量を隠蔽するために、総電力供給量についてのコミットメント(総電力量コミットメント78a)が含まれる。また電力マッチングレコード78には、譲渡された電力供給権73に対応する物理発電設備A,Bの発電実績と、譲渡先の電力消費設備Gの電力消費実績との整合性が採れていることを証明するゼロ知識証明78bが含まれる。
【0102】
電力マッチングレコード78を受信したブロックチェーンシステム30は、電力マッチングレコード78を含むブロック63をブロックチェーン60に登録する。この際、ブロックチェーンシステム30は、電力消費者への電力供給権73の譲渡に関する電力供給権トランザクションレコード70cに示される電力消費設備Gへの電力供給権74に対応するUTXOに、電力マッチングレコード78を関連付ける。
【0103】
このように、30分単位の大量のスマートメータレコードの代わりに、集約した電力マッチングレコード78がブロックチェーン60に記録される。これによりブロックチェーン60のスケーラビリティーおよびストレージコストの問題が解決する。このとき、ブロックチェーン60の内部データと外部データが整合性を持つことを、スマートメータレコードを開示せずに証明するために、ゼロ知識証明78bが利用される。これにより発電事業者の発電実績や電力消費者の電力消費実績の秘匿状態が守られ、プライバシーの問題も解決される。
【0104】
なお、電力マッチングレコード78をブロックチェーン60に記録する際に、スマートコントラクト410がゼロ知識証明の検証を行う。そのため、不正な電力マッチングレコードがブロックチェーン60上に記録されることを抑止することができる。
【0105】
<電力供給権の取引へのUTXO方の適用>
次にUTXO方式による電力供給権の取引について具体的に説明する。
図6は、電力供給権の取引の一例を示す図である。電力供給権71~74は、電力を供給する権利を有する発電期間と、その期間に発電する予定の電力とによって、供給できる電力が示される。横軸を時刻、縦軸を電力とするグラフで表すと、電力供給権71~74それぞれで供給可能な電力が矩形で表される。仮想発電設備Dで供給可能な電力は、物理発電設備Aと物理発電設備Bとのそれぞれで供給可能な電力の合計となる。
【0106】
電力供給権73の発電可能な電力の一部を、電力消費設備Gを運用する電力消費者に譲渡する場合、仮想発電設備Dで供給可能な電力を示す矩形の範囲内の電力が、電力供給権74として電力消費設備Gに譲渡される。
【0107】
このようにブロックチェーンシステム30では、取引対象の電力供給権が時刻と電力に基づいた二次元の情報で特定され、UTXO方式を利用して管理される。電力供給権の管理は、多くの場合、一ヶ月といったまとまった期間で行われる。そのため、データ量が膨大にはならない。従って、すべての電力供給権トランザクションレコードをブロックチェーン60上で管理することが可能である。
【0108】
UTXO方式を採用しているため、ブロックチェーンシステム30は同じリソース(期間とその期間内の電力とで表される矩形領域の電力)を複数の異なるユーザに譲渡するこが許容されない。そのため、各物理発電設備の各時刻の電力供給が複数の異なる電力消費設備に割り当てられることがなくなり、発電実績のダブルカウントを防止することができる。ブロックチェーン60において、電力消費設備Gの消費電力の分として譲渡された電力供給権74を示す電力供給権トランザクションレコードには電力マッチングレコード78が関連付けられる。
【0109】
<発電実績と電力消費実績との電力供給権との関連付け>
電力供給権トランザクションレコードは、電力供給権の譲渡が行われたことを示すトランザクションであり、実際の電力の供給ルートとは異なる。例えば仮想発電設備は電力を供給する権利を別の電力会社に転売することができる。この転売は、理論上、無限回数分繰り返すことができる。最終的に、ある仮想発電設備から電力消費設備への電力供給権を譲渡する電力供給トランザクションレコードの登録により譲渡の流れが終了する。
【0110】
従って、UTXOの関係を示すグラフの末端は必ず電力消費設備となる。またそのグラフにおいて、電力消費設備の一つ手前は、最終的にその電力消費設備に対して電力供給した仮想発電設備となる。
【0111】
電力供給権トランザクションレコードは、電力供給権の譲渡を意味するため、原則として実際の発電時刻より前にブロックチェーンに記録される。しかし、発電実績と電力消費実績は、いずれもその時になってみないと分からない不確定な量である。従って電力消費設備への電力供給権の譲渡を示す電力供給権トランザクションレコードについては、権利の対象となる総電力供給期間の後にブロックチェーン60に登録することができる。なお電力消費設備への電力供給権の譲渡を示す電力供給権トランザクションレコードを総電力供給期間の前に登録しておき、総電力供給期間の経過後に電力供給権の再譲渡を行うことで、事後的に電力供給権で消費された電力量の調整を行ってもよい。
【0112】
電力消費設備へ電力供給権を譲渡する仮想発電設備を運用する小売電気事業者のノード100は、取引された電力供給権の総電力供給期間の経過後、電力発電実績と電力消費実績のマッチング結果を意味する電力マッチングレコード78を生成する。そしてノード100は、生成した電力マッチングレコード78を、電力消費設備への電力供給権の譲渡を示す電力供給権トランザクションレコードに関連付けて、ブロックチェーン60に登録する。
【0113】
なお電力マッチングレコード78にはゼロ知識証明78bが含まれ、ゼロ知識証明78bがスマートコントラクト410で検証される。これにより、電力マッチングレコード78は適切な電力消費設備の適切なUTXOに対してしか関連付けることができない。
【0114】
なお図6の例では、電力供給権71と電力供給権72それぞれの一部の電力が電力供給権74の電力となっている。UTXO方式の場合、電力供給権71と電力供給権72の一部を譲渡した場合、譲渡した後に残った電力の分の電力供給権は、自分自身へ譲渡する電力供給権トランザクションレコードによって譲渡元の権利として残される。
【0115】
<電力供給権の取引例>
以下、図7図8を参照して、電力供給権の取引例について説明する。
図7は、電力供給権の取引の第1の例を示す図である。図7の例では物理発電設備A,B,Cそれぞれから仮想発電設備Dへ電力供給権が譲渡されている。そして仮想発電設備Dが有する電力供給権に基づいて、電力消費設備Gへの電力供給契約が結ばれている。このとき物理発電設備A,B,Cの発電実績が電力消費設備Gの電力消費実績を大きく上回っている。この場合、仮想発電設備Dから自分自身へ余剰分の電力供給権を譲渡(仮想通貨のおつりに相当)する電力供給権トランザクションレコードと、仮想発電設備Dから電力消費設備Gへの電力供給を示す電力供給権トランザクションレコードとが生成される。
【0116】
仮想発電設備Dから電力消費設備Gへの電力供給を示す電力供給権トランザクションレコードには電力マッチングレコード79aが付与される。そして電力マッチングレコード79aを含む電力供給権トランザクションレコードがブロックチェーン60に登録される。
【0117】
図7では、電力供給権の取引における左側の設備がUTXOのインプットの対象であり、右側の設備がUTXOのアウトプットの対象である。発電後に電力供給権トランザクションレコードのアウトプットに対応する電力供給権を所有する仮想発電設備を運用する小売電気事業者のノードだけが、その電力供給権に対応する期間の電力マッチングを行うことができる。つまり、小売電気事業者のノードは、電力供給権トランザクションレコードのインプットで指定したUTXOの一部に対して電量マッチングを行う。そして小売電気事業者のノードは、その電力マッチングに関するデータセットを電力供給権トランザクションレコードのアウトプットフィールドに追加することができる。結果的に、該当する「UTXOの一部」は電力マッチングにより消滅し、電力供給権はターミネートする(以後、誰にも譲渡できなくなる)。
【0118】
図8は、電力供給権の取引の第2の例を示す図である。図8の例では物理発電設備A,B,Cそれぞれから仮想発電設備Qへ電力供給権が譲渡されている。さらに仮想発電設備Qから仮想発電設備Rへ電力供給権が譲渡されている。そして仮想発電設備Rが有する電力供給権に基づいて、電力消費設備Gへの電力供給契約が結ばれている。
【0119】
仮想発電設備Rから電力消費設備Gへ電力供給権を譲渡する電力供給権トランザクションレコードには電力マッチングレコード79bが付与される。そして電力マッチングレコード79bを含む電力供給権トランザクションレコードがブロックチェーン60に登録される。なお電力消費設備Gへの電力供給を示す電力供給権トランザクションレコードはターミネートし、その後、該当する電力供給権を譲渡することはできなくなる。
【0120】
図8に示すように、複数の仮想発電設備を介して電力供給権が電力消費設備に譲渡される場合がある。物理発電設備と電力消費設備との間に介在する仮想発電設備の数は3以上の場合もあり得る。
【0121】
電力供給権を譲渡する側のノードは、電力供給権トランザクションレコードをブロックチェーンに書き出すと同時に、譲渡する相手のノードに電力供給権トランザクションレコードの内容を送信する。従って小売電気事業者のノードは、自身が譲渡先となる電力供給権トランザクションレコードのデータをすべてローカルで保持・管理している。
【0122】
<電力供給トランザクションレコード>
電源供給権トランザクションレコードのデータ構造は、インプットとアウトプットの種別に応じて異なる。例えば図7図8では電力供給権の譲渡元の名称に隣接してインプットの種別が示されており、譲渡先の名称に隣接してアウトプットの種別が示されている。
【0123】
図9は、電源供給権トランザクションレコードのデータ構造の一例を示す図である。電力供給権トランザクションレコード80のインプット81の種別には、譲渡元電力設備自身の発電に基づく新規電力供給権のインプット(i1)と譲渡に基づく電力供給権のインプット(i2)がある。新規電力供給権は、物理発電設備を運用する発電事業者のノードが発行する電力供給権である。譲渡に基づく電力供給権は、仮想発電設備を運用する小売電気事業者のノードが発行する電力供給権である。インプット81の種別ごとのインプット81の内容は以下の通りである。
【0124】
[譲渡元電力設備自身の発電に基づく新規電力供給権のインプット(i1)]
新規電力供給権の電源供給権トランザクションレコードには、譲渡元の物理発電設備ID、譲渡元の物理発電設備の発電に基づく電力供給権を表す矩形領域(発電期間×電力)、および譲渡元の物理発電設備による電子署名が含まれる。
【0125】
[譲渡に基づく電力供給権のインプット(i2)]
譲渡に基づく電力供給権の電源供給権トランザクションレコードには、電力供給権を譲り受けた際の電力供給権トランザクションレコード、その電源供給権トランザクションレコード内の電力供給権のアウトプット番号、譲渡元の電力設備による電子署名が含まれる。
【0126】
電力供給権トランザクションレコード80のアウトプット82の種別には、電力消費設備以外(例えば仮想発電設備)に電力供給権を譲渡した場合のアウトプット(o1)と、電力消費設備に電力供給権を譲渡した場合のアウトプット(o2)とがある。電力消費設備に電力供給権を譲渡した場合とは、電力供給権がターミネートする場合である。アウトプット82の種別ごとのアウトプット82の内容は以下の通りである。
【0127】
[電力消費設備以外に電力供給権を譲渡した場合のアウトプット(o1)]
電力消費設備以外に電力供給権を譲渡する電源供給権トランザクションレコードには、譲渡先電力設備ID、物理発電設備ID、および電力供給権を表す矩形領域(発電期間×電力)が含まれる。
【0128】
[電力消費設備に電力供給権を譲渡した場合のアウトプット(o2)]
電力消費設備に電力供給権を譲渡する電源供給権トランザクションレコードには、電力消費設備IDと電力マッチングレコードとが含まれる。電力マッチングレコードは、スマートメータレコードに基づいて生成される情報である。
【0129】
以上が、電力供給トランザクションレコードの内容である。
<スマートコントラクト>
ブロックチェーン60に記録される電力供給トランザクションレコードの内容の正当性は、ブロックチェーンシステム30におけるスマートコントラクト410によって保証される。例えば各電力供給権トランザクションレコードがUTXO方式の原則(アウトプットをインプットの総量の範囲内で生成する)を守るようにスマートコントラクト410が制御する。これにより電力供給権のダブルカウントを防止することができる。以下にスマートコントラクトの検証内容を示す。
【0130】
[スマートコントラクトへの入力値]
・電力供給権トランザクションレコード
[スマートコントラクトの検証項目]
・電力供給権トランザクションレコードのインプットの電子署名の正当性の検証
・値の範囲の正当性の検証(以下の4項目の検証)
-認証機関の署名付きの譲渡先電力設備IDがブロックチェーンに登録されていること。
-認証機関の署名付きの物理発電設備IDがブロックチェーンに登録されていること。
-認証機関の署名付きの電力消費設備IDがブロックチェーンに登録されていること(電力供給権のターミネートの場合のみ)。
-電力供給権を表す全ての矩形領域が正常な値の範囲に存在すること。
・電力供給権のダブルカウントが発生していないことの検証(以下の3項目の検証)。
-電力供給権トランザクションレコードのアウトプットで譲渡される電力供給権を表す各矩形領域が、電力供給権トランザクションレコードのインプットの電力供給権を表す全ての矩形領域の和集合の中に含まれること。
-異なる二つの電力供給権トランザクションレコードのアウトプットの電力供給権を表す矩形領域のペアのうち、重なるものが存在しないこと。
-各電力供給権トランザクションレコードのインプットの新規電力供給権と物理発電設備が同じでかつ矩形領域が重なる新規電力供給権が一つもブロックチェーン60上に記録されていないこと(譲渡元が物理発電設備の場合のみ)。
・電力マッチングレコードのマッチング正当性証明の検証(電力供給権のターミネートの場合のみ)。
【0131】
以上がスマートコントラクト410における検証内容である。スマートコントラクト410がマッチング正当性証明を検証することで、発電実績や電力消費実績を示すスマートメータレコードの内容を秘匿したままでも、取引の正当性を保証することができる。
【0132】
<電力マッチング>
電力マッチングは、譲渡される電力供給権に対応する物理発電設備における総電力供給期間の発電実績と、譲渡先の電力消費者が運用する電力設備における総電力供給期間の電力消費実績の整合性を検証することである。発電実績と電力消費実績とは、スマートメータレコードに基づいて判断される。そして電力マッチングの結果が電力マッチングレコードに設定される。
【0133】
図10は、スマートメータレコードと電力マッチングレコードとに含まれる情報の一例を示す図である。例えば物理発電設備に取り付けられたスマートメータ53aは、取り付け先の物理発電設備を識別する物理発電設備ID、発電期間、発電量、電子署名が含まれるスマートメータレコード75a,75b,・・・を定期的に生成する。スマートメータレコード75a,75b,・・・の生成周期は例えば30分である。その場合、スマートメータレコード75a,75b,・・・に示される発電期間の長さも30分となる。発電量は、発電期間の間に発電された電力量である。電子署名は、スマートメータレコードの内容に誤りがないことを示す物理発電設備の電子署名である。物理発電設備に取り付けられた他のスマートメータ53bも、同様の内容のスマートメータレコード76a,76b,・・・を生成する。
【0134】
電力消費設備に取り付けられたスマートメータ53cは、取り付け先の電力消費設備を識別する電力消費設備ID、消費期間、消費量、および電子署名を含むスマートメータレコード77a,77b,・・・を定期的に生成する。スマートメータレコード77a,77b,・・・の生成周期は例えば30分である。その場合、スマートメータレコード77a,77b,・・・に示される消費期間の長さも30分となる。消費量は、消費期間の間に消費した電力量である。電子署名は、スマートメータレコードの内容に誤りがないことを示す電力消費設備の電子署名である。
【0135】
ここでスマートメータ53a,53b,53cは信頼できるものとする。すなわちスマートメータ53a,53b,53cが電子署名を付与したスマートメータレコードに記録された発電量や電力消費量を含むすべてのデータは、信頼できるものとする。なお、電力設備ID(物理電力設備IDおよび電力消費設備IDを含む)は一定のビット幅を持つランダム値であり、仮名性(pseudonym)を持つものとする。
【0136】
物理発電設備のスマートメータレコード75a,75b,・・・,76a,76b,・・・と電力消費設備のスマートメータレコード77a,77b,・・・とを集約することで、電力マッチングレコード78が生成される。電力マッチングレコード78には、電力消費設備ID、総電力供給期間、総電力量コミットメント、マッチング証明、および最終仮想発電設備による電子署名が含まれる。マッチング証明は、電力マッチングが正しく行われたことを証明する情報である。マッチング証明には、例えばゼロ知識証明が用いられる。
【0137】
電力マッチングレコード78を生成するノードは、電力マッチングを行う。電力マッチングは、物理発電設備の発電実績と電力消費設備の電力消費実績とを照らし合わせ、電力消費実績に相当する電力が、取引の対象となっている電力供給権に対応する物理発電設備で発電できていることを確認する処理である。
【0138】
図11は、電力マッチングの一例を示す図である。図11には、総電力供給期間における物理発電設備A,B,Cで発電した電力の電力供給権を電力消費設備Gに譲渡する場合の電力マッチングの例が示されている。2021年5月4日の6:00からの所定期間が総電力供給期間となっている。電力マッチングは、スマートメータレコードにおける発電期間単位(図11の例では30分)で行われる。
【0139】
例えば6:00から6:30の期間の電力消費設備Gの電力消費実績(30分間の消費電力)は6.8kwである。同じ期間の物理発電設備Aの発電実績は3.0kw、物理発電設備Bの発電実績は2.0kw、物理発電設備Cの発電実績は1.8kwである。電力マッチングを行うノードは、物理発電設備の発電実績の合計が、電力消費設備の電力消費実績と等しいこと、または発電実績が電力消費実績以上であることを確認する。6:00から6:30の期間の発電実績の合計が6.8kwであり、電力消費設備Gの電力消費実績分の電力が物理発電設備で発電されている。
【0140】
6:30から7:00の期間の電力消費設備Gの電力消費実績は9.9kwである。同じ期間の物理発電設備Aの発電実績は5.1kw、物理発電設備Bの発電実績は2.1kw、物理発電設備Cの発電実績は2.7kwである。6:30から7:00の期間の発電実績の合計が9.9kwであり、電力消費設備Gの電力消費実績分の電力が物理発電設備で発電されている。
【0141】
7:00から7:30の期間の電力消費設備Gの電力消費実績は7.7kwである。同じ期間の物理発電設備Aの発電実績は3.9kw、物理発電設備Bの発電実績は2.0kw、物理発電設備Cの発電実績は1.8kwである。7:00から7:30の期間の発電実績の合計が7.7kwであり、電力消費設備Gの電力消費実績分の電力が物理発電設備で発電されている。
【0142】
総電力供給期間内の30分単位のすべての期間について、電力消費設備Gの電力消費実績分の電力が物理発電設備で発電されていることが確認できたら、電力マッチングを行うノードは電力マッチングレコード78を生成する。さらにそのノードは、生成した電力マッチングレコードをアウトプットに含む電力供給権トランザクションレコード80を生成する。そして生成された電力供給権トランザクションレコード80がブロックチェーン60に登録される。
【0143】
このように、電力を販売する小売電気事業者のノードは、物理発電設備によって供給された電力と電力消費設備によって消費された電力を、30分単位でマッチングさせる。ただし、200万件分のスマートメータレコードをすべてブロックチェーン60に記録することはできない。そのため小売電気事業者のノードは、電力マッチングごとに、関連する発電実績と電力消費実績とのスマートメータレコードを集約して電力マッチングレコードを生成し、電力マッチングレコードのみをブロックチェーン60に記録する。このとき小売電気事業者のノードは、電力マッチングレコードに関連するすべてのデータをローカルのメモリまたはストレージ装置に保存する。
【0144】
次にマッチング正当性証明について詳細に説明する。小売電気事業者は、自身のノードを使用して、電力マッチングの正当性に関するゼロ知識証明を生成する。マッチング正当性証明の仕様は、以下の通りである。
【0145】
<マッチング正当性証明>
マッチング正当性証明は、公開入力値と秘匿入力値に基づいて、所定の命題が正しいことを証明する値である。公開入力値は以下の通りである。
【0146】
[公開入力値]
・物理発電設備IDの集合
・電力消費設備ID
・物理発電設備と電力消費設備の電子署名の検証鍵
・総電力供給期間
・総電力量コミットメント
以上が公開入力値である。総電力量コミットメントは、コミットメントスキームに基づくコミットメント関数(COMMr(x))の関数値である。rはコミットメント乱数であり、xは総電力消費量である。コミットメント関数は、コミットメント乱数の値が異なれば異なる値を生成する。またある1つの総電力量コミットメントを生成するコミットメント乱数と総電力消費量との組み合わせは、1種類しか存在しない。
【0147】
秘匿入力値は以下の通りである。
[秘匿入力値]
・譲渡される電力供給権に対応するすべての物理発電設備の総電力供給期間内のすべてのスマートメータレコード(物理発電設備ID、発電期間、発電量、物理発電設備の電子署名を含む)
・電力供給権の譲渡先となる電力消費設備の総電力供給期間内のすべてのスマートメータレコード(電力消費設備ID、発電期間、電力消費量、電力消費設備の電子署名を含む)
・コミットメント乱数
以上が秘匿入力値である。マッチング正当性証明の命題は、以下のすべての命題を同時に満たすことである。
【0148】
[命題]
・すべての物理発電設備のすべてのスマートメータレコードの物理発電設備IDが正しいこと。
・電力消費設備のすべてのスマートメータレコードの電力消費設備IDが正しいこと。
・譲渡される電力供給権に対応するすべての物理発電設備について、物理発電設備から得られたスマートメータレコードの発電期間が総電力供給期間をカバーしていること。
・電力供給権の譲渡先となる電力消費設備のスマートメータレコードの消費期間が、総電力供給期間をカバーしていること。
・すべての物理発電設備のすべてのスマートメータレコードの電子署名が正しいこと。
・電力消費設備のすべてのスマートメータレコードの電子署名が正しいこと。
・総電力供給期間内の30分単位のすべての単位期間について、電力消費設備のスマートメータレコードに示される発電量(発電実績)の和が、同じ単位期間の電力消費設備のスマートメータレコードに示される消費電力量(電力消費実績)と等しくなること。
・電力消費設備のすべてのスマートメータレコードの電力消費量の和をコミットメント関数の変数としたときのコミットメント関数の値が、総電力量コミットメントと等しくなること。すなわち電力消費設備のすべてのスマートメータレコードの電力消費量の和をΣとし、総電力量コミットメントをcmとしたとき、COMMe(Σ)=cmとなること。
【0149】
以上がマッチング正当性証明の命題である。物理発電設備IDまたは電力消費設備IDが正しいことは、例えば設備IDを証明する認証機間から設備IDを証明する署名を取得することで確認できる。またスマートメータレコードの電子署名が正しいことは、例えばスマートメータレコードの所定のハッシュ関数によるハッシュ値と、電子署名を物理発電設備の公開鍵で復号した値との比較によって確認できる。比較の結果一致していれば、電子署名は正しいと判断できる。
【0150】
以上の命題を証明するゼロ知識証明が、マッチング正当性証明である。このようなゼロ知識証明としては、例えば非対話型のゼロ知識証明が用いられる。非対話型のゼロ知識証明としてはzk-SNARK(Zero-Knowledge Succinct Non-Interactive ARgument of Knowledge)がある。
【0151】
zk-SNARKを用いた場合には、信頼できる第三者機関により、事前設定としてCRS(Common Reference String)が生成される。トランザクション生成部130は、CRSと命題とその命題が真である証拠とに基づいて所定の計算を行い、ゼロ知識証明Πを生成する。ブロックチェーンシステム30のスマートコントラクト410は、CRS、命題、およびゼロ知識証明Πを用いて検証の計算を行い、結果が1となれば命題が真であることが証明されたと判断する。
【0152】
非対話型のゼロ知識証明には、zk-SNARK以外に例えばzk-STARK(Zero-Knowledge Succinct Transparent ARgument of Knowledge)がある。zk-STARKを用いれば信頼できる第三者機関が不要となる。
【0153】
マッチング正当性証明は、スマートコントラクト410により検証される。スマートコントラクト410は、例えば電力マッチングレコードに基づいて以下の検証を行う。
・電力消費設備に電力供給した仮想発電設備による電子署名の正当性
・マッチング対象UTXOの正当性(実在するUTXOを指していること)
・総電力供給期間の正当性(異常値ではないこと、他の電力マッチングレコードとの期間の重複が存在しないこと(電力マッチングのダブルカウントが発生していないこと))
・マッチング正当性証明の正当性(ゼロ知識証明の命題が真となること)
スマートコントラクト410は、以上の内容がすべて正しいと検証できた場合、電力マッチングレコードを含む電力供給権トランザクションレコードをブロックチェーン60に登録する。
【0154】
<非化石証書の発行と検証>
ここで電力消費事業者が非化石エネルギーで発電された電力の電力供給権を購入し、自身の電力消費設備で消費した電力に割り当てた場合、その電力消費事業者は、電力供給権の譲渡元の小売電気事業者から非化石証書の発行を受けることができる。
【0155】
例えば非化石価値を証明したい電力消費者は、電力を供給した小売電気事業者に非化石証書の発行を依頼する。小売電気事業者のノードは、自身に電力供給権が譲渡された際の電力供給権トランザクションレコードの内容およびその電力供給権をターミネートした時の電力供給権トランザクションレコードの内容を含む非化石証書を生成する。そして小売電気事業者のノードは、生成した非化石証書を、電力消費者のノードに送信する(非化石証書の発行)。
【0156】
非化石証書を受領した電力消費者のノードは、発行された非化石証書を、非化石価値検証者44のノード500に非化石証書を送信する。非化石価値検証者44のノード500は、非化石証書に含まれた各電力供給権トランザクションレコードに対応する電力供給権トランザクションレコード(コミットメント及びゼロ知識証明)をブロックチェーンから取得する。そしてノード500は、ゼロ知識証明を検証することにより、電力マッチングの内容が正しいことを確認する(非化石証書の検証)。
【0157】
<電力供給権取引および非化石証書の発行・検証の手順>
次に電力供給権の取引手順について説明する。
図12は、取引対象の電力の総電力供給期間開始前の処理手順の一例を示すシーケンス図である。図12の例では、まず発電事業者41aと小売電気事業者43bとの間で、発電事業者41aが運用する物理発電設備51aで発電する電力についての電力供給権の譲渡契約が結ばれている(ステップS11)。電力供給権の譲渡契約は本システム外(例えばオフライン)で行われる。電力供給権の譲渡契約では、物理発電設備51aで発電できる電力と総電力供給期間(例えば翌月の一ヶ月間)とが定められる。
【0158】
その後、発電事業者41aは、自身のノード200を用いて、物理発電設備51aで発電できる電力の電力供給権の譲渡を示す電力供給権トランザクションレコードを生成する。そしてノード200は、生成した電力供給権トランザクションレコードをブロックチェーンシステム30に送信する(ステップS12)。この電力供給権トランザクションレコードは、ブロックチェーンシステム30内のノード400で受信されたものとする。
【0159】
電力供給権トランザクションレコードを受信したノード400のスマートコントラクト410は、受信した電力供給権トランザクションレコードに示される電力供給権の譲渡の内容が正しいかどうかを検証する。そしてスマートコントラクト410は、正しいと判断した場合にのみ受信した電力供給権トランザクションレコードをブロックチェーン60に記録する(ステップS13)。
【0160】
例えば小売電気事業者43bは、取得した電力供給権を他の小売電気事業者43bに譲渡する契約を結ぶ(ステップS14)。電力供給権を再譲渡する譲渡契約は本システム外(例えばオフライン)で行われる。契約後、譲渡元の小売電気事業者43bは、自身が有するノード100aを用いて電力供給権トランザクションレコードを生成する。そしてノード100aは、生成した電力供給権トランザクションレコードをブロックチェーンシステム30に送信する(ステップS15)。この電力供給権トランザクションレコードは、ブロックチェーンシステム30内のノード400で受信されたものとする。
【0161】
電力供給権トランザクションレコードを受信したノード400のスマートコントラクト410は、受信した電力供給権トランザクションレコードに示される電力供給権の譲渡の内容が正しいかどうかを検証する。そしてスマートコントラクト410は、正しいと判断した場合にのみ受信した電力供給権トランザクションレコードをブロックチェーン60に記録する(ステップS16)。小売電気事業者43aは、自身に譲渡された電力供給権を他の小売電気事業者に再譲渡することができる。このような電力供給権の再譲渡は何度も繰り返すことができる。
【0162】
電力消費設備52aを運用する電力消費者42aは、小売電気事業者43aから、ある一定の期間(総電力供給期間)、電力の供給を受ける契約を結ぶ(ステップS17)。この契約は、例えば本システム外(例えばオフライン)で行われる。この契約に従った電力マッチング(供給された電力についての電力供給権トランザクションレコードのターミネート)は総電力供給時間後に行われる。
【0163】
図13は、取引対象の電力の総電力供給期間開始後の処理手順の一例を示すシーケンス図である。電力消費設備52aへの電力供給契約に係る電力供給権に対応する物理発電設備51aを運用する発電事業者41aのノード200は、物理発電設備51aのスマートメータレコードを小売電気事業者43aのノード100に送信する(ステップS21)。また電力消費設備52aを運用する電力消費者42aのノード300は、電力消費電設備52aのスマートメータレコードを小売電気事業者43aのノード100に送信する(ステップS22)。
【0164】
小売電気事業者43aのノード100は、物理発電設備51aのスマートメータレコードと電力消費設備52aのスマートメータレコードとを30分単位で一ヶ月分マッチングする(ステップS23)。ノード100は、電力マッチングにより正当性が検証できた場合、マッチング正当性証明(ゼロ知識証明)を生成する(ステップS24)。ノード100は、生成したマッチング正当性証明を含む電力マッチングレコードを生成する(ステップS25)。そしてノード100は、生成した電力マッチングレコード(電力消費設備52aでの消費分)を含む電力供給権トランザクションレコードをブロックチェーンシステム30に送信する(ステップS26)。この電力供給権トランザクションレコードを、ブロックチェーンシステム30内のノード400が受信したものとする。
【0165】
ノード400のスマートコントラクト410は、マッチング正当性証明の検証を行う(ステップS27)。スマートコントラクト410は、マッチングの内容が正しい場合にのみ電力供給権トランザクションレコードをブロックチェーン60に記録する(ステップS28)。これにより、電力マッチングが行われた電力供給権(電力供給権トランザクションのインプットに設定された電力供給権)はターミネートする。
【0166】
なお小売電気事業者43aのノード100は、ステップS26で送信する電力供給権トランザクションレコードに、電力マッチングにおいて余った分の電力に対応する電力供給権を自分自身に譲渡するアウトプットを含めることができる。この電力供給権トランザクションレコードがブロックチェーン60に記録されることにより、電力マッチングにおいて余った分の電力供給権がお釣りとして自身に戻される。
【0167】
小売電気事業者43aのノード100は、電力マッチングで使用したデータ(30分単位のスマートメータレコード、コミットメント乱数など)を、ローカルのデータベースに保存する(ステップS29)。ノード100は、保存したデータを非化石証書の発行などに利用することができる。
【0168】
図14は、非化石証書の発行と検証の処理手順の一例を示すシーケンス図である。例えば電力消費者42aが電力消費設備52a用の電力供給元として取得した電力供給権の電力が、非化石エネルギーで発電を行う物理発電設備で発電された電力であるものとする。この場合、電力消費者42aは、ノード300を用いて、小売電気事業者43aのノード100に、該当する電力供給権に関する非化石証書の発行依頼を送信する(ステップS41)。ノード100は、その電力供給権の電力マッチング時に保存しておいたデータに基づいて、該当する電力マッチングに対応する電力供給権トランザクションレコードの内容を含む非化石証書を発行する(ステップS42)。ノード100は、発行した非化石証書をノード300に送信する。
【0169】
ノード300は、非化石価値を証明したい相手(例えば非化石価値検証者44)が有するノード500に、非化石証書を送信する(ステップS43)。ノード500は、ブロックチェーンシステム30に該当する取引記録を要求する(ステップS44)。ブロックチェーンシステム30は、指定された取引の総電力量コミットメントとマッチング正当性証明とをノード500に送信する(ステップS45)。ノード500は、総電力量コミットメントとマッチング正当性証明とに基づいて所定の計算を行うことにより、電力マッチングが正当であることを検証する(ステップS46)。例えば非化石価値検証者44のノード500には、非化石エネルギーで発電を行う物理発電設備の物理発電設備IDが予め登録されている。非化石価値検証者44は、非化石証書に示される物理発電設備の物理発電設備IDの正当性を検証し、正当な物理発電設備IDが非化石エネルギーで発電を行う物理発電設備の物理発電設備IDとして予め登録されていることを確認する。
【0170】
これにより、電力消費者42aが運用する電力消費設備52aが非化石エネルギーによって発電された電力を消費したことが確認される。
〔その他の実施の形態〕
第2の実施の形態では非化石エネルギーで生成された資源が電力の場合の例を示したが、水素、バイオ燃料などの他の資源についての取引にも利用することができる。
【0171】
上記については単に本発明の原理を示すものである。さらに、多数の変形、変更が当業者にとって可能であり、本発明は上記に示し、説明した正確な構成および応用例に限定されるものではなく、対応するすべての変形例および均等物は、添付の請求項およびその均等物による本発明の範囲とみなされる。
【符号の説明】
【0172】
1,2 生産者
3 消費者
4 ブロックチェーンシステム
5 ブロックチェーン
5a,5b トランザクションレコード
6 第1のデータ
7 第2のデータ
8 第3のデータ
8a コミットメント関数の値
8b 証明情報
10 情報処理装置
11 記憶部
12 処理部


図1
図2
図3
図4
図5
図6
図7
図8
図9
図10
図11
図12
図13
図14