Windows10でPyTorchをインストールしてVSCodeで使う

以前はWindows 10でディープラーニングするのに、AnacondaでPython環境を作ってTensorFlowを使ってVisual Studioでコーディングしてたけど、



最近はだいぶ状況が変わってきた。

Anacondaでnumpyが動かなくなったり、使いたいパッケージ(のバージョン)がcondaで入らなかったりで、そもそもAnacondaのメリットよりもデメリットで時間を取られることが増えた。(それはMinicondaでも同じ)
なので、Pythonは普通に公式のインストーラーでWindowsにインストールすることにした。

コーディング環境についても、VSCode(Visual Studio Code)が優秀だと気づいた。
VSCodeはIDEじゃなくてエディタなんだけど、Extensionをインストールして機能拡張はできる。オイラがIDEの方のVisual Studioを使っていた理由の8割ぐらいはIntelliSense(コード補完機能)だったので、同じくIntelliSenseが載っているなら動作も軽いVSCodeの方が快適なのでした。

そして、ディープラーニングのライブラリはTensorFlowからPyTorchへ乗り換えつつある。
理由はそんなにハッキリとしたものじゃないんだけど、最近は発表される論文と一緒に公開されるソースコードにPyTorch実装のものが増えている点と、対応する依存関係(CUDAのバージョンとか)のアップデートの早さとか。最近やっとバージョン1に達して、身近な人達がどんどんPyTorchへ移行しているというのもある。


スポンサーリンク


ということで、今現在のオイラの環境は以下↓

一応、インストール手順もメモしておく。

PyTorch 1.0.1は現時点で最新のCUDA Toolkit 10.1とcuDNN v7.5に対応しているのであんまり気にしなくて良いけど、この手のライブラリのバージョンの依存関係は間違えるとエラー地獄にはまるのでインストール前にしっかり確認した方が良いです。(何度かハマった)

追記:PyTorchとtensorboardXを一緒に使いたい場合は、TensorBoard(というかTensorFlow)の動作環境にも合わせてやる必要があります。
https://www.tensorflow.org/install/gpu

CUDAとcuDNNのインストール

CUDAの公式ページからCUDA Toolkit 10.1のインストーラーをダウンロードしてインストール。
cuDNN v7.5.0 (Feb 25, 2019), for CUDA 10.1は、まずMembership登録してログインし、cuDNN一式のzipをダウンロードする。
そしてzipを展開して出てきたbin, include, libディレクトリを丸ごとCUDAのパスが通ったディレクトリに配置する。オイラはいつもCUDAデフォルトのインストールパスに一緒に突っ込んでいる↓

C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v10.1

ところで、cuDNNってCUDA Deep Neural Network libraryの略なんですね。


スポンサーリンク

Pythonのインストール

Pythonはバージョン3.6を使う。公式ページからPython3.6.8のWindows x86-64 executable installerをダウンロードしてきて実行するだけ。
インストールパスだけデフォルトから以下に変えておいた。

C:\dev\Python36

PyTorchのインストール

PyTorchは、公式ページのSTART LOCALLYで自分の環境を選ぶと適切なpipのコマンド表示されるので、それを叩けばインストールできる↓



ということで、以下のコマンドをコマンドプロンプトで実行するだけでPyTorchのインストール完了↓

pip3 install https://download.pytorch.org/whl/cu100/torch-1.0.1-cp36-cp36m-win_amd64.whl
pip3 install torchvision

VSCodeのインストール

VSCodeは公式ページからWindows用のインストーラーをダウンロードしてインストール。
そして日本語の言語パックPython用のExtensionもインストールする。

これでPyTorch環境は整ったので、あとは適当なサンプルコードがちゃんと実行できることを確認してみよう。
GitHubにPyTorch公式のサンプルコードがある↓
https://github.com/pytorch/examples

Basic MNIST Exampleとかが手軽で良いんじゃないでしょうか。
サンプルが実行できたらとりあえずOKだ。

追記:最近は、PyTorchに特化したIDEもある↓


PyTorchの習得

PyTorch公式サイトのサンプルで学ぶPyTorchや、
https://pytorch.org/tutorials/beginner/pytorch_with_examples.html
https://pytorch.org/tutorials/beginner/former_torchies/nnft_tutorial.html

PyTorch公式でチートシートを用意してくれているので、そこを見ると習得が速いかも。
チートシートの内容を画像化して公開している人もいる↓

PyTorch Cheat Sheet

小技集をJupyter Notebookにまとめている方もいる↓
https://github.com/bfortuner/pytorch-cheatsheet/blob/master/pytorch-cheatsheet.ipynb

あとは、torchvisionに有名な畳み込みニューラルネットワークが実装されているので、それを読むと真似しやすいかも↓
https://pytorch.org/docs/stable/torchvision/models.html

追記:PyTorch専用IDEも登場してる↓



スポンサーリンク

関連記事

html5のcanvasの可能性
Gource:バージョン管理の履歴を可視化するツール
プログラミングスキルとは何か?
サンプルコードにも間違いはある?
科学技術計算向けスクリプト言語『Julia』
CGAN (Conditional GAN):条件付き敵対的生成ネットワーク
RSSフィードを読込んで表示するWordpressプラグイン『RSSImport』
Dlib:C++の機械学習ライブラリ
uGUI:Unityの新しいGUI作成システム
UnityからROSを利用できる『ROS#』
PythonでMayaのShapeノードプラグインを作る
Raspberry Piでセンサーの常時稼働を検討する
C++始めようと思うんだ
CGレンダラ研究開発のためのフレームワーク『Lightmetrica (ライトメトリカ)』
Russian3DScannerのトポロジー転送ツール『WrapX』
Deep Fluids:流体シミュレーションをディープラーニングで近似する
まだ続くブログの不調
OpenVDB:3Dボリュームデータ処理ライブラリ
UnityのMonoBehaviourクラスをシングルトン化する
頭蓋骨からの顔復元と進化過程の可視化
画像生成AI Stable Diffusionで遊ぶ
網元AMIで作ったWordpressサイトのインスタンスをt1microからt2microへ移行した
Google Colaboratoryで遊ぶ準備
Python拡張モジュールのWindows用インストーラー配布サイト
LLM Visualization:大規模言語モデルの可視化
OpenCVのバージョン3が正式リリースされたぞ
YOLO (You Only Look Once):ディープラーニングによる一般物体検出手法
iPhone・iPod touchで動作する知育ロボット『ROMO』
PyTorch3D:3Dコンピュータービジョンライブラリ
ZBrushでカスタムUIを設定する
Mechanizeで要認証Webサイトをスクレイピング
Googleが画像解析旅行ガイドアプリのJetpac社を買収
C++ 標準テンプレートライブラリ (STL)
MLDemos:機械学習について理解するための可視化ツール
OpenFace:Deep Neural Networkによる顔の個人識別フレームワーク
ManuelBastioniLAB:人体モデリングできるBlenderアドオン
Faster R-CNN:ディープラーニングによる一般物体検出手法
Boost オープンソースライブラリ
Mitsuba 3:オープンソースの研究向けレンダラ
OpenCVの顔検出過程を可視化した動画
UnityでLight Shaftを表現する
Fast R-CNN:ディープラーニングによる一般物体検出手法

コメント