使用 Numba 加速 Python 嵌套循环:性能优化教程

使用 numba 加速 python 嵌套循环:性能优化教程

本文针对Python中嵌套循环计算密集型任务的性能瓶颈,提供了一种有效的解决方案:使用Numba库进行即时编译(JIT)。通过Numba的`@njit`装饰器和并行计算特性,可以显著提升代码执行速度,尤其是在处理大型数据集时。本文将详细介绍如何使用Numba加速嵌套循环,并提供性能对比示例,帮助读者优化Python代码,提高计算效率。

Numba 简介

Numba 是一个开源的 Python 编译器,它使用 LLVM 将 Python 代码转换为优化的机器代码。Numba 的核心在于其即时编译 (JIT) 能力,这意味着它可以在运行时编译 Python 代码,从而显著提高性能。Numba 特别擅长加速数值计算密集型的代码,例如包含循环、数组操作和数学函数的代码。

优化嵌套循环的步骤

以下是如何使用 Numba 加速 Python 中嵌套循环的步骤:

安装 Numba:

立即学习“Python免费学习笔记(深入)”;

首先,确保你已经安装了 Numba。可以使用 pip 进行安装:

pip install numba

导入 Numba:

在你的 Python 脚本中导入 numba 库。

from numba import njit, prangeimport numpy as np # 引入 numpy

使用 @njit 装饰器:

度加剪辑 度加剪辑

度加剪辑(原度咔剪辑),百度旗下AI创作工具

度加剪辑 63 查看详情 度加剪辑

在要加速的函数上添加 @njit 装饰器。这将指示 Numba 编译该函数。

@njitdef your_function(args):    # 包含嵌套循环的代码    ...    return result

考虑并行化 (可选):

对于可以并行执行的循环,可以使用 prange 替换 range,并使用 @njit(parallel=True) 装饰器。这将允许 Numba 在多个 CPU 核心上并行执行循环。

@njit(parallel=True)def your_function(args):    # 包含嵌套循环的代码    for i in prange(len(data)):        ...    return result

示例代码

以下是一个使用 Numba 加速嵌套循环的示例。该示例基于问题中提供的代码,并展示了如何使用 @njit 和并行化来提高性能。

from timeit import timeitfrom numba import njit, prangeimport numpy as npP_mean = 1500P_std = 100Q_mean = 1500Q_std = 100W = 1  # Number of matches won by PL = 0  # Number of matches lost by PL_P = np.exp(-0.5 * ((np.arange(0, 3501, 10) - P_mean) / P_std) ** 2) / (    P_std * np.sqrt(2 * np.pi))L_Q = np.exp(-0.5 * ((np.arange(0, 3501, 10) - Q_mean) / Q_std) ** 2) / (    Q_std * np.sqrt(2 * np.pi))def probability_of_loss(x):    return 1 / (1 + np.exp(x / 67))def U_p_law(W, L, L_P, L_Q):    omega = np.arange(0, 3501, 10)    U_p = np.zeros_like(omega, dtype=float)    for p_idx, p in enumerate(omega):        for q_idx, q in enumerate(omega):            U_p[p_idx] += (                probability_of_loss(q - p) ** W                * probability_of_loss(p - q) ** L                * L_Q[q_idx]                * L_P[p_idx]            )    normalization_factor = np.sum(U_p)    U_p /= normalization_factor    return omega, U_p@njitdef probability_of_loss_numba(x):    return 1 / (1 + np.exp(x / 67))@njitdef U_p_law_numba(W, L, L_P, L_Q):    omega = np.arange(0, 3501, 10, dtype=np.float64)    U_p = np.zeros_like(omega)    for p_idx, p in enumerate(omega):        for q_idx, q in enumerate(omega):            U_p[p_idx] += (                probability_of_loss_numba(q - p) ** W                * probability_of_loss_numba(p - q) ** L                * L_Q[q_idx]                * L_P[p_idx]            )    normalization_factor = np.sum(U_p)    U_p /= normalization_factor    return omega, U_p@njit(parallel=True)def U_p_law_numba_parallel(W, L, L_P, L_Q):    omega = np.arange(0, 3501, 10, dtype=np.float64)    U_p = np.zeros_like(omega)    for p_idx in prange(len(omega)):        p = omega[p_idx]        for q_idx in prange(len(omega)):            q = omega[q_idx]            U_p[p_idx] += (                probability_of_loss_numba(q - p) ** W                * probability_of_loss_numba(p - q) ** L                * L_Q[q_idx]                * L_P[p_idx]            )    normalization_factor = np.sum(U_p)    U_p /= normalization_factor    return omega, U_pomega_1, U_p_1 = U_p_law(W, L, L_P, L_Q)omega_2, U_p_2 = U_p_law_numba(W, L, L_P, L_Q)omega_3, U_p_3 = U_p_law_numba_parallel(W, L, L_P, L_Q)assert np.allclose(omega_1, omega_2)assert np.allclose(omega_1, omega_3)assert np.allclose(U_p_1, U_p_2)assert np.allclose(U_p_1, U_p_3)t1 = timeit("U_p_law(W, L, L_P, L_Q)", number=10, globals=globals())t2 = timeit("U_p_law_numba(W, L, L_P, L_Q)", number=10, globals=globals())t3 = timeit("U_p_law_numba_parallel(W, L, L_P, L_Q)", number=10, globals=globals())print("10 calls using vanilla Python     :", t1)print("10 calls using Numba              :", t2)print("10 calls using Numba (+ parallel) :", t3)

代码解释:

probability_of_loss_numba: 使用 @njit 装饰器加速 probability_of_loss 函数。U_p_law_numba: 使用 @njit 装饰器加速原始函数。U_p_law_numba_parallel: 使用 @njit(parallel=True) 装饰器加速原始函数,并使用 prange 进行并行化。assert np.allclose(…): 验证 Numba 加速后的函数结果与原始函数结果是否一致,确保正确性。timeit: 使用 timeit 模块测量不同版本的函数执行时间,进行性能比较。

输出示例 (AMD 5700x):

10 calls using vanilla Python     : 2.427635274827480310 calls using Numba              : 0.01395714003592729610 calls using Numba (+ parallel) : 0.003793451003730297

正如输出所示,使用 Numba 可以显著提高代码的执行速度。

注意事项

数据类型: Numba 在处理 NumPy 数组时效果最佳。确保你的数据存储在 NumPy 数组中。首次运行时间: Numba 需要一些时间来编译函数。因此,首次运行使用 @njit 装饰的函数可能会比未装饰的函数慢。但是,后续运行将会非常快。支持的 Python 功能: Numba 并非支持所有的 Python 功能。在使用 Numba 之前,请查阅 Numba 的官方文档,了解其支持的功能。错误处理: Numba 在编译时可能会报错。仔细阅读错误信息,并根据提示修改代码。并行化: 并非所有循环都适合并行化。确保循环的迭代之间没有依赖关系。fastmath 参数: 对于一些数学运算,可以尝试使用 @njit(fastmath=True)。fastmath 允许编译器进行更激进的优化,但这可能会导致一些精度损失。请根据你的应用场景权衡精度和性能。

总结

Numba 是一个强大的工具,可以显著提高 Python 中数值计算密集型代码的性能。通过使用 @njit 装饰器和并行化,可以轻松加速包含嵌套循环的代码。希望本教程能够帮助你优化 Python 代码,提高计算效率。

以上就是使用 Numba 加速 Python 嵌套循环:性能优化教程的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/589676.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月10日 15:17:22
下一篇 2025年11月10日 15:18:50

相关推荐

  • 如何才能获取狗狗币 狗狗币买卖渠道汇总

    狗狗币(doge)因其独特的社区文化和活跃的市场表现,受到众多投资者关注。本文将为您汇总获取狗狗币的可靠渠道,帮助新手顺利购买并管理doge资产。 建议用户使用币安或欧易OKX两大主流交易平台进行交易,这些平台提供安全可靠的交易环境和实时行情服务。 币安注册链接与下载地址: 欧易注册链接与下载地址:…

    2025年12月9日 好文分享
    000
  • 分析师确认比特币已突破15万美元阻力位

    投资者可通过币安和欧易okx平台,实时跟踪比特币价格及相关交易工具,便于快速响应市场变化。 币安注册链接与下载地址: 欧易OKX注册与下载地址: 据最新市场分析,分析师确认比特币(BTC)已成功突破15万美元阻力位,这一突破标志着市场多头趋势进一步加强。本文将解读突破原因及投资者可参考的操作策略。 …

    2025年12月9日
    000
  • 欧一官网下载V6.132.0版 欧一交易所APP最新下载链接

    欧一(ouyi)交易所APP是一款专业的数字资产管理与交易工具,最新的V6.132.0版本对性能和用户体验进行了全面优化,为用户提供了更加安全、便捷的服务。本文将为您提供该版本APP的最新下载链接和详细安装指南。 下载安装步骤 1、请首先准备好您的设备,确保网络连接稳定,以便顺利完成下载与安装流程。…

    2025年12月9日
    000
  • 支持多链行情同步显示的工具有哪些?十大多链行情工具推荐

    随着币圈生态日益丰富,多链资产的投资需求逐渐增加,支持多链行情同步显示的工具成为投资者关注的重点。本文将为您介绍十大优质多链行情工具,帮助用户高效追踪多链数字资产价格。 为了便捷操作和安全交易,建议用户使用币安和欧易OKX等主流交易平台,这些平台支持多链资产管理和实时行情查看。 币安注册链接与下载地…

    2025年12月9日 好文分享
    000
  • 如何判断行情网站价格数据的可靠性?常用币种行情网站推荐

    投资者在获取行情数据时,可结合币安和欧易okx平台的实时行情参考,这些主流交易所提供权威价格信息和交易数据。 币安注册链接与下载地址: 欧易OKX注册与下载地址: 在币圈交易中,获取可靠的行情数据至关重要。行情网站提供的价格信息直接影响投资决策,因此判断数据的可靠性是新手和资深投资者必须掌握的技能。…

    2025年12月9日
    000
  • 以太坊价格突破 $4700,机构资金持续涌入

    近日,以太坊(eth)价格突破 $4,700 关口,引发市场广泛关注。分析显示,机构资金持续涌入成为推动价格上涨的主要因素。本文将解析本轮行情的原因及投资者可参考的操作策略。 投资者可通过币安和欧易OKX平台,实时跟踪以太坊价格及相关交易工具,以便快速响应市场变化。 币安注册链接与下载地址: 欧易O…

    2025年12月9日
    000
  • 币安交易所app官网 v3.1.8 币安binance安卓版入口

    币安(Binance)是全球知名的数字资产交易平台,为用户提供安全、稳定、便捷的加密货币交易服务。通过币安App,您可以随时随地进行多种数字货币的买卖、管理您的数字资产以及获取最新的市场动态。 本文将为您提供币安交易所app官网 v3.1.8 安卓版的官方下载链接与详细的安装步骤,点击本文中提供的下…

    2025年12月9日 好文分享
    000
  • OK币销毁50%的OKB供应量价格应声上涨

    近日,ok币(okb)平台宣布销毁50%的okb供应量,消息一出,okb价格应声上涨,市场反应积极。本文将解析此次销毁事件对价格的影响及投资者可参考的操作策略。 建议投资者通过币安和欧易OKX、火币HTX平台跟踪OKB价格及交易动态,这些主流交易平台提供实时行情和安全交易工具。 币安注册链接与下载地…

    2025年12月9日
    000
  • 什么是 ETF?为何对以太坊价格有如此影响?

    etf(交易型开放式指数基金)是一种在证券交易所交易的基金,它将投资者资金集中,用于跟踪特定资产或指数的价格表现。最近,以太坊(eth)相关的etf引发市场关注,因为它对eth价格产生了显著影响。本文将解析etf的概念及其对以太坊价格的作用机制。 投资者可通过币安和欧易OKX平台获取以太坊实时价格及…

    2025年12月9日
    000
  • 币圈一级市场有什么币值得埋伏吗?

    华兴资本徐锟指出,2025年一季度一级市场虽投资量环比回落,但AI大模型与具身智能成资本焦点,估值逻辑分化显现,开源模型重生态协同,闭源模型重商业化落地,具身智能进入资本聚焦期,商业化验证成关键;同时市场“二八效应”凸显,国资主导募资,头部机构优势强化,中小机构承压。 2025年一级市场埋伏指南:高…

    2025年12月9日
    000
  • 币安交易所官网 虚拟币交易账户注册、使用及app下载指南

    对于刚入门的用户来说,掌握币安官网入口、交易所账户注册与币安官方app下载方法,是开启交易的第一步。 币安交易所官网入口: 币安官方最新版App下载地址: 币安交易所(Binance)是目前全球交易量排名领先的数字货币交易平台之一,支持比特币(BTC)、以太坊(ETH)、狗狗币(DOGE)等上百种虚…

    2025年12月9日 好文分享
    000
  • 普通人怎么购买比特币 比特币普通人购买账户安装注册教程

    普通人可通过正规平台安全购买比特币。首先需理解个人地址、准备身份材料并设置高强度密码及二次验证;其次选择如币安、欧意等主流中心化平台,完成官网注册、身份认证和安全工具绑定;最后进入C2C交易区,选择BTC交易对,筛选高信誉商家,下单支付并确认收款后,比特币将转入账户。 一、准备工作:建立基础认知 1…

    2025年12月9日 好文分享
    000
  • 2025年8月13日比特币今日价格行情

    推荐用户使用币安和欧易okx两大主流平台获取实时比特币行情,这些平台不仅提供价格更新,还支持便捷交易和风险管理功能。 币安注册链接与下载地址: 欧易OKX注册链接与下载地址: 2025年8月13日,比特币(BTC)价格持续波动,引发投资者对实时行情和消息渠道的高度关注。本文将为您汇总比特币今日价格、…

    2025年12月9日
    000
  • 比特币行情价格 比特币行情消息获取汇总

    2025年8月13日,比特币(btc)价格持续波动,投资者对实时行情和市场消息的需求日益增加。本文将为您汇总今日比特币价格及可靠的行情消息获取渠道,帮助您及时了解市场动态并做出投资决策。 建议通过币安和火币HTX平台获取比特币实时价格及相关消息,这些主流交易平台提供完整的行情更新和安全交易服务。 币…

    2025年12月9日
    000
  • 以太坊今日价格行情 以太币实时行情价格消息渠道汇总

    建议用户通过币安和欧易okx两大主流平台获取以太币实时价格及行情资讯,这些平台提供安全交易环境和实时行情工具。 币安注册链接与下载地址: 欧易OKX注册链接与下载地址: 今日(2025年8月13日)以太坊(ETH)价格持续波动,投资者对实时行情和最新消息关注度较高。本文将为您汇总以太币今日价格、实时…

    2025年12月9日
    000
  • 欧交易所网页版注册链接 欧oe交易所新用户快速开户与资金保护设置教程

    欧交易所网页版为新用户提供便捷的注册入口和安全的资金保护设置,助力快速参与数字资产交易。本文详细介绍如何通过官方链接完成注册、开户流程,以及设置资金保护措施,确保用户账户安全与交易顺畅。 注册与开户步骤 1、访问官方平台:通过欧易交易所官方网页()或者手机端app()进入注册页面。 2、填写注册信息…

    2025年12月9日 好文分享
    000
  • 以太币行情今日价格 ETH以太坊行情消息获取汇总

    今日(2025年8月13日)以太币(eth)今日价格波动明显,引发投资者对实时行情和最新消息的高度关注。本文将为您汇总eth今日价格及可靠行情消息获取渠道,帮助您及时掌握市场动态并做出投资决策。 建议投资者使用币安和欧易OKX两大主流平台获取以太币实时价格及行情资讯,这些平台提供安全交易环境和实时行…

    2025年12月9日
    000
  • 比特币买卖账户注册及使用流程指南

    推荐投资者使用币安、欧易okx或火币htx平台,这些大主流交易平台不仅安全可靠,还提供完整的交易和行情工具。 币安注册链接与下载地址: 欧易OKX注册与下载地址: 火币HTX注册链接与下载地址: 对于刚进入币圈的新手而言,了解比特币(BTC)买卖账户的注册与使用流程非常关键。本文将详细介绍从注册账户…

    2025年12月9日
    000
  • 以太坊ETH买卖账户注册及使用流程指南

    推荐投资者使用币安、欧易okx或火币htx这些大主流交易平台,这些平台不仅安全可靠,还提供实时行情和多样化交易工具。 币安注册链接与下载地址: 欧易OKX注册与下载地址: 火币HTX注册链接与下载地址: 对于刚接触币圈的新手而言,了解以太坊(ETH)买卖账户的注册与使用流程至关重要。本文将为您详细介…

    2025年12月9日
    000
  • 币安将上线的Overlay Protocol(OVL币)是什么?OVL代币经济与空投领取

    目录 什么是Overlay Protocol什么是OVLOverlay Protocol(OVL)空投领取Overlay Protocol优缺点 overlay protocol 是一个专为非流动性资产设计的流动性层,旨在解决传统交易方式中普遍存在的流动性难题。其原生代币 $ovl 即将于8月14日…

    2025年12月9日 好文分享
    000

发表回复

登录后才能评论
关注微信