• 技术文章 >后端开发 >Python教程

    Python中简单易用的并行加速技巧

    WBOYWBOY2023-04-12 14:25:15转载37

    1.简介

    我们在日常使用Python进行各种数据计算处理任务时,若想要获得明显的计算加速效果,最简单明了的方式就是想办法将默认运行在单个进程上的任务,扩展到使用多进程或多线程的方式执行。

    而对于我们这些从事数据分析工作的人员而言,以最简单的方式实现等价的加速运算的效果尤为重要,从而避免将时间过多花费在编写程序上。而今天的文章费老师我就来带大家学习如何利用joblib这个非常简单易用的库中的相关功能,来快速实现并行计算加速效果。

    2.使用joblib进行并行计算

    作为一个被广泛使用的第三方Python库(譬如scikit-learn项框架中就大量使用joblib进行众多机器学习算法的并行加速),我们可以使用pip install joblib对其进行安装,安装完成后,下面我们来学习一下joblib中有关并行运算的常用方法:

    2.1 使用Parallel与delayed进行并行加速

    joblib中实现并行计算只需要使用到其Parallel和delayed方法即可,使用起来非常简单方便,下面我们直接以一个小例子来演示:

    joblib实现并行运算的思想是将一组通过循环产生的串行计算子任务,以多进程或多线程的方式进行调度,而我们针对自定义的运算任务需要做的仅仅是将它们封装为函数的形式即可,譬如:

    import time
    
    def task_demo1():
    
    time.sleep(1)
    
    return time.time()
    

    接着只需要像下面的形式一样,为Parallel()设置相关参数后,衔接循环创建子任务的列表推导过程,其中利用delayed()包裹自定义任务函数,再衔接()传递任务函数所需的参数即可,其中n_jobs参数用于设置并行任务同时执行的worker数量,因此在这个例子中可以看到进度条是按照4个一组递增的,可以看到最终时间开销也达到了并行加速效果:

    其中可以根据计算任务以及机器CPU核心数具体情况为Parallel()调节参数,核心参数有:

    譬如下面的例子,在我这台逻辑核心数为8的机器上,保留两个核心进行并行计算:

    关于并行方式的选择上,由于Python中多线程时全局解释器锁的限制,如果你的任务是计算密集型,则推荐使用默认的多进程方式加速,如果你的任务是IO密集型譬如文件读写、网络请求等,则多线程是更好的方式且可以将n_jobs设置的很大,举个简单的例子,可以看到,通过多线程并行,我们在5秒的时间里完成了1000次请求,远快于单线程17秒请求100次的成绩(此例仅供参考,大家在学习尝试时请不要过于频繁访问他人的网站):

    你可以根据自己实际任务的不同,好好利用joblib来加速你的日常工作。


    以上就是Python中简单易用的并行加速技巧的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:51CTO.COM,如有侵犯,请联系admin@php.cn删除
    专题推荐:Python 技巧 数据计算
    上一篇:Python编程:轻松搞透上下文管理器(Context Manager) 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • 如何使用Python实现视频去重的小工具• python调试模块ipdb怎么使用• Python五连冠!2021年 IEEE编程语言排行榜出炉!• 使用click创建完美的Python命令行程序• 万字长文,Python字符串格式化讲解
    1/1

    PHP中文网