我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Pytorch 如何加速Dataloader提升数据读取速度

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Pytorch 如何加速Dataloader提升数据读取速度

在利用DL解决图像问题时,影响训练效率最大的有时候是GPU,有时候也可能是CPU和你的磁盘。

很多设计不当的任务,在训练神经网络的时候,大部分时间都是在从磁盘中读取数据,而不是做 Backpropagation 。

这种症状的体现是使用 Nividia-smi 查看 GPU 使用率时,Memory-Usage 占用率很高,但是 GPU-Util 时常为 0% ,如下图所示:

如何解决这种问题呢?

在 Nvidia 提出的分布式框架 Apex 里面,我们在源码里面找到了一个简单的解决方案:

https://github.com/NVIDIA/apex/blob/f5cd5ae937f168c763985f627bbf850648ea5f3f/examples/imagenet/main_amp.py#L256 ​


class data_prefetcher():
    def __init__(self, loader):
        self.loader = iter(loader)
        self.stream = torch.cuda.Stream()
        self.mean = torch.tensor([0.485 * 255, 0.456 * 255, 0.406 * 255]).cuda().view(1,3,1,1)
        self.std = torch.tensor([0.229 * 255, 0.224 * 255, 0.225 * 255]).cuda().view(1,3,1,1)
        # With Amp, it isn't necessary to manually convert data to half.
        # if args.fp16:
        #     self.mean = self.mean.half()
        #     self.std = self.std.half()
        self.preload()

    def preload(self):
        try:
            self.next_input, self.next_target = next(self.loader)
        except StopIteration:
            self.next_input = None
            self.next_target = None
            return
        with torch.cuda.stream(self.stream):
            self.next_input = self.next_input.cuda(non_blocking=True)
            self.next_target = self.next_target.cuda(non_blocking=True)
            # With Amp, it isn't necessary to manually convert data to half.
            # if args.fp16:
            #     self.next_input = self.next_input.half()
            # else:
            self.next_input = self.next_input.float()
            self.next_input = self.next_input.sub_(self.mean).div_(self.std)

我们能看到 Nvidia 是在读取每次数据返回给网络的时候,预读取下一次迭代需要的数据,

那么对我们自己的训练代码只需要做下面的改造:


training_data_loader = DataLoader(
    dataset=train_dataset,
    num_workers=opts.threads,
    batch_size=opts.batchSize,
    pin_memory=True,
    shuffle=True,
)
for iteration, batch in enumerate(training_data_loader, 1):
    # 训练代码

#-------------升级后---------

data, label = prefetcher.next()
iteration = 0
while data is not None:
    iteration += 1
    # 训练代码
    data, label = prefetcher.next()

这样子我们的 Dataloader 就像打了鸡血一样提高了效率很多,如下图:

当然,最好的解决方案还是从硬件上,把读取速度慢的机械硬盘换成 NVME 固态吧~

补充:Pytorch设置多线程进行dataloader时影响GPU运行

使用PyTorch设置多线程(threads)进行数据读取时,其实是假的多线程,他是开了N个子进程(PID是连续的)进行模拟多线程工作。

以载入cocodataset为例

DataLoader


dataloader = torch.utils.data.DataLoader(COCODataset(config["train_path"],
                                                     (config["img_w"], config["img_h"]),
                                                     is_training=True),
                                         batch_size=config["batch_size"],
                                         shuffle=True, num_workers=32, pin_memory=True)

numworkers就是指定多少线程的参数,原为32。

检查GPU是否运行该程序

查看运行在gpu上的所有程序:


fuser -v /dev/nvidia*

如果没有返回,则该程序并没有在GPU上运行

指定GPU运行

将num_workers改成0即可

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Pytorch 如何加速Dataloader提升数据读取速度

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Pytorch如何加速Dataloader提升数据读取速度

这篇文章将为大家详细讲解有关Pytorch如何加速Dataloader提升数据读取速度,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在利用DL解决图像问题时,影响训练效率最大的有时候是GPU,有时候也可能
2023-06-15

MyBatis iterate如何提升数据加载速度

MyBatis 的` 标签可以用于在 SQL 查询中迭代集合,但是在处理大量数据时,性能可能会受到影响。为了提高数据加载速度,你可以尝试以下方法:分批查询:将大量数据分成多个批次进行查询,这样可以减少每次查询的数据量,从而提高查询速度。你可
MyBatis iterate如何提升数据加载速度
2024-09-19

如何提高redis读取速度

有以下几种方法可以提高Redis的读取速度:1. 使用合适的数据结构:Redis支持多种数据结构,比如字符串、哈希、列表、集合和有序集合。选择合适的数据结构可以更高效地存储和查询数据。2. 使用合适的数据存储方案:Redis支持多种持久化方
2023-08-24

如何在Pytorch中使用Dataset和DataLoader读取数据

本篇文章给大家分享的是有关如何在Pytorch中使用Dataset和DataLoader读取数据,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。一、前言确保安装scikit-im
2023-06-15

如何提升网页的加载速度?

编程学习网:相信在使用浏览器去浏览网页的时候,有些时候总会是出现网页加载慢的情况,除了网速的问题的话,更多的时候还是需要进行相关的设置来去提升网页的加载速度,会发现快的速度将会是让人感觉到非常的爽,下面我们来分享一下该如何才能进行优化,最终提升效率。方法是有很多种,在这里就不逐个的来列举出来了,有需要的朋友们可以参考一下。
如何提升网页的加载速度?
2024-04-23

win7宽带速度如何提升 通过注册表加速win7宽带速度

宽带速度相信不会有人嫌弃太快了,大家都是希望宽带的速度越快www.cppcns.com越好,那么怎么样才能加速win7电脑的宽带速度呢? 1、点击开javascript始,在搜索框里面输入regedit,回车进入注册表。 2、然后定位到:
2023-06-02

phpcms如何结合CDN加速提升网站访问速度?(在phpcms中,如何结合CDN服务提升网站的访问速度?)

结合CDN服务,PHPcms网站可通过缓存静态内容、减少延迟、负载均衡等原理提升访问速度。具体操作包括选择CDN提供商、修改网站代码、清除缓存等步骤。CDN加速提升网站速度,需要注意缓存设置、CDN费用、SSL支持以及性能监控和优化。通过合理运用CDN,PHPcms网站可以有效提升用户体验和页面加载效率。
phpcms如何结合CDN加速提升网站访问速度?(在phpcms中,如何结合CDN服务提升网站的访问速度?)
2024-04-02

美国虚拟主机网站加载速度如何提升

提升美国虚拟主机网站加载速度可以通过以下方法:使用CDN(内容分发网络):CDN可以帮助加速网站的加载速度,通过在全球范围内的多个服务器上缓存网站内容,使用户可以从距离更近的服务器上加载网站内容。压缩网站资源:压缩网站的图片、CSS和Jav
美国虚拟主机网站加载速度如何提升
2024-04-18

Vue如何通过懒加载提升页面响应速度

这篇文章将为大家详细讲解有关Vue如何通过懒加载提升页面响应速度,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Vue的优点Vue具体轻量级框架、简单易学、双向数据绑定、组件化、数据和结构的分离、虚拟DOM
2023-06-15

PHP8如何通过Just-In-Time Compilation提升文件加载速度?

PHP8如何通过Just-In-Time Compilation提升文件加载速度?随着互联网的发展,网页应用程序的性能要求也越来越高。PHP作为广泛应用于网页开发的编程语言,在性能方面一直备受诟病。然而,随着PHP8的发布,引入了Just-
2023-10-24

如何使用pytorch加载并读取COCO数据集

这篇文章主要介绍“如何使用pytorch加载并读取COCO数据集”,在日常操作中,相信很多人在如何使用pytorch加载并读取COCO数据集问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何使用pytorch
2023-06-30

如何通过PHP开发缓存提升网页加载速度

如何通过PHP开发缓存提升网页加载速度在现今互联网高速发展的时代,网页的加载速度对于用户体验尤为重要。而PHP作为一种流行的服务器端脚本语言,可以通过缓存技术来提高网页的加载速度。本文将介绍如何使用PHP开发缓存来提升网页加载速度,并提供一
如何通过PHP开发缓存提升网页加载速度
2023-11-07

如何使用Memcache提升PHP应用程序的数据访问速度?

如何使用Memcache提升PHP应用程序的数据访问速度?概述:在开发PHP应用程序时,数据访问速度是一个重要的考量因素。当应用程序需要频繁读取数据库或进行复杂的计算时,可能会导致性能下降。为了解决这个问题,可以使用Memcache来缓存数
如何使用Memcache提升PHP应用程序的数据访问速度?
2023-11-07

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录