2016-12-04 59 views
7

嗨我正在嘗試在keras上製作超級分辨率模型。我想指的是https://github.com/titu1994/Image-Super-Resolution無法使用自定義度量加載keras模型

但經過我編譯並保存一個新的模型,當我加載模型時,就會發生度量錯誤

Traceback (most recent call last): 
    File "autoencoder2.py", line 56, in <module> 
    load_model("./ani.model") 
    File "/home/simmani91/anaconda2/lib/python2.7/site-packages/keras/models.py", line 155, in load_model 
    sample_weight_mode=sample_weight_mode) 
    File "/home/simmani91/anaconda2/lib/python2.7/site-packages/keras/engine/training.py", line 665, in compile 
    metric_fn = metrics_module.get(metric) 
    File "/home/simmani91/anaconda2/lib/python2.7/site-packages/keras/metrics.py", line 84, in get 
    return get_from_module(identifier, globals(), 'metric') 
    File "/home/simmani91/anaconda2/lib/python2.7/site-packages/keras/utils/generic_utils.py", line 14, in get_from_module 
    str(identifier)) 
Exception: Invalid metric: PSNRLoss 

,這裏是我的公制(PSNRLoss)代碼,創建模型,執行

def PSNRLoss(y_true, y_pred): 
    return -10. * np.log10(K.mean(K.square(y_pred - y_true))) 

def create_model(): 
    shape = (360,640,3) 
    input_img = Input(shape=shape) 

    x = Convolution2D(64, shape[0],shape[1], activation='relu', border_mode='same', name='level1')(input_img) 
    x = Convolution2D(32,shape[0],shape[1], activation='relu', border_mode='same', name='level2')(x) 

    out = Convolution2D(3, shape[0],shape[1], border_mode='same', name='output')(x) 

    model = Model(input_img, out) 
    #model.compile(optimizer='adadelta', loss='binary_crossentropy') 
    adam = optimizers.Adam(lr=1e-3) 
    model.compile(optimizer=adam, loss='mse', metrics=[PSNRLoss]) 

    return model 

path = "./picture/" 

if not os.path.exists("./ani.model"): 
    ani_model = create_model() 
    ani_model.save("./ani.model") 

load_model("./ani.model") 

有什麼方法可以用PSNR指標加載模型?

謝謝您的閱讀。

回答

6

改爲使用load_model("ani.model", custom_objects={"PSNRLoss": PSNRLoss})加載模型。

相關問題