ニューラル ネットワークに基づくプロジェクトにおけるボトルネックは通常、ネットワークの実装ではありません。場合によっては、大量のコードを記述し、大量のハイパーパラメータ構成を試した後でも、ネットワークが機能しないことがあります。特に、何百万ものパラメータに直面した場合、小さな変更がこれまでの努力をすべて台無しにする可能性があります。 さまざまな問題に直面した後、ニューラル ネットワークのデバッグのコストを削減することを望んで、ニューラル ネットワークのデバッグに役立つ実用的なヒントをまとめた人もいます。
勾配の問題を確認する場合によっては、勾配が問題の原因となることがあります。グラデーションに関連するデバッグ方法をいくつか紹介します。
トレーニングプロセスを確認するネットワークのトレーニングの進行状況を頻繁に確認すると、時間を節約できます。 Snake ゲームのトレーニングを例にとると、ネットワークを数日間トレーニングしてネットワークが何かを学習したかどうかを確認する代わりに、現在学習した重みを使用して 10 分ごとにゲームを実行します。数時間後、毎回同じことをして報酬がゼロになっていることに気づいたら、何かが間違っている可能性があるとわかり、これにより数日分のトレーニング時間を節約できました。 定量的な成果に頼らない定量的な出力だけを見ると、有用なデバッグ情報を見逃してしまう可能性があります。たとえば、音声翻訳ネットワークをトレーニングする場合、評価関数が減少しているかどうかを確認するだけでなく、翻訳された音声を読んで意味が通じるかどうかを確認することが重要です。画像認識用のネットワークをトレーニングする場合は、ネットワークによって提供されるラベルを必ず手動で確認してください。 定量的な出力に依存すべきでない理由は 2 つあります。まず、評価関数にエラーがある可能性があります。エラー評価関数によって出力された数値だけを見ると、何かが間違っていることに気づくまでに数週間かかる場合があります。第二に、ニューラル ネットワークの出力には定量的に表示できないエラー パターンが存在する可能性があります。特定の単語が常に間違って翻訳されていることに気付いたり、左上象限の画像認識ネットワークが常に間違っていることに気付いたりするかもしれません。これらの観察は、そうでなければ気付かれないデータ処理コードのバグを見つけるのに役立ちます。 小さなデータセットを試すコードにバグがあるかどうか、またはデータのトレーニングが困難かどうかを判断する別の方法は、データセットを 100,000 個のトレーニング例から 100 個または 1 個のトレーニング例に削減するなど、最初により小さなデータセットを適合させることです。 1 つのトレーニング例に対して、ネットワークのテスト エラーが依然として高く、データにうまく適合しない場合は、ネットワーク コードに問題がある可能性がほぼ確実です。 よりシンプルなネットワークを試すフルサイズのネットワークをトレーニングするのが難しい場合は、レイヤー数が少なく、より高速にトレーニングできる小規模なネットワークを使用してみてください。フルサイズのネットワークが失敗したところで小規模ネットワークが成功した場合、フルサイズ モデルのネットワーク アーキテクチャが複雑すぎることが示唆されます。シンプル ネットワークとフルサイズ ネットワークの両方が失敗する場合は、コードにバグがある可能性があります。 フレームワークを使ってみる機械学習フレームワークを使用してニューラル ネットワークをコーディングしなかった場合は、同じネットワーク アーキテクチャを機械学習フレームワークでコーディングすることで、何が問題だったのかを確認できます。次に、print ステートメントを非フレームワーク バージョンとフレームワーク バージョンに配置し、print ステートメントが異なる場所、つまりエラーがある場所が見つかるまで、出力をレイヤーごとに比較します。バックプロパゲーション中にエラーが発生した場合は、最後のレイヤーから始めて、差異が見つかるまでレイヤーごとに重みの勾配を印刷できます。しかし、この方法はネットワークの最初の反復にのみ機能します。これは、最初の反復の出力の違いにより、2 回目以降の反復では開始点が異なるためです。 参考: https://towardsdatascience.com/debugging-tips-for-neural-networks-f7dc699d6845 [この記事は51CTOコラム「Machine Heart」、WeChatパブリックアカウント「Machine Heart(id:almosthuman2014)」によるオリジナル翻訳です] この著者の他の記事を読むにはここをクリックしてください |
<<: Transformer モデルにはいくつのバリエーションがありますか?復旦大学の邱希鵬教授のチームが包括的なレビューを行った。
>>: 人工知能が動物を理解するにはどれくらいの時間がかかるのでしょうか?
同国の「第14次5カ年計画」では、「人工知能」を重要なブレークスルーを必要とする最先端科学技術分野の...
2021 年には、ML と NLP の分野で多くのエキサイティングな進展がありました。 Sebas...
人工知能の発展は65年の歴史があり、厳しい冬も栄光も経験してきました。シンボリックエキスパートシステ...
今年末までに、世界中で接続されるデバイスの数は 500 億台に達すると予測されており、モノのインター...
屈原・漁夫のアルゴリズムの追求を分析する前に、「漁夫」の原文を見てみましょう。屈原は流刑になった後、...
ニューラル ネットワーク (NN) アーキテクチャ ダイアグラムの作成には、多くの場合、時間と労力が...
スマート シティは単なる概念や未来の夢ではなく、今や現実のものとなっています。モノのインターネット、...
チャットボットはかつて大々的に宣伝された期待に応えようとしており、Intercom が委託した新しい...
いずれにしても、2019年もいつの間にか半分が過ぎてしまいました。このニュースを聞いて、何もせずに半...
想像してみてください。あなたはずっと夢見てきた機械学習の職種の面接を受けに行こうとしています。すべて...
[[389144]]今まで見たことのない犬種や色であっても、私たちは一目見てその犬を認識することがで...