首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >不能用detectron2恢复训练

不能用detectron2恢复训练
EN

Stack Overflow用户
提问于 2021-12-06 11:22:19
回答 1查看 704关注 0票数 2

我正在训练一个更快的R CNN架构的模型。对于第一个会话,我使用了以下配置:

代码语言:javascript
复制
def get_train_cfg(config_file_path, checkpoint_url, train_dataset_name, test_dataset_name, num_classes, device, output_dir):
  
    cfg = get_cfg()
    cfg.merge_from_file(model_zoo.get_config_file(config_file_path))
    cfg.MODEL_WEIGHTS = model_zoo.get_checkpoint_url(checkpoint_url)
    cfg.DATASETS.TRAIN = (train_dataset_name,)
    cfg.DATASETS.TEST = (train_dataset_name,)

    cfg.DATALOADER.NUM_WORKERS = 2
    cfg.SOLVER.IMS_PER_BATCH = 1
    cfg.SOLVER.BASE_LR = 0.0001
    cfg.SOLVER.MAX_ITER = 16000
    cfg.SOLVER.STEPS = []

    cfg.MODEL.ROI_HEADS.NUM_CLASSES = num_classes
    cfg.MODEL.DEVICE = device
    cfg.OUTPUT_DIR = output_dir

    return cfg

我想继续训练。我有last_checkpointmetrics.jsoncfg.picklemodel_final.pth

这是我的记事本链接

训练应从16001次迭代开始,16000次迭代时的总损失约为0.8次。但学习率从16000次到16000次没有从0.0001次变化。当我继续通过resume_or_load(resume=True)进行训练时,会显示以下错误

代码语言:javascript
复制
[12/04 05:54:36 d2.data.datasets.coco]: Loaded 381 images in COCO format from ../input/cascade-rcnn/train.json
[12/04 05:54:36 d2.data.build]: Removed 1 images with no usable annotations. 380 images left.
[12/04 05:54:36 d2.data.dataset_mapper]: [DatasetMapper] Augmentations used in training: [ResizeShortestEdge(short_edge_length=(640, 672, 704, 736, 768, 800), max_size=1333, sample_style='choice'), RandomFlip()]
[12/04 05:54:36 d2.data.build]: Using training sampler TrainingSampler
[12/04 05:54:36 d2.data.common]: Serializing 380 elements to byte tensors and concatenating them all ...
[12/04 05:54:36 d2.data.common]: Serialized dataset takes 2.23 MiB
[12/04 05:54:37 d2.engine.hooks]: Loading scheduler from state_dict ...
[12/04 05:54:37 d2.engine.train_loop]: Starting training from iteration 16000
[12/04 05:54:37 d2.engine.hooks]: Total training time: 0:00:00 (0:00:00 on hooks)
[12/04 05:54:37 d2.data.datasets.coco]: Loaded 381 images in COCO format from ../input/cascade-rcnn/train.json
[12/04 05:54:38 d2.data.dataset_mapper]: [DatasetMapper] Augmentations used in inference: [ResizeShortestEdge(short_edge_length=(800, 800), max_size=1333, sample_style='choice')]
[12/04 05:54:38 d2.data.common]: Serializing 381 elements to byte tensors and concatenating them all ...
[12/04 05:54:38 d2.data.common]: Serialized dataset takes 2.23 MiB
WARNING [12/04 05:54:38 d2.engine.defaults]: No evaluator found. Use DefaultTrainer.test(evaluators=), or implement its build_evaluator method.
[12/04 05:54:38 d2.utils.events]: iter: 16001 lr: N/A max_mem: 1627M

它显示了

代码语言:javascript
复制
lr: N/A

为什么会这样呢?

我在用,

  • Python: 3.7.10,
  • Detectron2 :0.6分,
  • 火炬: 1.9.1cu101
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-12-06 16:19:54

实际上没有错误。

问题是您的配置将最大迭代指定为16000。

代码语言:javascript
复制
cfg.SOLVER.MAX_ITER = 16000

但是,基于控制台输出,您的上一次会话似乎已经完成了16000次迭代。因此,新的会议没有什么可做的了。

将最大迭代次数更改为大于16000的值(一旦从先前保存的配置中读取)应继续进行培训,就像您期望的那样。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70244703

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档