V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
chinabrowser
V2EX  ›  Python

奇怪的问题,在模型推理间加入间隔导致 CPU 使用率异常的高

  •  
  •   chinabrowser · 2023-12-22 14:16:18 +08:00 · 922 次点击
    这是一个创建于 378 天前的主题,其中的信息可能已经有所发展或是发生改变。
    from SceneDetector import SceneDetector
    from multiprocessing import Pipe, Process
    import numpy as np
    import time
    import cv2
    
    def SceneWorker(pipe_conn, model_path, is_onnx = False):
        sd = SceneDetector(model_path, is_onnx = True)
        while True:
            data = pipe_conn.recv()
            if data is None:
                break
    
            results = sd.infer_scenes(data)
    
            pipe_conn.send(results)
    
    if __name__ == '__main__':
        model_path = 'models/scene_model.onnx'
        scene_conn, scene_child_conn = Pipe()
        scene_process = Process(target=SceneWorker, args=(scene_child_conn, model_path, True,))
        scene_process.start()
    
        test_img = cv2.imread('TestImages/1440P_1000M_8X.jpg') 
    
        for _ in range(5000):
            scene_conn.send([test_img])
            results = scene_conn.recv()[0]
            print(results)
            time.sleep(0.1)  #这里在推理间加入了间隔
    
        scene_conn.send(None)
        scene_process.join()
        
    

    High CPU Usage Jupyter Test 推理本身时间只用不到 2ms ,连续推理时 CPU 占用率会短暂上升,推理结束后立刻归零,但是如果推理之间有间隔,则 CPU 占用则会保持在一个很高的水平。一开始以为是time.sleep的问题,后来试过了用threadingEventasyncioawait做间隔,结果也是一样的。 使用Torch或者Onnx的模型结果都是一样的,把cv预处理删除掉也不影响 CPU 使用,所以也不是cv的问题。今天还测试了把推理单独开一个进程,也没有改善。

    tangtang369
        1
    tangtang369  
       2023-12-22 15:05:00 +08:00
    ```
    def SceneWorker(pipe_conn, model_path, is_onnx = False):
    sd = SceneDetector(model_path, is_onnx = True)
    while True:
    data = pipe_conn.recv()
    if data is None:
    break

    results = sd.infer_scenes(data)

    pipe_conn.send(results)
    # 在这里增加这个 你再跑下
    time.sleep(0)
    ```
    chinabrowser
        2
    chinabrowser  
    OP
       2023-12-22 15:18:53 +08:00
    @tangtang369 `time.sleep(0)`的话可以瞬间完成
    chinabrowser
        3
    chinabrowser  
    OP
       2023-12-22 15:23:52 +08:00
    @tangtang369
    500 次推理,通过管道的话是 13 秒,直接在主进程做预测是 3.7 秒,大部分时间在加载模型上
    Measure-Command -Expression {python .\PipeLineTest.py}

    Days : 0
    Hours : 0
    Minutes : 0
    Seconds : 13
    Milliseconds : 186
    Ticks : 131865097
    TotalDays : 0.000152621640046296
    TotalHours : 0.00366291936111111
    TotalMinutes : 0.219775161666667
    TotalSeconds : 13.1865097
    TotalMilliseconds : 13186.5097

    Measure-Command -Expression {python .\OnnxProfiling.py}

    Days : 0
    Hours : 0
    Minutes : 0
    Seconds : 3
    Milliseconds : 758
    Ticks : 37589256
    TotalDays : 4.35060833333333E-05
    TotalHours : 0.001044146
    TotalMinutes : 0.06264876
    TotalSeconds : 3.7589256
    TotalMilliseconds : 3758.9256
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1212 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 18:16 · PVG 02:16 · LAX 10:16 · JFK 13:16
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.