Tensorflow: NotFoundError: Нет такого файла или каталога - PullRequest
0 голосов
/ 04 июня 2018

Я столкнулся с проблемой восстановления веса модели tenorflow.

Итак, во время обучения модели я сохранял контрольную точку модели после каждых 500 итераций,

if j%500==0:
                    with open('iterres.txt','a') as f:
                        f.write(str({'epoch': i, 'test_accuracy': evaluate_(model,batch_size=100),'iteration':j}) + '\n')
                        os.system('mkdir ' + str(i)+'epoch'+str(j))
                        saver.save(sess, '/home/g_cloud/exe_paul/'+str(i)+'epoch'+str(j)+'/'+str(i))

Теперь у меня была папка контрольной точки со всеми весами и мета:

Я скачал весы и создал новую папку с именем «new_backup», где все весы и мета есть:

Когда я пытаюсь загрузить эти файлы из этой папки:

import tensorflow as tf


labels_dict={
              1: 'Yes', 
              0: 'No'
            }


with tf.Session() as sess:


    saver = tf.train.import_meta_graph('../new_backup/1.meta')
    restore = saver.restore(sess,tf.train.latest_checkpoint('../new_backup/'))
    graph=tf.get_default_graph()

    query= graph.get_tensor_by_name("input:0")
    result=graph.get_tensor_by_name("netout:0")

Затем я получаю эту ошибку:

NotFoundError: /home/g_cloud/exe_paul/1epoch1000; No such file or directory

Это была моя облачная учетная запись, а 1epoch1000 была старой папкой, в которой весь вес был сохранен во время тренировки.Моя проблема в том, что если я пойду в облако и использую тот же скрипт для восстановления модели, когда есть папка 1epoch1000, тогда скрипт работает, но в противном случае выдает эту ошибку.

Как я могу изменить мета, чтобы перенаправить путь или как я могувосстановить модель где угодно?

1 Ответ

0 голосов
/ 05 июня 2018

Я попытался найти ответ, но безуспешно. Затем я провел некоторый эксперимент, поэтому при сохранении модели вы получите четыре файла:

model.data
model.index
model.meta
checkpoint

Теперь откройте контрольную точку в виде файла .txt, где вы будетесм. некоторые пути:

model_checkpoint_path: "/home/g_cloud/exe_paul/1epoch1000/model"
all_model_checkpoint_paths: "/home/g_cloud/exe_paul/1epoch500/0"
all_model_checkpoint_paths: "/home/g_cloud/exe_paul/1epoch1000/0"
all_model_checkpoint_paths: "/home/g_cloud/exe_paul/1epoch2000/1"
all_model_checkpoint_paths: "/home/g_cloud/exe_paul/1epoch2500/1"
all_model_checkpoint_paths: "/home/g_cloud/exe_paul/1epoch3000/1"

Просто измените первый путь, который говорит контрольную точку модели, на локальный путь вашей машины, где находится ваша модель.

После этого измените путь на локальный путь в:

saver = tf.train.import_meta_graph('../new_backup/1.meta')
restore = saver.restore(sess,tf.train.latest_checkpoint('../new_backup/'))

И это все.

...