高速微分ソートアルゴリズム、カスタムC++、CUDAのパッケージで、パフォーマンスが向上しました。

高速微分ソートアルゴリズム、カスタムC++、CUDAのパッケージで、パフォーマンスが向上しました。

[[390293]]

昨年の初め、Google は論文「Fast Differentiable Sorting and Ranking」で、O(nlogn) の時間計算量と O(n) の空間計算量を持つ初の微分可能ソート アルゴリズムを発表しました。これは、既存の方法よりも桁違いに高速です。

最近、誰かが GitHub でプロジェクトをオープンソース化しました。これは、ソフトウェア パッケージの形式で高速な微分ソートとランキングを実装したものです。このプロジェクトは数日間オンラインになり、300 以上のスターを獲得しました。

  • プロジェクトアドレス: https://github.com/teddykoker/torchsort
  • 高速微分ソートおよびランキングの論文アドレス: https://arxiv.org/pdf/2002.08871.pdf

トーチソート

Torchsort は、Blondel らによって提案された高速微分ソートおよびランキングを実装し、純粋な PyTorch で実装されています。コードの大部分は、プロジェクト「google-research/fast-soft-sort」のオリジナルの Numpy 実装からコピーされており、高速パフォーマンスのためにカスタム C++ および CUDA カーネルが使用されています。

Torchsort のインストールは非常に簡単です。一般的に使用されている pip インストール方法を使用できます。インストール コードは次のとおりです。

  1. pip インストール torchsort

CUDA 拡張機能をビルドする場合は、CUDA ツールチェーンをインストールする必要があります。 CUDA 以外のランタイム環境で docker などのアプリケーションをビルドする場合は、インストール前に環境変数「TORCH_CUDA_ARCH_LIST="Pascal;Volta;Turing"」をエクスポートする必要があります。

使い方

torchsort には、soft_rank と soft_sort という 2 つの関数があり、それぞれに、regularization (l2 または kl) (正規化関数) とregularization_strength (スカラー値) というパラメーターがあります。それぞれは、正規化の強度に応じて精度を変えながら、2D テンソルの最後の次元をソートします。

  1. 輸入トーチ
  2. トーチソートをインポートする
  3. x = torch.tensor([[ 8 , 0 , 5 , 3 , 2 , 1 , 6 , 7 , 9 ]])
  4. torchsort.soft_sort(x, 正規化の強度= 1.0 )
  5. # テンソル([[ 0.5556 , 1.5556 , 2.5556 , 3.5556 , 4.5556 , 5.5556 , 6.5556 , 7.5556 , 8.5556 ]])
  6. torchsort.soft_sort(x, 正規化の強度= 0.1 )
  7. # テンソル([[- 0 ., 1 ., 2 ., 3 ., 5 ., 6 ., 7 ., 8 ., 9 .]])
  8. トーチソート.ソフトランク(x)
  9. # テンソル([[ 8 ., 1 ., 5 ., 4 ., 3 ., 2 ., 6 ., 7 ., 9 .]])

どちらの操作も完全に微分可能であり、次のように CPU または GPU に実装できます。

  1. x = torch.tensor([[ 8 ., 0 ., 5 ., 3 ., 2 ., 1 ., 6 ., 7 ., 9 .]], requires_grad=True).cuda()
  2. y = トーチソート.soft_sort(x)
  3. torch.autograd.grad(y[ 0,0 ],x) の関数
  4. # (テンソル([[ 0.1111 , 0.1111 , 0.1111 , 0.1111 , 0.1111 , 0.1111 , 0.1111 , 0.1111 ]],
  5. # デバイス = 'cuda:0' ),)

表示例

スピアマン順位係数は、2 つの変数間の単調な相関を測定するのに非常に役立つ指標です。 Torchsort を使用して微分可能なスピアマン順位係数関数を作成し、そのメトリックに対してモデルを直接最適化することができます。

  1. 輸入トーチ
  2. トーチソートをインポートする
  3. 定義spearmanr(予測、ターゲット、**kw):
  4. pred = torchsort.soft_rank(pred, **kw)
  5. ターゲット = torchsort.soft_rank(ターゲット、**kw)
  6. pred = pred - pred.mean()
  7. pred = pred / pred.norm()
  8. ターゲット = ターゲット - ターゲット.mean()
  9. ターゲット = ターゲット / ターゲット.norm()
  10. 戻り値(予測 * ターゲット).sum()
  11. pred = torch.tensor([[ 1 ., 2 ., 3 ., 4 ., 5 .]], requires_grad=True)
  12. ターゲット = torch.tensor([[ 5 ., 6 ., 7 ., 8 ., 7 .]])
  13. スピアマン = スピアマンr(予測、ターゲット)
  14. # テンソル( 0.8321 )
  15. torch.autograd.grad(スピアマン、予測)
  16. # (テンソル([[- 5 .5470e- 02 , 2 .9802e- 09 , 5 .5470e- 02 , 1 .1094e- 01 , - 1 .1094e- 01 ]]),)

ベンチマーク

torchsort と fast_soft_sort はどちらも時間計算量が O(n log n) で、組み込みの torch.sort と比較してオーバーヘッドが若干追加されます。 Numba JIT のバッチ サイズが 1 の場合 (左の図を参照)、fast_soft_sort のフォワード パスは Torchsort CPU カーネルとほぼ同じパフォーマンスを発揮しますが、バックワード パスは依然として一部の Python コードに依存しているため、パフォーマンスが大幅に低下します。

さらに、torchsort カーネルはバッチ処理をサポートしており、バッチ サイズが大きくなるにつれて fast_soft_sort よりも優れたパフォーマンスが得られます。

トーチソート CUDA カーネルは、2000 未満のシーケンス長では優れたパフォーマンスを発揮し、非常に大きなバッチに拡張できます。将来的には、CUDA カーネルがさらに最適化され、組み込みの torch.sort に近いパフォーマンスが実現される可能性があります。

<<:  2025年までに音声認識市場は267億9000万ドルに達する

>>:  NLP を上手に使いこなすには、適切な「武器」が必要です。GLUE で 1 位にランクされている武器をご存知ですか?

ブログ    
ブログ    
ブログ    

推薦する

...

米国の専門家:中国のロボット優位性が懸念される

フォーブスは10月2日、寄稿者ティム・バジャリン氏による記事を掲載し、中国ロボットの利点と、中国と米...

認知分析について知っておくべきことすべて

コンテキストを提供し、大量の情報に隠された答えを発見するために、コグニティブ コンピューティングはさ...

一般相対性理論の予測に沿って、M87ブラックホールの最新の研究結果がネイチャー誌に掲載されました。

9月27日、ネイチャー誌は45の機関からなる国際科学研究チームの最新の研究成果を発表した。 200...

インテリジェント交通の時代に踏み出すには、これら 3 つのことをうまく行う必要があります。

[[438413]]都市の生命線であり動脈である交通の発展は極めて重要です。しかし、近年、都市化が...

50枚の写真が「毒された」安定した拡散、車と牛の区別がつかない

AI侵害に対するアーティストの反撃がここに——絵画に「毒」を入れると、AIが「毒化」されて使用時に誤...

TensorFlow が機械学習開発に使用できるのはなぜですか?

機械学習は複雑な分野ですが、データの取得、モデルのトレーニング、予測の提供、将来の結果の改善のプロセ...

GPTモデルが人間のように聞こえるのはそのためです

翻訳者 | 劉涛レビュー | Chonglou AIがなぜ機能するのか誰も知らないですよね?はい、そ...

ガートナー: 2024 年の主要な戦略的テクノロジー トレンド

2024 年までに、AI は企業で主流となり、クラウド サービス、セキュリティ、持続可能性も影響力を...

...

...

Googleが検索エンジンアルゴリズムを調整:HTTPSサイトのランキングが上昇

[[117728]] Googleは公式ブログで、検索エンジンのアルゴリズムを調整し、HTTPS暗号...

世界初!人間の脳のようなスーパーコンピュータ「シェナン」がまもなく発売され、ムーアの法則を破り、エネルギー消費を数桁削減する

人間の脳は地球上で最も効率的な計算装置です。わずか 20W の電力と 1.3kg の質量で、1 秒間...

...