前提
Google Colab上でKerasのmulti_gpu_modelをimportしたいのですがうまくいきません。
追記: multi_gpu_modelが既に廃止になっていたため、tf.distribute.MirroredStrategyを利用してコードを書き換えたいです。
実現したいこと
ここに実現したいことを箇条書きで書いてください。
- multi_gpu_modelをgoogle Colab上でimport可能にする
- multi_gpu_modelからtf.distribute.MirroredStrategyに変更した場合にコードをどのように書き換えるか
発生している問題・エラーメッセージ
ImportError Traceback (most recent call last) <ipython-input-30-bf8bcc9a4cfa> in <module> 4 #from tensorflow.python.keras.utils.multi_gpu_utils import multi_gpu_model 5 #from tensorflow.python.keras.utils.multi_gpu_utils import multi_gpu_model ----> 6 from tensorflow.keras.utils import multi_gpu_model ImportError: cannot import name 'multi_gpu_model' from 'tensorflow.keras.utils' (/usr/local/lib/python3.7/dist-packages/keras/api/_v2/keras/utils/__init__.py) --------------------------------------------------------------------------- NOTE: If your import is failing due to a missing package, you can manually install dependencies using either !pip or !apt. To view examples of installing some common dependencies, click the "Open Examples" button below. ---------------------------------------------------------------------------
該当のソースコード
python
1from tensorflow.keras.utils import multi_gpu_model 2#import tensorflow as tf 3#from keras.applications import Xception 4#from keras.utils import multi_gpu_model 5#from tensorflow.python.keras.utils.multi_gpu_utils import multi_gpu_model
python
1def AutoEncoder(gpu_num=1): 2 input_layer = Input(shape=(128, 128, 3)) 3 4 conv11 = Conv2D(32, (3, 3), activation='relu', padding='same')(input_layer) 5 conv12 = Conv2D(32, (3, 3), activation='relu', padding='same')(conv11) 6 pool1 = MaxPooling2D()(conv12) 7 8 conv21 = Conv2D(16, (3, 3), activation='relu', padding='same')(pool1) 9 conv22 = Conv2D(16, (3, 3), activation='relu', padding='same')(conv21) 10 encoded = MaxPooling2D()(conv22) 11 12 conv31 = Conv2D(8, (3, 3), activation='relu', padding='same')(encoded) 13 conv32 = Conv2D(8, (3, 3), activation='relu', padding='same')(conv31) 14 15 up1 = UpSampling2D()(conv32) 16 conv41 = Conv2D(16, (3, 3), activation='relu', padding='same')(up1) 17 conv42 = Conv2D(16, (3, 3), activation='relu', padding='same')(conv41) 18 19 up2 = UpSampling2D()(conv42) 20 conv51 = Conv2D(32, (3, 3), activation='relu', padding='same')(up2) 21 conv52 = Conv2D(32, (3, 3), activation='relu', padding='same')(conv51) 22 23 decoded = Conv2D(3, (1, 1), activation='sigmoid', padding='same')(conv52) 24 25 model = Model(inputs=input_layer, outputs=decoded) 26 27 if gpu_num >= 2: 28 model = multi_gpu_model(model, gpus=gpu_num) 29 30 adam = Adam(lr=0.0001) 31 model.compile(optimizer=adam, loss='binary_crossentropy') 32 33 return model 34 35import cv2 36import glob 37import os 38 39#from keras.callbacks import TensorBoard 40from tensorflow.python.keras.callbacks import TensorBoard 41 42#from models import AutoEncoder 43#from utils import ImageLoader 44 45 46#DATA_DIR = os.path.join('data') 47#DATA_DIR = os.path.join('screw') 48DATA_DIR = '/content/drive/MyDrive/DeepLearningHandson/chapter4/screw' 49TRAIN_DATA_DIR = os.path.join(DATA_DIR, 'train') 50VALID_DATA_DIR = os.path.join(DATA_DIR, 'valid') 51LOGS_DIR = os.path.join('logs') 52MODEL_FILEPATH = os.path.join('results', 'autoencoder_experiment_01.h5') 53 54model = AutoEncoder(gpu_num=8) 55#model = AutoEncoder(gpu_num=8) 56image_size = model.input.shape[1:3] 57 58model.summary() 59 60train_images = ImageLoader(TRAIN_DATA_DIR, tuple(image_size)).load() 61valid_images = ImageLoader(VALID_DATA_DIR, tuple(image_size)).load() 62 63tensorboard_callback = TensorBoard(log_dir=LOGS_DIR) 64 65model.fit( 66 train_images, 67 train_images, 68 validation_data=(valid_images, valid_images), 69 batch_size=125, 70 epochs=100, 71 callbacks=[tensorboard_callback] 72) 73 74model.save(MODEL_FILEPATH)
試したこと
kerasの前にtensorflowをつけたりpythonをつけたりネット上の文献で見当たるものは試してみましたがうまくいきませんでした。
もしかしたら自分が見逃しているパターンもあるかもしれないので解答ほどよろしくお願いします。
補足情報(FW/ツールのバージョンなど)
ここにより詳細な情報を記載してください。

回答1件
あなたの回答
tips
プレビュー