• Search Research Projects
  • Search Researchers
  • How to Use
  1. Back to project page

2020 Fiscal Year Research-status Report

最短ベクトル問題における新しいsieving計算の手法の開発

Research Project

Project/Area Number 20K11669
Research InstitutionThe University of Tokyo

Principal Investigator

柏原 賢二  東京大学, 大学院総合文化研究科, 助教 (70282514)

Project Period (FY) 2020-04-01 – 2023-03-31
Keywords格子の最短ベクトル問題 / 基底簡約 / 大規模並列計算 / sieving
Outline of Annual Research Achievements

この研究は、格子の最短ベクトル問題の大規模並列プログラムでの高速なアルゴリズムを開発するものである。基底の簡約問題について、アルゴリズムを考案し、その実装を行ない、スーパーコンピュータ上で実行した。
格子の最短ベクトル問題のアルゴリズムにおいて、sievingと呼ばれる手法と基底簡約を組み合わせたアルゴリズムが現在もっとも速く計算できる方法になっている。その実装がGithubにて公開されていて、それをベースに改良を試みた。公開されているプログラムは、多数のCPUでメモリを共有できるマシンを前提にしたプロセス並列に基づいて実装されている。有効なsievingには大量のメモリが必要なことが知られている。われわれは、並列ノード間でメモリが共有できないような環境で実行できるような、プロセス並列のアルゴリズムを考案した。プロセス間の情報共有には、ファイルに基底ファイルを保存することで行なった。
最短ベクトル問題へのもっとも一般的な枠組みは基底簡約を行うものである。格子の最短ベクトル問題の基底簡約におけるアプローチにおいては、同じ格子を生成する基底変換により、基底をどんどんと簡約することによって、ゴールに近づく。各プロセスは、それぞれ基底を持ち、それが探索における現在の位置を表す。単純に基底ファイルを共有してしまうと、すべてのプロセスが同じ計算をしてしまって意味がないので、優れている基底がうまく共有されるように工夫する仕組みを取り入れた。現在は実験をして効果を確認しているところである。

Current Status of Research Progress
Current Status of Research Progress

3: Progress in research has been slightly delayed.

Reason

もともとは、公開されているプログラムの変更ではなく、独自のプログラムを作成していた。開発の効率性の面から公開されているプログラムを元に開発することに、年度の途中で計画を変更したために遅れた面がある。しかも、公開されているプログラムは、私の利用している環境のいくつかでは、うまく並列計算が動かずに時間を費やした。しかし、公開されているプログラムを利用する方針に転換したことで、いままで気がつかなかったアルゴリズムの欠点に気がつくことができたので、結果的には、一般的な枠組みにそって開発する方向に転換したことはよかった。

Strategy for Future Research Activity

さらに効率的な並列基底簡約の実装について考える。効率的なsievingにはテラバイトの単位でメモリが大量に必要なことがわかっているが、通常はそれほどの大量のメモリを利用できるとは限らない。1つのCPUあたりに利用できるメモリが少なくても、なるべく効率的に計算できるような手法を開発していきたい。そして、並列計算機の上で実装して、効率性を検証していきたい。

Causes of Carryover

感染症の蔓延により思ったように成果発表ができなかったことと、計算機上で走らせるプログラムの作成に時間がかかった。また、借りたスーパーコンピュータが混んでいて、投入したジョブがすぐに実行されずに計算が思うように実行できなかった。また、プログラムの開発が進んでから、一気に計算した方がよいと判断した。

URL: 

Published: 2021-12-27  

Information User Guide FAQ News Terms of Use Attribution of KAKENHI

Powered by NII kakenhi