随笔小杂记(六)——tqdm进度条显示出现多余行

随笔小杂记(六)——tqdm进度条显示出现多余行

前言

自己打算搭建一个自己的分类库,方便(虽然大概率以后很难出分类的相关实验了,但是还是整理一下,主要也算复习吧)以后自己做实验。然后在整理训练代码的时候,用tqdm显示进度条时,发现进度条出现了多余行~

原因

在一个迭代过程中,如果迭代未完成就被中断,随后也没有从断点继续把剩余迭代完成,就会残存一个未能完成但参与显示的进度条,从而导致多行输出。

for epoch in range(20):
        print('epoch {}'.format(epoch + 1))
        # training-----------------------------
        model.train()
        with tqdm(train_dataloader, desc=f'Epoch {epoch + 1}/{epoch}',postfix=dict,mininterval=0.3) as pbar: 
            for batch_x, batch_y in train_dataloader:
                .....
                pbar.set_postfix(loss=loss.item(), accuracy='{:.3f}'.format(accuracy)) 
                pbar.update(1)
        ## 问题出现在这里
        print('\nTrain Loss: {:.6f}, Acc: {:.6f}'.format(train_loss / (len(train_datasets)), train_acc / (len(train_datasets))))
        # evaluation--------------------------------
        model.eval()
        with tqdm(val_dataloader, desc=f'Epoch {epoch + 1}/{epoch}',postfix=dict,mininterval=0.3) as pbar: 
            for batch_x, batch_y in val_dataloader:
                ...
                pbar.set_postfix(loss=loss.item(), accuracy='{:.3f}'.format(accuracy)) 
                pbar.update(1)
        print('Test Loss: {:.6f}, Acc: {:.6f}'.format(eval_loss / (len(val_datasets)), eval_acc / (len(val_datasets))))

自己后面仔细观察发现,他多余的那个进度条是上个迭代中的最后一行,最后一个残存的未能参与显示的进度条会在迭代完成前出现,而我在迭代结束前有一行print('\nTrain Loss: {:.6f}, Acc: {:.6f}'.format(train_loss / (len(train_datasets)), train_acc / (len(train_datasets)))),导致人为在进度条显示中给了一个分割,所以就出现了多宇行,结果如下:

解决方法

思路:在你有其他输出以前,让迭代明白他已经迭代完成。

方法一:将tqdm作为对象创建,然后迭代中断时,通过t.close()销毁对象,使用close()方法手动销毁未完成的进度条。

from tqdm import tqdm
#创建tqdm对象
t = tqdm(range(0,1000000))
#迭代
for i in t:
	pass
t.close()

方法二:在做模型训练和检验时,通过使用model.train(),model.eval()让tqdm完成迭代
比如,在原因中的代码,把print('\nTrain Loss: {:.6f}, Acc: {:.6f}'.format(train_loss / (len(train_datasets)), train_acc / (len(train_datasets))))移动到model.eval()之后,让tqdm明白完成迭代,输出残存的最后一行,然后再进行输出。如下:

for epoch in range(20):
        print('epoch {}'.format(epoch + 1))
        # training-----------------------------
        model.train()
        with tqdm(train_dataloader, desc=f'Epoch {epoch + 1}/{epoch}',postfix=dict,mininterval=0.3) as pbar: 
            for batch_x, batch_y in train_dataloader:
                .....
                pbar.set_postfix(loss=loss.item(), accuracy='{:.3f}'.format(accuracy)) 
                pbar.update(1)
        # evaluation--------------------------------
        model.eval()
        ## 这里
        print('\nTrain Loss: {:.6f}, Acc: {:.6f}'.format(train_loss / (len(train_datasets)), train_acc / (len(train_datasets))))
        with tqdm(val_dataloader, desc=f'Epoch {epoch + 1}/{epoch}',postfix=dict,mininterval=0.3) as pbar: 
            for batch_x, batch_y in val_dataloader:
                ...
                pbar.set_postfix(loss=loss.item(), accuracy='{:.3f}'.format(accuracy)) 
                pbar.update(1)
        print('Test Loss: {:.6f}, Acc: {:.6f}'.format(eval_loss / (len(val_datasets)), eval_acc / (len(val_datasets))))

更改后结果如下:

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Mathcad 是一种功能强大的数学软件,它可以让我们非常方便地进数学计算和分析。学习使用Mathcad 对我来说是一种挑战,但同时也是一次非常有意义的经历。 首先,通过学习Mathcad,我深刻认识到数学公式和计算的重要性。在过去,我常常依赖计算器和纸笔进数学计算,但这种方式往往效率不高,并且难以避免出错。而Mathcad 提供了一个直观且可视化的界面,让我们可以更加直观地理解和应用数学原理。 其次,学习Mathcad 也提高了我的数学建模和问题解决能力。在学习过程中,我发现Mathcad 的强大之处在于它能够将数学公式和实际问题相结合。通过输入不同的数学公式和数据,我可以揭示和解决一些实际世界中的问题,例如电路分析、力学运动、概率统计等,这为我提供了宝贵的数学建模实践经验。 此外,通过学习Mathcad,我也掌握了一种全新的数学表达方式。通过使用Mathcad的函数和符号库,我可以更加准确地表达数学概念和计算过程。这种表达方式简洁明了,易于理解和阅读,有助于提高我的数学思维能力和表达能力。 尽管学习Mathcad可能会遇到一些挑战,例如复杂的函数和符号操作,对于初学者来说不太友好,但通过不断实践和学习,我相信我可以克服这些问题,并不断进步。 总的来说,学习Mathcad 是一次充满挑战和收获的过程。它帮助我提高了数学知识和技能,提升了我的数学建模和问题解决能力。我相信在未来的学习和工作中,Mathcad 将成为我强大的数学工具。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值