Pytorch Lightning验证时TQDMProgressBar进度条输出异常问题与解决方案

问题描述

在使用Pytorch Lightning时,若使用Pycharm或在Colab中用“python train.py”方式运行时,验证时的进度条会出现一个batch打印一行的情况。

例如:

trainer = pl.Trainer(
            callbacks=[TQDMProgressBar()],
        )

在Pycharm中运行时,进度条会出现如下情况:

Epoch 0: 100%|██████████| 20/20 [00:13<00:00,  1.49it/s, v_num=10]
Validation: 0it [00:00, ?it/s]
Validation:   0%|          | 0/5 [00:00

Validation DataLoader的进度条出现多次。

解决方案

重写TQDMProgressBarinit_validation_tqdm方法。代码如下:

class MyTQDMProgressBar(TQDMProgressBar):

    def __init__(self):
        super(MyTQDMProgressBar, self).__init__()

    def init_validation_tqdm(self):
        bar = Tqdm(
            desc=self.validation_description,
            position=0,  # 这里固定写0
            disable=self.is_disabled,
            leave=True,  # leave写True
            dynamic_ncols=True,
            file=sys.stdout,
        )
        return bar

然后使用MyTQDMProgressBar代替TQDMProgressBar即可。

你可能感兴趣的:(pytorch,python,深度学习)