Microsoftの機械学習アプリLobe(beta版)でリンゴとみかんを分類するWEBアプリ作成を試してみる(2)Windows10でPython3.6+TensorFlow1.15をセットアップ
前回は、lobeで、TensorFlow用のモデルをエクスポートしました。
このモデルを用いて、『リンゴとミカンを分類するWEBアプリ』を作成したいのですが、
- lobe/web-bootstrap を用いる (→未対応?)
- Flask を用いる
- TensorFlow.js を用いる(モデルをTensorFlow.js用に変更する)
の3つを思いつきましたが、とりあえず、 Flask を 用いてみたいと思います。
なお、 https://docs.lobe.ai/docs/export/export/ によりますと、lobeでのTensorFlow出力は
TensorFlow 1.15 SavedModel
となっていますので、まず、TensorFlow 1.15をWindowsにインストールしてみてみたいと思います。
また、エクスポートされた中身を見てみると、一部がこちらのようになっているため、
python 3.6
が必要のようです。
しかし、これがものすごく大変、、、いろいろ調べてみて、私の環境では、以下のやり方がベストと判断しました。やってみます。
- 1. Microsoftの機械学習アプリLobe(beta版)でリンゴとみかんを分類するWEBアプリ作成を試してみる 目次(全5回)
- 2. 開発環境
- 3. 今回構築した環境
- 4. Windows10にTensorFlow1.15インストールの流れ
- 5. VisualStudioCodeのインストール
- 6. Git for Windowsのインストール
- 7. vanilla Python3.6のインストール
- 8. pipenvのインストール
- 9. pipenv関連の環境変数を変更
- 10. pipenvで仮想環境を構築
- 11. ワークスペースを保存して設定を変更
- 12. autopep8,flake8,mypyのインストール
- 13. numpyとmatplotlibのインストール
- 14. test.pyを作成しpythonが実行できることを確認
- 15. TensorFlow1.15のインストール
- 16. Keras2.3.1のインストール
- 17. TensorFlowの動作確認
- 18. 参考:.gitignore
- 19. 今回のインストールについて参考にしたサイトのリンクのまとめ
- 20. 次の記事
Microsoftの機械学習アプリLobe(beta版)でリンゴとみかんを分類するWEBアプリ作成を試してみる 目次(全5回)
- (1)LobeのインストールからTensorFlowモデルのエクスポートまで
- (2)Windows10でPython3.6+TensorFlow1.15をセットアップ
- (3)Windows10ローカル環境でtf_example.pyを実行
- (4)Windows10ローカル環境でFlaskを用いて画像判定
- (5)FlaskアプリをHerokuにデプロイ
開発環境
Windows10 Pro
今回構築した環境
VisualStudioCode 1.50
Git for Windows v2.29.2
python 3.6
pipenv 2020.8.13
TensorFlow 1.15.3
keras 2.3.1
Windows10にTensorFlow1.15インストールの流れ
2020年現在、TensorFlow1.15はPython3.7に対応しているそうです。
- VisualStudioCodeをインストール
- gitをインストール(参考リンク)
- vanilla Python3.6をインストール
- VisualStudioCodeのターミナル画面でコマンドプロンプトを開く
- pipenvのインストール
- システム環境変数の設定(参考リンク)
- 仮想環境を構築する。新規フォルダ「tf1-venv」を作成し,右クリックして「Codeで開く」
pipenv --python 3.6
- VScodeの拡張機能Python(ms-python.python)をインストール
- [ユーザーホーム]\AppData\Roaming\Code\User\settings.jsonの設定(コマンドプロンプトになるようにする)
- ワークスペースを保存し、[ワークスペースフォルダ]\.vscode\settings.jsonの設定を行う
pipenv install autopep8 flake8 mypy --dev
pipenv install numpy matplotlib
- test.pyを作成しサンプルコードをコピペ
- test.pyを実行してみる。具体的には、ターミナル画面で、
python test.py
pipenv install tensorflow==1.15.3
pipenv install keras==2.3.1
- TensorFlowの動作確認
- Kerasの動作確認
長いですが、やってみます。
VisualStudioCodeのインストール
https://azure.microsoft.com/ja-jp/products/visual-studio-code/ からダウンロードしてインストールします。
data:image/s3,"s3://crabby-images/f1da5/f1da5bc2af0a800c09121afe464addeccece0ddc" alt=""
Git for Windowsのインストール
こちらのサイトの通りに、Git for Windowsをインストールします。
https://git-scm.com/download/win から、ダウンロードしてインストールします。
data:image/s3,"s3://crabby-images/65b00/65b00b6e44e8e1faecddc389eff61998992d1d26" alt=""
Git-2.29.2-64-bit.exe がダウンロードされますので、ダブルクリックしてから、 こちらのサイトの通りにインストールします。
data:image/s3,"s3://crabby-images/56705/56705a079d4ad8a9126ff833fb5f971429c16fee" alt=""
data:image/s3,"s3://crabby-images/ed284/ed2841603b0cbd7969d9b842f89fb763054a9b6c" alt=""
data:image/s3,"s3://crabby-images/d4628/d46285761c6b773e9c24715bcafea9df27b67fd6" alt=""
data:image/s3,"s3://crabby-images/e65d2/e65d2456f8854ddc83a2ff66fb48377626ee81fd" alt=""
vanilla Python3.6のインストール
https://pythonlinks.python.jp/ja/index.html から、Python 3.6 > Windows(64bit) > python-3.6.8-amd64.exe をダウンロードして、インストールします。
data:image/s3,"s3://crabby-images/12953/1295353ae753d1d5cf2090cd5c18fb5b3838094b" alt=""
『Windows + Python + PipEnv + Visual Studio Code でPython開発環境』( 2020年05月04日 )の通りに、インストールします。
data:image/s3,"s3://crabby-images/365f9/365f9e8fee73c42faa8534701e495e80a3313b73" alt=""
data:image/s3,"s3://crabby-images/e4847/e4847827e993f214ef5580b92ade6631cd3db930" alt=""
data:image/s3,"s3://crabby-images/4038a/4038a54575c3be975bb571bea73b87229e15f484" alt=""
data:image/s3,"s3://crabby-images/0d1c5/0d1c58e11a1c1d1f1a912c059a3872690da202b9" alt=""
data:image/s3,"s3://crabby-images/99f2e/99f2e9d3f5a224ad3eb2425b579f8d71efb6234b" alt=""
pipenvのインストール
D:/ に、D:/python/ フォルダを作成し、VisualStudioCodeで開きます。
data:image/s3,"s3://crabby-images/ed304/ed3042d0f7bebcfda18487b9625943e90d1de4e7" alt=""
Ctrl + @ により、ターミナル画面を出します。
data:image/s3,"s3://crabby-images/02072/02072f3e67b8d46ca0a594a05865c4e3238e9271" alt=""
cmd(コマンドプロンプト)画面が出てくるので、
pip install pipenv
を入力し、Enterを押します。
data:image/s3,"s3://crabby-images/38025/38025dfcce5214014dd2f9ba16b87014577d7765" alt=""
data:image/s3,"s3://crabby-images/f010c/f010c25ee918e80f00ee26ed0b1998e5b95bf732" alt=""
data:image/s3,"s3://crabby-images/e3fc7/e3fc7ef77ff26fcb23259826cf45b4f611fb2af1" alt=""
いったん、VisualStudioCodeを閉じます。
pipenv関連の環境変数を変更
こちらのサイトに従い、pipenvを用いてディレクトリ(プロジェクト)毎に仮想環境を作るために、環境変数を変更します。
画面左下の『検索』をクリック →「環境変数」と入力→「システム環境変数の編集」をクリック
data:image/s3,"s3://crabby-images/59aef/59aef23a2d96ac5ec63cfe74a4d0c3df1da791c0" alt=""
data:image/s3,"s3://crabby-images/5ef5d/5ef5d0b1ab1c3c3481e4c4d5035d42a5858945cf" alt=""
data:image/s3,"s3://crabby-images/40379/403791cdd4049c2ffc5bc1909949009c789979f6" alt=""
PIPENV_VENV_IN_PROJECT
true
と入力したのち、OK > OK > OK で閉じます。
data:image/s3,"s3://crabby-images/c99c5/c99c5ecaf535ae2cdeac1506e4feab056f33d825" alt=""
pipenvで仮想環境を構築
D:/python/ フォルダに、新規フォルダ「tf1-venv」を作成し、右クリックして「Codeで開く」を選択し、VisualStudioCodeで開きます。
data:image/s3,"s3://crabby-images/eb8b3/eb8b3fd1057b0c5a0ac6dc85a77dc45d4f6e829a" alt=""
画面左側の上の方の四角形4つのボタンをクリックして、Extensionsを開き、
data:image/s3,"s3://crabby-images/0fab1/0fab1d82e6dccdf48832215a63014d61dc082722" alt=""
拡張機能 Python(ms-python.python)をインストールします。
data:image/s3,"s3://crabby-images/ca7e9/ca7e94b3c5c51bbde038c08336cce39862102920" alt=""
Ctrl+@ でターミナル画面を出して、以下を入力して仮想環境を構築します。
pipenv --python 3.6
data:image/s3,"s3://crabby-images/ec6b3/ec6b38cfefb9fa0b2a32357f7bcd85e9cd66259c" alt=""
ワークスペースを保存して設定を変更
VSCodeの『ワークスペース』についてはこちらをご覧下さい。settings.jsonが見つけられず苦労しましたが、自分で作成するのですね。。。
File > Save Workspace As… をクリック
data:image/s3,"s3://crabby-images/53f74/53f742ccb1d76266e3a0f60175a10879abe936c1" alt=""
名前は何でもよいですが、今回は tf1 という名前で保存しました。
data:image/s3,"s3://crabby-images/c44a9/c44a91f6699db1319e7eb685e88f097c62f67f22" alt=""
私の環境では、この時点では、 .vscode/settings.json
はありませんでした。手動で.vscode/ フォルダと、settings.jsonを作成してもよいのですが、別の方法でやってみます。
File > Preferences > Settings をクリック(Ctrl + , でもいけます。)
data:image/s3,"s3://crabby-images/6b10e/6b10ee7f13fccbfb0bd22ebee251975b97a44120" alt=""
tf1-venv Folder タブをクリック
data:image/s3,"s3://crabby-images/e705c/e705c7a2bbe2050b4eaf4f051a40cf03a2c45ea8" alt=""
画面右上の、ファイルのようなアイコンをクリックします。
data:image/s3,"s3://crabby-images/fec9b/fec9bd8ee39397189965ffabe9fb900c4005fbe2" alt=""
すると、今回の私の環境では、
C:/python/tf1-venev/.code/ フォルダ
C:/python/tf1-venev/.code/settings.json ファイル
が作成され、settings.jsonが開きます。
data:image/s3,"s3://crabby-images/1b10d/1b10dca87a869bec5594ce60a9acd510525fc045" alt=""
settings.json にこちらのコードをコピペします。
引用元:Windows + Python + PipEnv + Visual Studio Code でPython開発環境(@youkidkk 2020年05月04日に更新 )
{
// 拡張機能のロード時にターミナルでPython環境をアクティブにする。
"python.terminal.activateEnvInCurrentTerminal": true,
// 仮想環境のパス。作成した仮想環境を指定する。
"python.venvPath": "{$workspaceFolder}/.venv",
"python.autoComplete.extraPaths": [
"{$workspaceFolder}/.venv/Lib/site-packages",
],
// フォーマッターの設定。autopep8 を指定する。
"python.formatting.provider": "autopep8",
"python.jediEnabled": false,
// Lintの設定。flake8、mypy を有効化する。
"python.linting.flake8Enabled": true,
"python.linting.mypyEnabled": true,
"python.linting.pylintEnabled": false,
// 以下はお好みで。
"editor.formatOnSave": true,
"python.autoComplete.addBrackets": true,
}
data:image/s3,"s3://crabby-images/84e19/84e19ffb7bd1bf18f640341ae05a346223420b2c" alt=""
autopep8,flake8,mypyのインストール
コードフォーマット、Lint のため、 pipenvで3つのパッケージをインストールします。
pipenv install autopep8 flake8 mypy --dev
data:image/s3,"s3://crabby-images/e5590/e5590a6ed33c816309968f08a3c082c6b9c399f7" alt=""
numpyとmatplotlibのインストール
サンプルコード用に、numpyとmatplotlibパッケージをインストールしてみます。
pipenv install numpy matplotlib
data:image/s3,"s3://crabby-images/85a17/85a1791ca3593b05851cc10912c27220ab5f94db" alt=""
test.pyを作成しpythonが実行できることを確認
test.pyというファイルを作成し、こちらのコードをコピペします。
引用元:Windows + Python + PipEnv + Visual Studio Code でPython開発環境(@youkidkk 2020年05月04日に更新 )
import numpy as np
import matplotlib.pyplot as plt
x = np.linspace(-np.pi, np.pi)
y = np.sin(x)
plt.plot(x, y)
plt.show()
data:image/s3,"s3://crabby-images/5884b/5884b56104f3d7009c42f94287b407563ed215fc" alt=""
私の環境では、突如、Python -Get Started という以下の画面がいきなり出てきました。Jupyter Notebookが使えるようなことが書いてありますが、今回は置いておきます。
data:image/s3,"s3://crabby-images/d35af/d35af6a86f675ff5dfc8511fc26e040d1957ce24" alt=""
test.pyを保存したのち、ターミナル画面で以下を入力して、test.pyを実行します。
python test.py
data:image/s3,"s3://crabby-images/54ba4/54ba40d2b3e0c1ae12ec14816f601dd9219f0f03" alt=""
ちゃんとtf1-venv 仮想環境で実行してくれましたが、本当は、 “pipenv shell" してから、上記を実行した方が安全だったかもしれません。
グラフの右上の×ボタンをクリックして、グラフを閉じると、以下のような画面になります。
data:image/s3,"s3://crabby-images/0ed11/0ed11b9fccf774159cecfc4eda80037ea218cfdb" alt=""
その他、test.pyを実行する方法としては、test.py を開いているときに画面右上に出てくる△ボタンをクリックしても実行されるようです。すごく簡単、、、
data:image/s3,"s3://crabby-images/0370e/0370e3436e086be5651d4548086bab16f2f1107d" alt=""
TensorFlow1.15のインストール
以下を入力して、TensorFlow1.51をインストールします。
参考:TensorFlow 1.15.3(旧バージョン)のインストール(Windows 上)
pipenv install tensorflow==1.15.3
data:image/s3,"s3://crabby-images/3df91/3df91fa26bc9ea66fc45e11a69cd2afb7c577a17" alt=""
あ、本当は、 仮想環境を無効にする exit をしてから、pipenv install するべきなのかもしれませんが、warningを読むと、おそらく、自動で外からインストールしてくれているようです。インストールも3分くらいで終わりました。
→ VisualStudioCodeでは自動的にpipenv環境に入ってしまうらしく、exitとかせずに、このまま仮想環境の中でpipenv installすると、warning通りにうまいことやってくれるようです。
data:image/s3,"s3://crabby-images/d09df/d09df5afafcb2480f9719aaf65e4bf2678aa0be7" alt=""
なお、TensorFlow公式サイトには、インストールのためのいろいろな条件が記載されています。よくわかりません。。。
data:image/s3,"s3://crabby-images/d3653/d3653a9556dfeb7bb85ef985dd0da88e8dba8dc8" alt=""
Keras2.3.1のインストール
TensorFlow 1.15 で動くKerasは2.3.1だそうです。バージョンを指定してインストールします。
pipenv install keras==2.3.1
data:image/s3,"s3://crabby-images/ab872/ab872fadd6fc2fbfddedae88e004c39bb4697e6f" alt=""
TensorFlowの動作確認
tf1-test.pyファイルを作成し、以下をコピペします。
import tensorflow as tf
print( tf.__version__ )
data:image/s3,"s3://crabby-images/6fd00/6fd0074de9d0a311fc3ca893dd29d6d6145b54d2" alt=""
data:image/s3,"s3://crabby-images/daa94/daa944a3f49f3778533b3c43ef8aafd5971b48b8" alt=""
画面右上の△のボタン(実行ボタン)をクリックして、tf1-test.pyを実行します。
data:image/s3,"s3://crabby-images/00c89/00c89d5e4147e1d16fad9f0c8b2395ef1462e33f" alt=""
無事、ターミナル画面に、”1.15.3” と表示されました。
次に、keras-test.pyを作成して、以下を入力して、上記と同様に実行します。(kerasをインポートしているのに使っていないよとflake8に指摘されますが、まあ、よしとします。)
import keras
data:image/s3,"s3://crabby-images/b3a31/b3a31bdb3054d66e8a9f4c6d716de469314a1d29" alt=""
ターミナル画面に、"Using Tensorflow backend."を頂きました。
個人的には3年ぶりにkerasをインストールしました。Anaconda無しでもいけました。2017年頃と比べて、pipenvやflake8, autopep8が良い感じで、個人的にはこちらの方が好きになりそうです。私のプログラミングはお遊びなので、Jupyter Notebookを使用したければ、Google Colabでやれば十分かなといった感じです。
参考:2017年頃のTensorFlow, Kerasのインストール方法
参考:.gitignore
data:image/s3,"s3://crabby-images/60c3f/60c3f949edfb941d28569d440f180ea975f10423" alt=""
今回のインストールについて参考にしたサイトのリンクのまとめ
ものすごく時間がかかってWindows10にTensorFlow1.15をインストールしました。次は、Flaskを用いて、lobeのモデルを使ったWEBアプリを作成したいと思います。
ディスカッション
コメント一覧
まだ、コメントがありません