0

0

如何解决 SciPy minimize 中迭代耗时持续增长的问题

碧海醫心

碧海醫心

发布时间:2025-12-27 14:46:02

|

916人浏览过

|

来源于php中文网

原创

如何解决 SciPy minimize 中迭代耗时持续增长的问题

`minimize()` 的每次迭代耗时递增,根本原因在于将初始时间戳 `now` 作为 `args` 固定传入目标函数,导致时间差计算失真;实际耗时并未增长,而是因 `now` 始终不变,使得 `time.time() - now` 累积增大。

在使用 scipy.optimize.minimize 进行数值优化时,一个常见但容易被忽视的性能“幻觉”是:迭代耗时看似逐轮上升,实则源于错误的时间基准。从你提供的日志可见,start iteration - X.XXX 的数值从 0.001 持续飙升至近 900 秒——但这并非真实运算变慢,而是因为 now 是调用 minimize 时一次性传入的固定时间戳,后续每次调用 objective() 都在用当前系统时间减去这个“冻结”的起点,造成时间差线性增长。

? 问题定位:args 是静态快照,不是动态变量

根据 SciPy 官方文档,minimize 的 args 参数是一个固定元组(tuple),在优化开始前即被绑定并全程复用,不会随每次函数调用而更新:

def objective(df_initial_guess, shape, now):  # ❌ now 被冻结为首次传入值
    print("start iteration -", time.time() - now)  # → 差值越来越大!

因此,now 在第一次 minimize(..., args=(shape, now)) 中被求值后就再无变化,time.time() - now 本质上等价于“本次调用距程序启动的绝对秒数”,与单次迭代耗时完全无关。

AI神器大全
AI神器大全

AI工具集合导航站

下载

✅ 正确做法:在目标函数内动态获取基准时间

应将时间测量逻辑移入 objective 函数内部,每次调用都重新捕获起始时刻:

import time
from scipy.optimize import minimize

def objective(df_initial_guess, shape):
    now = time.time()  # ✅ 每次迭代独立计时起点
    print("start iteration -", time.time() - now)  # → 始终≈0(精度内)

    # 后续步骤保持不变...
    df_initial_guess = df_initial_guess.reshape(shape)
    global df_training_data

    print("initial guess and training data organized -", time.time() - now)
    # ... 其他计算步骤 ...

    data = np.array(data) * 100
    df_training_data[57] = data
    print("anomaly calculation done -", time.time() - now)
    print()

    return df_training_data.loc[df_training_data.iloc[:, 7] >= 1, 57].mean()

# 调用时不再传递 now
result = minimize(objective, df_initial_guess, args=(shape,))

⚠️ 注意事项与优化建议

  • 避免全局变量副作用:你代码中通过 global df_training_data 修改外部 DataFrame,这不仅影响可重入性,还可能引发多线程/多进程下的竞态问题。推荐改为显式传参或封装为类方法。
  • 启用 callback 进行真实监控:若需追踪优化过程中的真实耗时,可利用 minimize 的 callback 参数:
    def callback(xk):
        print(f"Iteration {callback.count}: x={xk[:3]}...")  # 示例
        callback.count += 1
    callback.count = 0
    result = minimize(objective, df_initial_guess, args=(shape,), callback=callback)
  • 考虑向量化与缓存:日志显示 formula spectrum calculation done 单步耗时超 100 秒,远高于其他步骤。检查该部分是否可向量化(如用 NumPy 替代循环)、是否重复计算了可缓存的中间结果(如预计算常量矩阵)。
  • 内存虽平稳 ≠ 无开销:你说内存“flat”,但需注意 Python 的引用计数、DataFrame 的链式索引(.loc[...])可能隐式触发拷贝,建议用 .values 或 np.asarray() 显式转为数组提升性能。

✅ 总结

所谓“迭代越来越慢”,本质是一场时间测量的误会。修正 now 的作用域后,你将看到真实的各阶段耗时分布——进而精准定位瓶颈(例如你日志中始终占主导的 formula spectrum calculation)。优化始于正确认知,而非盲目调参。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1561

2023.10.24

全局变量怎么定义
全局变量怎么定义

本专题整合了全局变量相关内容,阅读专题下面的文章了解更多详细内容。

87

2025.09.18

python 全局变量
python 全局变量

本专题整合了python中全局变量定义相关教程,阅读专题下面的文章了解更多详细内容。

105

2025.09.18

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

743

2023.08.10

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

375

2025.12.24

java多线程相关教程合集
java多线程相关教程合集

本专题整合了java多线程相关教程,阅读专题下面的文章了解更多详细内容。

27

2026.01.21

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

27

2026.01.21

C# 多线程与异步编程
C# 多线程与异步编程

本专题深入讲解 C# 中多线程与异步编程的核心概念与实战技巧,包括线程池管理、Task 类的使用、async/await 异步编程模式、并发控制与线程同步、死锁与竞态条件的解决方案。通过实际项目,帮助开发者掌握 如何在 C# 中构建高并发、低延迟的异步系统,提升应用性能和响应速度。

102

2026.02.06

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

19

2026.03.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.8万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号